使用LNMP架构建设Discuz实例

LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构。

Linux 是一类Unix计算机操作系统的统称,是目前最流行的免费操作系统。代表版本有:debian、centos、ubuntu、fedora、gentoo等。

Nginx 是一个高性能的HTTP和反向代理服务器,也是一个IMAP/POP3/SMTP代理服务器。

Mysql 是一个小型关系型数据库管理系统。

PHP 是一种在服务器端执行的嵌入HTML文档的脚本语言。

这四种软件均为免费开源软件,组合到一起,成为一个免费、高效、扩展性强的网站服务系统。

本次实验大体步骤为:

​ 安装nginx→安装mysql数据库→安装php工具→架设Discuz论坛

一、安装nginx服务

事先将本次实验需要的软件包进行远程挂载

[root@localhost ~]# mount.cifs //192.168.10.171/rpm /mnt
Password for root@//192.168.10.171/rpm:  
[root@localhost ~]# df -h
wen件系统              容量  已用  可用 已用% 挂载点
/dev/sda2              20G   13G  7.9G   61% /
devtmpfs              7.8G     0  7.8G    0% /dev
tmpfs                 7.8G     0  7.8G    0% /dev/shm
tmpfs                 7.8G  9.0M  7.8G    1% /run
tmpfs                 7.8G     0  7.8G    0% /sys/fs/cgroup
/dev/sda5              10G   53M   10G    1% /home
/dev/sda1             6.0G  174M  5.9G    3% /boot
tmpfs                 1.6G   24K  1.6G    1% /run/user/0
/dev/sr0              4.3G  4.3G     0  100% /run/media/root/CentOS 7 x86_64
//192.168.10.171/rpm  288G   74G  215G   26% /mnt       //实验所需

解压并安装环境包

[root@localhost ~]# cd /mnt
[root@localhost mnt]# tar zxf nginx-1.12.0.tar.gz -C /opt/       //解压软件包
[root@localhost mnt]# useradd -M -s /sbin/nologin nginx        //创建程序用户,不设家目录
[root@localhost mnt]# yum -y install \
gcc \
gcc-c++ \
pcre-devel \
zlib-devel \
expat-devel \
pcre

其中,

gcc、gcc-c++ :底层C语言支持包

pcre、pcre-devel :pcre语言的开发、编译器

zlib-devel :支持压缩

expat-devel :使新建的网站能够解析xml格式的文件

编译安装

完成后,移动进文件夹中

[root@localhost mnt]# cd /opt/nginx-1.12.0/
[root@localhost nginx-1.12.0]# ./configure \          //配置
--user=nginx \
--group=nginx \
--prefix=/usr/local/nginx \
--with-http_stub_status_module
[root@localhost nginx-1.12.0]# make && make install    //手工编译&安装
[root@localhost nginx-1.12.0]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
//方便计算机能够识别

其中,

--user=nginx :指定控制服务的用户

--group=nginx :指定控制服务的组

--prefix=/usr/local/nginx :指定安装路径

--with-http_stub_status_module:状态统计模块

建立配置文件,方便Systemctl & Service进行控制(二选一即可)

Systemctl

[root@localhost nginx-1.12.0]# vim /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
wq保存退出
[root@localhost nginx-1.12.0]# cd /lib/systemd/system/
[root@localhost system]# chmod 754 nginx.service     //给予控制权限

Service

[root@localhost nginx-1.12.0]# vim /etc/init.d/nginx
#输入以下内容:
#!/bin/bash
wenjian="/usr/local/nginx/sbin/nginx"
pid="/usr/local/nginx/logs/nginx.pid"
case $1 in
start)
    $wenjian ;;
stop)
    kill -s QUIT $(cat $pid) ;;
restart)
    $0 stop
    $0 start
;;
reload)
    kill -s HUP $(cat $pid) ;;
*)
    echo "Please,try again"
    exit 1 ;;
esac
exit 0
wq保存退出
[root@localhost nginx-1.12.0]# cd /etc/init.d/
[root@localhost init.d]# chmod 754 nginx     //给予控制权限

启动nginx服务,并验证

[root@localhost init.d]# systemctl stop firewalld.service     //关闭防火墙
[root@localhost init.d]# setenforce 0                       //关闭增强性安全功能
[root@localhost init.d]# systemctl start nginx.service      //开启nginx服务
[root@localhost init.d]# systemctl enable nginx.service     //设置nginx服务开机自启
[root@localhost init.d]# netstat -atnp | egrep "(80|nginx)"    //查看服务是否启动
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      1075/nginx: master  

