CentOS 7 安装php7(已有php5.4)

简介: 新的程序需要php7才能支持,老程序必须用php5.x 准备安装php7之前已经用yum安装了php5.4了,因为有老程序必须使用所以需要保留php5.4 采用源码编译安装 wget http://am1.

新的程序需要php7才能支持,老程序必须用php5.x

准备安装php7
之前已经用yum安装了php5.4了,因为有老程序必须使用
所以需要保留php5.4

采用源码编译安装

wget http://am1.php.net/distributions/php-7.2.0.tar.bz2
tar -jxvf php-7.2.0.tar.bz2
cd php-7.2.0

安装依赖库
yum -y install libxml2-devel curl-devel libpng libpng-devel libxslt libxslt-devel

./configure --prefix=/usr/local/php7 --with-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-inline-optimization --enable-mbregex --enable-mbstring --enable-opcache --enable-pcntl --enable-shmop --enable-soap --enable-sockets --enable-sysvshm --enable-sysvmsg --enable-sysvsem --enable-xml --enable-zip --with-fpm-user=nginx --enable-ftp --enable-exif  --enable-session --with-mhash --with-ldap

–prefix=/usr/local/php7 单独安装在php7的文件夹,避免和php5冲突*
--with-ldap 增加ldap支持

编译

make

然后可以测试一下

make test #测试时间要十几分钟,可以跳过

安装

make install

准备配置文件

cp php.ini-production /usr/local/php7/etc/php.ini
cd /usr/local/php7/etc/
cp php-fpm.conf.default php-fpm.conf
cd php-fpm.d
cp www.conf.default www.conf
vi www.conf #修改端口号9001

创建php7-fpm的服务
cd /usr/lib/systemd/system
cp php-fpm.service php-fpm7.service #拷贝php5的服务
cp /etc/sysconfig/php-fpm /usr/local/php7/etc/
vi php-fpm7.service #修改路径

[Unit]
  Description=The PHP FastCGI Process Manager
  After=syslog.target network.target
 
  [Service]
  Type=notify
  PIDFile=/run/php-fpm/php-fpm7.pid
  EnvironmentFile=/usr/local/php7/etc/php-fpm
  ExecStart=/usr/local/php7/sbin/php-fpm --nodaemonize
  ExecReload=/bin/kill -USR2 $MAINPID
  PrivateTmp=true
 
  [Install]
  WantedBy=multi-user.target

这个方式启动有点问题

启动后一直等等,这个时候php网站可以访问
然后一段时间会超时失败。失败后php网站无法访问。

init.d的方式启动

vi /etc/init.d/php-fpm7

\# ! /bin/sh
\# chkconfig: 2345 80 90
\# Comments to support chkconfig on CentOS

set -e

PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
DESC="php-fpm7 daemon"
NAME=php-fpm7
DAEMON=/usr/local/php7/sbin/$NAME

CONFIGFILE=/usr/local/php7/etc/php-fpm.conf
PIDFILE=/usr/local/php7/var/run/$NAME.pid
SCRIPTNAME=/etc/init.d/$NAME

\# Gracefully exit if the package has been removed.
test -x $DAEMON || exit 0

d_start() {
  $DAEMON -y $CONFIGFILE || echo -n " already running"
}

d_stop() {
  kill -QUIT `cat $PIDFILE` || echo -n " not running"
}

d_reload() {
  kill -HUP `cat $PIDFILE` || echo -n " can't reload"
}

case "$1" in
  start)
    echo -n "Starting $DESC is success"
    d_start
    echo "."
    ;;
 stop)
    echo -n "Stopping $DESC is success"
    d_stop
    echo "."
    ;;
 reload)
    echo -n "Reloading $DESC configuration..."
    d_reload
    echo "reloaded."
  ;;
  restart)
      echo -n "Restarting $DESC is success"
      d_stop
      sleep 1
      d_start
      echo "."
       ;;
  *)
     echo "Usage: $SCRIPTNAME {start|stop|restart|force-reload}" >&2
     exit 3
    ;;
esac

启动

chmod +x /etc/init.d/php-fpm7
/etc/init.d/php-fpm7 start

开机启动

chkconfig --add php-fpm7
chkconfig php-fpm7 on
chkconfig --list #检查是否成功

目录
相关文章
|
23天前
|
消息中间件 Linux API
centos7 安装rabbitmq自定义版本及配置
centos7 安装rabbitmq自定义版本及配置
|
22天前
|
弹性计算 关系型数据库 MySQL
centos7 mysql安装及配置
本文详细介绍了在阿里云服务器ECS上通过yum源安装MySQL 8.0.12的过程,包括更新yum源、下载并安装MySQL源、解决安装过程中可能遇到的问题等步骤。此外,还介绍了如何启动MySQL服务、设置开机自启、配置登录密码、添加远程登录用户以及处理远程连接异常等问题。适合初学者参考,帮助快速搭建MySQL环境。
110 8
centos7 mysql安装及配置
|
19天前
|
存储 Linux Docker
CentOS 7.6安装Docker实战案例及存储引擎和服务进程简介
关于如何在CentOS 7.6上安装Docker、介绍Docker存储引擎以及服务进程关系的实战案例。
65 3
CentOS 7.6安装Docker实战案例及存储引擎和服务进程简介
|
23天前
|
分布式计算 资源调度 Hadoop
centos7二进制安装Hadoop3
centos7二进制安装Hadoop3
|
24天前
|
Linux Python
Centos7安装Python虚拟环境之virtualenv
Centos7安装Python虚拟环境之virtualenv
|
24天前
|
存储 缓存 Linux
LDAP学习笔记之一:Centos7安装389-DS(RHDS)
LDAP学习笔记之一:Centos7安装389-DS(RHDS)
|
24天前
|
前端开发 小程序 Unix
Centos安装前端开发常用软件
Centos安装前端开发常用软件
|
11天前
|
NoSQL 关系型数据库 MySQL
不是 PHP 不行了,而是 MySQL 数据库扛不住啊
【9月更文挑战第8天】这段内容讨论了MySQL在某些场景下面临的挑战及其原因,并指出这些问题不能完全归咎于MySQL本身。高并发读写压力、数据量增长以及复杂查询和事务处理都可能导致性能瓶颈。然而,应用程序设计不合理、系统架构不佳以及其他数据库选择和优化策略不足也是重要因素。综合考虑这些方面才能有效解决性能问题,而MySQL通过不断改进和优化,仍然是许多应用场景中的可靠选择。
|
24天前
|
存储 SQL 关系型数据库
PHP与MySQL交互的奥秘
【8月更文挑战第29天】在编程的世界里,PHP和MySQL就像是一对默契的舞伴,共同演绎着数据的交响曲。本文将带你探索它们之间的互动,从连接数据库到执行查询,再到处理结果,每一步都充满了节奏与和谐。我们将一起走进这段代码的旅程,感受数据流动的魅力。
|
21天前
|
SQL 关系型数据库 MySQL
PHP与MySQL交互之基础教程
【8月更文挑战第31天】 在数字世界中,数据是推动一切的核心力量。本文将引导你探索PHP与MySQL的协同工作,通过实际代码示例,展示如何建立连接、执行查询以及处理结果集。无论你是初学者还是希望巩固知识的开发者,这篇文章都将为你提供宝贵的实践知识。