千家信息网

使用LNMP架构建设Discuz实例

发表于:2024-12-13 作者:千家信息网编辑
千家信息网最后更新 2024年12月13日,使用LNMP架构建设Discuz实例LNMP代表的就是:Linux系统下Nginx+MySQL+PHP这种网站服务器架构。Linux 是一类Unix计算机操作系统的统称,是目前最流行的免费操作系统。代
千家信息网最后更新 2024年12月13日使用LNMP架构建设Discuz实例

使用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 /mntPassword for root@//192.168.10.171/rpm:  [root@localhost ~]# df -hwen件系统              容量  已用  可用 已用% 挂载点/dev/sda2              20G   13G  7.9G   61% /devtmpfs              7.8G     0  7.8G    0% /devtmpfs                 7.8G     0  7.8G    0% /dev/shmtmpfs                 7.8G  9.0M  7.8G    1% /runtmpfs                 7.8G     0  7.8G    0% /sys/fs/cgroup/dev/sda5              10G   53M   10G    1% /home/dev/sda1             6.0G  174M  5.9G    3% /boottmpfs                 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=nginxAfter=network.target[Service]Type=forkingPIDFile=/usr/local/nginx/logs/nginx.pidExecStart=/usr/local/nginx/sbin/nginxExecReload=/usr/bin/kill -s HUP $MAINPIDExecStop=/usr/bin/kill -s QUIT $MAINPIDPrivateTmp=true[Install]WantedBy=multi-user.targetwq保存退出[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/bashwenjian="/usr/local/nginx/sbin/nginx"pid="/usr/local/nginx/logs/nginx.pid"case $1 instart)    $wenjian ;;stop)    kill -s QUIT $(cat $pid) ;;restart)    $0 stop    $0 start;;reload)    kill -s HUP $(cat $pid) ;;*)    echo "Please,try again"    exit 1 ;;esacexit 0wq保存退出[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 = 3306default-character-set=utf8socket = /usr/local/mysql/mysql.sock[mysql]                           ##客户端     port = 3306default-character-set=utf8socket = /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 passwordEnter 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 -pEnter password:      ##进入数据库,密码为之前设定的abc23mysql> 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即可进行安装流程。

0