nginx正向代理+反向代理

目录

Nginx工作原理及模块介绍​​​​​​​

Nginx原理

负载均衡+反向代理


Nginx WEB服务器最主要就是各种模块的工作,模块从结构上分为核心模块、基础模块和第三方模块,其中三类模块分别如下:
核心模块:HTTP模块、EVENT模块和MAIL模块等;
基础模块:HTTP Access模块、HTTP FastCGI模块、HTTP Proxy模块和HTTP Rewrite模块;
第三方模块:HTTP Upstream Request Hash模块、Notice模块和HTTP Access Key模块、Limit_req模块等;
Nginx的模块从功能上分为如下三类。
Handlers(处理器模块):此类模块直接处理请求,并进行输出内容和修改headers信息等操作,Handlers处理器模块一般只能有
一个;
Filters (过滤器模块):此类模块主要对其他处理器模块输出的内容进行修改操作,最后由Nginx输出;
Proxies (代理类模块):此类模块是Nginx的HTTP Upstream之类的模块,这些模块主要与后端一些服务比如FastCGI等进行交
互,实现服务代理和负载均衡等功能。
Nginx由内核和模块组成,其中内核的设计非常微小和简洁,完成的工作也非常简单,仅仅通过查找配置文件(nginx.conf)将客户
端(用户)的请求映射到一个location block(配置段|区域),而location是Nginx配置中的一个指令,用于匹配用户访问的URL路
径,而在这个location中所配置的每个指令将会启动不同的模块去完成相应的工作。

Nginx原理

1.Nginx的主要应用类别
 使用 Nginx 结合FastCGI运行 PHP、JSP 、Perl等程序
 使用 Nginx 作反向代理、正向代理、负载均衡、规则过滤
 使用 Nginx 运行静态HTML页、图片
 使用 Nginx与其他新技术的结合应用
​
2.Nginx的配置文件nginx.conf位于其安装目录的conf目录下
​
3.nginx.conf由多个块组成,最外面的块是main,main包含Events和HTTP,HTTP包含upstream和多个Server,Server又包含多个location:

Nginx正向代理+反向代理原理

正向代理
1.客户端通过nginx代理服务器,去访问指定请求资源。
2.对于目标服务器来说,客户端的数据请求和IP是看不见的,只能看到代理服务器的请求去访问目标服务器

nginx正向代理+反向代理_第1张图片

反向代理
1.指的是客户端去访问代理服务器,因为代理服务器是作用在服务器端的
2.代理服务器再通过反向代理+负载均衡将请求分发多台服务器。
3.反向代理的服务特点是代理服务器,代理的对象是应用服务器,也就是客户端想访问的目标服务器

nginx正向代理+反向代理_第2张图片

nginx正向代理+反向代理_第3张图片

main(全局设置)、server(主机设置)、upstream(负载均衡服务器设置)和 location(URL匹配特定位置的设置)。
main块设置的指令将影响其他所有设置;
server块的指令主要用于指定主机和端口;
upstream指令主要用于负载均衡,设置一系列的后端服务器;
location块用于匹配网页位置。
这四者之间的关系式:server继承main,location继承server,upstream既不会继承其他设置也不会被继承。
在这四个部分当中,每个部分都包含若干指令,这些指令主要包含Nginx的主模块指令、事件模块指令、HTTP核心模块指令,同时每个部分还可以使用其他HTTP模块指令,例如Http SSL模块、HttpGzip Static模块和Http Addition模块等。
server标志定义虚拟主机开始,
listen用于指定虚拟主机的服务端口,
server_name用来指定IP地址或者域名,多个域名之间用空格分开。
index用于设定访问的默认首页地址,
root指令用于指定虚拟主机的网页根目录,这个目录可以是相对路径,也可以是绝对路径。
Charset用于 设置网页的默认编码格式。
access_log用来指定此虚拟主机的访问日志存放路径,最后的main用于指定访问日志的输出格式。

nginx正向代理+反向代理_第4张图片

虚拟主机

基于域名

