Nginx高性能WEB服务器系列v1_第1页
Nginx高性能WEB服务器系列v1_第2页
Nginx高性能WEB服务器系列v1_第3页
Nginx高性能WEB服务器系列v1_第4页
Nginx高性能WEB服务器系列v1_第5页
已阅读5页,还剩74页未读 继续免费阅读

下载本文档

版权说明:本文档由用户提供并上传,收益归属内容提供方,若内容存在侵权,请进行举报或认领

文档简介

1、Nginx高性能WEB服务器系列目 录1. Nginx入门简介22. Nginx工作原理及安装配置33. Nginx常用命令管理及升级64. Nginx配置文件精讲一95. Nginx配置文件精讲二146. 实战线上Nginx多站点配置187. 企业实战Nginx+Tomcat动静分离架构198. 企业实战Nginx+PHP(FastCGI)高性能服务器269. Nginx与Tomcat/PHP架构优化3010. Nginx配置优化及深入讲解3511. Nginx Rewrite规则详解一4012. 构建Nginx均衡LAMP高性能服务器4113. Nginx日志分析及脚本编写5014. Ng

2、inx日志切割案例讲解5315. Nginx防盗链配置案例配置5516. Nginx运维日常故障解决方案5817. Nginx构建安全站点HTTPS架构58Ø 加载SSL支持的Nginx并使用私钥时去除口令:6118. Nginx均衡TCP协议服务器案例6319. 构建企业级Nginx+Keepalived集群架构6520. 企业Nginx+Keepalived双主架构案例实战721. Nginx入门简介WEB服务器也称为WWW(WORLD WIDE WEB)服务器,主要功能是提供网上信息浏览服务。 WWW 是 Internet的多媒体信息查询工具,是 Internet 上

3、近年才发展起来的服务,也是发展最快和目前用的最广泛的服务。正是因为有了WWW工具,才使得近年来 Internet 迅速发展,且用户数量飞速增长。Nginx ("engine x") 是一个高性能的 HTTP 和 反向代理 服务器,也是一个 IMAP/POP3/SMTP 代理服务器。 Nginx 是由 Igor Sysoev 为俄罗斯访问量第二的 Rambler.ru 站点开发的,第一个公开版本0.1.0发布于2004年10月4日。其将源代码以类BSD许可证的形式发布,因它的稳定性、丰富的功能集、示例配置文件和低系统资源的消耗而闻名。它已经在众多

4、流量很大的俄罗斯网站上使用了很长时间,这些网站包括Yandex、Mail.Ru、VKontakte,以及Rambler。据Netcraft统计,在2012年8月份,世界上最繁忙的网站中有11.48%使用Nginx作为其服务器或者代理服务器。目前互联网主流公司360、百度、新浪、腾讯、阿里等,目前中国互联网企业70%以上公司都在使用nginx作为自己的web服务器。Nginx特点是占有内存少,并发能力强,事实上nginx的并发能力确实在同类型的网页服务器中表现较好。Nginx由内核和模块组成,其中,内核的设计非常微小和简洁,完成的工作也非常简单,仅仅通过查找配置文件将客户端请求映射到一个loca

5、tion block(location是Nginx配置中的一个指令,用于URL匹配),而在这个location中所配置的每个指令将会启动不同的模块去完成相应的工作。Nginx相对于Apache优点:1) 高并发响应性能非常好,官方Nginx处理静态文件并发5w/s2) 反向代理性能非常强。(可用于负载均衡)3) 内存和cpu占用率低。(为Apache的1/5-1/10)4) 对后端服务有健康检查功能。5) 支持PHP cgi方式和fastcgi方式。6) 配置代码简洁且容易上手。2. Nginx工作原理及安装配置Nginx由内核和模块组成,其中,内核的设计非常微小和简洁,完成的工作也非常简单,

