百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

Docker实战-使用NGINX实现4层的负载均衡

off999 2025-01-07 14:54 30 浏览 0 评论

Docker实战-使用NGINX实现4层的负载均衡

前言

我们俗称的3层,4层,7层都是相对于网络结构而言的, 表示是在网络7层架构的哪个层次实现的负载均衡。 今天我们这个文章就给大家实战一下,通过docker使用nginx来实现4层的负载均衡。

四层负载均衡:工作在传输层,由于在传输层,只有TCP/UDP协议,这两种协议中除了包含源IP、目标IP以外,还包含源端口号及目的端口号。四层负载均衡服务器在接受到客户端请求后,以后通过修改数据包的地址信息(IP+端口号)将流量转发到应用服务器。

Nginx在web端应用广泛,更多的是在web层作为前端的proxy和负载均衡层, 在nginx1.9以后,支持stream方式,通过stream方式来实现TCP/UCP层的负载均衡;我们这里就是使用stream来实现的。


安装Nginx
使用docker安装即可

docker image pull nginx


查看是否启动stream

root@c6461d00cb4c:/etc/nginx# nginx -V
nginx version: nginx/1.21.5
built by gcc 10.2.1 20210110 (Debian 10.2.1-6) 
built with OpenSSL 1.1.1k  25 Mar 2021
TLS SNI support enabled
configure arguments: --prefix=/etc/nginx 
--sbin-path=/usr/sbin/nginx 
--modules-path=/usr/lib/nginx/modules 
--conf-path=/etc/nginx/nginx.conf 
--error-log-path=/var/log/nginx/error.log 
--http-log-path=/var/log/nginx/access.log 
--pid-path=/var/run/nginx.pid --lock-path=/var/run/nginx.lock 
--http-client-body-temp-path=/var/cache/nginx/client_temp 
--http-proxy-temp-path=/var/cache/nginx/proxy_temp 
--http-fastcgi-temp-path=/var/cache/nginx/fastcgi_temp 
--http-uwsgi-temp-path=/var/cache/nginx/uwsgi_temp 
--http-scgi-temp-path=/var/cache/nginx/scgi_temp 
--user=nginx --group=nginx 
--with-compat --with-file-aio --with-threads 
--with-http_addition_module 
--with-http_auth_request_module --with-http_dav_module 
--with-http_flv_module 
--with-http_gunzip_module --with-http_gzip_static_module 
--with-http_mp4_module 
--with-http_random_index_module --with-http_realip_module 
--with-http_secure_link_module --with-http_slice_module 
--with-http_ssl_module --with-http_stub_status_module 
--with-http_sub_module --with-http_v2_module --with-mail 
--with-mail_ssl_module 
--with-stream --with-stream_realip_module --with-stream_ssl_module 
--with-stream_ssl_preread_module --with-cc-opt='-g -O2 
-ffile-prefix-map=/data/builder/debuild/nginx-1.21.5/debian/debuild-base/nginx-1.21.5=. 
-fstack-protector-strong -Wformat -Werror=format-security -Wp,
-D_FORTIFY_SOURCE=2 
-fPIC' --with-ld-opt='-Wl,-z,relro -Wl,-z,now -Wl,--as-needed -pie'

--with-stream 表示已经支持到了stream模块


修改/etc/nginx/nginx.conf

 stream{
         upstream netty_test{
           server 192.168.56.1:6666 weight=1;
           server 192.168.56.1:7777 weight=1;
        }
      
      server {           
            listen 6665;
            proxy_pass netty_test;
          }  
      }


注意这里有一个搞了好久的坑
stream这段,和http是一个级别的,所以stream这一段不能直接放在conf.d的文件夹里,启动会报错
错误如下:


nginx: [emerg] "stream" directive is not allowed here 
in /etc/nginx/conf.d/netty.conf:1
nginx: configuration file /etc/nginx/nginx.conf test failed


和http的定义放在一个层次, 可以参考nginx.conf里的写法

把stream这块直接放到nginx.conf的http段的上方

user  nginx;
worker_processes  auto;

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


