详解php-fmp.conf和php.ini文件
我的mac上php配置文件的安装路径是/usr/local/etc/php/7.3,编译安装php的话 configure 编译参数指定,目录下有conf.d/ pear.conf php-fpm.conf php-fpm.d/ php.ini几个文件目录。https://p1.pstatp.com/large/pgc-image/ea3fec18ec2d4ac4aaeac0806ec57850
php.ini文件是php虚拟机的配置文件,是php解释器本身的配置文件
expose_php = On //PHP信息暴露在http头中 X-Powered-By:PHP/7.2.27 Off关闭disable_functions = phpinfo,system,exec,shell_exec,passthru,popen,dl,proc_open,popen,curl_exec,curl_multi_exec//禁止使用函数列表 ,分割error_reporting //错误报告级别E_ALL & ~E_NOTICE & ~E_STRICT & ~E_DEPRECATEDdisplay_errors = Off //关闭错误输出显示,可以用日志代替,避免暴露安全信息display_startup_errors// PHP 启动过程中的错误信息也不会被显示allow_url_fopen = Off //允许打开远程文件log_errors //脚本运行的错误信息记录到服务器错误日志或者error_loglog_errors_max //log_errors 的最大字节数 默认值为1024,如果设置为0表示不限长度error_log //错误文件php-fpm的配置文件在/usr/local/etc/php/7.3/php-fpm.conf,格式和ini文件差不多
pid = run/php-fpm.pid //pid文件error_log = log/php-fpm.log //错误日志syslog.ident = php-fpm // 用于FPM多实例情况log_level = notice //日志级别alert, error, warning, notice, debuglog_limit = 4096 //日志大小 默认1024emergency_restart_threshold = 0 //子进程在时间段内有IGSEGV或SIGBUS退出,重启emergency_restart_interval //设置间隔时间段process_control_timeout // 子进程等待master进程对信号的回应时间process.max = 128 //最大子进程数;rlimit_files = 1024 // 设置主进程文件描述符rlimit的数量;rlimit_core = 0 // 设置主进程rlimit最大核数;events.mechanism = epoll // 使用处理event事件的机制 ;- select (any POSIX os) ; - poll (any POSIX os) ; - epoll (linux >= 2.5.44) ; - kqueue (FreeBSD >= 4.1, OpenBSD >= 2.9, NetBSD >= 2.0) ; - /dev/poll(Solaris >= 7) ; - port (Solaris >= 10)daemonize = yes // 将fpm转至后台运行,如果设置为“no”,那么fpm会运行在前台//进程池user = nobody //进程的发起用户和group = nobody//用户组用户必须设置,group不是listen = 127.0.0.1:9000 //监听ip和端口pm = dynamic //选择进程池管理器如何控制子进程的数量 static://对于子进程的开启数路给定一个锁定的值(pm.max_children) dynamic: //子进程的数目为动态的,它的数目基于下面的指令的值(以下为dynamic适用参数) pm.max_children: //同一时刻能最大子进程的数量 pm.start_servers: //启动时启动的子进程数量 pm.min_spare_servers: //"idle"状态的最小子进程,如果空闲进程数量小于这个值,子进程会被创建 pm.max_spare_servers: //最大空闲子进程数量,空闲子进程数量超过这个值,那么相应的子进程会被杀掉。 ondemand: //启动时不会创建,只有当发起请求链接时才会创建(pm.max_children, pm.process_idle_timeout)pm.process_idle_timeout = 10s; //空闲进程超时时间pm.max_requests = 500 //在派生新的子进程前,每一个子进程应该处理的请求数目pm.status_path = /status //配置一个URI,以便查看fpm状态页;ping.path = /ping //该ping URI将会去调用fpm监控页面,如果这个没有设置,那么不会有URI被做为ping页;ping.response = pong //用于ping制平请求的响应,响应的格式text/plain(对200响应代码);access.log = log/$pool.access.log //access日志;access.format = "%R - %u %t "%m %r%Q%q" %s %f %{mili}d %{kilo}M %C%%";slowlog = log/$pool.log.slow //慢请求日志request_slowlog_timeout = 0 //慢日志请求超时时间,对一个php程序进行跟踪。;request_terminate_timeout = 0 //终止请求超时时间,在worker进程被杀掉之后,提供单个请求的超时间隔。由于某种原因不停止脚本执行时,应该使用该选项,0表示关闭不启用;rlimit_files = 1024 //设置打开文件描述符的限制;rlimit_core = 0 //设置内核对资源的使用限制,用于内核转储security.limit_extensions = .php .php3 .php4 .php5 //限制FPM执行解析的扩展名 Nginx 504 Gateway Time-out的含义是没有请求到可以执行的PHP-CGI;Nginx 502 Bad Gateway的含义是请求的PHP-CGI已经执行,但是由于读取资源的等没有执行完毕而导致PHP-CGI进程终止。php-cgi的内存消耗大约20M-30M,适当的设置max_children,以免打满报504;max_requests指明了每个children最多处理多少个请求后便会被关闭,如果该值设置过小会导致 children频繁的自杀和建立而浪费 大量时间,若所有的children差不多都在这个时候自杀,则重建前将没有children响应请求会502,php 程序执行时间过长而超时,超过request_terminate_timeout会502。 转发了
页:
[1]