美文网首页
LNMP环境搭建 CentOS7.x 安装 Nginx PHP

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

作者: _Van丶 | 来源:发表于2020-09-03 23:21 被阅读0次

    一、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(完)。

    相关文章

      网友评论

          本文标题:LNMP环境搭建 CentOS7.x 安装 Nginx PHP

          本文链接:https://www.haomeiwen.com/subject/lpsasktx.html