前提条件
- 已创建ECS实例并为实例分配公网IP地址
我使用的是以下配置的ECS实例:
实例规格:ecs.n4.small
操作系统:CentOS 7.9 64位
网络类型:专有网络
IP地址:公网IP - 已在实例安全组的入方向添加安全组规则并放行22、80、443、3306端口。具体操作,请参见添加安全组规则。
安装完成后的软件版本信息
Nginx版本:Nginx 1.20.1
MySQL版本:MySQL 5.7.37
PHP版本:PHP 7.0.33
一:准备编译环境
- 远程连接需要部署LNMP环境的ECS实例
- 关闭防火墙
1. 查看防火墙状态
systemctl status firewalld
2. 如果防火墙的状态参数是active,则防火墙为开启状态。如果防火墙为关闭状态可以忽略此步骤。
如果您想临时关闭防火墙,需要运行以下命令:
systemctl stop firewalld
如果您想永久关闭防火墙,需要依次运行以下命令:
# 关闭防火墙
systemctl stop firewalld
# 实例开机时,禁止启动防火墙服务。
systemctl disable firewalld
- 关闭SELinux。
运行getenforce命令查看SELinux的当前状态
如果是Disabled,则SELinux为关闭状态
如果是Enforcing,则为开启状态
SELinux关闭的方式分为临时关闭和永久关闭,请根据自身业务需求进行选择。
二:安装Nginx
1. 安装Nginx。
yum -y install nginx
2. 查看Nginx版本。
nginx -v
返回结果如下所示,表示Nginx安装成功。
nginx version: nginx/1.20.1
三:安装MySQL
1. 更新YUM源。
rpm -Uvh http://dev.mysql.com/get/mysql57-community-release-el7-9.noarch.rpm
2. 安装MySQL
yum -y install mysql-community-server
注:我这里GPG验证不通过,所以在yum install 版本后面加上 --nogpgcheck,绕过GPG验证。即:yum install mysql-community-server --nogpgcheck
3. 查看MySQL版本号
mysql -V
返回结果如下所示,表示MySQL安装成功。
mysql Ver 14.14 Distrib 5.7.37, for Linux (x86_64) using EditLine wrapper
4. 启动MySQL
systemctl start mysqld
5. 设置开机启动MySQL。
systemctl enable mysqld
systemctl daemon-reload
四:安装PHP
1. 更新YUM源
运行以下命令添加epel源。
yum install https://repo.ius.io/ius-release-el7.rpm https://dl.fedoraproject.org/pub/epel/epel-release-latest-7.noarch.rpm
添加Webtatic源
rpm -Uvh https://mirror.webtatic.com/yum/el7/webtatic-release.rpm
2. 安装PHP
yum -y install php70w-devel php70w.x86_64 php70w-cli.x86_64 php70w-common.x86_64 php70w-gd.x86_64 php70w-ldap.x86_64 php70w-mbstring.x86_64 php70w-mcrypt.x86_64 php70w-pdo.x86_64 php70w-mysqlnd php70w-fpm php70w-opcache php70w-pecl-redis php70w-pecl-mongodb
3. 查看PHP版本
php -v
返回结果如下所示,表示安装成功。
PHP 7.0.33 (cli) (built: Dec 6 2018 22:30:44) ( NTS )
五:配置Nginx
1. 备份Nginx配置文件
cp /etc/nginx/nginx.conf /etc/nginx/nginx.conf.bak
2. 编辑Ngnix配置文件
vim /etc/nginx/nginx.conf,按i,修改配置如下,:wq保存退出
部分代码如下:
server {
listen 80;
listen [::]:80;
server_name _;
root /usr/share/nginx/html;
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
# 添加下列信息
location / {
index index.php index.html index.htm;
}
# 添加下列信息,配置Nginx通过fastcgi方式处理您的PHP请求。
location ~ .php$ {
root /home/www; #将/home/www/替换为您的网站根目录。
fastcgi_pass 127.0.0.1:9000; #Nginx通过本机的9000端口将PHP请求转发给PHP-FPM进行处理。
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params; #Nginx调用fastcgi接口处理PHP请求。
}
error_page 404 /404.html;
location = /404.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
3. 查看nginx配置是否正确
nginx -t
4. 启动Nginx服务
systemctl start nginx
5. 设置Nginx服务开机自启动
systemctl enable nginx
六:配置MySQL
1. 查看/var/log/mysqld.log文件,请自行保存root用户的初始密码,我这里的临时密码是TuXoQw.gs0W,
grep 'temporary password' /var/log/mysqld.log
返回:2022-02-19T02:30:15.533743Z 1 [Note] A temporary password is generated for root@localhost: TuXoQw.gs0W,
2. 配置MySQL的安全性
mysql_secure_installation
Enter password for user root: #输入上一步获取的root用户初始密码
2.1 设置新密码
New password: #输入新密码。长度为8至30个字符,必须同时包含大小写英文字母、数字和特殊符号。特殊符号包含()` ~!@#$%^&*-+=|{}[]:;‘<>,.?/
Re-enter new password: #确认新密码。
Estimated strength of the password: 100 #返回结果包含您设置的密码强度。
Change the password for root ? ((Press y|Y for Yes, any other key for No) :Y #输入Y确认使用新密码。
#新密码设置完成后,需要再次验证新密码。
New password:#再次输入新密码。
Re-enter new password:#再次确认新密码。
#输入Y,再次确认使用新密码。
Do you wish to continue with the password provided?(Press y|Y for Yes, any other key for No) :Y
#输入Y删除匿名用户
Remove anonymous users? (Press y|Y for Yes, any other key for No) :Y
#输入Y禁止使用root远程登录MySQL。
Disallow root login remotely? (Press y|Y for Yes, any other key for No) :Y
#输入Y删除test库以及用户对test库的访问权限。
Remove test database and access to it? (Press y|Y for Yes, any other key for No) :Y
#输入Y重新加载授权表。
Reload privilege tables now? (Press y|Y for Yes, any other key for No) :Y
七:配置PHP
1. 在网站根目录新建phpinfo.php,这里只是测试使用,正式环境请把phpinfo.php删除
vim /home/www/phpinfo.php,按i,输入以下代码,按Esc键,输入:wq并回车,保存关闭配置文件
<?php echo phpinfo(); ?>
2. 启动PHP-FPM
systemctl start php-fpm
3. PHP-FPM开机自启动
systemctl enable php-fpm
八:测试访问LNMP配置信息页面
在浏览器的地址栏输入http://<ECS实例公网IP地址>/phpinfo.php进行访问。
访问结果如下图所示,表示LNMP环境部署成功。
到这里已经安装完成了,接下来是安装多版本PHP,如果不需要,可以忽略
源码安装PHP7.3.4
#在此目录下进行
cd /usr/local/src/
#下载源码包
wget https://www.php.net/distributions/php-7.3.4.tar.gz
# 解压
tar -zxvf php-7.3.4.tar.gz
# 切换到php-7.3.4目录
cd php-7.3.4
#配置编译参数
./configure --prefix=/usr/local/php73 --with-config-file-path=/usr/local/php73/etc
# 安装
make && make install
# 查看是否安装成功
/usr/local/php73/bin/php -v
设置快捷命令
1. vi ~/.bash_profile
# 加入以下两行后保存退出
alias php73="/usr/local/php73/bin/php"
alias php70="/usr/bin/php"
# 默认使用7.3.4版本
alias php="php73"
2. source ~/.bash_profile
复制php.ini文件
1. 复制源码包里面的php.ini-development到/usr/local/php73/etc目录下
cp /usr/local/src/php-7.3.4/php.ini-development /usr/local/php73/etc/php.ini
2. 测试php.ini加载问题
php --ini
返回以下信息说明配置成功:
Configuration File (php.ini) Path: /usr/local/php73/etc
Loaded Configuration File: /usr/local/php73/etc/php.ini
编译安装扩展
1. 在 源码包 /usr/local/src/php-7.3.4/ext/ 目录下可以看到 php 所有的原生扩展,
/usr/local/src/php-7.3.4/ext/
# 以安装 sockets 为例,切换到sockets目录
cd sockets
# 执行 phpize
/usr/local/php73/bin/phpize
# 配置编译
./configure --with-php-config=/usr/local/php73/bin/php-config
# 编译并且安装
make && make install
# 在/usr/local/php73/etc/php.ini配置文件加入模块
`extension=sockets`
# 查看模块是否安装成功
php73 -m | grep sockets
返回 `sockets` 说明安装成功
修改 php-fpm 监听端口
# 复制php7.3.4的php-fpm 配置文件
cp /usr/local/php73/etc/php-fpm.conf.default /usr/local/php73/etc/php-fpm.conf
# 编辑php-fpm.conf
vim /usr/local/php73/etc/php-fpm.conf
去掉;pid = run/php-fpm.pid前面的分号
# 复制www.conf文件
cp /usr/local/php73/etc/php-fpm.d/www.conf.default /usr/local/php73/etc/php-fpm.d/www.conf
vim /usr/local/php73/etc/php-fpm.d/www.conf
输入 /9000 回车,找到 listen = 127.0.0.1:9000 这一行将 9000 修改为 9073
# 关闭php-fpm
killall php-fpm
# 重启 php-fpm
/usr/sbin/php-fpm
/usr/local/php73/sbin/php-fpm
Nginx配置多版本PHP
1. 修改nginx配置文件
vim /etc/nginx/nginx.conf
修改如下:
server {
listen 80;
listen [::]:80;
server_name _;
set $root "/home/www";
# Load configuration files for the default server block.
include /etc/nginx/default.d/*.conf;
location / {
root $root;
index index.php index.html index.htm;
}
# php73 匹配路由
location ^~ /php73 {
root $root;
fastcgi_pass 127.0.0.1:9073; # 这里端口需和前面 php-fpm 修改的端口保持一致
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
# php70
location ^~ /php70 {
root $root;
fastcgi_pass 127.0.0.1:9000; # 这里端口需和前面 php-fpm 修改的端口保持一致
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
# 没有匹配到以上两种路由,默认走 php73
location ~ \.php$ {
root $root;
fastcgi_pass 127.0.0.1:9073;
fastcgi_index index.php;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
include fastcgi_params;
}
error_page 404 /404.html;
location = /404.html {
}
error_page 500 502 503 504 /50x.html;
location = /50x.html {
}
}
# 2. 重启 Nginx
systemctl restart nginx.service
测试PHP多版本
1. 运行以下命令查看PHP版本是否对应
php -v
php73 -v
php70 -v
2. 浏览器访问测试
mkdir /home/www/php73
mkdir /home/www/php70
cp /home/www/phpinfo.php /home/www/php73/phpinfo.php
cp /home/www/phpinfo.php /home/www/php70/phpinfo.php
依次访问以下路径,查看对应版本
http://<ECS实例公网IP地址>/php73/phpinfo.php
http://<ECS实例公网IP地址>/php70/phpinfo.php
http://<ECS实例公网IP地址>/phpinfo.php
接下来的代码管理需要用到的工具安装
安装Git版本控制工具
1. yum安装Git
yum -y install git
2. 输入 git --version查看Git是否安装完成以及查看其版本号
git --version
返回以下信息说明安装成功:
git version 1.8.3.1
yum安装的git被安装在/usr/libexec/git-core目录下
安装composer
1. 下载composer
curl -sS https://getcomposer.org/installer | php
2. 将composer.phar文件移动到bin目录以便全局使用composer命令
mv composer.phar /usr/local/bin/composer
3. 配置composer使用国内镜像库,这里切换为阿里云 Composer 镜像
composer config -g repo.packagist composer https://mirrors.aliyun.com/composer/
4. 输入composer验证是否安装成功
这里注意下,Composer不允许使用root用户执行,所以执行会报这个错误
Do not run Composer as root/super user! See https://getcomposer.org/root for detail
回车,出现以下信息表示安装成功
______
/ ____/___ ____ ___ ____ ____ ________ _____
/ / / __ \/ __ `__ \/ __ \/ __ \/ ___/ _ \/ ___/
/ /___/ /_/ / / / / / / /_/ / /_/ (__ ) __/ /
\____/\____/_/ /_/ /_/ .___/\____/____/\___/_/
/_/
Composer version 2.2.6 2022-02-04 17:00:38
解决办法:创建一个新用户 , 使用新用户执行操作 即可 .
# 创建新用户
useradd newname
# 设置密码
passwd newname,输入密码
# 切换到新用户
su newname
执行 原来的操作 , 顺利完成 composer 指令
多版本PHP执行composer安装
/usr/local/php73/bin/php /usr/local/bin/composer install