CentOS7系统手动部署LNMP 环境操作演示
本文档介绍如何手动在ECS实例上搭建LNMP环境(CentOS 7),其中LNMP分别代表Linux、Nginx、MySQL和PHP。
项目配置
本篇教程在示例步骤中使用了以下版本的软件。操作时,请您以实际软件版本为准。
-
操作系统:CentOS 7.2 64位
-
Nginx版本:Nginx 1.10.2
-
MySQL版本:MySQL 5.6.24
-
PHP版本:PHP 5.6.38
适用对象
适用于熟悉Linux操作系统,刚开始使用阿里云进行建站的个人用户。
基本流程
使用云服务器ECS搭建LNMP平台的操作步骤如下:
-
准备编译环境。
-
安装Nginx。
-
安装MySQL。
-
安装PHP-FPM。
-
测试访问。
本文主要说明手动安装LNMP平台的操作步骤,您也可以在 云市场 购买LNMP镜像直接启动ECS,以便快速建站。
-
说明 本篇教程创建的ECS实例选用了CentOS 7.2 64位的操作系统,专有网络和公网IP。
-
关闭防火墙。
输入
systemctl status firewalld
命令查看当前防火墙的状态。如果防火墙的状态参数是active,则防火墙为开启状态。如果防火墙的状态参数是inactive,则防火墙为关闭状态。如上图所示,此处防火墙为开启状态,需要运行如下命令关闭防火墙:
-
如果您想临时关闭防火墙,输入命令
systemctl stop firewalld
。说明 这只是暂时关闭防火墙,下次重启Linux后,防火墙还会开启。
-
如果您想永久关闭防火墙,输入命令
systemctl disable firewalld
。说明 您可参考firewalld官网信息来决定何时开启防火墙。
关闭SELinux。
-
如果您想临时关闭SELinux,输入命令
setenforce 0
。说明 这只是暂时关闭SELinux,下次重启Linux后,SELinux还会开启。
-
如果您想永久关闭SELinux,输入命令
vi /etc/selinux/config
编辑SELinux配置文件。回车后,把光标移动到SELINUX=enforcing
这一行,按下i
键进入编辑模式,修改为SELINUX=disabled
, 按下Esc
键,然后输入:wq
并回车以保存并关闭SELinux配置文件。说明 您可参考redhat关于SELinux的官方文档来决定何时开启SELinux。
-
如果SELinux状态参数是Enforcing,则SELinux为开启状态。如果SELinux状态参数是Disabled, 则SELinux为关闭状态。如上图所示,此处SELinux为开启状态,需要运行如下命令关闭SELinux:
-
重启系统使设置生效。
参考添加安全组规则,放行所需端口入方向规则。
步骤二:安装Nginx。-
安装依赖包。
yum groupinstall "Development tools" -yyum install zlib-devel pcre-devel openssl-devel -yyum install epel-release -yyum install perl perl-devel perl-ExtUtils-Embed libxslt libxslt-devel libxml2 libxml2-devel gd gd-devel GeoIP GeoIP-devel -y
-
下载源码包解压编译。
wget http://nginx.org/download/nginx-1.10.2.tar.gz tar xvf nginx-1.10.2.tar.gz -C /usr/local/src cd /usr/local/src/nginx-1.10.2 ./configure --prefix=/etc/nginx \ --sbin-path=/usr/sbin/nginx \--conf-path=/etc/nginx/nginx.conf \--error-log-path=/var/log/nginx/error.log \--http-log-path=/var/log/nginx/access.log \--pid-path=/var/run/nginx.pid \--lock-path=/var/run/nginx.lock \--http-client-body-temp-path=/var/tmp/nginx/client \--http-proxy-temp-path=/var/tmp/nginx/proxy \--http-fastcgi-temp-path=/var/tmp/nginx/fcgi \--http-uwsgi-temp-path=/var/tmp/nginx/uwsgi \--http-scgi-temp-path=/var/tmp/nginx/scgi \--user=nginx --group=nginx \--with-pcre --with-http_v2_module \--with-http_ssl_module \--with-http_realip_module \--with-http_addition_module \--with-http_sub_module \--with-http_dav_module \--with-http_flv_module \--with-http_mp4_module \--with-http_gunzip_module \--with-http_gzip_static_module \--with-http_random_index_module \--with-http_secure_link_module \--with-http_stub_status_module \--with-http_auth_request_module \--with-mail --with-mail_ssl_module \--with-file-aio \--with-ipv6 \--with-http_v2_module \--with-threads \--with-stream \--with-stream_ssl_modulemake && make install mkdir -p /var/tmp/nginx/client
-
添加运行Nginx服务进程的用户。
useradd nginx chown -R nginx:nginx /etc/nginx/
-
添加nginx.service启动配置文件。
输入命令
vi /usr/lib/systemd/system/nginx.service
打开Nginx的启动配置文件,按下i
键,然后在配置文件中写下如下内容:[Unit]Description=nginx - high performance web serverDocumentation=https://nginx.org/en/docs/After=network-online.target remote-fs.target nss-lookup.targetWants=network-online.target [Service]Type=forkingPIDFile=/var/run/nginx.pidExecStartPre=/usr/sbin/nginx -t -c /etc/nginx/nginx.confExecStart=/usr/sbin/nginx -c /etc/nginx/nginx.confExecReload=/bin/kill -s HUP $MAINPIDExecStop=/bin/kill -s TERM $MAINPID [Install] WantedBy=multi-user.target
按下
Esc
键,然后输入:wq
并回车以保存并关闭Nginx启动配置文件。 -
启动Nginx服务并设置开机自动启动。
systemctl start nginx systemctl enable nginx
-
登录ECS管理控制台,单击左侧导航栏中的实例,在实例列表中找到正在部署环境的实例,从这个实例的IP地址项中复制它的公网IP,用浏览器访问这个IP地址可看到默认欢迎页面。
-
准备编译环境。
yum install ncurses-devel bison gnutls-devel –y yum install cmake -y
-
准备MySQL数据存放目录。
mkdir /mnt/datagroupadd -r mysqluseradd -r -g mysql -s /sbin/nologin mysqlid mysql
-
更改数据目录属主和属组。
chown -R mysql:mysql /mnt/data
-
下载稳定版源码包解压编译。
wget https://downloads.mysql.com/archives/get/file/mysql-5.6.24.tar.gztar xvf mysql-5.6.24.tar.gz -C /usr/local/srccd /usr/local/src/mysql-5.6.24cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ > -DMYSQL_DATADIR=/mnt/data \ > -DSYSCONFDIR=/etc \ > -DWITH_INNOBASE_STORAGE_ENGINE=1 \ > -DWITH_ARCHIVE_STORAGE_ENGINE=1 \ > -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ > -DWITH_READLINE=1 \ > -DWITH_SSL=system \ > -DWITH_ZLIB=system \ > -DWITH_LIBWRAP=0 \ > -DMYSQL_TCP_PORT=3306 \ > -DDEFAULT_CHARSET=utf8 \ > -DDEFAULT_COLLATION=utf8_general_ci \ > -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ > -DWITH_SYSTEMD=1 \ > -DINSTALL_SYSTEMD_UNITDIR=/usr/lib/systemd/system \ make && make install
-
修改安装目录的属组为mysql。
chown -R mysql:mysql /usr/local/mysql/
-
初始化数据库并复制配置文件。
cd /usr/local/mysql/usr/local/mysql/scripts/mysql_install_db --user=mysql --datadir=/mnt/data/mv /etc/my.cnf /etc/my.cnf.bak cp /usr/local/mysql/support-files/my-default.cnf /etc/my.cnf
-
修改配置文件中的安装路径及数据目录存放路径。
echo -e "basedir = /usr/local/mysql\ndatadir = /mnt/data\n" >> /etc/my.cnf
-
添加mysql.service启动配置文件。
输入命令
vi /usr/lib/systemd/system/mysql.service
打开MySQL的启动配置文件,按下i
键,然后在配置文件中写下如下内容:[Unit]Description=MySQL Community ServerAfter=network.targetAfter=syslog.target [Install]WantedBy=multi-user.targetAlias=mysql.service [Service]User=mysqlGroup=mysqlPermissionsStartOnly=trueExecStart=/usr/local/mysql/bin/mysqldTimeoutSec=600Restart=alwaysPrivateTmp=false
按下
Esc
键,然后输入:wq
并回车以保存并关闭MySQL启动配置文件。 -
设置PATH环境变量。
echo "export PATH=$PATH:/usr/local/mysql/bin" > /etc/profile.d/mysql.shsource /etc/profile.d/mysql.sh
-
设置开机启动MySQL。
systemctl enable mysql
-
启动MySQL服务。
systemctl start mysql mysql –h 127.0.0.1
Nginx作为web服务器,当它接收到请求后,不支持对外部程序的直接调用或者解析,必须通过FastCGI进行调用。如果是PHP请求,则交给PHP解释器处理,并把结果返回给客户端。PHP-FPM是支持解析PHP的一个FastCGI进程管理器。提供了更好管理PHP进程的方式,可以有效控制内存和进程、可以平滑重载PHP配置。
-
安装依赖包。
yum install libmcrypt libmcrypt-devel mhash mhash-devel libxml2 libxml2-devel bzip2 bzip2-devel
-
下载稳定版源码包解压编译。
wget http://cn2.php.net/get/php-5.6.38.tar.bz2/from/this/mirror cp mirror php-5.6.38.tar.bz2 tar xvf php-5.6.38.tar.bz2 -C /usr/local/src cd /usr/local/src/php-5.6.38 ./configure --prefix=/usr/local/php \ --with-config-file-scan-dir=/etc/php.d \--with-config-file-path=/etc \--with-mysql=/usr/local/mysql \--with-mysqli=/usr/local/mysql/bin/mysql_config \--enable-mbstring \--with-freetype-dir \--with-jpeg-dir \--with-png-dir \--with-zlib \--with-libxml-dir=/usr \--with-openssl \--enable-xml \--enable-sockets \--enable-fpm \--with-mcrypt \--with-bz2make && make install
-
添加PHP和PHP-FPM配置文件。
cp /usr/local/src/php-5.6.38/php.ini-production /etc/php.inicd /usr/local/php/etc/ cp php-fpm.conf.default php-fpm.confsed -i 's@;pid = run/php-fpm.pid@pid = /usr/local/php/var/run/php-fpm.pid@' php-fpm.conf
-
添加php-fpm.service启动配置文件。
输入命令
vi /usr/lib/systemd/system/php-fpm.service
打开PHP-FPM的启动配置文件,按下i
键,然后在配置文件中写下如下内容:[Unit]Description=The PHP FastCGI Process ManagerAfter=network.target[Service]Type=simplePIDFile=/usr/local/php/var/run/php-fpm.pid ExecStart=/usr/local/php/sbin/php-fpm --nodaemonize --fpm-config /usr/local/php/etc/php-fpm.confExecReload=/bin/kill -USR2 $MAINPIDPrivateTmp=true[Install]WantedBy=multi-user.target
按下
Esc
键,然后输入:wq
并回车以保存并关闭PHP-FPM启动配置文件。 -
启动PHP-FPM服务并设置开机自动启动。
systemctl start php-fpm systemctl enable php-fpm
-
启动服务。
service php-fpm start
-
添加Nginx对FastCGI的支持。
-
备份默认的Nginx配置文件。
cp /etc/nginx/nginx.conf /etc/nginx/nginx.confbakcp nginx.conf.default nginx.conf.default.bakcp /etc/nginx/nginx.conf.default /etc/nginx/nginx.conf
-
输入命令
vi /etc/nginx/nginx.conf
打开Nginx的配置文件,按下i
键,在所支持的主页面格式中添加PHP格式的主页,类似如下:location / { root /etc/nginx/html; index index.php index.html index.htm; }
-
取消以下内容前面的注释:
location ~ \.php$ { root html; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; include fastcgi_params; }
-
将
root html;
改成root /etc/nginx/html;
。 -
将
fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name;
改成fastcgi_param SCRIPT_FILENAME /etc/nginx/html/$fastcgi_script_name;
。 -
按下
Esc
键,然后输入:wq
并回车以保存并关闭Nginx配置文件。
-
-
输入命令
systemctl restart nginx
重新载入Nginx的配置文件。 -
输入命令
vi /etc/nginx/html/index.php
打开index.php文件,按下i
键,然后在文件中写入如下内容:<?php$conn=mysql_connect('127.0.0.1','root','');if ($conn){echo "LNMP platform connect to mysql is successful!"; }else{echo "LNMP platform connect to mysql is failed!"; } phpinfo();?>
-
按下
Esc
键,然后输入:wq
并回车以保存并关闭index.php文件。
登录 ECS管理控制台,单击左侧导航栏中的实例,在实例列表中复制正在部署环境的实例的公网IP地址。用浏览器访问这个公网IP地址,如您看见如下图所示页面,则表示LNMP平台构建完成。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
从零开始构建自己的爬虫代理IP数据库并定期检验IP有效性
ProxyIPPool 从零开始构建自己的代理IP池;根据代理IP网址抓取新的代理IP;对历史代理IP有效性验证 源码地址:https://github.com/TOMO-CAT/ProxyIPPool 为什么要使用代理IP 在爬虫的过程中,很多网站会采取反爬虫技术,其中最经常使用的就是限制一个IP的访问次数。当你本地的IP地址被该网站封禁后,可能就需要换一个代理来爬虫。其中有很多网站提供免费的代理IP(如www.xicidaili.com ),我们需要做的就是从代理网站抓取代理IP,测试代理IP的有效性后将合适的代理IP加入数据库表中作为我们爬虫的代理IP池。 开发思路 1、通过本地IP抓取第一批启动代理IP 我们从代理IP网站抓取代理IP的过程本身就是爬虫,如果短时间内请求次数过多会被网站禁止访问,因此我们需要利用本地IP去抓取第一批代理IP,然后使用代理IP去抓取新的代理IP。 2、对第一批启动的代理IP验证有效性后存入数据库 我们在数据库IP.db下建了两个表:proxy_ip_table(存储所有抓取的IP,用于查看抓取IP功能是否正常)和validation_ip_tabl...
- 下一篇
滑动宫格验证码都给碰上了?没事儿,看完此文分分钟拿下
本节我们将介绍新浪微博宫格验证码的识别。微博宫格验证码是一种新型交互式验证码,每个宫格之间会有一条指示连线,指示了应该的滑动轨迹。我们要按照滑动轨迹依次从起始宫格滑动到终止宫格,才可以完成验证,如下图所示。 鼠标滑动后的轨迹会以黄色的连线来标识,如下图所示。 访问新浪微博移动版登录页面,就可以看到如上验证码,链接为https://passport.weibo.cn/signin/login。不是每次登录都会出现验证码,当频繁登录或者账号存在安全风险的时候,验证码才会出现。 一、本节目标 我们的目标是用程序来识别并通过微博宫格验证码的验证。 二、准备工作 本次我们使用的Python库是Selenium,使用的浏览器为Chrome,请确保已经正确安装好Selenium库、Chrome浏览器,并配置好ChromeDriver。 三、识别思路 识别从探寻
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- SpringBoot2整合Thymeleaf,官方推荐html解决方案
- SpringBoot2整合Redis,开启缓存,提高访问速度
- CentOS8安装MyCat,轻松搞定数据库的读写分离、垂直分库、水平分库
- CentOS7安装Docker,走上虚拟化容器引擎之路
- CentOS7设置SWAP分区,小内存服务器的救世主
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- MySQL8.0.19开启GTID主从同步CentOS8
- Hadoop3单机部署,实现最简伪集群
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- CentOS7编译安装Cmake3.16.3,解决mysql等软件编译问题