CentOS 7 下搭建PHP环境(LAMP)

孤人 提交于 2019-11-30 07:42:48

 

PHP相关组件安装

安装EPEL源

由于CentOS自带的yum源中php版本太低,所以需要添加第三方源Webtaticremi,这里我选择Webtatic,而第三方源大多依赖EPEL源,所以需要先安装EPEL,CentOS 7只需要如下操作即可

yum install epel-release

安装Webtatic源

在终端输入

rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm

webtatic源就安装成功了,再yum update一下,不出意外EPEL应该会有一个版本更新,输入y确认即可

安装PHP

输入yum list | grep php查看可以安装的php版本信息

可以看到webtatic源包含了多个版本的php,然后在命令行输入以下命令

yum install -y php71w php71w-opcache php71w-xml php71w-mcrypt php71w-gd php71w-devel php71w-mysql php71w-intl php71w-mbstring php71w-fpm

可以根据自己的需要安装指定版本的php,只需要修改命令中的数字为对应版本即可

安装完成后,在命令行输入php -v

到这里php就安装成功了

安装和配置Mysql

DB的安装

MariaDB数据库管理系统是MySQL的一个分支,主要由开源社区在维护,采用GPL授权许可。开发这个分支的原因之一是:甲骨文公司收购了MySQL后,有将MySQL闭源的潜在风险,因此社区采用分支的方式来避开这个风险

由于MariaDB完全兼容Mysql,所以我们选择安装MariaDB来替代Mysql

MariaDB的安装方法(推荐)

RHEL系的系统默认的DB是mariadb,但是版本比较低,这里我选择通过mariadb官方源来安装

可以进入MariaDB官方下载地址选择对应系统版本(注意: 64位机器选择x86_64),然后选择最新的Stable版本,我这里选择的是10.2

/etc/yum.repo.d/创建MariaDB.repo,将与系统版本对应的Yum源信息复制进去,我这里是CentOS7

 
  1. # MariaDB 10.2 CentOS repository list - created 2018-01-29 07:46 UTC

  2. # http://downloads.mariadb.org/mariadb/repositories/

  3. [mariadb]

  4. name = MariaDB

  5. baseurl = http://yum.mariadb.org/10.2/centos7-amd64

  6. gpgkey=https://yum.mariadb.org/RPM-GPG-KEY-MariaDB

  7. gpgcheck=1

接着在终端输入

yum install MariaDB-server MariaDB-client MariaDB-devel

等待安装完成即可

Mysql的安装方法

如果不想安装MariaDB,也可以选择安装Mysql 首先在终端输入以下命令

rpm -ivh https://dev.mysql.com/get/mysql57-community-release-el7-11.noarch.rpm

这时mysql官方源就装好了,接着在终端输入

yum install mysql mysql-server mysql-devel

可以看到,官方源的5.7版本已经替换掉了系统自带的mariadb,输入y确认,开始下载安装,网速不给力,就慢慢等吧

Mysql的基本配置

启动Mysql服务

安装完成后,首先启动mysql服务,输入以下命令

systemctl start mysqld

设置开机自启动

systemctl enable mysqld

可以看到mysql服务端已经启动了

修改Mysql默认密码及配置文件

mysql安装完成之后,在/var/log/mysqld.log文件中为root用户生成了一个默认密码

通过下面的命令找到root默认密码,然后登录mysql进行修改

grep 'temporary password' /var/log/mysqld.log

修改密码

 
  1. mysql -uroot -p

  2. SET PASSWORD = PASSWORD('your new password');

  3. # 或者

  4. set password for 'root'@'localhost'=password('root');

修改密码失败了,这是由于mysql5.7默认安装了密码安全检查插件(validate_password),默认密码检查策略要求密码必须包含:大小写字母、数字和特殊符号,并且长度不能少于8位,否则就会出现上面的错误

修改配置文件

mysql的配置文件在/etc/my.cnf,首先修改密码策略,在[mysqld]下添加配置项

 
  1. # 选择0(LOW), 1(MEDIUM), 2(STRONG)其中一种,选择2需要提供密码字典文件

  2. validate_password_policy = 0

  3. # 如果不需要密码策略,直接禁用

  4. validate_password = off

以上配置2选1即可

修改默认编码

由于mysql默认的编码不是utf8,在使用过程中可能会出现乱码,所以需要手动修改配置文件,这里我将默认编码改为utf8mb4(uft8的超集,支持emoji表情)

 
  1. [mysqld]

  2. character_set_server=utf8mb4

  3. init_connect='SET NAMES utf8mb4'

  4. innodb_buffer_pool_size=64MB

  5. event_scheduler=on

  6.  
  7. [mysql]

  8. default_character_set=utf8mb4

  9.  
  10. [client]

  11. default_character_set=utf8mb4

完成修改,在终端输入systemctl restart mysqld重启mysql

查看数据库编码,已经生效

添加远程登录用户

mysql默认只允许root帐户在本地登录,如果要在其它机器上连接mysql,必须修改root允许远程连接,或者添加一个允许远程连接的帐户,为了安全起见,新建一个用户

 
  1. grant all privileges on *.* to '用户名'@'%' identified by '密码';

  2. # 刷新用户权限

  3. flush privileges;

到这里mysql的安装配置就大致完成了

安装Apache

Apache的安装就很简单了,直接输入命令

yum install -y httpd httpd-devel

安装完成后,找到httpd配置文件/etc/httpd/conf/httpd.conf

出于安全考虑,关闭网站的目录浏览功能,在<Directory "/var/www/html">条目中,修改Options Indexs FollowSymLinks 为

Options -Indexs +FollowSymLinks

启动httpd

 
  1. systemctl start httpd

  2. systemctl enable httpd

测试

apache的默认路径在/var/www/html下,在这个目录新建一个test.php文件,然后写入以下内容

 
  1. <?php

  2. phpinfo();

  3. ?>

在浏览器打开http://服务器ip/test.php,如果能够显示php信息,则说明已经php环境已经成功搭建;如果打不开,关闭防火墙

systemctl stop firewalld

如果还是失败,查看80端口是否被占用

netstat -apn | grep 80

 补充:---自己试验过有效

问题:安装完成后,除了根目录剩下的文件都访问失败,原因是seLinux

解决办法:关闭selinux

        (1)不重启的头闭 setenforce 0   #重启电脑后失效
        (2)重启电脑的关闭 vi /etc/selinux/config
                把SELINUX=enforce   改成disabled就可以了,重启电脑,永久生效

重启电脑:reboot
 

易学教程内所有资源均来自网络或用户发布的内容,如有违反法律规定的内容欢迎反馈
该文章没有解决你所遇到的问题?点击提问,说说你的问题,让更多的人一起探讨吧!