ubuntu php5.6源码安装

本系列的lnmp的大框架基本上是按照http://www.linuxzen.com/lnmphuan-jing-da-jian-wan-quan-shou-ce-si-lnmpda-jian-yuan-ma-an-zhuang.html来写的

 

#########################update-2015-11-29##########################################

 下面的nginx配置文件和php配置文件都有一个小错误,之前误打误撞通过了,今天复习的时候发现又报 connect() to unix:/var/run/php-fpm/php-fpm.sock failed (2: No such file or directory) 这个错误,然后就开始了艰苦卓绝的找错。后来在stack overflow上找到了一个解决方法:

http://serverfault.com/questions/477630/impossible-to-run-php-fpm-on-server-restarts-ubuntu-12-04-x64

大意是在/usr/local/php/etc/php-fpm.conf中listen的目录在/var/run/php-fpm/php-fpm.sock中,但是/var/run是个动态目录,开机后目录下的文件都会重新加载初始化,而php-fpm这个目录根本就不存在,系统也不会为你自动创建,所以改成listen=/var/run/php-fpm.sock即可。同时/usr/local/nginx/nginx.conf的内容也要改。把fastcgi_pass   unix:/var/run/php-fpm/php-fpm.sock;改成fastcgi_pass   unix:/var/run/php-fpm.sock;

user和group网上都是www或者www-data而我用会报错permission denied,用nobody可以通过。

#########################update-2015-11-29##########################################

 

今天又花了一天时间装了php,感觉php的源码安装也挺麻烦的,整个过程各种报错。

下篇文章准备整合所有查找到的报错和解决方法。

php和nginx一样,在安装前需要装一堆的依赖。有libmcrypt、mcrypt、mhash。其实远不止这三个包,在后面的configure和make中还会陆陆续续安装一些依赖。

1、安装libmcrypt、mcrypt、mhash(整个过程都在/usr/local/src/php目录下)

#创建/usr/local/src/php目录并进入
mkdir /usr/local/src/php
cd /usr/local/src/php
#下载libmcrypt,解压,编译,安装
wget http://sourceforge.net/projects/mcrypt/files/Libmcrypt/2.5.8/libmcrypt-2.5.8.tar.gz tar -xzvf libmcrypt-2.5.8.tar.gz cd libmcrypt-2.5.8 ./configure make -j2 make install #下载mhash,解压,编译,安装 wget http://sourceforge.net/projects/mhash/files/mhash/0.9.9.9/mhash-0.9.9.9.tar.gz tar -xzvf mhash-0.9.9.9.tar.gz cd mhash-0.9.9.9 ./configure make -j2 make install # 这两个包安装完成后要把动态链接库做一个软连接到/usr/lib,以为接下来的mcrypt依赖于这两个包 ln -s /usr/local/lib/libmcrypt* /usr/lib ln -s /usr/local/lib/libmhash.* /usr/lib/ ln -s /usr/local/bin/libmcrypt-config /usr/bin/libmcrypt-config #下载mcrypt,解压,安装,编译 wget http://sourceforge.net/projects/mcrypt/files/MCrypt/2.6.8/mcrypt-2.6.8.tar.gz/download tar -zxvf mcrypt-2.6.8.tar.gz cd mcrypt-2.6.8 ./configure make -j2 make install

 

2、生成配置文件(整个过程都在/usr/local/src/php/php-5.6.15目录下)

wget http://cn2.php.net/distributions/php-5.6.15.tar.gz
tar -xzvf php-5.6.15.tar.gz
cd php-5.6.15
sudo ./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql/ --with-zlib --enable-xml --disable-rpath --enable-bcmath --enable-shmop --enable-sysvsem --with-curl --enable-fpm --with-mcrypt --with-gd --with-openssl --with-mhash --enable-sockets --with-ldap --with-ldap-sasl --with-xmlrpc -enable-zip --enable-soap

在configure的时候要注意,--enable-safe-mode --enable-discard-path --enable-fastcgi --enable-force-cgi-redirect参数从5.3版本开始就默认开启了,5.4开始不支持这些选项,所以在参考其他教程时要注意有些选项不需要写到自己的configure中了。我看到的90%的参考教程都写了一两个不支持的参数的。当然你如果写了也没关系,系统不会计算进去。

有一个选项需要强调一下,就是--enable-fpm,如果你在搭建环境时是需要php和nginx结合的,那么这个选项必写。由于我是搭建的LNMP,所以这个参数加上了。想要详细了解选项的,使用./configure -h查看。

我在configure遇到的问题:

①configure: error: Please reinstall the libcurl distribution -easy.h should be in <curl-dir>/include/curl/

  解决方法:需要安装curl-devel,ubuntu源中没有,去官网下载并编译安装(也可以直接apt-get下载php5-curl、curl、libcurl4-gnutls-dev)

cd /usr/local/src/php
wget http://curl.haxx.se/download/curl-7.45.0.tar.gz sudo tar xzvf curl-7.45.0.tar.gz cd curl-7.45.0.tar.gz sudo ./configure sudo make -j2 sudo make install

再次configure又遇到问题

②configure: error: sasl.h not found!

  解决方法:sudo apt-get install libsasl2-dev 

再次使用上面的configure,生成配置文件,没有再报错了。

 

3、编译安装(在/usr/local/src/php/php-5.6.15下)

  cd /usr/local/src/php/php-5.6.15

  sudo make -j2

