企业级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/

在这里插入图片描述

  • 6
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值