使用LNMP架构建设Discuz实例
LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构。

偏关网站制作公司哪家好,找创新互联建站!从网页设计、网站建设、微信开发、APP开发、响应式网站建设等网站项目制作,到程序开发,运营维护。创新互联建站成立于2013年到现在10年的时间,我们拥有了丰富的建站经验和运维经验,来保证我们的工作的顺利进行。专注于网站建设就选创新互联建站。
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即可进行安装流程。
当前名称:使用LNMP架构建设Discuz实例
网站网址:http://www.scyingshan.cn/article/jheccj.html

 建站
建站
 咨询
咨询 售后
售后
 建站咨询
建站咨询 
 