企业级LNMP架构部署及运用

tech2026-06-05  3

目录

一、LNMP架构部署及运用1.1 LNMP架构解读1.2 MySQL安装配置1.3 PHP解析环境的安装-11.4 PHP解析环境的安装-21.5 配置Nginx支持PHP环境1.6 LNMP下部署Discuz 二、部署LNMP

一、LNMP架构部署及运用

1.1 LNMP架构解读

■ LNMP平台就是Linux、Ngnix、MySQL、PHP的组合架构,需要Linux服务器、MySQL数据库、PHP解析环境 ■ 本案例在单台服务器上部署LNMP环境 ■ 案例架构

1.2 MySQL安装配置

■ 为了与Ngin x、PHP环境保持一致, 此处选择采用源代 码编译的方式安装MySQL组件

■ MySQL部署的方法

编译安装MySQL优化调整初始化数据库启动MySQL服务并设置root数据库账号的密码

1.3 PHP解析环境的安装-1

■ 配置网页动静分离, 解析PHP, 有两种方法可以选择

使用PHP的FPM模块将访问PHP页面的Web请求转交给Apache服务器去处理

■ 较新版本的PHP已经自带FPM模块, 对PHP解析实例进 行管理、优化解析效率

Fast CGl将Http Server和动态脚本语言分离开Nginx专门处理静态请求, 转发动态请求PHP-FPM专门解析PHP动态请求

■ 单服务器的LNMP架构通常使用FPM方式来解析PHP

1.4 PHP解析环境的安装-2

■ PHP编译安装步骤

编译安装PHP ◆ 编译选项时添加“–enable-fpm”以启用此模块安装后的调整 ◆ 主要是配置文件的建立与相应命令工具的路径优化安装ZendGuardLoader (提高PHP解析效率) , 并进行加载配置

1.5 配置Nginx支持PHP环境

■ 调用本机的php-fpm进程配置方法

建立FPM配置文件php-fpm.conf, 修改配置选项 ◆ PID文件、运行用户、服务进程数等启动php-fpm进程

■ 配置Nginx支持PHP解析

在Ng in x的配置文件的server{} 配置段中设置将PHP的网页请求转给FPM模块处理

■ PHP页面访问测试

1.6 LNMP下部署Discuz

■官方网站:http://www.discuz.net ■ 部署Discuz论坛系统

下载并解压discuz代码包将upload文件夹上传到网站的网页目录, 将修改权限为777创建所需要的数据库, 如bbs, 并授权给run bbs用户在浏览器中访问网站的bbs/install/目录,按提示操作便可完成安装

二、部署LNMP

