3、CentOS7 使用docker和nginx实现简单的负载均衡

使用docker和nginx实现简单的负载均衡

 

  1. 在服务器中搭建一个nginx服务器并启动:

[[email protected] ~]# yum -y install nginx

[[email protected] ~]# systemctl start nginx

[[email protected] ~]# netstat -tunlp | grep 80

tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      7684/nginx: master

 

  1. 在docker中从源中拉一下nginx的官方镜像,docker pull nginx,留着备用

3、CentOS7 使用docker和nginx实现简单的负载均衡

 

3.在本地目录新建两个文件夹,我这里的新建在/mydata/test1,/mydata/test2/

[[email protected] ~]# mkdir -p /mydata/test1 /mydata/test2

[[email protected] ~]# ll /mydata/

total 0

drwxr-xr-x 2 root root 6 Aug  1 11:02 test1

drwxr-xr-x 2 root root 6 Aug  1 11:02 test2

 

4.分别在两个test文件夹中新建index.html来标志,在第一个html中输出this is nginx1,在第二个html中输出this is nginx2

[[email protected] ~]# cd /mydata/test1/

[[email protected] test1]# cat >index.html

this is nginx-1   

[[email protected] test1]# cd /mydata/test2/

[[email protected] test2]# cat >index.html

this is nginx-2

[[email protected] test2]#

 

5.通过docker运行两个nginx服务器的容器,并分别将静态目录映射到我们刚刚创建的目录中

[[email protected] test2]# docker run --name nginx-test1 -d -P -p 8080:80 -v /mydata/test1:/usr/share/nginx/html nginx

ca6af7113e54ea6bccbabff6cf60355b280efc539b208c1250b05318a1d1e26c

[[email protected] test2]# docker run --name nginx-test2 -d -P -p 8081:80 -v /mydata/test2:/usr/share/nginx/html nginx

96c4413f23d71d723fed0b6835219b1554207dbaef67996367cee4b88e9c4a34

3、CentOS7 使用docker和nginx实现简单的负载均衡

 

6.修改宿主机中的nginx的配置文件

在http{}中添加如下代码

upstream myweb { #myproject为自定义名字

#ip_hash;  #开启则代表用ip地址的形式来分配,可解决sesson问题
server 127.0.0.1:8080 weight=1; #weight越大,权重越高,被分配的几率越大
server 127.0.0.1:8081 weight=1; #我全部在本机,因此用了本地的ip,只要相应换成对应的ip或者域名即可
}

3、CentOS7 使用docker和nginx实现简单的负载均衡

  1. 也是该nginx的配置文件:

在http{}的server{}里的location下添加下面内容:

 

 location / {  

      #如果服务器要获取客户端真实IP,可以用下三句设置主机头和客户端真实地址

      #proxy_set_header Host $host;

      #proxy_set_header X-Real-IP $remote_addr;

      #proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;

 

      root   /usr/share/nginx/html;

      index  index.html index.htm;

     proxy_pass http://myweb;  #myweb为之前在nginx.conf中upstream后定义的名字

 }  

 

3、CentOS7 使用docker和nginx实现简单的负载均衡

8.保存后退出,重启服务器:systemctl restart nginx

9.通过浏览器输入当前域名,并刷新页面,有时输出nginx1,有时输出nginx2,配置成功

确保两个容器是起来的、防火墙和selinux都已经关闭:

3、CentOS7 使用docker和nginx实现简单的负载均衡

 3、CentOS7 使用docker和nginx实现简单的负载均衡

3、CentOS7 使用docker和nginx实现简单的负载均衡

至此,一个简答的负载均衡模型配置完成