6、仅仅通过查找配置文件将客户端请求映射到一个location block(location是Nginx配置中的一个指令,用于URL匹配),而在这个location中所配置的每个指令将会启动不同的模块去完成相应的工作。Nginx的模块从结构上分为核心模块、基础模块和第三方模块:核心模块:HTTP模块、EVENT模块和MAIL模块基础模块:HTTP Access模块、HTTP FastCGI模块、HTTP Proxy模块和HTTP Rewrite模块,第三方模块:HTTP Upstream Request Hash模块、Notice模块和HTTP Access Key模块。Nginx的高并发得益于其

7、采用了epoll模型,与传统的服务器程序架构不同,epoll是linux内核2.6以后才出现的。Nginx采用epoll模型,异步非阻塞,而Apache采用的是select模型:Select特点:select 选择句柄的时候,是遍历所有句柄,也就是说句柄有事件响应时,select需要遍历所有句柄才能获取到哪些句柄有事件通知,因此效率是非常低。epoll的特点:epoll对于句柄事件的选择不是遍历的,是事件响应的,就是句柄上事件来就马上选择出来,不需要遍历整个句柄链表,因此效率非常高。接下来正式安装Nginx,首先需要安装pcre库。#安装pcre支持rewrite库,也可以安装源码,注*安装源

8、码时,指定pcre路径为解压源码的路径,而不是编译后的路径,否则会报错(make1: * /usr/local/pcre/Makefile Error 127 错误)yum install pcre-devel pcre -y#下载Nginx源码包cd /usr/src wget -c /download/nginx-1.6.2.tar.gz #解压Nginx源码包tar -xzf nginx-1.6.2.tar.gz#进入解压目录,然后sed修改Nginx版本信息为WScd nginx-1.6.2 ; sed -

9、i -e 's/1.6.2/g' -e 's/nginx/WS/g' -e 's/"NGINX"/"WS"/g' src/core/nginx.h#预编译Nginxuseradd www ;./configure -user=www -group=www -prefix=/usr/local/nginx -with-http_stub_status_module -with-http_ssl_module#.configure预编译成功后,执行make命令进行编译make#make执行成功后,执行make

10、install 正式安装make install#自此Nginx安装完毕/usr/local/nginx/sbin/nginx -t 检查nginx配置文件是否正确,返回OK即正确。rootlocalhost # /usr/local/nginx/sbin/nginx -tnginx: the configuration file /usr/local/nginx/conf/nginx.conf syntax is oknginx: configuration file /usr/local/nginx/conf/nginx.conf test is successfulrootlocalho

11、st #然后启动nginx,/usr/local/nginx/sbin/nginx 回车即可。查看进程是否已启动:rootlocalhost # ps -ef |grep nginxnobody 5381 30285 0 May16 ? 00:04:31 nginx: worker process root 30285 1 0 2014 ? 00:00:00 nginx: master process /usr/local/nginx/sbin/nginxroot 32260 32220 0 12:34 pts/0 00:00:00 grep nginxrootlocalhost #3. Ng

12、inx常用命令管理及升级查看nginx进程 ps -ef|grep nginx说明:nginx的进程由主进程和工作进程组成。启动nginxnginx启动结果显示nginx的主线程和工作线程,工作线程的数量跟nginx.conf中的配置参数worker_processes有关。平滑启动nginx kill -HUP cat /var/run/nginx.pid 或者nginx -s reload其中进程文件路径在配置文件nginx.conf中可以找到。平滑启动的意思是在不停止nginx的情况下,重启nginx,重新加载配置文件,启动新的工作线程,完美停止旧的工作线程。完美停止nginx kill

13、 -QUIT cat /var/run/nginx.pid快速停止nginx kill -TERM cat /var/run/nginx.pid或者kill -INT cat /var/run/nginx.pid完美停止工作进程(主要用于平滑升级) kill -WINCH cat /var/run/nginx.pid强制停止nginx pkill -9 nginx检查对nginx.conf文件的修改是否正确 nginx -t -c /etc/nginx/nginx.conf 或者 nginx -t停止nginx的命令nginx -s stop或者pkill nginx查看nginx的版本信息n

