之前写好了nginx的安装配置,后面就是php的安装和mysql的安装,不过时间有限,而且放一篇里也太长,所以都是分开来写,php安装完毕后就是mysql的配置了。

一:检查是否安装了php

1)yum安装检查:yum list installed |grep php

2)rpm安装检查:rpm -qa |grep php

3)自己编译安装的有多种方式查询,例如查找php的执行程序,或者检查进程ps -ef |grep php等方法。


二:检查如果没有安装php,即可准备php安装前的前置软件,用yum install xxxx即可安装,当然不嫌麻烦也可以自己编译安装,这里就不详细说了。

1)zlib以及zlib-devel  zlib提供数据压缩的函数库,也是nginx的前置软件,由于zlib需要编译php的zlib扩展,而编译中会需要使用zlib.h这个头文件,头文件在zlib-devel中,因此也需要下载zlib-devel。

2)libxml2以及libxml-devel libxml2是一个c语言的xml程序库,可以简单的对xml进行各种操作,并且支持xpath查询,以及部分支持xslt转换等功能。

3)libxslt以及libxslt-devel 如果不安装libxslt-devel会提示找不到xslt.config文件,xslt是转换xml到其他格式的扩展。


3)openssl以及openssl-devel 安全套接字层密码库

4)jpeg IJG的jpeg库,php的gd库所需。

5)libpng 是c语言写的比较底层的读写png文件的跨平台的库,可以帮助轻松的读写png文件的每一行像素,php的gd库所需。

6)freetype以及freetype-devel 免费开源的且可移植的字体引擎,提供统一的接口访问多种字体格式,这两个都是gd库的依赖软件,所以如果没有安装,或者版本太低,在安装php时设定的是安装gd库则会报错,另外不安装-devel也是会报错的,因为编译扩展的时候会缺少ft2build.h文件,报错如下图。


7)gd gd是php处理图形的扩展库

8)curl,由于我的yum里的版本太低了,所以直接自己编译安装的,安装方式很简单,也就是wget curl下载地址后tar解压,新建/usr/local/curl文件夹,然后进入curl解压后的文件夹里配置./configure --prefix=/usr/local/curl即可,最后make以及make install就安装好了。

注意:xxx-devel是xxx软件的开发包,包含头文件以及静态库甚至源码。


三:php下载安装

1)用wget下载php的tar.gz文件:wget http://br2.php/get/php-7.2.2.tar.gz

2)解压tar.gz文件:tar zxvf php-7.2.2.tar.gz

3)新建待会要安装php的文件夹:mkdir /usr/local/php,然后进入解压后的php安装包文件夹里,配置configure:

./configure --prefix=/usr/local/php  --with-curl=/usr/local/curl  --with-freetype-dir  --with-gd  --with-gettext  --with-iconv-dir  --with-kerberos  --with-libdir=lib64  --with-libxml-dir  --with-mysqli  --with-openssl  --with-pcre-regex  --with-pdo-mysql  --with-pdo-sqlite  --with-pear  --with-png-dir  --with-xmlrpc  --with-xsl  --with-zlib  --enable-fpm  --enable-bcmath  --enable-libxml  --enable-inline-optimization  --enable-mbregex  --enable-mbstring  --enable-opcache  --enable-pcntl  --enable-shmop  --enable-soap  --enable-sockets  --enable-sysvsem  --enable-xml  --enable-zip

注意:

--prefix=安装目录

--with-使用包名称[=包目录]

--enable-需要激活的功能


四:配置php相关文件

1)配置php.ini,这是php的配置文件:cp /home/myload/php-7.2.2/php.ini-development    /usr/local/php/lib/php.ini

2)配置php-fpm.conf,这是php-fpm配置文件:cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf

3)配置www.conf,配置用户的文件:cp etc/php-fpm.d/www.conf.default  etc/php-fpm.d/www.conf

4)将php-fpm启动文件复制到init.d文件夹中一份方便启动php:cp -R sbin/php-fpm /etc/init.d/php-fpm


五:启动php,确定是否安装成功

执行命令/etc/init.d/php-fpm即可

查看是否启动:ps -ef |grep php既可以看到php启动了哪些进程


六:安装成功后配置nginx支持php

1)更改php.ini文件,vim /usr/local/php/lib/php.ini

通过查找cgi.fix_pathinfo=1这个配置,并去除注释,并改为cgi.fix_pathinfo=0,这里并不属于nginx支持php配置相关,而是专属于nginx下php的一个安全漏洞,如果这里值为1,用户方可以通过上传图片来上传木马,然后通过url访问该图片地址,并在地址后加入/xxx.php将该图片作为php文件运行,这是只有在nginx里才会存在的问题,apache和iis都没有该问题

以上问题可以直接参看鸟哥的博客,写的相当详细:http://www.laruence/2010/05/20/1495.html


2)配置web专用的组和用户

添加www用户组:groupadd www

添加www用户组下的用户www:useradd -g www www


3)更改php-fpm.conf配置

将user=nobody的注释去掉,并将nobody改成上面配置的www用户

将group=nobody的注释去掉,并将nobody改成上面配置的www用户组

最后检查php-fpm.conf最后的include的值是不是正确的www.conf目录地址,如果不正确则换成正确的目录地址。


4)更改www.conf配置

将user=nobody的注释去掉,并将nobody改成上面配置的www用户

将group=nobody的注释去掉,并将nobody改成上面配置的www用户组


5)更改nginx.conf文件 /etc/local/nginx/conf/nginx.conf

将#user=nobody去掉注释并改为user=www

去除 location ~ \.php${...}这段代码的注释,并将fastcgi_param里的/scripts改为$document_root


最后将location / {...}里默认index后面添加上index.php,确保index.php作为默认的首页



6)重启php-fpm和nginx,可以killall php-fpm然后再/etc/init.d/php-pfm即可重启,/usr/local/nginx/sbin/nginx -s stop即可停止nginx,然后执行/usr/local/nginx/sbin/php即可重启。


7)在html目录里随便创建一个php文件,内容是phpinfo();,然后在浏览器中访问该文件地址,看是否得到正确的php相关信息,如果正确显示则配置成功。


七:配合apache支持php,这个后续再添加,to be continue...









更多推荐

linux安装php详细过程