阿里云服务器ECS部署LNMP环境(CentOS 7)

前提条件

  • 已创建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

一:准备编译环境

  1. 远程连接需要部署LNMP环境的ECS实例
  2. 关闭防火墙
1. 查看防火墙状态
systemctl status firewalld
2. 如果防火墙的状态参数是active,则防火墙为开启状态。如果防火墙为关闭状态可以忽略此步骤。
如果您想临时关闭防火墙,需要运行以下命令:
systemctl stop firewalld
如果您想永久关闭防火墙,需要依次运行以下命令:
# 关闭防火墙
systemctl stop firewalld
# 实例开机时,禁止启动防火墙服务。
systemctl disable firewalld
  1. 关闭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环境部署成功。


image.png

到这里已经安装完成了,接下来是安装多版本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

PHP编译常见错误以及解决方法

设置快捷命令

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
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,222评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,455评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 157,720评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,568评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,696评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,879评论 1 290
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,028评论 3 409
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,773评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,220评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,550评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,697评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,360评论 4 332
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,002评论 3 315
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,782评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,010评论 1 266
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,433评论 2 360
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,587评论 2 350

推荐阅读更多精彩内容