lnmp
l:linux操作系统
n:nginx前端页面
m:mysql数据库,账号密码,数据库等等都保存在这个数据库里面
p:php——nginx擅长处理的是静态页面,页面登录账户,需要请求到数据库,通过php把动态请
求转发到数据库。
如图所示:nginx和数据库mysql之间的访问以及结果的返回都需要中介php。
实现lnmp+discuz论坛
首先提前准备好mysql、php和discuz的安装包
第一步:安装配置数据库mysql
1、安装mysql的依赖环境
apt install -y libaio1 libncurses5
2、解压mysql安装包
tar -xf mysql-8.0.30-el7-x86_64.tar.gz
重命名成mysql并移至/usr/local/目录下
mv mysql-8.0.30-el7-x86_64.tar.gz mysql
mv mysql /usr/local/
3、创建mysql账户
useradd -s /sbin/nologin mysql
创建完之后记得要查看下是否成功
修改mysql这个目录的所有者和所在组
chown mysql.mysql -R /usr/local/mysql/
4、添加mysql主配置文件
vim /etc/my.cnf
[client] #客户端
port = 3306 #mysql监听端口
socket=/usr/local/mysql/mysql.sock #mysql套接字的文件
[mysqld] #服务端
user = mysql
basedir=/usr/local/mysql #安装目录
datadir=/usr/local/mysql/data #数据保存目录
port = 3306
character-set-server=utf8 #指定字符集
pid-file = /usr/local/mysql/mysqld.pid #mysql的pid文件
socket=/usr/local/mysql/mysql.sock #mysql的套接字文件
bind-address = 0.0.0.0 #表示任意地址都可以访问
skip-name-resolve #mysql服务器将不再尝试将主机名解析为IP地址
max_connections=2048 #最大连接数2048
default-storage-engine=INNODB #默认存储引擎为INNODB
max_allowed_packet=16M #允许的最大数据包16M
server-id = 1
sql_mode = STRICT_TRANS_TABLES,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,NO_ENGINE_SUBSTITUTION
修改配置文件所属者
chown mysql.mysql /etc/my.cnf
把配置文件整个添加到系统里以便系统能识别配置文件
5、初始化mysql
./mysqld \
--initialize-insecure \
--user=mysql \
--basedir=/usr/local/mysql \
--datadir=/usr/local/mysql/data
6、复制mysql.server文件并赋权
将/usr/local/mysql/support-files/下的mysql.serve,复制到/etc/init.d/,并改名成mysqld
给mysqld添加可执行权限并重启mysqld服务
chmod +x /etc/init.d/mysqld
systemctl daemon-reload
systemctl restart mysqld
这时候查看3306端口显示mysqld已启来
7、初始化mysql账户
先初始化mysql账户,初始化账户root,初始化密码123456
登录mysql账户
8、实现远程连接mysql
首先创建一个远程登录identified的mysql用户并赋权,‘@’表示任意的IP地址
create user 'root'@'%' identified by '123456';
grant all privileges on *.* root'@'%';
使用alter修改加密方式,root用户加密方式就是密码123456
最后别忘了结束语flush,刷新权限
这时候我们使用Navicat便可实现远程连接
第二步:安排安装配置php
1、安装php依赖环境
apt-get install -y libgd-dev libjpeg8-dev libpng-dev libfreetype6-dev libxml2-dev zlib1g-dev libcurl4-openssl-dev libssl-dev libonig-dev libsqlite3-dev
2、解压安装php
在安装包里面创建一个组nobody
安装php组件
./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-pdo-mysql \
--with-openssl \
--with-sqlite-devel \
--with-oniguruma-devel \
--enable-fpm \
--enable-mbstring \
--enable-xml \
--enable-session \
--enable-ftp \
--enable-pdo \
--enable-tokenizer \
--enable-zip
最后安装php
make -j 4 && make install
3、配置php主配置文件php.ini
先创建两个软连接,使系统能识别php相关命令
php三个配置文件
- php.ini:主配置文件
- php-fpm.conf:进程服务端的配置文件
- www.conf:扩展配置文件
三个配置文件都有,但是名字并不是这个,都需要我们改名配置。
首先我们将php源码包里面的主配置文件移动并修改名字到指定位置
修改php.ini配置文件,具体操作如下
- #定义时区
- #定义mysql套接字的文件
4、配置php进程服务端的配置文件php-fpm.conf
首先将指定目录下的php-fpm.conf.default文件复制成php-fpm.conf
接着vim配置php-fpm.conf,修改如下两行
5、配置php扩展配置文件www.conf
首先在指定目录下还是老样子改名,这个文件不需要配置
6、启动php
首先启动配置文件,操作命令如下
- php-fpm:是一个fastcgi的管理工具,nginx的动态请求实际上是由php-fpm来处理
- 9000:是php默认端口
接着把源码包的php-fpm.service复制到系统管理服务目录下,使系统可以直接控制php服务
最后重启php服务
注意要查看日志是否重启成功,防止假启动。
第三步:配置nginx
修改nginx主配置文件,添加一个location,并修改主location,配置和注释如下
配置完之后,重启nginx服务
第四步:安装配置discuz
1、首先给discuz创建一个数据库,给论坛使用,具体操作如下
CREATE DATABASE bbs;
CREATE USER 'bbsuser'@'%' IDENTIFIED BY 'admin123';
GRANT ALL PRIVILEGES ON bbs.* TO 'bbsuser'@'%';
FLUSH PRIVILEGES;
CREATE USER 'bbsuser'@'localhost' IDENTIFIED BY 'admin123';
GRANT ALL PRIVILEGES ON bbs.* TO 'bbsuser'@'localhost';
FLUSH PRIVILEGES;
2、接着我们测试nginx访问数据库是不是正常
我们新建一个目录/var/www/html/(nginx配置文件里面我们定义好的location),在它的里面创建一个脚本文件 index.php,添加如下,表示如果正常显示success,失败则是Fail。
这时候我们访问nginx的index.php这个location,显示成功
3、安装论坛
首先解压Discuz_X3.5_SC_UTF8.zip
unzip Discuz_X3.5_SC_UTF8.zip -D /opt/Dis
接着将Dis目录下的upload文件夹复制到指定目录/var/www/html/下,并改名成bbs
然后给bbs修改权限
最后我们进入bbs/config/目录下,将如下两个文件复制重命名
并给重新赋权
第五步:实现论坛
我们登录http://192.168.254.14/bbs/install/index.php
实现安装论坛
最后我们登录论坛http://192.168.254.14/bbs/index.php