SpringCloud Gateway 2.x 并发调优

SpringCloud Gateway 2.x 并发调优,第1张

由于2x gateway 使用的是netty。

要设置起本身可同时工作的线程数需要设置netty中的 reactornettyioWorkerCount 参数。

该参数无法直接配置,需要通过 SystemsetProperty 设置,故我们可以创建以下配置类来配置该参数:

此时我们便可以在yaml文件中通过以下方法配置工作线程数

其他的netty参数同样可以以这样的方式进行配置

1首先在Linux系统下设置静态的IP地址
vim /etc/network/interfaces #编辑网网卡配置文件
auto lo
iface lo inet loopback
auto eth0 #开机自动连接网络
iface eth0 inet static #static表示使用固定ip,dhcp表述使用动态ip
address 19216821168 #设置ip地址
netmask 2552552550 #设置子网掩码
gateway 192168212 #设置网关
ctrl+o #保存配置
ctrl+x #退出
2在/etc/profile 加入脚本
vim /etc/profilegrep -v "hostname(指定的域名)" /etc/hosts > ~/hosts_temp
cat ~/hosts_temp > /etc/hosts
LC_ALL=C ifconfig | grep 'inet addr:'| grep -v '127001' |cut -d: -f2 | awk '{ print $1}' >> /etc/hosts
3重启网络使设置生效
/etc/initd/networking restart #重启网络

504
gateway
time-out怎么解决?
nginx所报告的“504
gateway
time-out”的含义指定的客户端所发出的的请求没有到达网关,换句话说就是请求没有到可以执行的php-fpm。
一般来说,nginx报告的“504
gateway
time-out”则是与nginxconf的设置有关。
504
gateway
time-out怎么解决
1先查看nginx配置
2然后停掉192168919的相关服务,再访问:
3修改源代码src/>nginx -s reload之后, nginx 正在平滑的重启。

wroker有正在处理的连接,等处理结束,该worker就会退出(退出之前,该worker不会处理新的连接)。

等调用对应nginx 的进程结束之后,这个process就会重启了。

大约20分钟后,这些进程都变成了 'worker process' 了。

使用nginx作为前端代理,在reload nginx的时候,发现nginx会一直处于shutting状态,当reload nginx次数多了以后,cup会飙升到100%, gateway的状态也会处于busy状态。

现象如下:

跟踪socket连接发现,此 nginx 进程,一直保持跟gateway的连接。
当nginx reload的次数多的时候,gateway就会处于busy状态。

如果把gateway restart了,gateway的进程id会改变,nginx中的shutting down 状态的进程也会消失,但是gateway restart就断掉和客户端的连接了。

看起来nginx reload后不会断开连接,然后gateway reload也不会断开连接(gateway restart会断开连接),
然后二者仍然保持着连接。

nginx和gateway都reload,那么nginx会产生新的worker进程,但是应该shutdown的老进程因为和gateway还有连接,所以也不会销毁,这样时间长了会有很多处于shutting状态的进程,这些进程都会占用资源。

重启的话就会把客户端的连接断开重连,会把连接初始化时给客户端发送的消息重新发一遍。

nginx worker shutting down状态超时退出配置

nginx reload之后有时会遇到shutting down状态worker过多的现象,尤其是websocket连接的worker很长时间无法退出。

如何解决过多worker长时间处于shutting down状态,不退出问题呢?

使用worker_shutdown_timeout配置,该配置配置在MAIN_CONF中,配置参数为时间。

如配置为1h,shutting down状态的worker一小时之后自动退出。

谈谈 nginx 信号集
>

504 Gateway Time-out就字面意思,我们可以理解为网页请求超时,也就是浏览网站网页所发出的请求没有反应或者未响应,在网站程序层面来说,就是请求未能够执行相应的PHP-CGI程序,或者PHP-CGI程序未能做出相应的处理,又或者是CGI程序的响应处理结果未能够反馈到浏览器或者未能及时反馈到浏览器。

是由于nginx默认的fastcgi进程响应缓冲区太小造成: 这种情况下导致fastcgi进程被挂起,如果fastcgi服务队这个挂起处理不是很好的话,就可能提示“504 Gateway Time-out”错误。

解决方法:

1、点击系统桌面左下角的开始,在开始菜单中点击命令提示符(管理员)(A)。

2、复制:ipconfig /flushdns命令,在打开的管理员命令提示符窗口中,右键点击空白处,将ipconfig /flushdns命令复制到窗口中。

3、当ipconfig /flushdns命令复制完成以后,按下键盘上的回车键(Enter),

显示:Windows IP配置

已成功刷新 DNS 解析缓存

退出管理员命令提示符窗口。

4、这样就能正常上网了。

504 gateway time-out怎么解决?
Nginx所报告的“504 gateway time-out”的含义指定的客户端所发出的的请求没有到达网关,换句话说就是请求没有到可以执行的PHP-fpm。
一般来说,Nginx报告的“504 gateway time-out”则是与nginxconf的设置有关。
504 gateway time-out怎么解决
1先查看Nginx配置
2然后停掉192168919的相关服务,再访问:
3修改源代码src/>提升服务器的文件句柄打开打开vi /etc/security/limitsconf 底部加上 soft nofile 51200 hard nofile 51200
vi /etc/sysctlconf 底部添加fsfile-max=51200
2
提升nginx的进程文件打开数vi />

欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/dianzi/12912721.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-05-28
下一篇 2023-05-28

发表评论

登录后才能评论

评论列表(0条)

保存