背景
在没有使用kubernetes集群的情况下,如何实现Docker容器的平滑滚动更新,且不影响线上流量。以流量入口为例,入口服务为Nginx和Golang语言为主的程序来接收上游下发的流量。
解决方案
SO_REUSEPORT
SO_REUSEPORT是Linux内核3.9在SOCKET中引入的新功能,它允许将多个AF_INET或AF_INET6套接字绑定到相同的套接字地址。在将套接字绑定到接口之前,每个套接字都应启用此选项。这样,多个进程可以同时在同一端口上监听。
开启 Reuseport
如图所示,当未启用SO_REUSEPORT选项时,单个侦听套接字将通知工作程序传入连接,每个工作程序都尝试建立连接。启用SO_REUSEPORT选项后,每个IP地址和端口组合有多个套接字监听器,每个工作进程有一套接字监听器。下面以Nginx为例,启用reuseport。Nginx在1.9.1版本的时候已经加入了该支持。
开启方式,只需要主配置文件listen端口后面加上reuseport
即可:
[root@master ~]# vim ngi