1 创建PHP用户和用户组,并在github下载PHP7源码

首先创建一个名为PHP且没有登录权限的用户和一个名为PHP的用户组,然后去GitHub下载PHP7源码包。

#######新建PHP用户和PHP组
[root@typecodes ~]# groupadd -r PHP && useradd -r -g PHP -s /bin/false -d /usr/local/PHP7 -M PHP
######从GitHub下载PHP7安装包
[root@typecodes ~]# wget -c --no-check-certificate -O PHP7-src-master.zip https://github.com/PHP/PHP-src/archive/master.zip
######开始解压PHP7包
[root@typecodes ~]# unzip -q PHP7-src-master.zip && cd PHP-src-master
#####安装编译PHP7时需要的依赖包
[root@typecodes PHP-src-master]# yum -y install libxml2 libxml2-devel openssl openssl-devel curl-devel libjpeg-devel libpng-devel freetype-devel libmcrypt-devel
2 PHP7编译参数的配置

准备工作做好后,就开始正式配置PHP7的安装明细了。注意,操作时一定要先把下面反斜杠“\”后面添加的注释文字去掉!!!

######开始生成配置文件 [root@typecodes PHP-src-master]# ./buildconf buildconf: checking installation... buildconf: autoconf version 2.69 (ok) rebuilding aclocal.m4 rebuilding configure rebuilding main/PHP_config.h.in ######开始配置 [root@typecodes PHP-src-master]# ./configure \ --prefix=/usr/local/PHP7 \ [PHP7安装的根目录] --exec-prefix=/usr/local/PHP7 \ --bindir=/usr/local/PHP7/bin \ --sbindir=/usr/local/PHP7/sbin \ --includedir=/usr/local/PHP7/include \ --libdir=/usr/local/PHP7/lib/PHP \ --mandir=/usr/local/PHP7/PHP/man \ --with-config-file-path=/usr/local/PHP7/etc \ [PHP7的配置目录] --with-MysqL-sock=/var/run/MysqL/MysqL.sock \ [PHP7的Unix socket通信文件] --with-mcrypt=/usr/include \ --with-mhash \ --with-openssl \ --with-MysqL=shared,MysqLnd \ [PHP7依赖MysqL库] --with-MysqLi=shared,MysqLnd \ [PHP7依赖MysqL库] --with-pdo-MysqL=shared,MysqLnd \ [PHP7依赖MysqL库] --with-gd \ --with-iconv \ --with-zlib \ --enable-zip \ --enable-inline-optimization \ --disable-debug \ --disable-rpath \ --enable-shared \ --enable-xml \ --enable-bcmath \ --enable-shmop \ --enable-sysvsem \ --enable-mbregex \ --enable-mbstring \ --enable-ftp \ --enable-gd-native-ttf \ --enable-pcntl \ --enable-sockets \ --with-xmlrpc \ --enable-soap \ --without-pear \ --with-gettext \ --enable-session \ [允许PHP会话session] --with-curl \ [允许curl扩展] --with-jpeg-dir \ --with-freetype-dir \ --enable-opcache \ [使用opcache缓存] --enable-fpm \ --enable-fastcgi \ --with-fpm-user=Nginx \ [PHP-fpm的用户] --with-fpm-group=Nginx \ [PHP-fpm的用户组] --without-gdbm \ --disable-fileinfo

执行上面的配置命令的结果如下图所示:

3 开始编译和安装PHP7

相对编译安装MysqL的大量cpu和内存消耗,PHP7的编译安装轻松多了,整个过程大约1个小时左右。

[root@typecodes PHP-src-master]# make clean && make && make install

看到下图就代表已经编译安装好了PHP7!

4 选做步骤:执行make test命令进行测试

这是一个非必需的操作步骤,执行make test命令。

有趣的一件事就是:在test期间,会和一个IP地址72.52.91.14建立tcp连接,它对应着PHP官网http://www.PHP.net。

执行完make test命令后,最终的结果如下:

5 查看编译成功后的PHP7安装目录

由于需要和MysqL进行通信,所以需要特别查看PHP7安装后的lib扩展库目录(/usr/local/PHP7/lib/PHP/extensions/no-debug-non-zts-20141001/)。需要确保至少存在MysqLi.sopdo_MysqL.so这两个动态库文件,如下图所示。

6 开始设置PHP7的配置文件PHP.ini、PHP-fpm.conf、www.conf和PHP-fpm脚本

可以用编译后的配置文件复制到PHP7的配置目录(/usr/local/PHP7/etc/),推荐使用《PHP7中php.ini、php-fpm和www.conf的配置》文中整理的3个PHP7配置文件和PHP-fpm服务控制脚本。

#######方法一:直接使用编译后未经优化处理的配置 [root@typecodes PHP-src-master]# cp PHP.ini-production /usr/local/PHP7/etc/PHP.ini [root@typecodes PHP-src-master]# cp /root/PHP-src-master/sapi/fpm/init.d.PHP-fpm /etc/init.d/PHP-fpm [root@typecodes PHP-src-master]# cp /usr/local/PHP7/etc/PHP-fpm.conf.default /usr/local/PHP7/etc/PHP-fpm.conf [root@typecodes PHP-src-master]# cp /usr/local/PHP7/etc/PHP-fpm.d/www.conf.default /usr/local/PHP7/etc/PHP-fpm.d/www.conf #######方法二:使用https://typecodes.com/web/PHP7configure.html文中的配置 [root@typecodes PHP-src-master]# mv ~/PHP.ini /usr/local/PHP7/etc/PHP.ini && mv ~/PHP-fpm /etc/init.d/PHP-fpm [root@typecodes PHP-src-master]# mv ~/PHP-fpm.conf /usr/local/PHP7/etc/PHP-fpm.conf && mv ~/www.conf /usr/local/PHP7/etc/PHP-fpm.d/www.conf
7 添加PHP的环境变量

将PHP编译生成的bin目录添加到当前Linux系统的环境变量中

[root@typecodes ~]# echo -e '\nexport PATH=/usr/local/PHP7/bin:/usr/local/PHP7/sbin:$PATH\n' >> /etc/profile && source /etc/profile
8 设置PHP日志目录和PHP-fpm进程文件(PHP-fpm.sock)目录

其中,设置PHP-fpm进程目录的用户和用户组为Nginx,并创建PHP会话session目录。

#######设置PHP日志目录和PHP-fpm的运行进程ID文件(PHP-fpm.sock)目录 [root@typecodes ~]# mkdir -p /var/log/PHP-fpm/ && mkdir -p /var/run/PHP-fpm && cd /var/run/ && chown -R Nginx:Nginx PHP-fpm #######修改session的目录配置 [root@typecodes etc]# mkdir -p /var/lib/PHP/session [root@typecodes etc]# chown -R Nginx:Nginx /var/lib/PHP
9 设置PHP开机启动以及测试配置文件是否正确
######配置开机自启动,增加到主机sysV服务 [root@typecodes PHP-src-master]# chmod +x /etc/init.d/PHP-fpm [root@typecodes PHP-src-master]# chkconfig --add PHP-fpm [root@typecodes PHP-src-master]# chkconfig PHP-fpm on ######测试PHP的配置文件是否正确合法 [root@typecodes sbin]# PHP-fpm -t [03-May-2015 17:50:04] NOTICE: configuration file /usr/local/PHP7/etc/PHP-fpm.conf test is successful
10 启动PHP服务

在完成上面的操作后,就可以正式使用PHP服务了。启动PHP进程服务的命令如下:

[root@typecodes sbin]# service PHP-fpm start Starting PHP-fpm done

然后可以通过命令ps -aux|grep PHP查看是否成功(图中的PHP-fpm进程数和进程用户Nginx都是由www.conf中pm.start_servers和user的值分别决定的):

11 查看PHP7版本信息

最后,可以通过命令PHP -v查看当前PHP版本信息,图中可以看到当前PHP7还使用了Zend OPcache缓存,是因为在PHP.ini文件中添加了zend_extension=opcache.so配置。

根据前文configure编译参数设定,安装后的PHP7配置文件所在路径是/usr/local/PHP7/etc。该目录下会有两个配置文件:PHP-fpm.confPHP.ini,以及一个文件夹PHP-fpm.d(包含www.conf文件)。

因此,这篇文章主要对这三个PHP配置文件的进行简单说明,具体的配置过程见本文末尾的附录部分。

1 配置PHP.ini

PHP.ini是PHP运行核心配置文件:

######避免PHP信息暴露在http头中
expose_PHP = Off

######避免暴露PHP调用MysqL的错误信息
display_errors = Off

######在关闭display_errors后开启PHP错误日志(路径在PHP-fpm.conf中配置)
log_errors = On

######设置PHP的扩展库路径
extension_dir = "/usr/local/PHP7/lib/PHP/extensions/no-debug-non-zts-20141001/"

######设置PHP的opcache和MysqL动态库
zend_extension=opcache.so
extension=MysqLi.so
extension=pdo_MysqL.so

######设置PHP的时区
date.timezone = PRC

######开启opcache
[opcache]
; Determines if Zend OPCache is enabled
opcache.enable=1

######设置PHP脚本允许访问的目录(需要根据实际情况配置)
;open_basedir = /usr/share/Nginx/html;

2 配置PHP-fpm.conf

PHP-fpm.conf是PHP-fpm进程服务的配置文件:

######设置错误日志的路径
error_log = /var/log/PHP-fpm/error.log
######引入www.conf文件中的配置
include=/usr/local/PHP7/etc/PHP-fpm.d/*.conf

3 配置www.conf(在PHP-fpm.d目录下)

www.conf这是PHP-fpm进程服务的扩展配置文件:

######设置用户和用户组
user = Nginx
group = Nginx

######根据Nginx.conf中的配置fastcgi_pass unix:/var/run/PHP-fpm/PHP-fpm.sock;设置PHP监听
; listen = 127.0.0.1:9000   #####不建议使用
listen = /var/run/PHP-fpm/PHP-fpm.sock

######开启慢日志
slowlog = /PHP-fpm/$pool-slow.log
request_slowlog_timeout = 10s

######设置PHP的session目录(所属用户和用户组都是Nginx)
PHP_value[session.save_handler] = files
PHP_value[session.save_path] = /var/lib/PHP/session

4 附录

在前文已经说明了,目前已经把这个关于Nginx、MysqL和PHP配置的全部托管在GitHub和coding.net上,地址如下:

GitHub地址:https://github.com/vfhky/mylnmp;

Coding地址:https://coding.net/u/vfhky/p/mylnmp/git。

文章来源:http://www.tuicool.com/articles/NjmQNj6

CentOS 7.1编译安装PHP7的更多相关文章

  1. ios – 如何使用Objective C类中的多个参数调用Swift函数?

    本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容,请发送邮件至dio@foxmail.com举报,一经查实,本站将立刻删除。

  2. ios – Swift 4添加手势:覆盖vs @objc

    我想在我的视图中添加一个手势,如下所示:但是,在Swift4中,我的编译器给出了以下错误:建议添加@objc以将此实例方法公开给Objective-C.实现此目的的另一个选项将覆盖touchesBegan()函数并使用它来处理点击.我试图以“Swift”的方式做到这一点,而不必带入Obj-C.有没有纯粹的Swift方式来添加这个轻击手势而不使用@objc?

  3. ios – 将视频分享到Facebook

    我正在编写一个简单的测试应用程序,用于将视频从iOS上传到Facebook.由于FacebookSDK的所有文档都在Objective-C中,因此我发现很难在线找到有关如何使用Swift执行此操作的示例/教程.到目前为止我有这个在我的UI上放置一个共享按钮,但它看起来已禁用,从我读到的这是因为没有内容设置,但我看不出这是怎么可能的.我的getVideoURL()函数返回一个NSURL,它肯定包含视

  4. ios – 以编程方式在Swift中添加联系人

    我想在Swift中以编程方式添加联系人.我发现了一些Objective-C示例,但我没有让它们工作,甚至在Objective-C中也没有.我不希望这涉及到AddressBookUI,因为我想从我自己的UI中获取值.解决方法这是在Swift中添加联系人的快速方法.我在我的iPhone5iOS7.1上验证了它,因为我发现模拟器并不总是与我的手机对AB的东西相同.您可以添加一个按钮并指向此方法:顺便说一下–它假设你已经分配了一个地址簿var,你可以通过覆盖viewDidAppear来打开视图.它也会执行安全提示

  5. ios – 为目标c中的方法传递未知类型的参数,可能吗?

    是否可以将未知类型的参数传递给objective-C方法?在C#中你可以写实现这一点,但我知道Objective-C没有泛型,所以有没有其他方法可以在Objective-C中实现这一点?我需要这个,因为我想创建一个方法来改变不同对象的文本颜色,如UITextField和UIButton的占位符文本.所以我的计划是创建一个名为textWhite的方法,然后在此方法中检查对象的类型,然后运行匹配的代码以使文本颜色变为白色.解决方法是的,可以传递未知类型的参数.见下面的例子.请参考使用id对象的链接作为参数Us

  6. ios – Swift指针算术和解除引用;将一些类似C的地图代码转换为Swift

    我有一点似乎没有工作的Swift代码……解决方法您正在指定locationPointer指向新位置,但仍在下一行中使用ptr,并且ptr的值尚未更改.将您的最后一行更改为:或者你可以改变指向var的指针并推进它:

  7. ios – “禁用模块时使用’@import’”错误 – 启用模块和链接框架= YES

    我有一个使用CocoaPods并使用’SCLAlertView-Objective-C’窗格的项目.该pod使用@importUIKit;模块样式导入.我在目标和项目设置中将“启用模块(C&Objective-C)”和“自动链接框架”设置为YES.当模块被禁用时,我仍然得到“使用’@import’错误.有没有什么可以阻止Xcode能够启用模块,如使用.pch文件,任何链接器标志,或者我没有提到的任

  8. XCode 6.3立即在抛出的Objective-C异常上引发SIGABRT

    考虑以下目标-C代码在XCode6.2中,它按预期工作(记录“错误消息”).但是,由于我们升级到6.3,抛出行(throwstd::logic_error…)引发SIGABRT(堆栈跟踪仅包含_cxa_throw和_pthread_kill,超出applicationdidFinishLaunchingWithOptions)并导致应用程序崩溃.这只发生在我们的应用程序中–当我将完全相同的代码复制

  9. ios – 在swift框架中使用Bridging Headers时失败

    我正在做一个快速的框架,我想使用旧的目标c类.为此,我使用桥接头方法但是当我尝试构建时出现此错误:我将我的{PROJECT}-Bridging-Header.h添加到Swift编译器中的Objective-C桥接头–代码生成我怎么解决它?

  10. ios – 200在xcode 7中生成DSMM警告

    解决方法我有同样的问题.Facebook表示他们已经意识到这一点并且不是高优先级,因为它不会影响应用程序.我回退到4.7.1警告问题不再存在.我不认为它会被拒绝但不能确定.

随机推荐

  1. 在airgapped(离线)CentOS 6系统上安装yum软件包

    我有一个CentOS6系统,出于安全考虑,它已经被空气泄漏.它可能从未连接到互联网,如果有,它很长时间没有更新.我想将所有.rpm软件包放在一个驱动器上,这样它们就可以脱机安装而无需查询互联网.但是,我在测试VM上遇到的问题是,即使指定了本地路径,yum仍然会挂起并尝试从在线存储库进行更新.另外,有没有办法使用yum-utils/yumdownloader轻松获取该包的所有依赖项和所有依赖项?目前

  2. centos – 命名在日志旋转后停止记录到rsyslog

    CentOS6.2,绑定9.7.3,rsyslog4.6.2我最近设置了一个服务器,我注意到在日志轮换后,named已停止记录到/var/log/messages.我认为这很奇怪,因为所有日志记录都是通过rsyslog进行的,并且named不会直接写入日志文件.这更奇怪,因为我在更新区域文件后命名了HUPed,但它仍然没有记录.在我停止并重新启动命名后,记录恢复.这里发生了什么?

  3. centos – 显示错误的磁盘大小

    对于其中一个磁盘,Df-h在我的服务器上显示错误的空白区域:Cpanel表明它只有34GB免费,但还有更多.几分钟前,我删除了超过80GB的日志文件.所以,我确信它完全错了.fdisk-l/dev/sda2也显示错误:如果没有格式化,我该怎么做才能解决这个问题?并且打开文件描述符就是它需要使用才能做到这一点.所以…使用“lsof”并查找已删除的文件.重新启动写入日志文件的服务,你很可能会看到空间可用.

  4. 如何在centos 6.9上安装docker-ce 17?

    我目前正在尝试在centOS6.9服务器上安装docker-ce17,但是,当运行yuminstalldocker-ce时,我收到以下错误:如果我用跳过的标志运行它我仍然得到相同的消息,有没有人知道这方面的方法?

  5. centos – 闲置工作站的异常负载平均值

    我有一个新的工作站,具有不寻常的高负载平均值.机器规格是:>至强cpu>256GB的RAM>4x512GBSSD连接到LSI2108RAID控制器我从livecd安装了CentOS6.564位,配置了分区,网络,用户/组,并安装了一些软件,如开发工具和MATLAB.在启动几分钟后,工作站负载平均值的值介于0.5到0.9之间.但它没有做任何事情.因此我无法理解为什么负载平均值如此之高.你能帮我诊断一下这个问题吗?

  6. centos – Cryptsetup luks – 检查内核是否支持aes-xts-plain64密码

    我在CentOS5上使用cryptsetupluks加密加密了一堆硬盘.一切都很好,直到我将系统升级到CentOS6.现在我再也无法安装磁盘了.使用我的关键短语装载:我收到此错误:在/var/log/messages中:有关如何装载的任何想法?找到解决方案问题是驱动器使用大约512个字符长的交互式关键短语加密.出于某种原因,CentOS6中的新内核模块在由旧版本创建时无法正确读取512个字符的加密密钥.似乎只会影响内核或cryptsetup的不同版本,因为在同一系统上创建和打开时,512字符的密钥将起作用

  7. centos – 大量ssh登录尝试

    22个我今天登录CentOS盒找到以下内容这是过去3天内的11次登录尝试.WTF?请注意,这是我从我的提供商处获得的全新IP,该盒子是全新的.我还没有发布任何关于此框的内容.为什么我会进行如此大量的登录尝试?是某种IP/端口扫描?基本上有4名匪徒,其中2名来自中国,1名来自香港,1名来自Verizon.这只发生在SSH上.HTTP上没有问题.我应该将罪魁祸首子网路由吗?你们有什么建议?

  8. centos – kswap使用100%的CPU,即使有100GB的RAM也可用

    >Linux内核是否应该足够智能,只需从内存中清除旧缓存页而不是启动kswap?

  9. centos – Azure将VM从A2 / 3调整为DS2 v2

    我正在尝试调整前一段时间创建的几个AzureVM,从基本的A3和标准A3到标准的DS2v2.我似乎没有能力调整到这个大小的VM.必须从头开始重建服务器会有点痛苦.如果它有所不同我在VM中运行CentOS,每个都有一个带有应用程序和操作系统的磁盘.任何人都可以告诉我是否可以在不删除磁盘的情况下删除VM,创建新VM然后将磁盘附加到新VM?

  10. centos – 广泛使用RAM时服务器计算速度减慢

    我在非常具体的情况下遇到服务器速度下降的问题.事实是:>1)我使用计算应用WRF>2)我使用双XeonE5-2620v3和128GBRAM(NUMA架构–可能与问题有关!

返回
顶部