Centos搭建开发环境,PHP7+ Nginx1.12+ Mysql5.7

Linux就该这么学

1.更新yum源

yum -y update

 

2. 安装 epel-release

yum install epel-release -y

检测安装成功:yum search nginx  结果含有:nginx.x86_64 : A high performance web server and reverse proxy server 表示成功

CentOS 系列的服务器系统有一个毛病,就是官方自带的源的软件比较古老,并且很多的软件都没有。因为他们的首要任务是保证服务器的稳定,而不是追求最新。但是太过于保守了,一般来说,我们会给服务器添加一个 epel-release 这个源。这个源里包含了例如 nginx 之类的我们需要的软件,使用起来比较方便。

 

3.安装服务器常用软件

yum -y install vim*  

Vim是一个类似于Vi的著名的功能强大、高度可定制的文本编辑器

yum install wget

wget 是一个从网络上自动下载文件的自由工具,支持通过 HTTP、HTTPS、FTP 三个最常见的 TCP/IP协议 下载,并可以使用 HTTP 代理。

yum -y install lrzsz

lrzsz是一款在linux里可代替ftp上传和下载的程序。

yum install zip unzip

作用:zip压缩、unzip解压缩  

 

4.安装Nginx

nginx 依赖的一些 lib 库:

yum install gcc-c++

yum install pcre pcre-devel

yum install zlib zlib-devel

yum install openssl openssl--devel 

安装 Nginx

cd /usr/local

打开 usr 下的 local 文件夹

yum install nginx -y

安装Nginx,此安装的包已经是更新过的源

systemctl start nginx

启动 nginx

systemctl enable nginx

将 nginx 设置为开机启动

完成安装在浏览器访问主机 ip ,看看是否能打开。

 

5.安装PHP7

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

安装php7的rpm包

yum search php7

查询下自己的php7是哪个版本以及扩展库,例如:php70w、php71w、php72w、php70w-fpm等

yum install php70w

以自己的包为准

yum install php70w-openssl php70w-common php70w-fpm php70w-mysql php70w-mysqld php70w-pdo 

安装PHP7的扩展库的版本号和PHP7的版本对应,也就是 php70w 的版本对应同版本的扩展库 php70w-fpm等。

 

6.安装Mysql

wget http://dev.mysql.com/get/mysql57-community-release-el7-8.noarch.rpm

下载mysql源安装包

rpm -ivh mysql57-community-release-el7-8.noarch.rpm

安装mysql源

yum -y install mysql-server

安装mysql

service mysqld start

或 

systemctl start mysqld

启动mysql服务器

systemctl status mysqld

查看mysql状态

systemctl enable mysqld

systemctl daemon-reload

开机启动

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

mysql安装完成之后,在/var/log/mysqld.log文件中给root生成了一个默认密码。通过上面的方式找到root默认密码( :后面为密码),然后登录mysql进行修改

mysql -uroot -p

按回车,输入刚才的临时密码,进入mysql来修改密码

set global validate_password_policy=0;

mysql5.7默认安装了密码安全检查插件(validate_password),默认密码检查策略要求密码必须包含:大小写字母、数字和特殊符号,并且长度不能少于8位。否则会提示ERROR报错。

此处代码用来修改密码强度:0 or LOW(密码任意,但长度在 8 位或以上)。

set global validate_password_length=4;

设置的密码少于8位,请执行上述命令(最少是4)

set password for 'root'@'localhost'=password('新密码');

执行此代码修改mysql登陆密码

GRANT ALL PRIVILEGES ON *.* TO 'yourname'@'%' IDENTIFIED BY 'YourPassword@123' WITH GRANT OPTION;

添加远程登录用户,默认只允许root帐户在本地登录,如果要在其它机器上连接mysql,必须修改root允许远程连接,执行上述代码。

 

7.配置php、nginx

配置php

vim /etc/php.ini

修改 php.ini 把 cgi.fix_pathinfo 的值改为0 ,前面有 ;的话去掉,大约在763行,进入文件后  输入 :763 定位过去。

vim /etc/php-fpm.d/www.conf

修改 www.cong 修改两处

listen.owner = nobody

listen.group = nobody

这两行前面的  ;去掉

user = apache

group = apache

将apache 更换成 nginx ,保存后退出( :wq )

systemctl start php-fpm

systemctl enable php-fpm

启动PHP,并将它设置为开机启动。

 

配置nginx

vim /etc/nginx/nginx.conf

打开配置文件

server {

  listen 80;

  server_name 127.0.0.1:9000;

  root /www/;

  index index.php index.html index.htm

  # Load configuration files for the default server block.

  include /etc/nginx/default.d/*.conf;

  location ~ \.php$ {

  fastcgi_pass 127.0.0.1:9000;

  fastcgi_param SCRIPT_FILENAME /www/$fastcgi_script_name;

  include fastcgi_params;

  }

  location / {

  }

  error_page 404 /404.html;

  location = /40x.html {

  }

  error_page 500 502 503 504 /50x.html;

  location = /50x.html {

  }

}

依照这个格式改,listen 监听端口,server_name 项目网址(默认设置127.0.0.1:9000),root 项目路径;  index 服务器按顺序找首页文件,前面的没有往后找,玩php就可以把 index.php放前面。

localtion 中把 fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; 中的 $document_root 改为 项目地址。

在项目文件路径下写个 info.php

<?php

echo phpinfo()

?>

保存退出后,在浏览器输入主机外网 ip/info.php ,查看下是否成功。

 

本文由 CentOS中文站 - 专注Linux技术 作者:centos 发表,其版权均为 CentOS中文站 - 专注Linux技术 所有,文章内容系作者个人观点,不代表 CentOS中文站 - 专注Linux技术 对观点赞同或支持。如需转载,请注明文章来源。

灰色头像

相关文章

发表评论

邮箱地址不会被公开。 必填项已用*标注