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