Centos搭建开发环境,PHP7+ Nginx1.12+ Mysql5.7
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技术 对观点赞同或支持。如需转载,请注明文章来源。