LNMP环境搭建 CentOS7.x 安装 Nginx PHP

2020-09-03  本文已影响0人  _Van丶

一、Nginx 安装


鉴于 Centos 默认 yum 源的 Nginx 版本太低了,手动编译安装又有点一些麻烦,那么如何采用 Yum 安装的方案安装最新版呢。那么,今天我们就来学习下如何用 yum 安装 Nginx 最新版。

1、配置 CenOS7 的 Nginx 最新 yum 源

可在 Nginx 官网 Centos 源 查看最新的源

sudo rpm -Uvh http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

2、安装 Nginx

sudo yum -y install nginx

3、启动 Nginx 并设置开机自启

# 启动 Nginx
sudo systemctl start nginx.service

# 设置开机自启
sudo systemctl enable nginx.service

# 此时可在浏览器中输入服务器 IP 查看是否成功显示 Nginx 默认欢迎页面

4、配置 Nginx

# 默认配置路径 /etc/nginx/nginx.conf, 引入配置路径 /etc/nginx/conf.d/
# 直接进入 /etc/nginx/conf.d/ 目录, 查看目录中文件
cd /etc/nginx/conf.d/
ls -l
# 如存在类似 www.conf 文件则直接修改
vim www.conf
#如只有 default.conf 或 www.conf.default 文件则 copy 一份再修改
cp www.conf.default www.conf
vim www.conf

# 基础配置
server {
        listen       80;
        # 设置 IP 或域名
        server_name  yourIP or servername;

                # 设置项目目录
        set $root "/usr/local/share/html";

        charset utf-8;

        #access_log  logs/host.access.log  main;

        location / {
            root   $root;
            # 默认优先走 index.php
            index  index.php index.html index.htm;
        }

        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #
        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   $root;
        }

        # proxy the PHP scripts to Apache listening on 127.0.0.1:80
        #
        #location ~ \.php$ {
        #    proxy_pass   http://127.0.0.1;
        #}

        # pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000
        #
        location ~ \.php$ {
            root           $root;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            # 这里将原有的 /scripts 替换成 $document_root
            fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
            include        fastcgi_params;
        }
        
        # deny access to .htaccess files, if Apache's document root
        # concurs with nginx's one
        #
        #location ~ /\.ht {
        #    deny  all;
        #}
    }
# 保存退出    
:wq

# 重载配置文件
nginx -s reload

二、PHP 安装


编译安装多版本 PHP 可看这里:yum 安装 PHP

1、安装 EPEL 源并配置 CentOS7 的源

EPEL (Extra Packages for Enterprise Linux)是基于Fedora的一个项目,为“红帽系”的操作系统提供额外的软件包,适用于RHEL、CentOS 和 Scientific Linux.

# 安装 EPEL 源
sudo yum -y install epel-release

# 配置 CentOS7 的源,可在 http://rpms.remirepo.net/ 查看
# 官网提供了各个国家的全量镜像源地址,这里使用清华大学镜像源
sudo rpm -Uvh https://mirrors.tuna.tsinghua.edu.cn/remi/enterprise/remi-release-7.rpm

2、安装 PHP

# 搜索可安装的 php 包
sudo yum search php

# 这里以 php7.4 版本为例,搜索 php74 版本对应的 redis 扩展包,其他扩展包同理
sudo yum search php74 | grep redis

# 安装 php, php-fpm 及 redis5 扩展(多个扩展以空格隔开即可),php 默认安装在 /usr/bin/ 目录下
# php.ini 文件路径为 /etc/opt/remi/php74/php.ini,找不到可使用`find / -name php.ini`查找 
sudo yum -y install php74 php74-php-fpm php74-php-pecl-redis5.x86_64

# 后续需要安装扩展(.x86_64 后缀可省略)可直接通过 yum 安装,例如
sudo yum -y install php74-php-bcmath php74-php-opcache.x86_64

# 查看扩展是否安装成功
php74 -m

3、启动 php-fpm 并设置开机自启

# 启动 php-fpm
sudo systemctl start php74-php-fpm.service

# 设置开机自启
sudo systemctl enable php74-php-fpm.service

# 默认配置路径 /etc/opt/remi/php74/php-fpm.conf, 引入配置路径 /etc/opt/remi/php74/php-fpm.d/

4、项目目录下编写 php 脚本检查配置是否正常

# 在 Nginx 配置的 root 目录下新建 index.php 并输入 phpinfo() 
echo "<?php phpinfo();" >> /usr/local/share/html/index.php

# 访问 IP 或者域名, 如正常输出 phpinfo 信息则配置成功

三、MySQL 安装


1、配置 MySQL 官方 yum 源

可在 https://dev.mysql.com/downloads/repo/yum/ 查看

sudo rpm -Uvh https://dev.mysql.com/get/mysql80-community-release-el7-3.noarch.rpm

2、安装 MySQL 服务端

sudo yum -y install mysql-community-server

# 查看版本看是否安装成功
mysql --version

3、启动 MySQL 服务并设置开机自启

# 启动 MySQL
sudo systemctl start mysqld.service

# 设置开机自启
sudo systemctl enable mysqld.service

4、初始密码更改

# 此时 MySQL 已经正常运行,不过要想进入 MySQL 还得先从日志文件中找出 root 用户的密码
sudo grep "password" /var/log/mysqld.log

# 执行一下命令,回车后会提示输入密码
mysql -uroot -p
  1. MySQL8.0 密码修改
# 由于8.0授权方式不一样,不能授权给自己,输入密码进入后要先创建一个用户
mysql> create user 'van'@'%' identified by 'your password';
# Query OK, 0 rows affected (0.02 sec)

mysql> GRANT ALL PRIVILEGES ON *.* TO 'van'@'%';
# Query OK, 0 rows affected (0.04 sec)

mysql> FLUSH PRIVILEGES;
# Query OK, 0 rows affected (0.00 sec)

# 此时可以通过本地客户端使用刚刚设置的密码测试连接是否成功
# 如果用客户端连接报不支持 caching_sha2_password 验证方式的错误
# 将远程访问用户的验证方式改为:msyql_native_password
mysql> ALTER USER 'van'@'%' IDENTIFIED WITH mysql_native_password BY 'your password';
# Query OK, 0 rows affected (0.04 sec)

mysql> FLUSH PRIVILEGES;
# Query OK, 0 rows affected (0.00 sec)
  1. MySQL5.x 密码修改
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';
# 这里有个问题,新密码设置的时候如果设置的过于简单会报错:
# ERROR 1819 (HY000): Your password does not satisfy the current policy requirements
# 原因是因为 MySQL 有密码设置的规范,具体是与 validate_password_policy 的值有关

# MySQL完整的初始密码规则可以通过如下命令查看:
mysql> SHOW VARIABLES LIKE 'validate_password%';
# 密码的长度是由 validate_password_length 决定的,而 validate_password_length 的计算公式是:
# validate_password_length = validate_password_number_count + validate_password_special_char_count + (2 * validate_password_mixed_case_count)

# 解决方法就是修改密码为规范复杂的密码:
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'default password in log';

#这时候我们要把密码规则改一下,执行下面sql就可以了:
mysql> set global validate_password_policy=0;

# 此时密码就可以设置的很简单,例如1234之类的。到此数据库的密码设置就完成了。
mysql> ALTER USER 'root'@'localhost' IDENTIFIED BY 'new password';

mysql> grant all on *.* to root@'%' identified by 'new password';
# 至此,大功告成

以上,Van(完)。

上一篇下一篇

猜你喜欢

热点阅读