首页 > 系统相关 >Docker Swarm部署nginx+api-service实现负载均衡

Docker Swarm部署nginx+api-service实现负载均衡

时间:2024-02-22 17:26:25浏览次数:40  
标签:log service Swarm server nginx api proxy ocr

背景介绍

api服务开发完毕之后如何快速部署实现负载均衡。如果不是重量级的项目,非常建议使用 Docker Swarm来实现,非常简单高效且稳定。

关于Docker Swarm集群的构建详见我的另一篇博客:Docker Swarm集群搭建

相关文件准备(这里以一个ocr服务为例)

  • docker-compose.yml
version: '3.8'

services:
  nginx:
    image: nginx:1.21
    ports:
      - "8080:8088"
    configs:
      - source: nginx.conf
        target: /etc/nginx/nginx.conf
    networks:
      - ocr
    deploy:
      replicas: 1
      restart_policy:
        condition: on-failure
      placement:
        constraints:
          - node.labels.ocr.replica==1

  api-server:
    image: paddleocr:gpu-v3
    hostname: api-server
    networks:
      - ocr
    deploy:
      replicas: 10
      restart_policy:
        condition: on-failure
      placement:
        constraints:
          - node.labels.ocr.replica==1

configs:
  nginx.conf:
    file: ./nginx.conf

networks:
  ocr:
    external: true # 用已经创建好的网络

  • nginx.conf
user  nginx;
worker_processes  2;

error_log  /var/log/nginx/error.log;
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;

    upstream ocr_servers {
        server api-server:8866;  # Docker 会自动进行 DNS 负载均衡到 API 服务的各个实例
    }

    server {
        listen 8088;
        
        location / {
            proxy_set_header Host $host;
            proxy_set_header X-Real-IP $remote_addr;
            proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
            proxy_set_header X-Forwarded-Proto $scheme;

            proxy_pass http://ocr_servers;
            proxy_read_timeout 600;  # 可根据实际需求调整

            proxy_redirect off;
            proxy_buffering off;
        }
    }
}

创建专用网络:

docker network create --driver overlay ocr

部署

docker stack deploy -c docker-compose.yml ocr

查看

docker stack ls
NAME      SERVICES
ocr       2
docker service ls
ID             NAME             MODE         REPLICAS   IMAGE              PORTS
c94y6w6r8lok   ocr_api-server   replicated   10/10      paddleocr:gpu-v3   
iliarkza8v68   ocr_nginx        replicated   1/1        nginx:1.21         *:8080->8088/tcp

标签:log,service,Swarm,server,nginx,api,proxy,ocr
From: https://www.cnblogs.com/JentZhang/p/18027763

相关文章

  • nginx与php pathinfo(TP5框架适用)
    最近在试用fastadmin这一个框架,是由tp5进行二开后的一款框架。fastadmin里面有个代码,要获取pathinfo否则会重定向到登录页,而默认的nginx配置获取的pathinfo一直为空,就导致无法正常进入后台。通过查找资料后,发现pathinfo是php的产物,与nginx无关。如果要让nginx把pathinfo环境变量......
  • nginx日志切割备份
    直接上脚本#!/bin/bash#源日志目录logs_path="/logs/nginx"#备份日志目录back_logs_path="${logs_path}/backup/$(date-d'yesterday'+'%F')"#创建备份目录,以日期命名,注意,每天零点整切割,开始记录新的一天的日志,备份目录应该是昨天mkdir-p${back_logs_path}#重命......
  • Nginx之SSI
    一、简介    SSI【ServerSideInclde】。基于服务端的网页制作技术,即服务端包含。该项目中用到了Nginx中的SSI模块的include命令,这个命令会包含一个页面,然后在nginx服务器中展开。二、使用    2.1、开启SSI        Linux路径地址为:   ......
  • nginx的安装(文心一言)
    在Ubuntu中安装Nginx可以通过APT包管理器进行。以下是在Ubuntu中安装Nginx的步骤:1.更新软件包列表:首先,打开终端并更新您的软件包列表,以确保您安装的是最新的软件包。sudoaptupdate2.安装Nginx:接下来,使用APT包管理器安装Nginx。sudoaptinstallnginx安装过程中,您可能会被提......
  • 自己新写的软件, 使用nginx反向代理
    windows版本安装包: https://nginx.org/en/download.html   nginx用于代理服务器,常用于负载均衡等,可以实现用户请求转发。 在python中,为了提高程序的并发性能,使其能够满足更高的访问量,一般会利用多进程以及协程,对程序进行改造。但是服务在启动的时候,随之确定的也就......
  • Nginx 配置限流
    Nginx配置限流1概述2限制请求速率2.1、正常限流2.2、处理突发流量2.3、设置白名单2.4、limit_req重复3限制连接数4上传/下载速率限制4.1、limit_rate4.2、limit_rate_after4.3、proxy_limit_rate4.4、动态限速4.2、基于变量动态限速1概述限流(RateLimitt......
  • Linux服务器配置nginx访问静态网页
    配置nginx 打开conf文件进行编辑:sudonano/etc/nginx/nginx.conf在http块内添加:server{listen80;server_namexxx.your_domain.com;root/root/work/your_web_folder;indexindex.html;}重启nginx:sudoservicenginxrestart如果......
  • Mac安装Nginx
    Nginx安装#查找nginx版本brewsearchnginx#安装nginx,默认是最新版本brewinstallnginx#指定版本安装方式为:nginx@版本号[email protected]#卸载nginxbrewuninstallnginxbrewuninstallnginx@版本号#查看已安装的软件brewlist#查看nginx安装信息(eg:......
  • [转帖]nginx利用request_body记录POST body(location中用proxy_pass)
    https://www.cnblogs.com/freedom-try/p/14699538.html1.完整过程1.1在nginx.conf中http里面添加配置如下:http{ ... log_formatpostdataescape=json'$remote_addr-$remote_user[$time_local]"$request" '$status$bod......
  • Linux 安装 Nginx
    一、步骤    1、配置EPEL源   sudoyuminstall-yepel-releasesudoyum-yupdate    2、安装Nginxsudoyuminstall-ynginx     安装成功后,默认网站目录为:/usr/share/nginx/html     默认的配置文件为:/etc/nginx/nginx.conf......