一、安装nginx 1、安装环境依赖包 yum -y install gcc gcc-c++ make pcre-devel zlib-devel perl 编译器 编译器 make工具 支持正则表达式的工具 压缩工具 perl语言工具 2、创建运行用户、组 [root@localhost opt]# useradd -M -s /sbin/nologin nginx ###创建nginx用户,-M代表不创建家目录 3、编译安装 [root@localhost opt]# cd /opt ###到/opt目录下 [root@localhost nginx-1.12.2]# tar zxvf nginx-1.12.2.tar.gz ### 解压nginx包 [root@localhost opt]# cd nginx-1.12.2/ ./configure --prefix=/usr/local/nginx --user=nginx --group=nginx --with-http_stub_status_module --指定安装目录 --指定程序账户nginx --组账户nginx --访问统计模块 [root@localhost mysql-5.7.20]# make && make install ### 编译安装的时间比较长,耐心等待 步骤四:优化路径 [root@localhost nginx-1.15.9]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/ ###做软连接,让系统所能识别 [root@localhost nginx-1.15.9]# ll /usr/local/sbin/ total 0 lrwxrwxrwx. 1 root root 27 Sep 3 08:12 nginx -> /usr/local/nginx/sbin/nginx 步骤五:nginx的运行控制 [root@localhost nginx-1.15.9]# nginx -t ###检测配置文件语法是否正确 [root@localhost nginx-1.15.9]# nginx ###启动nginx [root@localhost nginx-1.15.9]# netstat -anpt |grep nginx ###没有的netstat命令就yum -y install net-tools tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 21904/nginx: master 步骤六:添加nginx系统服务 为了使Nginx服务的启动、停止、重载等操作更加方便,可以编写基于CentOS 7.6的 Nginx服务控制文件使用systemctl工具来进行管理,CentOS7.6系统的管理习惯 [root@localhost ]#vi /lib/systemd/system/nginx.service [Unit] Description=nginx After=network.target [Service] Type=forking PIDFile=/usr/local/nginx/logs/nginx.pid ExecStart=/usr/local/nginx/sbin/nginx ExecReload=/usr/bin/kill -s HUP $MAINPID ExecStop=/usr/bin/kill -s QUIT $MAINPID PrivateTmp=true [Install] WantedBy=multi-user.target ##########上面配置参数解释############## [Unit] Description=nginx ###指定开头的名字nginx After=network.target ###指定网络服务模式 [Service] Type=forking ###指定类型 forking PIDFile=/usr/local/nginx/logs/nginx.pid ###记载进程号 ExecStart=/usr/local/nginx/sbin/nginx ###开启脚本 ExecReload=/usr/bin/kill -s HUP $MAINPID ###重载$MAINPID ExecStop=/usr/bin/kill -s QUIT $MAINPID ###停止$MAINPID PrivateTmp=true ###开启缓存 [Install] WantedBy=multi-user.target ###多用户登录模式 [root@localhost nginx-1.12.2]# chmod 754 /lib/systemd/system/nginx.service #给调整配置文件设置权限 [root@localhost nginx-1.12.2]# systemctl enable nginx ###开机自启 systemctl stop nginx ###如果nginx服务处于开启状态,敲这条命令的时候可能出现错误,用pkill -9 nginx全部干掉,然后在启动服务 [root@localhost nginx-1.12.2]# pkill -9 nginx ###干掉nginx服务 [root@localhost nginx-1.12.2]# netstat -anpt |grep nginx ###在查看一下nginx是否全部关闭 [root@localhost nginx-1.12.2]# systemctl start nginx ###启动nginx服务 [root@localhost nginx-1.12.2]# netstat -anpt |grep nginx ###查看nginx是否正常启动了 tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 22658/nginx: master 测试:览器输入服务器ip地址 20.0.0.6查看nginx是否正常访问

