3、CentOS7 使用docker和nginx实现简单的负载均衡
- 在服务器中搭建一个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
- 在docker中从源中拉一下nginx的官方镜像,docker pull 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
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或者域名即可
}
- 也是该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后定义的名字
}
8.保存后退出,重启服务器:systemctl restart nginx
9.通过浏览器输入当前域名,并刷新页面,有时输出nginx1,有时输出nginx2,配置成功:
确保两个容器是起来的、防火墙和selinux都已经关闭:
至此,一个简答的负载均衡模型配置完成