14、ginx -v查看完整的nginx的配置信息 nginx -VNginx升级方法:下载所需版本的Nginxwget /download/nginx-1.4.2.tar.gz 获取旧版本nginx的configure选项/usr/local/nginx/sbin/nginx -V 编译新版本的nginxtar -xvf nginx-1.4.2.tar.gz cd nginx-1.4.2 ./configure -prefix=/usr/local/nginx -user=www -group=www -with-http_stub_status_module

15、 -with-http_ssl_module make 备份旧版本的nginx可执行文件,复制新版本的nginx这行文件mv /usr/local/nginx/sbin/nginx /usr/local/nginx/sbin/nginx.old cp objs/nginx /usr/local/nginx/sbin/测试新版本nginx是否正常/usr/local/nginx/sbin/nginx -t平滑重启升级nginxkill USR2 cat /usr/local/nginx/log/nginx.pid 旧版本Nginx的pid变为oldbin,这是旧版本和新版本的nginx同时运行,

16、过一段时间等就nginx处理完用户请求后,执行下面操作从容关闭旧版本的Nginx进程kill -WINCH cat /usr/local/nginx/log/nginx.oldbin 决定是否升级到新版的nginxkill HUP cat /usr/local/nginx/log/nginx.oldbin #nginx在不重载配置文件启动工作进程 kill QUIT cat /usr/local/nginx/log/nginx.oldbin #关闭旧版nginx 验证nginx是否升级成功/usr/local/nginx/sbin/nginx V #显示下图则升级成功4. Nginx配置文件精

17、讲一#定义Nginx运行的用户和用户组user www www;#启动进程,通常设置成和cpu的数量相等worker_processes 8;worker_cpu_affinity 00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;#为每个进程分配cpu,上例中将8个进程分配到8个cpu,当然可以写多个,或者将一个进程分配到多个cpu。worker_rlimit_nofile 102400;#这个指令是指当一个nginx进程打开的最多文件描述符数目,理论值应该是最多打#开文件数(ulimit -n)与

18、nginx进程数相除,但是nginx分配请求并不是那么均匀#,所以最好与ulimit -n的值保持一致。#全局错误日志及PID文件error_log /usr/local/nginx/logs/error.log; #错误日志定义等级, debug | info | notice | warn | error | crit pid /usr/local/nginx/nginx.pid;#一个nginx进程打开的最多文件描述符数目,理论值应该是最多打开文件数(系统的值ulimit -n)与nginx进程数相除,但是nginx分配请求并不均匀.#所以建议与ulimit -n的值保持一致。worke

19、r_rlimit_nofile 65535;#工作模式及连接数上限events use epoll; #epoll是多路复用IO(I/O Multiplexing)中的一种方式,但是仅用于linux2.6以上内核,可以大大提高nginx的性能 worker_connections 102400;#单个后台worker process进程的最大并发链接数 (最大连接数=连接数*进程数) multi_accept on; #尽可能多的接受请求#设定http服务器,利用它的反向代理功能提供负载均衡支持http #设定mime类型,类型由mime.type文件定义 include mime.types

20、; default_type application/octet-stream; #设定日志格式 access_log /usr/local/nginx/log/nginx/access.log; sendfile on; #sendfile 指令指定 nginx 是否调用 sendfile 函数(zero copy 方式)来输出文件,对于普通应用必须设为 on#如果用来进行下载等应用磁盘IO重负载应用,可设置为 off,以平衡磁盘与网络I/O处理速度,降低系统的uptime.#autoindex on; #开启目录列表访问,合适下载服务器,默认关闭。tcp_nopush on; #防止网络阻