报错①:

usr/bin/ld: ext/ldap/.libs/ldap.o: undefined reference to symbol 'ber_strdup@@OPENLDAP_2.4_2'
//usr/lib/x86_64-linux-gnu/liblber-2.4.so.2: error adding symbols: DSO missing from command line

解决方法:

一开始我查资料说是没有安装openldap,然后就查了openldap的安装方法,结果openldap用db做存储方案,就是说还要编译安装db(这个db不是mysql,就叫db)。结果搞了半天db和openldap都安装完再编译发现还是报这个错。最后在网上一个一个试,找到了一个解决方法。原文是这么说的

遇到这种类似的情况,说明「./configure 」沒抓好一些环境变数值。
在PHP源码目录下 vi Makefile 找到 EXTRA_LIBS 行,在行末添加 ‘ -llber ‘ 保存退出再次make即可。
cd /usr/local/src/php/php-5.6.15
vim Makefile
找EXTRA_LIBS行,在末尾添加--llber

希望遇到这个问题的同学可以引以为戒不要走弯路了。

再次编译,又报错②:

/usr/local/src/php/php-5.6.15/sapi/cli/php: error while loading shared libraies: libmysqlclient.so.20: cannot open shared object file: No such file or directory

解决办法:

找到libmysqlclient.so.20,并做软链接

shell> find / -name "libmysqlclient.so.20"
/usr/local/mysql/lib/libmysqlclient.so.20
/usr/local/src/mysql-5.7.9/libmysql/CMakeFiles/CMakeRelink.dir/libmysqlclient.so.20
/usr/local/src/mysql-5.7.9/libmysql/libmysqlclient.so.20
shell> echo "/usr/local/lib" >>/etc/ld.so.conf
shell> echo "/usr/local/mysql/lib" >>/etc/ld.so.conf 
shell> sudo ldconfig
shell> make

再次编译,又他妈报错了,此时我的心情真的是崩溃的

报错③:

  chmod: 无法访问"ext/phar/phar.phar": 没有那个文件或目录

解决办法:

  mkdir -p ext/phar/phar.phar

再次编译,没有错了。

make install

 

4、配置php(在/usr/local/src/php/php-5.6.15下)  

cd /usr/local/src/php/php-5.6.15
cp php.ini-production /usr/local/php/php.ini # 如果是开发就复制php.ini-development cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf ln -s /usr/local/php/bin/php /usr/bin/
echo "listen = /var/run/php-fpm/php-fpm.sock" >>/usr/local/php/etc/php-fpm.conf
echo “listen = /var/run/php-fpm.sock” >> /usr/local/php/etc/php-fpm.conf

使用nginx服务器等待检测php是否安装成功

编辑nginx配置文件:

shell> vi /usr/local/nginx/conf/nginx.conf
     location ~ \.php$ {
            fastcgi_pass   unix:/var/run/php-fpm/php-fpm.sock;
fastcgi_pass  unix:/var/run/php-fpm.sock; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME
/scripts$fastcgi_script_name; include fastcgi_params; include fastcgi.conf; }

在/usr/local/nginx/html下创建index.php

shell> cd /usr/local/nginx/html
shell> vi /usr/local/nginx/html/index.php
      <?php
        phpinfo();
      ?>

 

5、启动php

mkdir /var/run/php-fpm(这一步在每次启动系统时都要做,因为/var/run是个动态目录,系统重启php-fpm就没了).
/usr/local/php/sbin/php-fpm

报错①:

ERROR: [pool www] cannot get gid for group 'nobody'

解决方法:

groupadd nobody

关闭php在开启(不知道php有没有重启选项,只能这样做了)

sudo killall php-fpm
/usr/local/php/sbin/php-fpm

没报错了,此时我以为我已经成功了,呵呵,too young too simple

开始检测是否安装成功。

开启nginx:

  sudo /usr/lcoal/nginx/nginx

在浏览器输入localhost/index.html

结果:

 

 

 

呵呵呵。。。。。。。。。。。。。。。。。。。。。。。。。

就快要成功了我会轻易放弃?果断点了个error log,以为他会引领我找到错误日志,结果是这么个鸟玩意

等于没说。后来我一想这是nginx服务器啊,应该看nginx的错误日志,进入nginx,果然发现了logs

tail -f error.log,实时查看错误日志。再打开一个终端,执行php-fpm,此时error.log刷出了这样的信息:

此时报错:connect() to unix:/var/run/php-fpm/php-fpm.sock failed (13: Permission denied) while connecting to upstream

我检查了一下 /tmp/php-cgi.sock 发现该文件拥有者是root,而nginx和php-fpm都是www用户来运行的,按理讲,这个sock文件也应该是www才对。于是修改php-fpm.conf文件

sudo vim /usr/local/php/etc/php-fpm.conf
user=nobody
group=nobody
listen.owner
= nobody listen.group = nobody listen.mode = 0660

结果如下图:

成功了,但是没有www用户,猛然想起之前增加的组是nobody,于是又把php-fpm.conf改了

sudo vim /usr/local/php/etc/php-fpm.conf
listen.owner = www
listen.group = www
listen.mode = 0660

在浏览器中输入localhost/index.php

如图,成功!!!!!!!!

 

posted @ 2015-11-10 23:05  没错我就是菊花侠  阅读(3954)  评论(0编辑  收藏  举报