在实际的生产环境中遇到了实际需要解决的问题,需要把服务部署的方式梳理出来,在同一个服务器中部署多个PHP环境,架构图如下:
在工作实践中遇到的很多问题的普遍性都是相通的,公司运行的可新项目都是版本比较低的,需要一步一步去升级、优化,也就是一点一点的分步骤优化,有着诸多挑战,技术人的成长就是敢于一步一步抽丝剥茧,最后让架构变的丝滑。
依然使用Nginx作为链接PHP-FPM的Web服务器,分别使用9000、9001、90002端口分别去搭建不同的版本的php-fpm,设置Nginx不同的运行$document_root
中,这个是预设方案,在实施过程中需要准备一些准备的知识,谋定而后动。
emergency_restart_threshold
在指定的一段时间内,如果失效的PHP_FPM子进程数超过这个值,PHP_FPM主进程就优雅重启。
emergency_restart_threshold = 10
设定emergency_restart_interval
设置采用的时间跨度。
emergency_restart_interval = 0
下面要详细介绍的是php-fpm的配置:
user 拥有这个PHP-FPM进程池中的子进程系统用户,要把这个设置的值设为运行PHP应用的非根用户名户名。
group 拥有这个PHP-FPM进程池中的子进程系统用户组。要把这个设置的值设为运行PHP应用的非根用户所属的用户组名。
listen PHP-FPM进程池监听的IP地址和端口号,让PHP-FPM只接受Nginx从这里传入的请求。127.0.0.1:9000让指定的PHP-FPM进程池监听从本地端口9000进入的。可以使用任何大于1024且没被其他系统进程占用的端口号。
pm.max_children 这个设置设定任何时间点PHP-FPM进程池中最多能有多少个进程。
pm.start_servers = 3 PHP-FPM启动时PHP-FPM进程池中立即可用的进程数。
pm.min_spare_servers PHP应用空闲时PHP-FPM进程池中可以存在的进程数量最小值。这个值一般比pm.start_servers
设置的值一样,用于确保新进入的Http请求无需等待PHP-FPM在进程池中重新初始化进程。
pm.max_spare_servers PHP应用空闲时PHP-FPM进程池中可以存在的进程数量最大值。
pm.max_requests
回收进程之前,PHP_FPM进程池中各个进程最多能处理的Http请求数量。这个设置有助于避免PHP扩展库因编写拙劣而导致不断泄露内存。
showlog 这个设置的值是一个日志文件在文件系统中的绝对路径。这个日志文件用于记录处理时间超过n秒的Http请求信息,以便找出PHP应用的瓶颈,进行调试,记住,PHP_FPM进程池所属用户和用户组必须有这个文件的写权限。
request_showlog_timeout 如果当前Http请求的处理时间超过指定的值,就把请求的回溯信息写入showlog设置指定的日志文件。
user = nobody
group = nobody
listen = 127.0.0.1:9000
pm.max_children = 51
pm.start_servers = 3
pm.min_spare_servers = 2
pm.max_spare_servers = 4
pm.max_requests = 1000
showlog = /path/to/showlog.log
request_showlog_timeout = 5s
有时间在更新同一个服务器上部署多个PHP版本的服务器的内容。