21、塞keepalive_timeout 60;#keepalive超时时间,客户端到服务器端的连接持续有效时间,当出现对服务器的后,继请求时,keepalive-timeout功能可避免建立或重新建立连接。 tcp_nodelay on; #提高数据的实时响应性 #开启gzip压缩 gzip on;gzip_min_length 1k;gzip_buffers 4 16k;gzip_http_version 1.1;gzip_comp_level 2; #压缩级别大小,最大为9,值越小,压缩后比例越小,CPU处理更快。#值越大,消耗CPU比较高。gzip_types text/plain app

22、lication/x-javascript text/css application/xml;gzip_vary on;client_max_body_size 10m; #允许客户端请求的最大单文件字节数 client_body_buffer_size 128k; #缓冲区代理缓冲用户端请求的最大字节数, proxy_connect_timeout 90; #nginx跟后端服务器连接超时时间(代理连接超时) proxy_send_timeout 90; #后端服务器数据回传时间(代理发送超时) proxy_read_timeout 90; #连接成功后,后端服务器响应时间(代理接收超时)

23、proxy_buffer_size 4k; #设置代理服务器(nginx)保存用户头信息的缓冲区大小 proxy_buffers 4 32k; #proxy_buffers缓冲区,网页平均在32k以下的话,这样设置 proxy_busy_buffers_size 64k; #高负荷下缓冲大小(proxy_buffers*2) #设定请求缓冲 large_client_header_buffers 4 4k;client_header_buffer_size 4k;#客户端请求头部的缓冲区大小,这个可以根据你的系统分页大小来设置,一般一个请求的头部大小不会超过1k#不过由于一般系统分页都要大于1

24、k,所以这里设置为分页大小。分页大小可以用命令getconf PAGESIZE取得。open_file_cache max=102400 inactive=20s;#这个将为打开文件指定缓存,默认是没有启用的,max指定缓存数量,建议和打开文件数一致,inactive是指经过多长时间文件没被请求后删除缓存。open_file_cache_valid 30s;#这个是指多长时间检查一次缓存的有效信息。open_file_cache_min_uses 1;#open_file_cache指令中的inactive参数时间内文件的最少使用次数,如果超过这个数字,文件描述符一直是在缓存中打开的,如上例,

25、如果有一个文件在inactive #包含其它配置文件,如自定义的虚拟主机 include vhosts.conf;5. Nginx配置文件精讲二#这里为后端服务器wugk应用集群配置,根据后端实际情况修改即可,tdt_wugk为负载均衡名称,可以任意指定#但必须跟vhosts.conf虚拟主机的pass段一致,否则不能转发后端的请求。weight配置权重,在fail_timeout内检查max_fails次数,失败则剔除均衡。upstream tdt_wugk server :8080 weight=1 max_fails=2 fail_timeout=30s;server

26、:8081 weight=1 max_fails=2 fail_timeout=30s; #虚拟主机配置server #侦听80端口 listen 80; #定义使用访问 server_name ; #设定本虚拟主机的访问日志 access_log logs/access.log main;root /data/webapps/wugk; #定义服务器的默认网站根目录位置 index index.php index.html index.htm; #定义首页索引文件的名称 #默认请求 location / root /data/www/wugk; #定义服务器的默认网站根目录

27、位置 index index.php index.html index.htm; #定义首页索引文件的名称 #以下是一些反向代理的配置. proxy_next_upstream http_502 http_504 error timeout invalid_header; #如果后端的服务器返回502、504、执行超时等错误,自动将请求转发到upstream负载均衡池中的另一台服务器,实现故障转移。 proxy_redirect off; #后端的Web服务器可以通过X-Forwarded-For获取用户真实IP proxy_set_header Host $host; proxy_set_h

28、eader X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http:/tdt_wugk; #请求转向后端定义的均衡模块 # 定义错误提示页面error_page 500 502 503 504 /50x.html; location = /50x.html root html; #配置Nginx动静分离,定义的静态页面直接从Nginx发布目录读取。location .*.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|j