virtual host virtual server
把一台物理服务器划分成多个虚拟的服务器,每一个虚拟主机都可以有独立的域名和独立的目录
基于IP的虚拟主机
不同IP对应不同的网站,访问方便,用户可以直接通过IP访问,维护方便,但是一个服务器就需要多个IP地址
基于域名的虚拟主机(IP,端口号相同)
多个网站使用一个IP,通过不同的域名对应不同的网站
基于端口的虚拟主机
多个网站IP相同,通过不同的端口对应不同的网站,节省ip地址
不管是基于哪个部署虚拟主机,另外两个条件相同
nginx -s reload 重新加载配置文件如果不成功
可以直接killall -9 nginx再用nginx开启
基于域名
此配置是基于源码安装的路径
vim /usr/local/nginx/conf/nginx.conf
server {
        listen 80;
        server_name  www.xxoo.com;
        location / {
            root   /www;
            index  index.html index.htm;
        }
    }
    
#这里是添加了一个指定端口和虚假域名,可以通过域名去本地curl或者去网页IP+端口
因为域名是虚假(虚构)的,所以要去网页验证也是不可行的。除非你有一个自己的真实域名,可以写到配置文件去进行验证。总之 server模块是一个虚拟主机,可以帮助你
虚拟主机在本机是必须要做本地hosts解析的
​
并指定了root根目录下的网页路径
有需要也可以在 listen 加IP:端口,效果是一样的
可以用一个IP指定两个不同的端口,指定不同的网页路径
一个server模块=一个虚拟主机
vi /etc/hosts
192.168.163.20 www.xxoo.com #做hosts解析
​
echo 'nihao' >/www/index.html #输出内容到指定目录下的html文件
curl 指定链接 #验证网页
​
因为虚拟主机是配置文件中的一个模块。
​
​
nginx -t #检查配置文件是否正常
nginx -c /usr/local/nginx/conf/nginx.conf #启动指定配置文件
nginx -s reload #重启nginx服务器
nginx -s stop #关闭nginx

基于端口

基于端口
vi/usr/local/nginx/conf/nginx.conf
​
server {
        listen      100;   
        server_name www.kl.xyz;
        location / {
            root    /jd;
            index   index.html index.htm;
           }
   }
​
vi /etc/hosts
192.168.163.20 www.kl.com #做hosts解析
​
mkdir /jd
echo 'welcome' >/jd/index.html #输出内容到指定目录下的html文件
​
比如配置了两个模块。指定了不同的端口之后再去指定同一个页面路径或者不同的路径都是可以的。
基于IP地址+端口去访问或者基于域名+端口去访问都是可以的。前提不要把域名注释
​
nginx -t #测试配置文件格式是否正常
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful
​
nginx:配置文件/etc/nginx/nginx。conf语法正常
nginx:配置文件/etc/nginx/nginx。conf测试成功

负载均衡+反向代理

1.在源码安转的nginx.conf中server模块上面另起新模块去添加配置。下面的可以全部注释 nginx -t 检测文件格式是否正确
2.负载均衡模块upstream 格式和下面一样即可
3.这里的实验,是nginx作为
​
upstream httpserver {
             server 192.168.163.60:8080 weight=1;
             server 192.168.163.20:80 weight=1;
             server 192.168.163.30:30 weight=1;
}
#添加负载均衡模块。名字要和反向代理模块的要对应
​
​
​
server {
        location / {
            root    /html;
            index   index.html index.htm;
            proxy_pass http://httpserver;
           }
   }
​
1.在location里面添加了一天proxy_pass模块,这就是反向代理模块,除了名字要和负载均衡模块的名字要对应以外,要添加http://.这是必须的
2.负载均衡对应的服务端的应用。要保证应用的数据都是一致的,才能实现高并发请求分均给多台服务端。
3.如果数据不一致,比如有3w个用户同时访问你的同一个资源,你的负载均衡就做不到请求分均了。
4.以上实验是为了更贴切的看出负载均衡的一个效果,并不是生产环境中的实际效果
​

实际上,到这里我是没有写完的,一部分是自己有些东西还是没有得到验证,一部分是时间原因,后续会更新上来的。希望本文章可以帮助到你,如果对你有用,帮我点个赞,支持一下,谢谢~

你可能感兴趣的:(Linux,nginx,nginx,linux)