设为首页 收藏本站
查看: 1743|回复: 0

[经验分享] 配置nginx对php的支持

[复制链接]

尚未签到

发表于 2018-11-12 10:59:24 | 显示全部楼层 |阅读模式
  配置nginx对php的支持
  案例声明:本次案例所有软件包用的都是源码包
  一、基本环境:
  因为nginx与httpd服务用的是同一个端口,所以在安装nginx之前必须要停止apache服务,释放80端口;
  安装php需要用到哈希函数库,字符编码的转换和加密等,需要编译gcc等的支持,建议先把开发工具和开发库安装好,方便后续操作。
  [root@localhost ~]# service httpd stop
  [root@localhost ~]# yum -y groupinstall "Development
  libraries" "Development tools" "X Software Development“
  [root@localhost ~]# yum -y install gcc openssl-devel pcre-
  devel zlib-devel
  这里我们一会在配置nginx的时候指定的user和group是www,所有提前添加www用户和组,也可以自己定义,不过必须要和配置选项中指定的一致
  [root@localhost ~]# groupadd www
  [root@localhost ~]# useradd -g www www
  二、安装nginx服务
  [root@localhost ~]# tar -zxvf nginx-1.2.0.tar.gz    解压
  [root@localhost ~]# cd nginx-1.2.0
  [root@localhost nginx-1.2.0]# ./configure \         配置
  > --prefix=/usr/local/nginx \指定安装路径
  > --pid-path=/usr/local/nginx/nginx.pid \       指定pid文件
  > --user=www --group=www \指定所有者/组
  > --with-http_ssl_module \使支持https请求,需已安装openssl
  --with-http_flv_module \
  提供寻求内存使用基于时间的偏移量文件
  > --with-http_stub_status_module \ 获取nginx自上次启动以来的工作状态
  > --with-http_gzip_static_module \ 在线实时压缩输出数据流
  > --http-client-body-temp-path=/usr/local/nginx/client \
  设定http客户端请求临时文件路径
  > --http-proxy-temp-path=/usr/local/nginx/proxy \
  设定http代理临时文件路径
  > --http-fastcgi-temp-path=/usr/local/nginx/fcgi \
  设定http fastcgi临时文件路径
  > --http-uwsgi-temp-path=/usr/local/nginx/uwsgi \
  设定http uwsgi临时文件路径
  > --http-scgi-temp-path=/usr/local/nginx/scgi \
  设定http scgi临时文件路径
  > --with-pcre
  指向pcre库文件目录
  [root@localhost nginx-1.2.0]# make       编译
  [root@localhost nginx-1.2.0]# make install     安装
  上述配置参数是大多需要用到的,其他参数及解释,见本文最后的附录
  启动Nginx服务
  -c指定配置文件,默认为安装目录下的nginx.conf
  [root@localhost mysql]# /usr/local/nginx/sbin/nginx -c \
  > /usr/local/nginx/conf/nginx.conf
  [root@localhost mysql]# netstat -utnalp | grep :80
  tcp        0      0 0.0.0.0:80                  0.0.0.0:*                   LISTEN      41483/nginx
  三、安装php
  在安装php之前需要先安装php的扩展软件:
  1、安装php扩展软件
  安装mhash,提供哈稀函数库
  [root@localhost ~ ]# tar -zxvf mhash-0.9.9.9.tar.gz
  [root@localhost mhash-0.9.9.9]# cd mhash-0.9.9.9
  [root@localhost mhash-0.9.9.9]# ./configure
  [root@localhost mhash-0.9.9.9]# make
  [root@localhost mhash-0.9.9.9]# make install
  安装libiconv,处理中文各种编码之间的转换
  [root@localhost ~ ]# tar -zxvf libiconv-1.13.tar.gz
  [root@localhost libiconv-1.13]# cd libiconv-1.13
  [root@localhost libiconv-1.13]# ./configure
  [root@localhost libiconv-1.13]# make
  [root@localhost libiconv-1.13]# make install
  安装libmcrypt,提供加密功能的库文件
  [root@localhost libmcrypt-2.5.8]# tar -zxvf libmcrypt-2.5.8.tar.gz
  [root@localhost libmcrypt-2.5.8]# cd libmcrypt-2.5.8
  [root@localhost libmcrypt-2.5.8]# ./configure
  [root@localhost libmcrypt-2.5.8]# make
  [root@localhost libmcrypt-2.5.8]# make install
  安装完成libmcrypt库以后,不同的linux系统版本有可能还要
  安装libltdl
  在当前目录下有个libltdl目录
  [root@localhost libmcrypt-2.5.8]# cd libltdl
  [root@localhost libltdl ]# ./configure --with-gmetad --enable-gexec --enable-ltdl-install
  [root@localhost libltdl ]# make && make install
  安装完毕之后,由于库文件默认安装在/usr/local/lib目录下,系统是找不到的,所以要创建链接到/usr/lib
  [root@localhost ~ ]# ln -sv /usr/local/lib/libmcrypt* /usr/lib/
  [root@localhost ~ ]# ln -sv /usr/local/lib/libmhash.* /usr/lib/
  对库文件创建链接完毕之后,更新链接库
  [root@localhost ~ ] # ldconfig -v
  安装php
  root@localhost ~]# tar -zxvf php-5.4.9.tar.gz
  [root@localhost ~]# cd php-5.4.9
  [root@localhost php-5.4.9]# ./configure \
  --prefix=/usr/local/php5nginx \
  --with-config-file-path=/usr/local/php5nginx/etc \
  --with-mysql=/usr/local/mysql \
  --with-mysqli=/usr/local/mysql/bin/mysql_config \
  --with-iconv-dir=/usr/local \
  --with-freetype-dir --with-jpeg-dir \
  --with-png-dir --with-zlib --with-libxml-dir=/usr \
  --enable-xml --disable-rpath --enable-bcmath \
  --enable-shmop --enable-sysvsem \
  --enable-inline-optimization --with-curl --with-curlwrappers
  --enable-mbregex --enable-fpm --enable-mbstring
  --with-mcrypt --with-gd --enable-gd-native-ttf \
  --with-openssl --with-mhash --enable-pcntl \
  --enable-sockets --with-ldap --with-ldap-sasl \
  --with-xmlrpc --enable-zip --enable-soap \
  安装php
  [root@localhost php-5.4.9]# make ZEND_EXTRA_LIBS='-liconv'
  配置的时候指定字符转换
  [root@localhost php-5.4.9]# make install
  拷贝php的配置文件
  [root@localhost php-5.4.9]# cp php.ini-production
  >/usr/local/php5nginx/etc/php.ini
  \
  配置fast-cgi
  [root@localhost ~]# cd /usr/local/php5nginx/etc/
  [root@localhost etc]# cp php-fpm.conf.default php-fpm.conf
  生成配置文件
  [root@localhost etc]# vim php-fpm.conf
  编辑配置文件
  配置fast-cgi
  [global]
  pid = run/php-fpm.pid
  error_log = log/php-fpm.log
  log_level = error
  daemonize = yes
  [www]
  user = www
  group = www
  listen = 127.0.0.1:9000
  pm = dynamic
  pm.max_children = 32
  pm.start_servers = 15
  pm.min_spare_servers = 5
  pm.max_spare_servers = 32
  启动php-fpm,端口号为9000
  [root@localhost ~]# cd php-5.4.9/sapi/fpm/
  [root@localhost fpm]# cp init.d.php-fpm /etc/rc.d/init.d/php-fpm
  [root@localhost fpm]# chmod +x /etc/rc.d/init.d/php-fpm
  [root@localhost fpm]# chkconfig --add php-fpm
  [root@localhost fpm]# service php-fpm start|restart|reload|restart
  [root@localhost fpm]# ps aux | grep php-fpm
  三、nginx与php的整合
  编辑nginx.conf文件
  [root@localhost ~ ]# vim /usr/local/nginx/conf/nginx.conf
  location / {
  root html;
  index index.php index.html index.htm;
  }
  location ~ \.php$ {
  root
  html;
  fastcgi_pass 127.0.0.1:9000;   Php-fpm ip与端口
  fastcgi_index index.php;
  fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
  include fastcgi_params;        Fast-cgi参数文件
  }
  编辑fastcgi_params文件
  [root@localhost ~ ]# vim /usr/local/nginx/conf/fastcgi_params
  fastcgi_param GATEWAY_INTERFACE CGI/1.1;
  fastcgi_param SERVER_SOFTWARE nginx;
  ......
  fastcgi_param CONTENT_LENGTH $content_length;
  fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;   此处为一行,添加此行
  fastcgi_param SCRIPT_NAME $fastcgi_script_name;
  ......
  fastcgi_param DOCUMENT_ROOT $document_root;
  测试
  [root@localhost ~]# pkill -9 nginx
  [root@localhost ~]# /usr/local/nginx/sbin/nginx
  [root@localhost ~]# /etc/rc.d/init.d/php-fpm restart
  [root@localhost html]# vim index.php
  
  建立phpinfo的测试页
  打开浏览器,输入测试页路径,页面显示php的信息及表示安装成功!
  附录:
  nginx参数:
  --prefix= 指向安装目录--sbin-path 指向(执行)程序文件(nginx)
  --conf-path= 指向配置文件(nginx.conf)--error-log-path= 指向错误日志目录
  --pid-path= 指向pid文件(nginx.pid)--lock-path= 指向lock文件(nginx.lock)(安装文件锁定,防止安装文件被别人利用,或自己误操作。)
  --user= 指定程序运行时的非特权用户--group= 指定程序运行时的非特权用户组
  --builddir= 指向编译目录--with-rtsig_module 启用rtsig模块支持(实时信号)
  --with-select_module 启用select模块支持(一种轮询模式,不推荐在高载环境下使用)禁用:--without-select_module--with-poll_module 启用poll模块支持(功能与select相同,与select特性相同,为一种轮询模式,不推荐在高载环境下使用)
  --with-file-aio 启用file aio支持(一种APL文件传输格式)--with-ipv6 启用ipv6支持
  --with-http_ssl_module 启用ngx_http_ssl_module支持(使支持https请求,需已安装openssl)
  --with-http_realip_module 启用ngx_http_realip_module支持(这个模块允许从请求标头更改客户端的IP地址值,默认为关)
  --with-http_addition_module 启用ngx_http_addition_module支持(作为一个输出过滤器,支持不完全缓冲,分部分响应请求)
  --with-http_xslt_module 启用ngx_http_xslt_module支持(过滤转换XML请求)
  --with-http_image_filter_module 启用ngx_http_image_filter_module支持(传输JPEG/GIF/PNG 图片的一个过滤器)(默认为不启用。gd库要用到)
  --with-http_geoip_module 启用ngx_http_geoip_module支持(该模块创建基于与MaxMind GeoIP二进制文件相配的客户端IP地址的ngx_http_geoip_module变量)
  --with-http_sub_module 启用ngx_http_sub_module支持(允许用一些其他文本替换nginx响应中的一些文本)
  --with-http_dav_module 启用ngx_http_dav_module支持(增加PUT,DELETE,MKCOL:创建集合,COPY和MOVE方法)默认情况下为关闭,需编译开启
  --with-http_flv_module 启用ngx_http_flv_module支持(提供寻求内存使用基于时间的偏移量文件)
  --with-http_gzip_static_module 启用ngx_http_gzip_static_module支持(在线实时压缩输出数据流)
  --with-http_random_index_module 启用ngx_http_random_index_module支持(从目录中随机挑选一个目录索引)
  --with-http_secure_link_module 启用ngx_http_secure_link_module支持(计算和检查要求所需的安全链接网址)
  --with-http_degradation_module  启用ngx_http_degradation_module支持(允许在内存不足的情况下返回204或444码)
  --with-http_stub_status_module 启用ngx_http_stub_status_module支持(获取nginx自上次启动以来的工作状态)
  --without-http_charset_module 禁用ngx_http_charset_module支持(重新编码web页面,但只能是一个方向--服务器端到客户端,并且只有一个字节的编码可以被重新编码)
  --without-http_gzip_module 禁用ngx_http_gzip_module支持(该模块同-with-http_gzip_static_module功能一样)
  --without-http_ssi_module 禁用ngx_http_ssi_module支持(该模块提供了一个在输入端处理处理服务器包含文件(SSI)的过滤器,目前支持SSI命令的列表是不完整的)
  --without-http_userid_module 禁用ngx_http_userid_module支持(该模块用来处理用来确定客户端后续请求的cookies)
  --without-http_access_module 禁用ngx_http_access_module支持(该模块提供了一个简单的基于主机的访问控制。允许/拒绝基于ip地址)
  --without-http_auth_basic_module禁用ngx_http_auth_basic_module(该模块是可以使用用户名和密码基于http基本认证方法来保护你的站点或其部分内容)
  --without-http_autoindex_module 禁用disable ngx_http_autoindex_module支持(该模块用于自动生成目录列表,只在ngx_http_index_module模块未找到索引文件时发出请求。)
  --without-http_geo_module 禁用ngx_http_geo_module支持(创建一些变量,其值依赖于客户端的IP地址)
  --without-http_map_module 禁用ngx_http_map_module支持(使用任意的键/值对设置配置变量)--without-http_split_clients_module 禁用ngx_http_split_clients_module支持(该模块用来基于某些条件划分用户。条件如:ip地址、报头、cookies等等)
  --without-http_referer_module 禁用disable ngx_http_referer_module支持(该模块用来过滤请求,拒绝报头中Referer值不正确的请求)
  --without-http_rewrite_module 禁用ngx_http_rewrite_module支持(该模块允许使用正则表达式改变URI,并且根据变量来转向以及选择配置。如果在server级别设置该选项,那么他们将在 location之前生效。如果在location还有更进一步的重写规则,location部分的规则依然会被执行。如果这个URI重写是因为location部分的规则造成的,那么 location部分会再次被执行作为新的URI。 这个循环会执行10次,然后Nginx会返回一个500错误。)
  --without-http_proxy_module 禁用ngx_http_proxy_module支持(有关代理服务器)
  --without-http_fastcgi_module 禁用ngx_http_fastcgi_module支持(该模块允许Nginx 与FastCGI 进程交互,并通过传递参数来控制FastCGI 进程工作。 )FastCGI一个常驻型的公共网关接口。
  --without-http_uwsgi_module 禁用ngx_http_uwsgi_module支持(该模块用来医用uwsgi协议,uWSGI服务器相关)
  --without-http_scgi_module 禁用ngx_http_scgi_module支持(该模块用来启用SCGI协议支持,SCGI协议是CGI协议的替代。它是一种应用程序与HTTP服务接口标准。它有些像FastCGI但他的设计 更容易实现。)
  --without-http_memcached_module 禁用ngx_http_memcached_module支持(该模块用来提供简单的缓存,以提高系统效率)
  -without-http_limit_zone_module 禁用ngx_http_limit_zone_module支持(该模块可以针对条件,进行会话的并发连接数控制)
  --without-http_limit_req_module 禁用ngx_http_limit_req_module支持(该模块允许你对于一个地址进行请求数量的限制用一个给定的session或一个特定的事件)
  --without-http_empty_gif_module 禁用ngx_http_empty_gif_module支持(该模块在内存中常驻了一个1*1的透明GIF图像,可以被非常快速的调用)
  --without-http_browser_module 禁用ngx_http_browser_module支持(该模块用来创建依赖于请求报头的值。如果浏览器为modern ,则$modern_browser等于modern_browser_value指令分配的值;如 果浏览器为old,则$ancient_browser等于 ancient_browser_value指令分配的值;如果浏览器为 MSIE中的任意版本,则 $msie等于1)
  --without-http_upstream_ip_hash_module 禁用ngx_http_upstream_ip_hash_module支持(该模块用于简单的负载均衡)
  --with-http_perl_module 启用ngx_http_perl_module支持(该模块使nginx可以直接使用perl或通过ssi调用perl)
  --with-perl_modules_path= 设定perl模块路径--with-perl= 设定perl库文件路径--http-log-path= 设定access log路径
  --http-client-body-temp-path= 设定http客户端请求临时文件路径--http-proxy-temp-path= 设定http代理临时文件路径
  --http-fastcgi-temp-path= 设定http fastcgi临时文件路径--http-uwsgi-temp-path= 设定http uwsgi临时文件路径
  --http-scgi-temp-path= 设定http scgi临时文件路径-without-http 禁用http server功能
  --without-http-cache 禁用http cache功能--with-mail 启用POP3/IMAP4/SMTP代理模块支持
  --with-mail_ssl_module 启用ngx_mail_ssl_module支持--without-mail_pop3_module 禁用pop3协议(POP3即邮局协议的第3个版本,它是规定个人计算机如何连接到互联网上的邮件服务器进行收发邮件的协议。是因特网电子邮件的第一个离线协议标 准,POP3协议允许用户从服务器上把邮件存储到本地主机上,同时根据客户端的操作删除或保存在邮件服务器上的邮件。POP3协议是TCP/IP协议族中的一员,主要用于 支持使用客户端远程管理在服务器上的电子邮件)
  --without-mail_imap_module 禁用imap协议(一种邮件获取协议。它的主要作用是邮件客户端可以通过这种协议从邮件服务器上获取邮件的信息,下载邮件等。IMAP协议运行在TCP/IP协议之上, 使用的端口是143。它与POP3协议的主要区别是用户可以不用把所有的邮件全部下载,可以通过客户端直接对服务器上的邮件进行操作。)
  --without-mail_smtp_module 禁用smtp协议(SMTP即简单邮件传输协议,它是一组用于由源地址到目的地址传送邮件的规则,由它来控制信件的中转方式。SMTP协议属于TCP/IP协议族,它帮助每台计算机在发送或中转信件时找到下一个目的地。)
  --with-google_perftools_module 启用ngx_google_perftools_module支持(调试用,剖析程序性能瓶颈)
  --with-cpp_test_module 启用ngx_cpp_test_module支持
  --add-module= 启用外部模块支持--with-cc= 指向C编译器路径
  --with-cpp= 指向C预处理路径--with-cc-opt= 设置C编译器参数(PCRE库,需要指定–with-cc-opt=”-I /usr/local/include”,如果使用select()函数则需要同时增加文件描述符数量,可以通过–with-cc- opt=”-D FD_SETSIZE=2048”指定。)
  --with-ld-opt= 设置连接文件参数。(PCRE库,需要指定–with-ld-opt=”-L /usr/local/lib”。)
  --with-cpu-opt= 指定编译的CPU,可用的值为: pentium, pentiumpro, pentium3, pentium4, athlon, opteron, amd64, sparc32, sparc64, ppc64--without-pcre 禁用pcre库--with-pcre 启用pcre库
  --with-pcre= 指向pcre库文件目录--with-pcre-opt= 在编译时为pcre库设置附加参数--with-md5= 指向md5库文件目录(消息摘要算法第五版,用以提供消息的完整性保护)
  --with-md5-opt= 在编译时为md5库设置附加参数--with-md5-asm 使用md5汇编源
  --with-sha1= 指向sha1库目录(数字签名算法,主要用于数字签名)
  --with-sha1-opt= 在编译时为sha1库设置附加参数--with-sha1-asm 使用sha1汇编源
  --with-zlib= 指向zlib库目录--with-zlib-opt= 在编译时为zlib设置附加参数
  --with-zlib-asm= 为指定的CPU使用zlib汇编源进行优化,CPU类型为pentium, pentiumpro--with-libatomic 为原子内存的更新操作的实现提供一个架构
  --with-libatomic= 指向libatomic_ops安装目录--with-openssl= 指向openssl安装目录
  --with-openssl-opt 在编译时为openssl设置附加参数
  --with-debug 启用debug日志


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.iyunv.com/thread-634068-1-1.html 上篇帖子: nginx ssl双向验证 下篇帖子: Nginx+Tomcat群集服务
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表