29、s|css)$root /data/www/wugk;#expires定义用户浏览器缓存的时间为3天,如果静态页面不常更新,可以设置更长,这样可以节省带宽和缓解服务器的压力。expires 3d; #PHP脚本请求全部转发到 FastCGI处理. 使用FastCGI默认配置. location .php$ root /root; fastcgi_pass :9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /data/www/wugk$fastcgi_script_name; include fastcg

30、i_params; #设定查看Nginx状态的地址 location /NginxStatus stub_status on; 6. 实战线上Nginx多站点配置在真实的服务器环境,为了充分利用服务器资源,一台nginx web服务器同时会配置N个虚拟域名主机,即多个域名对于同样一个80端口。然后服务器IP数量很多,也可以配置基于多个IP对应同一个端口。vi修改nginx.conf server段配置内容如下:#virtual hosts config 2014/5/18server listen 80; server_name ; #access_log logs/host.access.l

31、og main; location / root html/a; index index.html index.htm; server listen 80; server_name ; #access_log logs/host.access.log main; location / root html/b; index index.html index.htm; 创建两个不同的目录mkdir p /usr/local/nginx/html/a,b,然后分别在两个目录创建两个不同的index.html网站页面即可。通过客户端配置hosts指向两个域名,然后在IE浏览器访问测试效果。7. 企业实

32、战Nginx+Tomcat动静分离架构Nginx动静分离简单来说就是把动态跟静态请求分开,不能理解成只是单纯的把动态页面和静态页面物理分离。严格意义上说应该是动态请求跟静态请求分开,可以理解成使用Nginx处理静态页面,Tomcat、Resin出来动态页面。动静分离从目前实现角度来讲大致分为两种,一种是纯粹的把静态文件独立成单独的域名,放在独立的服务器上,也是目前主流推崇的方案;另外一种方法就是动态跟静态文件混合在一起发布,通过nginx来分开。这样也是本次课程要讲解的,具体怎么来实现呢,如下图,通过location指定不同的后缀名实现不同的请求转发。通过expires参数设置,可以使浏览器缓

33、存过期时间,减少与服务器之前的请求和流量。具体Expires定义:是给一个资源设定一个过期时间,也就是说无需去服务端验证,直接通过浏览器自身确认是否过期即可,所以不会产生额外的流量。此种方法非常适合不经常变动的资源。(如果经常更新的文件,不建议使用Expires来缓存),我这里设置3d,表示在这3天之内访问这个URL,发送一个请求,比对服务器该文件最后更新时间没有变化,则不会从服务器抓取,返回状态码304,如果有修改,则直接从服务器重新下载,返回状态码200。线上Nginx动静分离完整配置(实际环境中可以使用,如下为nginx.conf文件内容)user www www;worker_proc

34、esses 8;worker_cpu_affinity 00000001 00000010 00000100 00001000 00010000 00100000 01000000 10000000;pid /usr/local/nginx/nginx.pid;worker_rlimit_nofile 102400;eventsuse epoll;worker_connections 102400;http include mime.types; default_type application/octet-stream; fastcgi_intercept_errors on; charse

35、t utf-8; server_names_hash_bucket_size 128; client_header_buffer_size 4k; large_client_header_buffers 4 32k; client_max_body_size 300m; sendfile on; tcp_nopush on; keepalive_timeout 60; tcp_nodelay on; client_body_buffer_size 512k; proxy_connect_timeout 5; proxy_read_timeout 60; proxy_send_timeout 5

36、; proxy_buffer_size 16k; proxy_buffers 4 64k; proxy_busy_buffers_size 128k; proxy_temp_file_write_size 128k; gzip on; gzip_min_length 1k; gzip_buffers 4 16k; gzip_http_version 1.1; gzip_comp_level 2; gzip_types text/plain application/x-javascript text/css application/xml; gzip_vary on;log_format mai

37、n '$remote_addr - $remote_user $time_local "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" $request_time'upstream jvm_web1 server :8080 weight=1 max_fails=2 fail_timeout=30s; server :8081 weight=1 ma

