LNMP架构——搭建Discuz论坛
一.LNMP架构
LNMP平台就是Linux,Nginx,MySQL,PHP的组合架构,需要Linux服务器,MySQL服务器,PHP解析环境
二.构成组件
Linux是一类Unix计算机操作系统的统称,是目前最流行的免费操作系统。
Nginx是一个高性能的HTTP和反向代理服务器。
Mysql是一个小型关系型数据库管理系统。
PHP是一种在服务器端执行的嵌入HTML文档的脚本语言。
三.LNMP优势
Nginx性能稳定、功能丰富、运维简单、处理静态文件速度快且消耗系统资源极少,小巧高效。
四.搭建过程
1、安装nginx
1.1、首先通过虚拟机。把所需的安装包通过SCP 发送到云平台上
1.2、进入/abc/abc/文件夹,查看,并安装nginx所用的安装包
yum -y install gcc gcc-c++ pcre-devel zlib-devel
1.3、解压nginx安装包
tar zxvf nginx-1.12.2.tar.gc -C /opt/
1.4、进入nginx安装包解压目录,创建用户,并编译安装环境
cd /opt/nginx-1.12.2/
useradd -M -s /usr/sbin/nologin nginx
./configure \
--prefix=/usr/local/nginx \
--user=nginx \
--group=nginx \
--with-http_stub_status_module
make && make install
1.5、创建命令文件
ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
1.6、开启nginx服务
nginx
1.7、为方便systemctl管理,配置文件
vi /etc/init.d/nginx
#!/bin/bash
#chkconfig: 35 99 20
#description:Nginx Http Server
PROG="/usr/local/nginx/sbin/nginx"
PIDF="/usr/local/nginx/logs/nginx.pid"
case "$1" in
start)
$PROG /启动调用
;;
stop)
kill -s QUIT $(cat $PIDF)
;;
restart)
$0 stop
$0 start
;;
reload)
kill -s HUP $(cat $PIDF)
;;
*)
echo "Usage: $0 {start|stop|restart|reload}" //输入错误的格式提醒
exit 1
esac
exit 0
vi /etc/nginx.conf
1.8、用浏览器,查看nginx搭建情况
2、安装MySQL
2.1、安装mysql必要软件包
yum -y install \
ncurses \
ncurses-devel \
bison \
cmake
2.2、进入目录,解压mysql安装包
cd /abc/abc
tar zxvf mysql-boost-5.7.20.tar.gz -C /opt/
2.3.创建MySQL用户,编译mysql配置文件
cd /opt/mysql-5.7.20/
useradd -s /sbin/nologin mysql ##设置不可登录
cmake配置
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
make && make install
2.4,配置mysql,调整配置文件
数据库目录进行权限调整
chown -R mysql:mysql /usr/local/mysql/
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
##支持模块
echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
##将MySQL写到本地环境配置中
echo 'export PATH' >> /etc/profile ##设置全局环境配置
重启配置文件
source /etc/profile
2.5、初始化数据库
cd /usr/local/mysql/
bin/mysqld \
> --initialize-insecure \ ##初始化
> --user=mysql \ ##用户
> --basedir=/usr/local/mysql \ ##安装目录
> --datadir=/usr/local/mysql/data ##数据库数据文件目录
2.6,将MySQL服务配置文件复制到/usr/lib/systemd/system/下便于使用systemctl管理
cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/
##便于systemctl管理
systemctl enable mysqld ##开机自启动
systemctl start mysqld.service ##开启数据库
netstat -ntap | grep 3306 ##查看MySQL端口号开启情况
tcp6 0 0 :::3306 :::* LISTEN 59464/mysqld
2.7,设置MySQL密码
mysqladmin -u root -p password
Enter password: ##空格
New password: ##新密码
Confirm new password: ##确认密码
3、编译安装PHP
3.1,安装环境依赖包
yum install -y \
> libjpeg \ ##jpeg图片格式和开发包
> libjpeg-devel \
> libpng libpng-devel \ ##png图片和开发包
> freetype freetype-devel \ ##字体库
> libxml2 \ ##xml文件库
> libxml2-devel \
> zlib zlib-devel \ ##压缩库
> curl curl-devel \ ##支持数据文件下载工具
> openssl openssl-devel ##安全访问连接
3.2,解压源码包到/opt
cd /mnt ##切换到挂载点
tar jxvf php-7.1.10.tar.bz2 -C /opt ##解压源码包到/opt
cd /opt
ls ##查看
mysql-5.7.20 nginx-1.12.2 php-7.1.10 rh
3.3,配置PHP
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 ##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压缩包
3.4,编译及安装
make ##编译
make install ##安装
3.5,配置核心配置文件(php.ini核心配置文件,php-fpm.conf进程服务配置文件,www.conf扩展配置文件 )
cp php.ini-development /usr/local/php/lib/php.ini ##复制到安装目录lib库中
vim /usr/local/php/lib/php.ini ##配置核心配置文件
mysqli.default_socket = /usr/local/mysql/mysql.sock ##默认连接文件
date.timezone = Asia/Shanghai ##时间
/usr/local/php/bin/php -m ##验证安装的模块
3.6,配置及优化FPM模块
cd /usr/local/php/etc/
cp php-fpm.conf.default php-fpm.conf ##优化复制默认进程服务配置文件
cd /usr/local/php/etc/php-fpm.d/
cp www.conf.default www.conf ##优化复制扩展配置文件
cd /usr/local/php/etc/
[]vim php-fpm.conf ##开启fpm.pid进程
pid = run/php-fpm.pid
/usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini
netstat -ntap | grep 9000 ##查看端口信息
tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 69104/php- fpm: mast
ln -s /usr/local/php/bin/* /usr/local/bin/ ##创建软连接便于系统识别
ps aux | grep -c "php-fpm"
3.7,让Nginx支持PHP功能
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;
}
vim /usr/local/nginx/html/index.php ##测试php网页
<?php
phpinfo();
?>
3.8、通过浏览器查看
3.9,进入数据库创建bbs数据库并设置管理员和密码
[] 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 'bbsusers'@'%' IDENTIFIED BY 'admin123';
##提权数据库用户bbsuser为管理员并设定密码
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> GRANT all ON bbs.* TO 'bbsusers'@'localhost' IDENTIFIED BY 'admin123';
Query OK, 0 rows affected, 1 warning (0.00 sec)
mysql> flush privileges; ##刷新数据库
Query OK, 0 rows affected (0.00 sec)
mysql> quit ##退出
vim /usr/local/nginx/html/index.php ##测试数据库连接状态
<?php
$link=mysqli_connect('192.168.13.130','bbsusers','admin123');
if($link) echo "<h1>Success!</h1>";
else echo "Fail!!";
?>
systemctl restart nginx.service ##重启服务
4、安装Discuz论坛压缩包
4.1,解压缩压缩包到/opt下,并将目录内容复制到bbs站点中
[root@localhost etc]# cd /mnt
[root@localhost mnt]# unzip Discuz_X3.4_SC_UTF8.zip -d /opt ##解压到/opt下
[root@localhost mnt]# cd /opt
[root@localhost opt]# ls
dir_SC_UTF8 mysql-5.7.20 nginx-1.12.2 php-7.1.10 rh 说明.htm
[root@localhost opt]# cd dir_SC_UTF8/ ##进入论坛目录
[root@localhost dir_SC_UTF8]# cp -r upload/ /usr/local/nginx/html/bbs/
##复制/opt目录里的内容到html站点的bbs目录中
4.2,进入站点并给程序用户提权
cd /usr/local/nginx/html/bbs/ ##进入bbs站点目录
chown -R root:nginx ./config/ ##为程序用户提权
chown -R root:nginx ./data/ ##修改属组
chown -R root:nginx ./uc_client/
chown -R root:nginx ./uc_server/
chmod -R 777 ./config/ ##修改全部权限
chmod -R 777 ./data/
chmod -R 777 ./uc_client/
chmod -R 777 ./uc_server/
4.3、访问47.97.222.64/bbs站点,安装Discuz论坛
4.4,设置运行环境为全新安装
4.5,安装数据库
数据服务器:192.168.13.130(此处输入创建数据库主机的IP)
数据库名:bbs
数据库用户名:bbsusers(用户名可在命令行修改)
数据库密码:admin123(密码可在命令行修改)
管理员账号:admin(该账号为默认)
密码:123123(密码可直接在网页设定)