二、安装MySQL数据库

解压并安装环境包

[root@localhost init.d]# cd /mnt
[root@localhost mnt]# yum -y install \
cmake \
ncurses \
ncurses-devel \
bison \
expect
[root@localhost mnt]# tar zxf /mnt/mysql-boost-5.7.20.tar.gz -C /opt
[root@localhost mnt]# useradd  -s /sbin/nologin mysql       //建立程序用户

其中,

cmake :编译器

ncurses、ncurses-devel :客户字符终端处理工具

bison :语法分析器

编译安装

[root@localhost mnt]# cd /opt/mysql-5.7.20
[root@localhost 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 
[root@localhost mysql-5.7.20]# make && make install     //编译&安装

其中,

-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 :存储引擎

-DMYSQL_DATADIR=/usr/local/mysql/data :数据库数据文件目录

-DWITH_BOOST=boost :底层运行库

-DWITH_SYSTEMD=1:主从参数

配置MySQL

[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
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysql]                           ##客户端     
port = 3306
default-character-set=utf8
socket = /usr/local/mysql/mysql.sock

[mysqld]                         ##服务器        
user = mysql                  ##用户
basedir = /usr/local/mysql      ##设置mysql的安装目录
datadir = /usr/local/mysql/data    ##设置mysql数据库的数据的存放目录
port = 3306                    ##设置3306端口
character_set_server=utf8            ##中文字符集
pid-file = /usr/local/mysql/mysqld.pid     ##pid文件路径
socket = /usr/local/mysql/mysql.sock     ##sock文件路径
server-id = 1                                           ##主从参数

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    ##给配置文件mysql属主属组
[root@localhost mysql-5.7.20]# echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
##将MySQL写到本地环境配置中
[root@localhost mysql-5.7.20]# echo 'export PATH' >> /etc/profile    ##设置全局环境配置
[root@localhost mysql-5.7.20]# source /etc/profile    ##重启配置文件

初始化数据库,为数据库设定初识密码

[root@localhost mysql-5.7.20]# cd /usr/local/mysql/
[root@localhost mysql]# bin/mysqld \
> --initialize-insecure \        ##初始化
> --user=mysql \                 ##用户
> --basedir=/usr/local/mysql \      ##安装目录
> --datadir=/usr/local/mysql/data   ##数据库数据文件目录
[root@localhost mysql]# cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/ 
##便于systemctl管理
[root@localhost mysql]# systemctl enable mysqld   ##开机自启动
[root@localhost mysql]# systemctl start mysqld.service     ##开启数据库
[root@localhost mysql]# netstat -ntap | grep 3306              ##查看MySQL端口号开启情况
tcp6  0  0 :::3306    :::*       LISTEN   59464/mysqld   
[root@localhost mysql]# mysqladmin -u root -p password
Enter password:               ##空格
New password:                ##新密码
Confirm new password:   ##确认密码

三、安装PHP工具

解压&安装环境包

[root@localhost mysql]# cd /mnt     ##切换到挂载点
[root@localhost mnt]# tar jxvf php-7.1.10.tar.bz2 -C /opt     ##解压源码包到/opt
[root@localhost mnt]# yum install -y \
> libjpeg \
> libjpeg-devel \
> libpng libpng-devel \
> freetype freetype-devel \
> libxml2 \
> libxml2-devel \
> zlib zlib-devel \
> curl curl-devel \
> openssl openssl-devel

其中,

libjpeg、ibjpeg-devel :支持jpeg图片格式和开发包

libpng、libpng-devel :支持png格式和对应放入开发包

freetype、freetype-devel :字体库

libxml2、libxml2-devel :xml文件库

zlib、zlib-devel :压缩库

curl、curl-devel :支持数据文件下载工具

openssl openssl-devel:安全访问连接

编译安装

[root@localhost mnt]# cd /opt/php-7.1.10/
[root@localhost php-7.1.10]# ./configure \
--prefix=/usr/local/php \
--with-mysql-sock=/usr/local/mysql/mysql.sock \
--with-zlib \
--with-mysqli \
--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
[root@localhost php-7.1.10]# make && make install      //编译&安装

其中,

--prefix=/usr/local/php :指定安装路径

--with-mysql-sock=/usr/local/mysql/mysql.sock :指定sock文件路径

--with-zlib :支持压缩

--with-mysqli :支持上传下载

--with-curl :客户端支持库

--with-gd :gd图像化界面

--with-jpeg-dir :支持jpeg

--with-png-dir :支持png

--with-freetype-dir :字体

--with-openssl :安全访问连接

--enable-fpm :开启fpm动态资源处理模块

--enable-mbstring :支持多字节的字符串

--enable-xml :支持xml文件

--enable-session :session支持会话

--enable-ftp :支持ftp服务

--enable-pdo :驱动连接管理

--enable-tokenizer :php自带函数库

--enable-zip:支持zip压缩格式

修改php核心配置文件

​ 共有三个:php.ini核心配置文件,php-fpm.conf进程服务配置文件,www.conf扩展配置文件

php.ini

[root@localhost php-7.1.10]# cp php.ini-development /usr/local/php/lib/php.ini   ##复制到安装目录lib库中
[root@localhost php-7.1.10]# vim /usr/local/php/lib/php.ini   ##配置核心配置文件

mysqli.default_socket = /usr/local/mysql/mysql.sock     ##默认连接文件
date.timezone = Asia/Shanghai                                      ##时间

php-fpm.conf、www.conf

[root@localhost php-7.1.10]# cd /usr/local/php/etc/
[root@localhost etc]# cp php-fpm.conf.default 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 php-fpm.d]# cd /usr/local/php/etc/  
[root@localhost etc]# vim php-fpm.conf      ##开启fpm.pid进程
pid = run/php-fpm.pid
[root@localhost etc]# /usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini
[root@localhost etc]# netstat -ntap | grep 9000     ##查看端口信息
tcp   0 0 127.0.0.1:9000   0.0.0.0:*    LISTEN   69104/php-fpm: mast 
[root@localhost etc]# ln -s /usr/local/php/bin/* /usr/local/bin/   ##创建软连接便于系统识别

让nginx支持PHP功能

[root@localhost etc]# vim /usr/local/nginx/conf/nginx.conf    ##配置nginx配置文件
将以下内容去除注释
    location ~ \.php$ {
        root           html;
        fastcgi_pass   127.0.0.1:9000;
        fastcgi_index  index.php;
        fastcgi_param  SCRIPT_FILENAME  /usr/local/nginx/html$fastcgi_script_name;   ##站点路径
        include        fastcgi_params;
    }
[root@localhost etc]# vim /usr/local/nginx/html/index.php               ##测试php网页
在网页中添加如下内容

建立bbs数据库

[root@localhost etc]# mysql -u root -p
Enter password:      ##进入数据库,密码为之前设定的abc23
mysql> CREATE DATABASE BBS;   ##创建bbs数据库
Query OK, 1 row affected (0.00 sec)

mysql> GRANT all ON bbs.* TO 'zhy'@'%' IDENTIFIED BY 'zhy94666';  
##提权数据库用户bbsuser为管理员并设定密码
Query OK, 0 rows affected, 1 warning (0.00 sec)       

mysql> GRANT all ON bbs.* TO 'zhy'@'localhost' IDENTIFIED BY 'zhy94666';
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> flush privileges;         ##刷新数据库
Query OK, 0 rows affected (0.00 sec)

mysql> quit       ##退出

[root@localhost etc]# systemctl restart nginx.service     ##重启服务

四、安装Discuz论坛

解压

[root@localhost etc]# cd  /mnt/
[root@localhost mnt]# unzip Discuz_X3.4_SC_UTF8.zip -d /tmp
[root@localhost mnt]# cd /tmp/dir_SC_UTF8/
[root@localhost dir_SC_UTF8]# cp -r upload/ /usr/local/nginx/html/bbs/

对文件进行提权

[root@localhost dir_SC_UTF8]# cd /usr/local/nginx/html/bbs/
[root@localhost bbs]# chown -R root:nginx ./config/
[root@localhost bbs]# chown -R root:nginx ./data/
[root@localhost bbs]# chown -R root:nginx ./uc_client/
[root@localhost bbs]# chown -R root:nginx ./uc_server/
[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/

访问

在浏览器中输入192.168.116.171/bbs/install/index.php即可进行安装流程。