38、x_fails=2 fail_timeout=30s;upstream jvm_web2 server :8082 weight=1 max_fails=2 fail_timeout=30s; server :8083 weight=1 max_fails=2 fail_timeout=30s;include vhosts.conf;如下为vhosts.conf内容:server listen 80; server_name ; index index.jsp index.html index.htm; root /data/webapps/wugk1; l

39、ocation / proxy_next_upstream http_502 http_504 error timeout invalid_header; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http:/jvm_web1; location .*.(php|jsp|cgi|shtml)?$ proxy_set_header Host $host; p

40、roxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http:/jvm_web1; location .*.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|css)$ root /data/webapps/wugk1;expires 30d; access_log /data/logs/jvm_web1/access.log main;error_log /data/logs/jvm_we

41、b1/error.log crit; server listen 80; server_name ; index index.jsp index.html index.htm; root /data/webapps/wugk2; location / proxy_next_upstream http_502 http_504 error timeout invalid_header; proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $pr

42、oxy_add_x_forwarded_for; proxy_pass http:/jvm_web2; location .*.(php|jsp|cgi|shtml)?$ proxy_set_header Host $host; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http:/jvm_web2; location .*.(html|htm|gif|jpg|jpeg|bmp|png|ico|txt|js|cs

43、s)$ root /data/webapps/wugk2;expires 30d; access_log /data/logs/jvm_web2/access.log main;error_log /data/logs/jvm_web2/error.log crit; 然后在创建如下目录:mkdir -p /data/logs/jvm_web1,jvm_web2 /data/webapps/wugk1,wugk2配置后端Tomcat服务器,这里省略哦,分别启动4个tomcat或者2个tomcat对应不同的均衡模块ip和端口即可。最后检查Nginx配置是否正确即可,然后测试动静分离是否成功,之需

44、要删除后端tomcat服务器上的某个静态文件,查看是否能访问,如果可以访问说明静态资源nginx直接返回了,不走后端tomcat服务器。8. 企业实战Nginx+PHP(FastCGI)高性能服务器LNAMP(Linux+Nginx+Apache+Mysql+PHP架构)CGI全称是“公共网关接口”(Common Gateway Interface),HTTP服务器与你的或其它机器上的程序进行“交谈”的一种工具,其程序须运行在网络服务器上。CGI可以用任何一种语言编写,只要这种语言具有标准输入、输出和环境变量。如php,perl,tcl等。FAST-CGI:WEB服务器与处理程序之间通信的一种

45、协议(app server 和web server 之间的通信协议),是CGI的改进方案。CGI程序反复加载是CGI性能低下的主要原因,如果CGI程序保持在内存中并接受FastCGI进程管理器调度,则可以提供良好的性能、伸缩性、Fail-Over特性等。FASTCGI是常驻型的CGI,它可以一直运行,在请求到达时,不会花费时间去fork一个进程来处理。FastCGI是语言无关的、可伸缩架构的CGI开放扩展,将CGI解释器进程保持在内存中,以此获得较高的性能。fastcgi是一个协议,php-fpm实现了这个协议,php-fpm的fastcgi协议需要有进程池,php-fpm实现的fastcgi

46、进程叫php-cgi,所以php-fpm其实是他自身的fastcgi或php-cgi进程管理器。Nginx+FastCGI安装配置:1) 下载安装并编译PHPwget yum -y install gd curl curl-devel libjpeg libjpeg-devel libpng libpng-devel freetype freetype-devel libxml2 libxml2-devel mysql mysql-devel2) 进入php目录进行编译安装:cd php-5.3.10./configure -prefix=/usr/local/php5 -enable-fpm

47、 -enable-debug -with-gd -with-jpeg-dir -with-png-dir -with-freetype-dir -enable-mbstring -with-curl -with-mysql=/usr/bin/mysql -with-mysqli=/usr/bin/mysql_configmake && make installcp php.ini-development /usr/local/php5/lib/php.inicp /usr/local/php5/etc/php-fpm.conf.default/usr/local/php5/et

