Docker 下 nginx搭建负载均衡

  1. 拉取nginx镜像

    docker pull nginx
    
  2. 通过nginx镜像启动3个容器(one、two、three)(相当于3个服务器)或多个,

    docker run -d -p 80:80   --name one   nginx
    docker run -d -p 8081:80 --name two   nginx
    docker run -d -p 8082:80 --name three nginx
    

    通过映射到宿主机的端口,宿主机可以通过127.0.0.1:映射端口访问到不同服务器nginx
    现在将one服务器做为主服务器,由one服务器负载均衡到two服务器与three服务上

  3. 在one服务器上配置负载均衡
    在one服务器nginx配置文件 http 段内新增如下代码

    upstream 127.0.0.1{
        server 172.17.0.3:80 ;	#这里IP是容器内部IP,端口是容器的端口,可以通过docker  inspect 容器ID 进行查看
        server 172.17.0.5:80 ;  #这里一定注意 该IP和端口 不是对应映射的宿主机的IP和端口
    }
    server {
        listen       80;
        server_name  127.0.0.1; 		
        location / {
            root   /usr/share/nginx/html;
            index  index.html index.htm;
            proxy_pass   http://127.0.0.1;
        	proxy_set_header Host $host;
        	proxy_set_header X-Real-IP $remote_addr;
        	proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
    		 } 
    }
    

打开浏览器访问,刷新会发现所有的请求均分别被主服务器one分配到two服务器与C服务器three上,实现了负载均衡效果。

为了更好的区分,建议先将各个服务器nginx中index.html修改为不同内容

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值