events {
    worker_connections  1024;
}

 stream{
         upstream netty_test{
           server 192.168.85.1:6666 weight=1;
                                           
           server 192.168.85.1:7777 weight=1;
        }                                                                    
                                                                             
      server {                                                               
                                                                             
            listen 6555;                                                     
            proxy_pass netty_test;                                           
                                                                             
                                                                             
                                                                             
          }                                                                  
      }                                                                      
                                                                             
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;                       
                                     
    include /etc/nginx/conf.d/*.conf;
}


重新加载配置

root@c6461d00cb4c:/etc/nginx# nginx -t
nginx: the configuration file /etc/nginx/nginx.conf syntax is ok
nginx: configuration file /etc/nginx/nginx.conf test is successful


TCP服务器代码

代码 https://gitee.com/inthirties_admin/netty
使用netty写的简单的服务端程序


运行服务端程序


重现启动容器

root@boot2docker:~# docker run -d -p 80:80 -p 6555:6555 -v nginx:/etc/nginx --name nginx nginx


36d2df0a1f1035c10f1a8bbb8139659a7b4836b83dbad33a2cd511303de0b31d


负载均衡测试



重新建立连接

?


结束语

Nginx在web端应用广泛,更多的是在web层作为前端的proxy和负载均衡层, 在nginx1.9以后,支持stream方式,通过stream方式来实现TCP/UCP层的负载均衡; 在本文章中使用docker的方式快速的搭建Nginx的负载均衡环境,并使用tcp客户端进行负载均衡的测试,nginx的stream方式是层结构的,nginx本身还提供7层的负载均衡实现,即简单的proxy反向代理的方式,这里就不介绍了。


下一篇文章将介绍使用docker环境使用haproxy来实现4层的负载均衡。 欢迎大家关注。

?

相关推荐

安全消防教育平台登录(消防安全教育网)

这个问题需要更明确的信息才能给出具体的解决方案。一般来说,如果你忘记了账号和密码,可以通过输入注册时填写的手机号或者邮箱来找回。如果有安全问题设置,也可以通过验证安全问题来找回。如果还是无法解决,可以...

音乐大全300首免费听(音乐歌曲大全免费)

1、《红昭愿》《红昭愿》,这首歌曲由音阙诗听演唱,音阙诗听在古风歌曲界早已有一定名气。这首《红昭愿》与他们之前的风格很相似,歌曲节奏欢快,其中掺杂了不同的音乐元素,融合在一起才有了这一动听的歌曲。2、...

搜狗输入法的优势(搜狗输入法的优势和劣势)

1、在输入50个左右的字符之后,搜狗输入法的耗电量为225μAh,只从绝对耗电量来看可以说是微乎其微的。但是如果是频繁使用,应该还是会耗一些电的。2、搜狗拼音输入法(简称搜狗输入法、搜狗拼音)是200...

直接下载mp3音乐的网站(直接下载mp3音乐的网站推荐)

说明书里有呀91flac音乐网,试试这个,绝对好使,但是不要在酷狗上面说有几个网站挺不错的一个酷猪首页上的歌曲都很好听还有一个是http://www.songtaste.com/music/这个网...

h5视频播放器(h5视频播放器适配竖屏模式)

要实现H5播放器在切换窗口时不暂停,可以使用WebAPI中的PageVisibilityAPI。该API允许开发者检测页面是否可见或隐藏。当页面切换到后台时,可以通过监听visibilitych...

云闪付app官方下载(云闪付官方下载最新版本)
  • 云闪付app官方下载(云闪付官方下载最新版本)
  • 云闪付app官方下载(云闪付官方下载最新版本)
  • 云闪付app官方下载(云闪付官方下载最新版本)
  • 云闪付app官方下载(云闪付官方下载最新版本)
百度云盘网页登录入口(百度网页入口官网网址)
百度云盘网页登录入口(百度网页入口官网网址)

手机登陆云盘可以通过更改UA设置来解决,方法如下:1.打开浏览器,点击进入浏览器的菜单选项。2.在设置的页面中,找到【浏览器标识/UA】,这个选项默认是【手机版】,即默认打开手机版网页。点击进入更改3.进入浏览器标识选择页面,将UA设置为电...

2026-02-03 00:15 off999

韩国色情大片震撼来袭

《千与千寻》导演:宫崎骏剧情简介:千寻和爸妈在去新家途中误入了一个诡异世界,爸妈因为贪吃变成了猪,许多半透明的怪人围攻千寻,幸被小白救下。小白给千寻吃了阻止身体消失的药,两人成为朋友。不料小白又被一...

天天斗地主单机(欢乐斗地主单机版免费)

有,可以在软件商店直接搜索单机斗地主。1.单机斗地主不要钱,不用流量。2.单机的玩法少,有单一的斗地主,闯关式的斗地主,残局式的斗地主,普通的斗地主。3.闯关式的斗地主,这种斗地主AI的水平都是控制...

最新网游(最新网游3d)

金山软件公司西山居工作室,于1995年5月在珠海成立,是国内最早的游戏开发工作室。1996年1月,西山居发布了中国大陆第一款商业游戏——《中关村启示录》,标志着金山公司正式进入游戏领域。龙骑士是首...

360一键重装系统(360一键重装系统后无法登录)

360并不提供自动重装系统的功能。重装系统是一项比较复杂的操作,需要对计算机硬件和软件有一定的了解,并且需要备份重要数据,重新安装操作系统和应用程序等。如果您需要重装系统,可以按照以下步骤进行操作:备...

免费离线单机斗地主(离线斗地主单机版免费)

想下载免流量不花钱斗地主,和麻将单机斗地主介绍:单机斗地主游戏是一款不需要联网的棋牌类手机游戏,此款斗地主最大的亮点是拥有强大的AI以及智能的提示功能。电脑具有很高的人工智能,为玩家提供了强劲的对手,...

58动漫(58动漫 官方入门网站)

打不开的原因可能有很多种,需要一一排查。首先要检查自己是否连接上了互联网,如果没有,就先联网。其次看一下叔叔有没有攻击。可能动漫网的版本比较低导致无法打开假的,58上面很多招聘工作跟他上线的信息不符合...

微信键盘输入法(微信键盘输入法下载)
  • 微信键盘输入法(微信键盘输入法下载)
  • 微信键盘输入法(微信键盘输入法下载)
  • 微信键盘输入法(微信键盘输入法下载)
  • 微信键盘输入法(微信键盘输入法下载)
精准客户电话号码采集软件(精准客户电话号码采集软件下载)

是正规平台。JMTOOL是一个采集工具软件。数据采集,又称数据获取,是利用一种装置,从系统外部采集数据并输入到系统内部的一个接口。数据采集技术目前广泛应用于各个领域。针对制造业企业的庞大生产数据,数据...

取消回复欢迎 发表评论: