LNMP 架构——PHP 安装
LAMP 和 LNMP 中的 PHP 的区别
LAMP 安装 PHP 和 LNMP 安装 PHP 有区别,LNMP 需要开启 php-fpm 服务。
在 LAMP 中,PHP 作为 apache 的一个模块,需要指定路径。 在 LANP 中,PHP 作为一个独立的服务,和 Nginx 没有直接的关系。
安装 PHP
1,进入 /usr/local/src(安装包统一放在该目录下)
[root@dl-001 src]# ls
apr-1.6.3 mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz php-7.1.6
apr-util-1.6.1 php-5.6.30 php-7.1.6.tar.bz2
httpd-2.2.34 php-5.6.30.tar.gz
//因为之前安装过了,所以直接进入该目录。没有安装的小伙伴下载安装并解压。第二2步的make clean可以省略。
2, 创建账号
[root@dl-001 src]# useradd -s /sbin/nologin php-fpm
// 该账号用来运行php-fpm服务,因为在LNMP环境中,PHP是以一种服务的形式独立存在的。
3, 进入 PHP 目录并删除之前编译的文件
[root@dl-001 src]# cd php-5.6.30
[root@dl-001 php-5.6.30]# ls
acinclude.m4 ltmain.sh README.NEW-OUTPUT-API
aclocal.m4 main README.PARAMETER_PARSING_API
build makedist README.REDIST.BINS
buildconf Makefile README.RELEASE_PROCESS
buildconf.bat Makefile.frag README.SELF-CONTAINED-EXTENSIONS
CODING_STANDARDS Makefile.fragments README.STREAMS
config.guess Makefile.gcov README.SUBMITTING_PATCH
config.log Makefile.global README.TESTING
config.nice Makefile.objects README.TESTING2
config.status makerpm README.UNIX-BUILD-SYSTEM
config.sub missing README.WIN32-BUILD-SYSTEM
configure mkinstalldirs run-tests.php
configure.in modules sapi
CREDITS netware scripts
ext NEWS server-tests-config.php
EXTENSIONS pear server-tests.php
footer php5.spec snapshot
generated_lists php5.spec.in stamp-h.in
genfiles php.gif stub.c
header php.ini-development tests
include php.ini-production travis
INSTALL README.EXT_SKEL TSRM
install-sh README.GIT-RULES UPGRADING
libphp5.la README.input_filter UPGRADING.INTERNALS
libs README.MAILINGLIST_RULES vcsclean
libtool README.md win32
LICENSE README.namespaces Zend
[root@dl-001 php-5.6.30]# make clean
find . -name \*.gcno -o -name \*.gcda | xargs rm -f
find . -name \*.lo -o -name \*.o | xargs rm -f
find . -name \*.la -o -name \*.a | xargs rm -f
find . -name \*.so | xargs rm -f
find . -name .libs -a -type d|xargs rm -rf
rm -f libphp5.la sapi/cli/php sapi/cgi/php-cgi libphp5.la modules/* libs/*
4, 初始化
[root@dl-001 php-5.6.30]# ./configure --prefix=/usr/local/php-fpm --with-config-file-path=/usr/local/php-fpm/etc --enable-fpm --with-fpm-user=php-fpm --with-fpm-group=php-fpm --with-mysql=/usr/local/mysql --with-mysqli=/usr/local/mysql/bin/mysql_config --with-pdo-mysql=/usr/local/mysql --with-mysql-sock=/tmp/mysql.sock --with-libxml-dir --with-gd --with-jpeg-dir --with-png-dir --with-freetype-dir --with-iconv-dir --with-zlib-dir --with-mcrypt --enable-soap --enable-gd-native-ttf --enable-ftp --enable-mbstring --enable-exif --with-pear --with-curl --with-openssl
。。。。。。。。。。。。
。。。。。。。。。。。。。
configure: error: Please reinstall the libcurl distribution - //报错
easy.h should be in <curl-dir>/include/curl/
解决办法:
[root@dl-001 php-5.6.30]# yum install -y libcurl-devel
//重新初始化
[root@dl-001 php-5.6.30]# ./configure --prefix=/usr/local/php-fpm --with-config-file-path=/usr/local/php-fpm/etc --enable-fpm --with-fpm-user=php-fpm --with-fpm-group=php-fpm --with-mysql=/usr/local/mysql --with-mysqli=/usr/local/mysql/bin/mysql_config --with-pdo-mysql=/usr/local/mysql --with-mysql-sock=/tmp/mysql.sock --with-libxml-dir --with-gd --with-jpeg-dir --with-png-dir --with-freetype-dir --with-iconv-dir --with-zlib-dir --with-mcrypt --enable-soap --enable-gd-native-ttf --enable-ftp --enable-mbstring --enable-exif --with-pear --with-curl --with-openssl
[root@dl-001 php-5.6.30]# echo $? //检查上一条命令是否报错
0
//此处如有多处报错,请参照我前面的博文。
5, 编译
[root@dl-001 php-5.6.30]# make
报错: virtual memory exhausted: Cannot allocate memory #虚拟内存耗尽: 无法分配内存
解决办法:
1、停掉虚拟机中未在使用的进程
2、临时增加 swap 分区内存
具体步骤如下:
[root@dl-001 ~]# dd if=/dev/zero of=/tmp/newdisk bs=1M count=100 手动创建一个新分区
记录了100+0 的读入
记录了100+0 的写出
104857600字节(105 MB)已复制,5.72931 秒,18.3 MB/秒
[root@dl-001 ~]# du -sh /tmp/newdisk
100M /tmp/newdisk
[root@adai002 ~]# mkswap /tmp/newdisk 格式化该swap分区
正在设置交换空间版本 1,大小 = 102396 KiB
无标签,UUID=d42e907a-aae0-4d5f-bf58-586fac415f48
[root@dl-001 ~]# free -m
total used free shared buff/cache available
Mem: 984 114 626 6 244 706
Swap: 2047 0 2047
[root@dl-001 ~]# swapon /tmp/newdisk 挂载到原swap分区
swapon: /tmp/newdisk:不安全的权限 0644,建议使用 0600。
[root@dl-001 ~]# free -m
total used free shared buff/cache available
Mem: 984 114 626 6 244 707
Swap: 2147 0 2147
[root@dl-001 ~]# chmod 0600 /tmp/newdisk 更改权限以保安全
待PHP编译完成后要卸载掉该分区
[root@dl-001 ~]# swapoff /tmp/newdisk 卸载分区
6, 安装
[root@dl-001 php-5.6.30]# make install
//执行PHP相关命令的两种方式
[root@dl-001 php-fpm]# /usr/local/php-fpm/sbin/php-fpm -m
[root@dl-001 php-fpm]# /usr/local/php-fpm/bin/php -m
[root@adailinux php-fpm]# /usr/local/php-fpm/sbin/php-fpm -t //php-fpm配置文件语法检测
7, 配置
添加配置文件
将配置文件添加到 php-fpm 配置文件目录:
[root@dl-001 php-5.6.30]# cp php.ini-production /usr/local/php-fpm/etc/php.ini
配置文件调试
//切换至配置文件所在目录
[root@dl-001 php-5.6.30]# cd /usr/local/php-fpm/etc/
//手动添加配置文件,写入如下内容:
[root@dl-001 etc]# vim php-fpm.conf
[global]
//定义全局参数
pid = /usr/local/php-fpm/var/run/php-fpm.pid
error_log = /usr/local/php-fpm/var/log/php-fpm.log
[www]
listen = /tmp/php-fcgi.sock
//监听地址,也可以写:listen = 127.0.0.1::9000,本地监听,也可以监听其他IP:port
//此处格式会影响配置Nginx和PHP结合时Nginx寻址PHP的路径
listen.mode = 666
//当监听的为socket文件时该部分才生效,用于指定.sock文件的权限
user = php-fpm
group = php-fpm
//定义php-fpm服务的用户
pm = dynamic
pm.max_children = 50
pm.start_servers = 20
pm.min_spare_servers = 5
pm.max_spare_servers = 35
pm.max_requests = 500
rlimit_files = 1024
//以上部分为进程相关信息
配置启动脚本
//切换至文件源目录:
[root@dl-001 etc]# cd /usr/local/src/php-5.6.30
//添加启动脚本到系统配置:
[root@dl-001 php-5.6.30]# cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpm
//更改文件权限:
[root@dl-001 php-5.6.30]# chmod 755 /etc/init.d/php-fpm
//添加到系统服务:
[root@dl-001 php-5.6.30]# chkconfig --add php-fpm
//设置开机启动:
[root@dl-001 php-5.6.30]# chkconfig php-fpm on
//启动php-fpm服务:
[root@dl-001 php-5.6.30]# service php-fpm start
Starting php-fpm done