Stage3-day19-Linux-Nginx反向代理服务

Nginx是反向代理,代理的是服务器,不同于我们平时使用的类似于vpn之类的正向代理,他们代理的是客户端.

配置Nginx

  1. 在software目录下创建一个新文件夹tomcats用来放置tomcat服务器:mkdir tomcats
  2. 把tomcat复制到tomcats目录下,分别命名为tomcat1和tomcat2,这样我们就有了多个服务器了
  3. 分别进入tomcat1和tomcat2 中的conf文件夹找到配置文件server.xml
  4. 编辑该文件,把接口改成和我们最开始配置的tomcat不一致的,这样才能有多个服务器的效果,注意该端口时为了避免改错,最好有一定规律,比如tomcat1我们把所有端口在原有基础上+1,tomcat2在所有端口基础上+2.....同时需要注意不要改到注释里的端口,那样不会生效,总共需要改3个地方,改完之后保存生效,同理,tomcat2每个端口在原基础上+2即可
  5. 改完保存之后启动tomcat即可,一定要启动服务,不然Nginx是访问不到的
  6. 找到Nginx配置文件,修改添加内容
  7. 找到server{listen 80...}在他前面添加我们红框内所写的内容,注意upstream后面的是用户名,可以随便填写,但是下面要用到这个用户名
  8. 然后我们在他下面找到,在error_page上面location ,在大括号前添加如下内容:
  9. 保存退出,cd ..返回上一级,然进入到sbin文件夹下执行重启指令:
  10. 这时候我们在外部地址栏中直接输入虚拟机ip地址就可以访问tomcat了,因为Nginx是80端口所以ip后不用加端口号就可以访问, 此时Nginx代理了两个tomcat服务器,他们会轮循的被Nginx代理,每次刷新网页都有可能是不同的服务器

Nginx负载均衡策略

1、轮询(默认)

每个web请求按时间顺序逐一分配到不同的后端服务器,如果后端服务器down掉,能自动剔除。

upstream 名字 {
        server 127.0.0.1:8081;
        server 127.0.0.1:8082;
}

2、最少连接

web请求会被转发到连接数最少的服务器上。

upstream  名字{
    least_conn;
    server 127.0.0.1:8081;
    server 127.0.0.1:8082;
}

3、weight 权重

指定轮询几率,weight和访问比率成正比,用于后端服务器性能不均的情况,weight默认是1

#服务器A和服务器B的访问比例为:2-1;比如有3个请求,前两个会访问A,第三个访问B,其它规则和轮询一样。

upstream nginxDemo {
   server 127.0.0.1:8081 weight=2; #服务器A
   server 127.0.0.1:8082; #服务器B
}

4、ip_hash

每个请求按访问ip的hash值分配,这样同一客户端连续的Web请求都会被分发到同一服务器进行处理,可以解决session的问题。当后台服务器宕机时,会自动跳转到其它服务器。

upstream nginxDemo {
   ip_hash;
   server 127.0.0.1:8081 weight=2; #服务器A
   server 127.0.0.1:8082; #服务器B
}

Nginx实行动静分离

把动态文件和静态文件分开,因为静态文件可以直接访问不需要经过服务器. 动静分离,静态文件所在的位置是任意的,建议把静态文件放到Nginx提供的静态目录html中.

同样的我们找到Nginx配置文件.进入后我们找到上面修改的地方修改以下地方,修改完成后保存退出,重启Nginx服务器,然后我们就可以直接访问静态资源了,不论当前轮询到哪一个服务器都可以使用这些静态资源,因为这些资源都是保存到Nginx下的,与tomcat无关.

猜你喜欢

转载自blog.csdn.net/qq_42837554/article/details/90678381