48、c/php-fpm.conf/usr/local/php5/sbin/php-fpm cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm3) Nginx配置文件设置:server include port.conf; server_name ; location / index index.html index.php; root /usr/local/nginx/html; location .php$ root html; fastcgi_pass :9000; fastcgi_index index.php; fastcgi_p

49、aram SCRIPT_FILENAME html$fastcgi_script_name; include fastcgi_params; 4) 测试Nginx+PHP整合结果9. Nginx与Tomcat/PHP架构优化PHP性能优化一般我们是在/usr/local/php5/etc/php-fpm.conf这个文件里面进行相应的配置。1) 如果设置成static,php-fpm进程数自始至终都是pm.max_children指定的数量,不再增加或减少。2) 如果设置成dynamic,则php-fpm进程数是动态的,最开始是pm.start_servers指定的数量,如果请求较多,则会自动

50、增加,保证空闲的进程数不小于pm.min_spare_servers,如果进程数较多,也会进行相应清理,保证多余的进程数不多于pm.max_spare_servers。这两种不同的进程管理方式,可以根据服务器的实际需求来进行调整。这里先说一下涉及到这个的几个参数,他们分别是pm、pm.max_children、pm.start_servers、pm.min_spare_servers和pm.max_spare_servers。Pm 表示使用那种方式,有两个值可以选择,就是static(静态)或者dynamic(动态)。在更老一些的版本中,dynamic被称作apache-like。这个要注意看

51、配置文件的说明。下面4个参数的含义:pm.max_children:静态方式下开启的php-fpm进程数量。pm.start_servers:动态方式下的起始php-fpm进程数量。pm.min_spare_servers:动态方式下的最小php-fpm进程数量。pm.max_spare_servers:动态方式下的最大php-fpm进程数量。如果dm设置为static,那么其实只有pm.max_children这个参数生效。系统会开启设置数量的php-fpm进程。如果dm设置为dynamic,那么pm.max_children参数失效,后面3个参数生效。系统会在php-fpm运行开始的时候启

52、动pm.start_servers个php-fpm进程,然后根据系统的需求动态在pm.min_spare_servers和pm.max_spare_servers之间调整php-fpm进程数。其他优化方法:1. Compile PHPs modules as less as possible, the simple the best (fast); 尽量少安装PHP模块,最简单是最好(快)的2. Increas PHP FastCGI child number to 100 and even more. Sometime, 200 is OK! ( On 4GB memory server); 2G把你的PHP FastCGI子进程数调到100或以上,在4G内存的服务器上200就可以(建议压力测试来得出自己服务器合理的值)3. Using SOCKET PHP FastCGI, and put into /dev/

温馨提示

  • 1. 本站所有资源如无特殊说明,都需要本地电脑安装OFFICE2007和PDF阅读器。图纸软件为CAD,CAXA,PROE,UG,SolidWorks等.压缩文件请下载最新的WinRAR软件解压。
  • 2. 本站的文档不包含任何第三方提供的附件图纸等,如果需要附件,请联系上传者。文件的所有权益归上传用户所有。
  • 3. 本站RAR压缩包中若带图纸,网页内容里面会有图纸预览,若没有图纸预览就没有图纸。
  • 4. 未经权益所有人同意不得将文件中的内容挪作商业或盈利用途。
  • 5. 人人文库网仅提供信息存储空间,仅对用户上传内容的表现方式做保护处理,对用户上传分享的文档内容本身不做任何修改或编辑,并不能对任何下载内容负责。
  • 6. 下载文件中如有侵权或不适当内容,请与我们联系,我们立即纠正。
  • 7. 本站不保证下载资源的准确性、安全性和完整性, 同时也不承担用户因使用这些下载资源对自己和他人造成任何形式的伤害或损失。

评论

0/150

提交评论