二、安装mysql数据库 步骤一:安装mysql yum -y install \ ncurses \ ncurses-devel \ bison \ cmake ###########上面环境包的解释########## yum -y install \ ncurses \ ncurses-devel \ ###字符终端处理库 bison \ ###通用解析器生成器,解析c++ cmake ###是一个跨平台的编译(Build)工具,可以用简单的语句来描述所有平台的编译过程 步骤二:创建mysql程序账户 [root@localhost ~]# useradd -s /sbin/nologin mysql 步骤三:到opt 软件包所在目录下 [root@localhost mysql-5.7.20]# cd /opt/ ###进入opt目录 [root@localhost mysql-5.7.20]#tar zxf mysql-boost-5.7.20.tar.gz ###解压mysql包 步骤四:编译安装 [root@localhost mysql-5.7.20]# cd /opt/mysql-5.7.20/ ###进入到/opt/mysql-5.7.20/目录 cmake \ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ -DSYSCONFDIR=/etc \ -DSYSTEMD_PID_DIR=/usr/local/mysql \ -DDEFAULT_CHARSET=utf8 \ -DDEFAULT_COLLATION=utf8_general_ci \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_ARCHIVE_STORAGE_ENGINE=1 \ -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \ -DMYSQL_DATADIR=/usr/local/mysql/data \ -DWITH_BOOST=boost \ -DWITH_SYSTEMD=1 ####上面模块的解释####### cmake \ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ ###指定安装路径 -DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ ###是通讯文件,没有sock文件就没法连接数据库 -DSYSCONFDIR=/etc \ ###指定配置文件目录 -DSYSTEMD_PID_DIR=/usr/local/mysql \ ###PID号 -DDEFAULT_CHARSET=utf8 \ ###指定字符集默认 -DDEFAULT_COLLATION=utf8_general_ci \ ###指定字符集默认 -DWITH_INNOBASE_STORAGE_ENGINE=1 \ ###开启存储引擎功能 -DWITH_ARCHIVE_STORAGE_ENGINE=1 \ ###开启存储引擎功能 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ ###开启存储引擎功能 -DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \ ###开启存储引擎功能 -DMYSQL_DATADIR=/usr/local/mysql/data \ ###数据存放位置 -DWITH_BOOST=boost \ ###兼容c++库 -DWITH_SYSTEMD=1 ###ID号 [root@localhost mysql-5.7.20]# make -j4&& make install ###编译并安装,先make -j4 然后make install 也可以 -j4是你核心数,最大不要超过虚拟机的核心数 步骤五:数据库目录进行权限调整 [root@localhost mysql-5.7.20]# chown -R mysql:mysql /usr/local/mysql/ ###对数据库目录赋予权限 步骤六:建立调整配置文件 [root@localhost mysql-5.7.20]# vim /etc/my.cnf [client] port = 3306 ###端口3306 default-character-set=utf8 ###字符集utf-8 socket = /usr/local/mysql/mysql.sock ###通讯文件 [mysql] port = 3306 default-character-set=utf8 socket = /usr/local/mysql/mysql.sock [mysqld] user = mysql ###程序用户mysql basedir = /usr/local/mysql ###工作目录 datadir = /usr/local/mysql/data ###数据目录 port = 3306 ###开放端口 character_set_server=utf8 ###字符集utf-8 pid-file = /usr/local/mysql/mysqld.pid ###pid进程号 socket = /usr/local/mysql/mysql.sock ###通讯文件位置 server-id = 1 ###ID编号 sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES [root@localhost mysql-5.7.20]# chown mysql:mysql /etc/my.cnf ###授权配置文件 步骤七:设置环境变量 [root@localhost mysql-5.7.20]# vim /etc/profile PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' ###在最后添加这一句环境变量 [root@localhost mysql-5.7.20]# source /etc/profile ###刷新 步骤八:初始化数据库 [root@localhost mysql-5.7.20]# cd /usr/local/mysql/ bin/mysqld \ --initialize-insecure \ --user=mysql \ --basedir=/usr/local/mysql \ --datadir=/usr/local/mysql/data ####上面初始化配置解释#### # 初始化安全 #指定程序用户 #基本工作目录 #数据存放目录 步骤九:启动mysql数据库 cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/ ####把启动脚本放到system/ 里方便操作管理,可以使用systemctl命令启动mysql [root@localhost mysql]# systemctl enable mysqld ###开机自启mysql [root@localhost mysql]# systemctl start mysqld ###启动mysql [root@localhost mysql]# netstat -anpt | grep 3306 ###查看服务是否起来 tcp6 0 0 :::3306 :::* LISTEN 53975/mysqld 步骤十:设置mysql数据库密码 [root@localhost mysql]# mysqladmin -u root -p password ###刚开始没密码是空的直接回车,然后输入密码abc123,在此确认abc123,这是在root账户下运行的 [root@localhost mysql]# mysql -u root -p ##这个命令敲下,提示要输入密码,这个就是刚才设置的密码abc123 三、PHP、安装配置PHP解析环境 步骤一:安装PHP依赖环境包 yum -y install \ libjpeg \ libjpeg-devel \ libpng libpng-devel \ freetype freetype-devel \ libxml2 \ libxml2-devel \ zlib zlib-devel \ curl curl-devel \ openssl openssl-devel ###上面环境包解析### yum -y install \ libjpeg \ ###处理jpeg图片 libjpeg-devel \ ###处理jpeg图片 libpng libpng-devel \ ###处理png图片,截图一般都是png格式 freetype freetype-devel \ ###字体样式 libxml2 \ ###xml2格式 libxml2-devel \ ###支持xml2版本格式 zlib zlib-devel \ ###支持压缩 curl curl-devel \ ###定位远程资源 openssl openssl-devel ###安全套接字协议(增加传输层安全,对网络连接进行加密) 步骤二:到软件包所在目录opt解压 [root@localhost ~]# cd /opt ###进入opt目录 [root@localhost opt]# tar xjvf php-7.1.10.tar.bz2 ###解压php包,最小化安装没有解压工具,就安装bzip2工具在解压 yum -y install bzip2 步骤三: 编译安装 [root@localhost opt]# cd php-7.1.10 ./configure \ --prefix=/usr/local/php \ --with-mysql-sock=/usr/local/mysql/mysql.sock \ --with-mysqli \ --with-zlib \ --with-curl \ --with-gd \ --with-jpeg-dir \ --with-png-dir \ --with-freetype-dir \ --with-openssl \ --enable-fpm \ --enable-mbstring \ --enable-xml \ --enable-session \ --enable-ftp \ --enable-pdo \ --enable-tokenizer \ --enable-zip ####上面模块解释#### ./configure \ --prefix=/usr/local/php \ ###指定安装路径 --with-mysql-sock=/usr/local/mysql/mysql.sock \ --with-mysqli \ ###启用mysql客户端 --with-zlib \ ###支持压缩功能 --with-curl \ ###定位远程资源 --with-gd \ ###gd库,图形处理 --with-jpeg-dir \ ###jpeg图片处理 --with-png-dir \ ###png图片处理 --with-freetype-dir \ ###字体样式 --with-openssl \ ###安全套接字协议 --enable-fpm \ ###进程管理器(处理动态请求) --enable-mbstring \ ###字符段处理 --enable-xml \ ###xml格式 --enable-session \ ###会话控制 --enable-ftp \ ###ftp服务 --enable-pdo \ ###连接数据库的驱动(驱动就是连接物理设备和系统的桥梁) --enable-tokenizer \ ###令牌(身份验证) --enable-zip ###压缩 [root@localhost php-7.1.10]# make -j4 && make install ###编译安装 步骤四:优化过程 ### php有三个配置文件php.ini 核心配置文件 php-fpm.conf 进程服务配置文件 www.conf 扩展配置文件 [root@localhost ~]# cp php.ini-development /usr/local/php/lib/php.ini ###在我们解压软件包内的一个配置模块,复制到咱们指定的目录中 [root@localhost ~]# vi /usr/local/php/lib/php.ini ###编辑,指定mysql的接口,对接。找到指定位置添加下面两条代码 mysqli.default_socket = /usr/local/mysql/mysql.sock ###如果去mysql拿数据必须借助通讯文件,代码在1170行 date.timezone = Asia/Shanghai ###时区,亚洲,上海,在939行 [root@localhost ~]# /usr/local/php/bin/php -m ### 验证安装的模块,特别要注意pdo驱动模块,没有他就不能用 步骤五:配置及优化FRM模块 [root@localhost ~]# cd /usr/local/php/etc/ ###进入到/usr/local/php/etc/ 目录 [root@localhost etc]# cp php-fpm.conf.default php-fpm.conf ### 里面有个模板拷贝一个并改名为php-fpm.conf [root@localhost etc]# cd /usr/local/php/etc/php-fpm.d/ [root@localhost php-fpm.d]# cp www.conf.default www.conf [root@localhost etc]# cd /usr/local/php/etc/ [root@localhost etc]# vi php-fpm.conf pid = run/php-fpm.pid ###启用模块,去掉;在17行 #启动fpm模块 -c启动 [root@localhost php-fpm.d]# /usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini ###-c是配置文件 [root@localhost php-fpm.d]# netstat -anpt |grep 9000 ###9000是fpm的端口 #优化 [root@localhost php-fpm.d]# ln -s /usr/local/php/bin/* /usr/local/bin/ ###把php所有指令便于系统所能管理 #过滤进程 ps aux|grep -c 'php-fpm' ###过滤进程 , -c统计的意思 4 步骤六:让nginx支持PHP功能 vi /usr/local/nginx/conf/nginx.conf ###在nginx.conf配置文件查找或添加 location ~ \.php$ { ###~代表支持正则表达式 ,识别以php为结尾的文件 root html; ###html是站点目录的名称 fastcgi_pass 127.0.0.1:9000; ###监听端口9000 fastcgi_index index.php; ###识别首页的类型 index.php; fastcgi_param SCRIPT_FILENAME /usr/local/nginx/html$fastcgi_script_name; ###识别脚本 include fastcgi_params; ###自定义的变量 } ###保存之后最好检查下语法是否正确 [root@localhost php-fpm.d]# nginx -t 步骤七:做php测试网页文档 [root@localhost php-fpm.d]# vi /usr/local/nginx/html/index.php <?php phpinfo(); ?> 步骤八: 重启nginx服务验证 [root@localhost php-fpm.d]# systemctl restart nginx 测试:浏览器输入20.0.0.6/index.php 就能查看公告搭建的网站

