当前位置: 首页 > news >正文

docker搭建nginx实现负载均衡

docker搭建nginx实现负载均衡

安装nginx

查询安装

[root@localhost ~]# docker search nginx
[root@localhost ~]# docker pull nginx

准备
创建一个空的nginx文件夹里面在创建一个nginx.conf文件和conf.d文件夹

运行映射之前创建的文件夹
端口:8075映射80

docker run -it \
--name nginx \
-p 8075:80 \
-p 8080:8080 \
--privileged \
--network wn_docker_net \
--ip 172.18.12.90 \
-v /etc/localtime:/etc/localtime \
-v /usr/local/software/nginx/conf/nginx.conf:/etc/nginx/nginx.conf \
-v /usr/local/software/nginx/html:/usr/share/nginx/html \
-v /usr/local/software/nginx/conf/conf.d:/etc/nginx/conf.d \
-v /usr/local/software/nginx/logs:/var/log/nginx \
-d nginx

配置实现负载均衡

打开nginx.conf

在http中配置

image-20231203195107286

完整的文件内容:


user  nginx;
worker_processes  auto;

error_log  /var/log/nginx/error.log notice;
pid        /var/run/nginx.pid;


events {
    worker_connections  1024;
}


http {
    include       /etc/nginx/mime.types;
    default_type  application/octet-stream;

    log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
                      '$status $body_bytes_sent "$http_referer" '
                      '"$http_user_agent" "$http_x_forwarded_for"';

    access_log  /var/log/nginx/access.log  main;

    sendfile        on;
    #tcp_nopush     on;

    keepalive_timeout  65;

    #gzip  on;

    #myCode:
    #配置上有服务器,形成负载
    upstream activityBalance{
       server 192.168.133.100:15348 weight=1;
       server 192.168.200.113:15348 weight=1;
    }
    server{
       keepalive_requests 120;        #单连接请求上限次数
       listen    8080;                  #监听端口号

       location /api/{
        proxy_pass         http://activityBalance/api/; #反向代理服务器的访问地址
        proxy_set_header   Host $host;                                             #主机ip
        proxy_set_header   X-real-ip        $remote_addr;                          #客户端访问的真实ip
        proxy_set_header   X-Fowarded-For   $proxy_add_x_forwarded_for;            #代理转发历史
        proxy_redirect     off;
       }
    }

    include /etc/nginx/conf.d/*.conf;
}

此时访问nginx会负载均衡到两个服务器

相关文章:

  • 学生成绩管理系统(Java)
  • [node] Node.js的Web 模块
  • 浅话人工智能和深度学习
  • 好用免费的AI换脸5个工具
  • 【Python3】【力扣题】383. 赎金信
  • 聊一聊大模型 | 京东云技术团队
  • 深度学习-学习笔记记录
  • kubernetes(k8s)容器内无法连接同所绑定的Service ClusterIP问题记录
  • Windows核心编程 HOOK
  • 【微服务】springboot整合quartz使用详解
  • 代码随想录二刷 | 栈与队列 |逆波兰表达式求值
  • HarmonyOs 4 (一) 认识HarmonyOs
  • Linux CentOS本地部署SQL Server数据库结合cpolar内网穿透实现公网访问
  • 6-55.汽车类的继承
  • Python-字典详解
  • 阿里云租赁费用_阿里云服务器多配置报价表
  • C语言实现植物大战僵尸(完整版)
  • 基于JavaScript的jimp库处理图片,添加绘制点
  • 阿里云新版公共实例从注册账号到创建设备生成参数教程
  • 【微信小程序】上传头像 微信小程序内接小程序客服
  • 今晚油价下调,加满一箱油将省9元
  • 吴双评《发展法学》|穷国致富的钥匙:制度,还是产业活动?
  • 官方数据显示:我国心血管疾病患者已超3亿人
  • 常州新型碳材料集群产值近二千亿,请看《浪尖周报》第24期
  • 哈马斯与以色列在多哈举行新一轮加沙停火谈判
  • 《五行令》《攻守占》,2个月后国博见