CentOS8 下Nginx使用教程

1、nginx安装

dnf install nginx -y

 

 

2、nginx常用目录

nginx.conf目录:/etc/nginx.nginx.conf

nginx启动目录:/usr/sbin/nginx

 

3、nginx热部署

所谓热部署,就是配置文件nginx.conf修改后,不需要stop Nginx,不需要中断请求,就能让配置文件生效!

/usr/sbin/nginx -s reload

 

4、配置nginx 访问资源目录

修改 nginx.conf 配置文件,在service标签内部加入下面的location,通过访问 ip地址:端口/source 就能访问  /home/source  目录了。

location /source {
  root /home;
  autoindex:on;
}

还可以有如下写法:

location /source {
  alias /home/source;
  autoindex:on;
}

 

5、反向代理

听着反向代理是不是很牛逼的事,实际上很容易理解:

正向代理:A要访问C的地址,但是由于网络或是墙的问题,A不能直接访问到C,但是呢有个B可以访问C,A也可以访问B,那么A在访问C的时候通过B代理,这就是正向代理。
A ---/---> C ;  A ------> B ; B ------> C ;那么 A ------> B ------> C

反向代理:A要访问C的地址,但是由于网络或安全的问题,A不能直接访问到C,但是呢有个B可以访问C,A也可以访问B,那么A在访问C的时候通过B代理,这就是正向代理。
A ---/---> C ;  A ------> B ; B ------> C ;那么 A ------> B ------> C

通过上面的示例是不是觉得 正向代理和反向代理一样?

对,确实原理一样,但是有有个明显的差别就是:

在正向代理中 A访问C,A是明确知道C的地址(要想访问www.google.com)。B相当于是访问的介质。

在反向代理中A访问C,A只知道B的地址不知道C的地址,当A访问B的时候由B请求C之后把请求结果返回给A。

配置方法很简单:把root换成proxy_pass , 路径换成网络地址。

location /WeChatApp {
  proxy_pass http://localhost:8878/;
}

 

6、负载均衡

复制均衡听着是不是也很NB,其实原理也非常简单,因为由反向代理,A只用访问B就行了,那么至于B要访问多少个C那是可以配置的:

比如说 由于用户量激增,需要新增服务器来部署应用应对并发访问,这时用户访问的还是B地址,只有配置B把请求分发给对台服务器应用,就能应对并发操作,这就是负载均衡。

在server标签外面添加:

upstream myserver{
    server http://192.168.1.40:8080; 
     server http://192.168.1.45:8480; 
}

在server标签内添加:

location /WeChatApp {
  proxy_pass http://myserver;
}

这样就把请求分发到不同的应用去处理了。

 

7、动静分离

牛逼的名称又来了,动静分离就是把通过反向代理,针对不同的资源配置不同的访问方式。

比如说查询用户列表需要查询数据库,需要组织返回的数据结构,这就是一个动态请求。
比如要访问图片、pdf文件...这些静态资源这一个静态请求。

那么针对不同的接口做不同的配置就实现了动静分离:

# 访问  动态资源
location /WeChatApp {
  proxy_pass http://localhost:8878/;
}

#访问 /home/image 静态资源目录
location /image {
  root /home;
  autoindex:on;
}

 

8、高可用的集群

通过nginx做代理 进行负载均衡就会出现一个问题,就是nginx服务器挂掉之后,它代理的接口地址都不能访问了。

为了解决这个问题就需要配置一个高可以的集群,原理很简单,就是在另一台服务器其上部署一个相同配置的nginx服务器,这样主nginx服务器挂掉之后,副的nginx服务器补上。

 

主流方案是Keepalived+Nginx实现双机热备。

 

posted @ 2020-12-26 10:55  一文搞懂  阅读(1148)  评论(0编辑  收藏  举报