1.MongoDB引入读写分离之后,重启服务时间变长,可以看到如下打印:
your mercy for graceful operations on workers is 60 seconds
搜索相关资料发现可以通过设置最大超时时间来降低服务重启时间,uWSGI默认重新加载超时时间是60s,可以通过设置worker-reload-mercy来改变,我们先来看看uWSGI官方文档描述:
reload-mercy
argument: required_argument
parser: uwsgi_opt_set_int
help: set the maximum time (in seconds) we wait for workers and other processes to die during reload/shutdown
worker-reload-mercy
argument: required_argument
parser: uwsgi_opt_set_int
help: set the maximum time (in seconds) a worker can take to reload/shutdown (default is 60)
reload-mercy是控制整个uWSGI实例的超时
worker-reload-mercy是控制单个worker的超时
因此把uWSGI启动的配置文件加上:
worker-reload-mercy = 1
虽然服务重启时间变短了,但是发现部署服务的时候,有些worker会无法启动,或者随着时间推移worker无法重启,进程都死掉。后来通过分析uWSGI配置参数,找到lazy-apps这个参数,看看官方文档描述:
lazy-apps
argu