步骤九:mysql数据库授权 ##登录mysql数据库,创建一个bbs数据库,并授权 [root@localhost ~]# mysql -u root -p ###会让你输入密码,咱们之前创建mysql的密码abc123 ##进入数据库之后 CREATE DATABASE bbs; ### 创建bbs数据库 GRANT all ON bbs.* TO 'bbsadm'@'%' IDENTIFIED BY 'admin123'; ### 允许ip地址 GRANT all ON bbs.* TO 'bbsadm'@'localhost' IDENTIFIED BY 'admin123'; ### 允许主机 flush privileges; ###刷新数据库 #######安装论坛######### [root@localhost ~]# cd /opt/ ###进到opt把论坛包上传进去 [root@localhost opt]# [root@localhost opt]# unzip Discuz_X3.4_SC_UTF8.zip ###把论坛包解压到当前目录,指定目录的话就在最后加 -d 路径 [root@localhost opt]# cd /opt/dir_SC_UTF8/ ###先进去/opt/dir_SC_UTF8目录下 [root@localhost dir_SC_UTF8]# cp -r upload/ /usr/local/nginx/html/bbs ###-r递归的方式复制upload/到/usr/local/nginx/html/bbs里 [root@localhost dir_SC_UTF8]# cd /usr/local/nginx/html/bbs/ [root@localhost bbs]# chown -R daemon ./config [root@localhost bbs]# chown -R daemon ./data/ [root@localhost bbs]# chown -R daemon ./uc_client/ [root@localhost bbs]# chown -R daemon ./uc_server/data/ [root@localhost bbs]# chmod -R 777 ./config/ [root@localhost bbs]# chmod -R 777 ./data/ [root@localhost bbs]# chmod -R 777 ./uc_client/ [root@localhost bbs]# chmod -R 777 ./uc_server/ 浏览器输入http://20.0.0.6/bbs/install/index.php就可以一步一步可视化操作了! 数据库服务器:localhost 数据库名字:bbs 数据库用户名:bbsadm 数据库密码:admin123 管理员账号:admin 管理员密码abc123 安装完后,论坛首页:http://20.0.0.6/bbs/index.php 后台登录网址:http://20.0.0.6/bbs/admin.php 进去后会显示FTP这条,可以优化一下,要把FTP提示给删掉!!! [root@localhost]# cd usr/local/nginx/html/bbs/ [root@localhost bbs]# mv install/install.lock [root@localhost bbs]# chmod 600 install.lock/

最新回复(0)