centos7使用yum安装nginx+php7+mysql5.6

本文主要介绍安装在centos7下如何安装nginx+php+mysql的环境,centos7的版本自带安装源的版本无法实现PHP5.4以上的版本,数据库默认用的是mariadb,文章介绍的安装是如何去定制PHP和mysql版本实现php5.4以上的版本以及原版的Mysql。本文以php7.0 以及mysql5.6为例。

(一)Nginx安装

先查看服务器上有没有其它的web服务,查看命令如下

rpm -aq|grep nginx
rpm -aq|grep httpd

也可以用 yum list installed|nginx来查看已安装的包,如果有已安装的包可以用yum -y  remove进行卸载,操作后执行下面的安装命令,直至安装完成

yum -y install nginx

设置开机自启动并启动nginx

systemctl enable nginx
systemctl start nginx

开放80端口

firewall-cmd --zone=public --add-port=80/tcp --permanent 
firewall-cmd --reload

命令含义:
--zone=public #作用域
--add-port=80/tcp #添加端口,格式为:端口/通讯协议
--permanent #永久生效,没有此参数重启后失效

到这一步nginx就安装完成了

(二)PHP的安装

先查询系统里是否有安装其它的PHP版本

rpm -aq|grep php

如果有安装请用yum -y  remove  名称 进行卸载, 接下安装PHP安装源,

yum -y install epel-release  #更新系统最新epel源
rpm -ivh http://rpms.remirepo.net/enterprise/remi-release-7.rpm  #向系统添加PHP安装源

如果是centos8把地址换成

http://rpms.remirepo.net/enterprise/remi-release-8.rpm

可以通过以下命令查看仓库中可安装的PHP版本

yum repolist all|grep php

这里我们安装PHP7.0,如果是PHP其它的版,请装后面命令里的70替换成你对应的版本号即可

yum -y install php70
yum -y install php70-php-fpm

安装其它的常用模块

yum -y install php70-php-gd php70-php-json php70-php-mbstring php70-php-mysqlnd php70-php-xml php70-php-xmlrpc php70-php-opcache

查看其它的可安装的PHP模块

yum list|grep php70-php

配置php-fpm配置文件,把运行用户以及用户组修改成nginx

vi /etc/opt/remi/php70/php-fpm.d/www.conf

找到user和group修改成如下内容

user = nginx
group = nginx

修改php.ini配置文件 /etc/opt/remi/php70/php.ini

short_open_tag = On
upload_tmp_dir= "/tmp"
session.save_path = "/tmp"
post_max_size = 300M
upload_max_filesize = 200M
date.timezone = PRC

使用systemctl添加自启动项,并启动php-fpm服务

systemctl enable php70-php-fpm
systemctl start php70-php-fpm

运行 php70 -v即可查看到PHP详细的版本信息

如果需要用php -v能使用查看可执行下面命令

ln -s /opt/remi/php70/root/usr/bin/php /usr/bin/php

在Nignx的配置文件server代码里添加PHP支持

配置文件默认位置:/etc/nginx/nginx.conf

location ~ \.php(.*)$ {
    try_files $uri =404;
	fastcgi_pass   127.0.0.1:9000;
	fastcgi_index  index.php;
	set $real_script_name $fastcgi_script_name;
	if ($fastcgi_script_name ~ "^(.+?\.php)(/.+)$") {
			set $real_script_name $1;
			set $path_info $2;
	 }
	fastcgi_param SCRIPT_FILENAME $document_root$real_script_name;
	fastcgi_param SCRIPT_NAME $real_script_name;
	fastcgi_param PATH_INFO $path_info;

	include        fastcgi_params;
}

配置后需重启一下nginx服务

systemctl restart nginx

(三)MySQL安装

查看是否已经安装Mysql或者mariadb

rpm -aq|grep mariadb
rpm -aq|grep mysql-community

如有安装请用 yum -y remove命令进行卸载
添加mysql安装源

MySQL5.7

rpm -ivh http://dev.mysql.com/get/mysql57-community-release-el7-10.noarch.rpm

MySQL8.0

rpm -ivh http://dev.mysql.com/get/mysql80-community-release-el8-1.noarch.rpm

或者用

yum -y install  http://dev.mysql.com/get/mysql80-community-release-el8-1.noarch.rpm

这个默认是最新的mysql8.0的安装源,这里我们需要安装的是mysql5.6的版本,所以我们需要对源配置文件进行相应的修改
源文件位置: /etc/yum.repos.d/mysql-community.repo
在文件第一行加入以下代码

[mysql56-community]
name=MySQL 5.6 Community Server
baseurl=http://repo.mysql.com/yum/mysql-5.6-community/el/7/$basearch/
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql
[mysql57-community]
name=MySQL 5.7 Community Server
baseurl=http://repo.mysql.com/yum/mysql-5.7-community/el/7/$basearch/
enabled=1
gpgcheck=1
gpgkey=file:///etc/pki/rpm-gpg/RPM-GPG-KEY-mysql

注:如果是需要安装mysql5.7请把上面代码的5.6参数改成5.7即可。

然后把MySQL 8.0 Community Server配置段代码里的enabled参数改成0

然后执行命令安装mysql5.6

 yum install mysql-community-server

如果安装失败用以下命令

rpm --import https://repo.mysql.com/RPM-GPG-KEY-mysql-2022

或者

yum -y install mysql-community-server --nogpgcheck

配置/etc/my.conf

[mysqld]
port= 3306
character_set_server=utf8
sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION" 
[client]
port= 3306
default_character_set=utf8

添加启动项并启动mysql服务

systemctl start mysqld
systemctl enable mysqld

然后输入 以下命令回车就可以登录上mysql了

mysql -uroot -p

这里默认的mysql密码为空

如果安装的是mysql5.7请执行下面命令查看mysql默认密码 执行命令:

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

安装必须重置一下默认mysql密码,登录上mysql后输入命令重置密码

mysql5.6

set password=password('你的密码') 

或者直接执行

mysqladmin -u root  password 你的密码  #注:这个命令不需要登录mysql执行

如果修改密码的时候碰到要求密码复制度,可以先尝试关闭mysql密码安全策略,具体操作命令如下

show variables like 'validate_password%';
set global validate_password_policy=0;
set global validate_password_length=1;
flush privileges;

启用mysql远程登录

如果需要启用mysql远程登录需要先开放3306端口,执行下面命令开放端口

firewall-cmd --zone=public --add-port=3306/tcp --permanent 
firewall-cmd --reload

如果是云主机还需要到云主机平台对应安全组或者防火墙里开放3306端口

mysql -uroot -p
use mysql
update user set host="%" where user="root" and host="localhost"
flush privileges;
exit;

MySQL5.7以上用

GRANT ALL ON *.* TO root@'%' IDENTIFIED BY '密码' WITH GRANT OPTION;

版权声明:
作者:鲤小牛
链接:https://yunweiba.com/123.html
来源:运维吧
文章版权归作者所有,未经允许请勿转载。

THE END
分享
二维码
< <上一篇
下一篇>>
文章目录
关闭
目 录