LNMP网络架构部署及应用(含discuz论坛的搭建)(转载)

文章目录
前言
1.2:MySQL安装配置
1.3:PHP解析环境的安装
1.4:配置Ngnx支持PHP环境
1.5:常见的PHP开源产品介绍
二:LNMP应用部署(实操)
2.1:Nginx安装
2.1.1:编译安装步骤
2.1.2:使用systemctl控制
2.1.3:开启nginx,关闭防火墙
2.2:mysql编译安装
2.2.1:安装mysql环境依赖包
2.2.2:cmake配置和make和make install
2.2.3:设置/usr/local/mysql目录的权限
2.2.4:编辑配置文件
2.2.5:设置环境变量
2.2.6:初始化数据库
2.2.7:开启数据库,检查状态
2.2.8:设置mysql密码
2.2.9:尝试登录数据库
2.3:PHP编译安装
2.3.1:安装环境包
2.3.2:编译安装
2.3.3:配置PHP的三个配置文件
2.3.4:创建软链接
2.3.5:编辑,让nginx支持PHP功能
2.3.6:测试数据库工作是否正常
2.4:搭建Discuz论坛
2.4.1:按解压论坛安装包
2.4.2:设置论坛权限
2.4.3:访问论坛
前言
LNMP是指一组通常一起使用来运行动态网站或者服务器的自由软件名称首字母缩写。L指Linux,N指Nginx,M一般指MySQL,也可以指MariaDB,P一般指PHP,也可以指Perl或Python

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

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

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

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

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

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

1.2:MySQL安装配置
为了与 Nginx、PHP环境保持一致,此处选择采用源代码编译的方式安装 My SQL组件
MySQL部署的方法
编译安装 MySQL
优化调整初始化数据库
启动mysq服务并设置root数据库账号的密码
1.3:PHP解析环境的安装
配置网页动静分离,解析PHP,有两种方法可以选择

使用PHP的FPM模块

将访问PHP页面的Web请求转交给 Apache服务器去处理

较新版本的PHP已经自带FPM模块,用来对PHP解析实例进行管理、优化解析效率

FastCG将 Http Server和动态脚本语言分离开
Nginx专门处理静态请求,转发动态请求
PHP FPM专门解析PHP动态请求
单服务器的LNMP架构通常使用FPM的方式来解析PHP

PHP编译安装步骤

编译安装PHP
编译选项时添加"- enable-fpm”以启用此模块
安装后的调整,主要是配置文件的建立与相应命令工具的路径优化
安装 Zend Guardloader(提高PHP解析效率),并进行加载配置
CGI还有跨平台的功能
1.4:配置Ngnx支持PHP环境
调用本机的php-fpm进程配置方法

建立FPM配置文件php- fpm. conf,修改配置选项,如:PD文件运行用户、服务进程数等

启动php-pm进程

在Ngnx的配置文件中的 serve}配置段配置将PHP的网页请求转给FPM模块处理

在Ngnx的配置文件中的 Server{}配置段配置将PHP的网页请求转给FPM模块处理

[root@localhost~]# vim /usr/local/nginx/conf/nginx. conf Servert{
location ~.php${
root /var/www/kgc;
fastcgi_pass 127.0.0.1:9000;
fastcgi_index index.php;
include fastcgi.conf;

1.5:常见的PHP开源产品介绍
Discuz!

康盛创想(北京困技有限公司推出的一套通用的社区论坛软件系统,如001年6月面世以来,是全 球成熟度最高、覆盖率最大的论坛软件系统之一

PHPWind

PHPWind(简称:PW)是一个基于PHP和 MySQL的论坛程序,是国内最受欢迎的通用型论坛程序之一。 PHPWind的前身是onstar,发布于2004年, PHPWind由杭州德天信息技术有限公司开发,软件全面开源免费

二:LNMP应用部署(实操)
2.1:Nginx安装
2.1.1:编译安装步骤
1.挂载宿主机的共享文件夹,读取下载好的源码文件

2.解压跨平台组件包和源码包
将跨平台组件包移动到源码包目录下

3.安装编译器和其他工具

yum -y install gcc
gcc-c++
make
pcre-devel
expat-devel
perl
zlib-devel
pcre

4.configure配置

./configure
–prefix=/usr/local/nginx
–user=nginx
–group=nginx
–with-http_stub_status_module

5.make编译和make install

6,路径优化

ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin ‘//nginx命令执行路径优化’
useradd -M -s /sbin/nologin nginx

2.1.2:使用systemctl控制
vim /lib/systemd/system/nginx.service ‘//添加使用systemctl工具进行管理’
[Unit]
Description=nginx ‘//描述’
After=network.target ‘//描述服务类别’

[Service]
Type=forking ‘//后台运行形势’
PIDFile =/usr/local/nginx/logs/nginx.pid ‘//PID文件位置’
ExecStart=/usr/local/nginx/sbin/nginx ‘//启动服务’
ExecReload=/usr/bin/kill -S HUP $MAINPID ‘//根据PID重载配置’
ExecStop=/usr/bin/kill -S QUIT $MAINPID ‘//根据PID终止进程’
PrivateTmp=true

[Install]
WantedBy=multi-user.target

chmod 754 /lib/systemd/system/nginx.service

2.1.3:开启nginx,关闭防火墙
[root@localhost system]# chmod +754 nginx.service
[root@localhost system]# systemctl start nginx.service
[root@localhost system]# netstat -ntap |grep 80
tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 5396/nginx: master
tcp 0 0 192.168.197.192:56680 192.168.100.3:445 ESTABLISHED -
[root@localhost system]# systemctl stop firewalld.service
[root@localhost system]# setenforce 0

2.2:mysql编译安装
2.2.1:安装mysql环境依赖包
yum -y install
ncurses \ ‘//字符终端的包,方便终端操作’
ncurses-devel
bison \ ‘//函数库’
cmake ‘//没有configure,使用cmake’

创建用户
useradd -s /usr/sbin/nologin mysql

2.2.2:cmake配置和make和make install
解压mysql-boost-5.7.20.tar.gz到opt目录下 ‘//boost是5.7版本的特性’
进入mysql1-57.20目录

cmake
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ ‘//sock;通讯文件,连接数据库,通讯协议的载体’
-DSYSCONFDIR=/etc \ ‘//配置目录指向etc’
-DSYSTEMD_PID_DIR=/usr/local/mysql \ ‘//pid文件位置’
-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 \ ‘//指定boost位置’
-DWITH_SYSTEMD=1 ‘//守护进程’

make && make install

2.2.3:设置/usr/local/mysql目录的权限
chown -R mysql.mysql /usr/local/mysql
1
2.2.4:编辑配置文件
cd /etc
vim 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
datadir=/usr/local/mysql/data
port = 3306
character_set_server=utf8
pid-file = /usr/local/mysql/mysqld.pid
socket = /usr/local/mysql/mysql.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

2.2.5:设置环境变量
echo ‘PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH’ >> /etc/profile
echo ‘export PATH’ >> /etc/profile
source /etc/profile

2.2.6:初始化数据库
cd /usr/local/mysql/
执行
bin/mysqld
–initialize-insecure
–user=mysql
–basedir=/usr/local/mysql
–datadir=/usr/local/mysql/data

cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/

2.2.7:开启数据库,检查状态
systemctl enable mysqld
systemctl start mysqld
systemctl stop mysqld
systemctl status mysqld
netstat -ntap |grep mysqld ‘//应该查出来3306端口’

2.2.8:设置mysql密码
mysqladmin -u root -p password ‘//刚开始没密码是空的直接回车,然后输入密码abe123,再次确认密码’
1
2.2.9:尝试登录数据库
mysql -u root -p ‘//这个命令敲下,提示要输入密码,这个就是刚才设置的密码abc123’
1
2.3:PHP编译安装
2.3.1:安装环境包
yum -y install
libjpeg
libjpeg-devel
libpng libpng-devel
freetype freetype-devel
libxml2
libxml2-devel
zlib zlib-devel
curl curl-devel
openssl openssl-devel

2.3.2:编译安装
cd /opt
tar xjvf php-7.1.10.tar.bz2 ‘//将下载的软件包解压到/opt’
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
–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

make && make install

2.3.3:配置PHP的三个配置文件
‘//php有三个配置文件 php.ini核心配置文件 php-fpm.conf进程服务配置文件www.conf 扩展配置文件’

cp php.ini-development /usr/local/php/lib/php.ini
vi /usr/local/php/lib/php.ini
‘//找到以下两行的位置,修改这两行’
mysql.default_socket = /usr/local/mysql/mysql.sock
date.timezone = Asia/Shanghai ‘//找到后,前方的;注释要去掉’

/usr/local/php/bin/php -m/验证安装的模块

2.3.4:创建软链接
/usr/local/php/sbin/php-fpm -c /usr/local/php/lib/php.ini
[root@localhost etc]# netstat -natp |grep 9000
tcp 0 0 127.0.0.1:9000 0.0.0.0:* LISTEN 32236/php-fpm: mast
ln -s /usr/local/php/bin/* /usr/local/bin/

ps aux | grep -c "php-fpm”//结果
[root@localhost etc]# ln -s /usr/local/php/bin/* /usr/local/bin/
[root@localhost etc]# ps aux |grep -c “php-fpm”

2.3.5:编辑,让nginx支持PHP功能
vi /usr/local/nginx/conf/nginx.conf //找到下面字段
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;
}
'//用/usr/local/nginx/html替换原来的路径
vi /usr/local/nginx/html/index.php

<?php phpinfo(); ?>

systemctl restart nginx

在网页测试http://192.168.197.190/index.php

2.3.6:测试数据库工作是否正常
mysq1 -u root -p ##输入abc123密码

CREATE DATABASE bbs;
GRANT all ON bbs.* To ‘bbsuser’@’%’ IDENTIFIED BY ‘admin123’;
GRANT all ON bbs.* To ‘bbsuser’@‘localhost’ IDENTIFIED BY ‘admin123’;
flush privileges;

vi /usr/local/nginx/html/index.php ###原来的测试页内容更改如下

<?php $link=mysqli_connect('192.168.197.192','bbsuser','admin123'); if($link) echo"

Success!!

"; else echo "Fail!!"; ?>

systemctl restart nginx

在网页测试http://192.168.197.192/index.php

2.4:搭建Discuz论坛
2.4.1:按解压论坛安装包
cd/opt
unzip Discuz_X3.4_SC_UTF8.zip -d /tmp
cd /tmp/dir_SC_UTF8/

2.4.2:设置论坛权限
cp -r upload /usr/local/nginx/html/bbs
cd /usr/local/nginx/html/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 77 ./uc_client/
chmod -R 777 ./uc_server/

2.4.3:访问论坛
http://ip/bbs/install/index.php

数据库服务器:localhost #本地架设就用 localhost,如果不是在本机上就要填写IP地址和端口
数据库名字户名:bbsuser
管理员账号:admin
密码:admin123

http://IP/bbs/admin.php//管理后台
账户:admin
密码:admin123

访问论坛 http://192.168.32.21/bbs/index.php

原文链接:https://blog.csdn.net/weixin_47219818/article/details/108128070?utm_medium=distribute.pc_feed.none-task-blog-personrec_tag-6.nonecase&depth_1-utm_source=distribute.pc_feed.none-task-blog-personrec_tag-6.nonecase&request_id=5f44272c0388ae0b5643d562

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
搭建基于LNMP(Linux + Nginx + MySQL + PHP)基础架构的政务平台,你可以按照以下流程进行: 1. 选择合适的Linux发行版:选择一个稳定、安全且适合政务应用的Linux发行版,如Ubuntu、CentOS等。 2. 安装操作系统:根据选择的Linux发行版,按照官方文档或参考在线教程进行操作系统的安装。 3. 系统配置:完成操作系统的安装后,进行一些基本的系统配置,如网络设置、防火墙配置等。 4. 安装Nginx:安装Nginx作为Web服务器。可以通过包管理器(如apt、yum)进行安装,也可以从源码编译安装。 5. 安装MySQL:安装MySQL数据库服务器,用于存储和管理数据。同样可以通过包管理器进行安装。 6. 配置Nginx和MySQL:根据实际需求,对Nginx和MySQL进行配置。配置文件通常位于`/etc/nginx/`和`/etc/mysql/`目录下。 7. 安装PHP:安装PHP解释器和相关扩展。可以使用包管理器进行安装,也可以从源码编译安装。 8. 配置Nginx和PHP:将Nginx与PHP进行集成,配置Nginx以将请求转发给PHP解释器处理。配置文件通常位于`/etc/nginx/`目录下。 9. 部署应用程序:根据政务平台的具体要求,进行应用程序的部署。这可能涉及到安装和配置各种应用程序和框架,如Laravel、WordPress等。 10. 数据库配置:根据政务平台的数据库需求,进行数据库的安装和配置。需要创建数据库、用户,并进行权限设置。 11. 安全设置:确保系统和应用程序的安全性。这包括使用合适的防火墙规则、加密通信、限制访问权限等。 12. 监控和日志:设置系统监控和日志记录机制,以便及时发现和解决问题。 13. 测试和优化:完成搭建后,进行测试和优化,确保平台的稳定性和性能。 14. 上线运维:将平台部署到生产环境后,进行持续的运维工作,包括系统更新、备份、故障排除等。 请注意,上述流程仅提供了一个基本的指导,具体的搭建流程可能因政务平台的具体需求而有所不同。建议在搭建过程中参考相关文档和教程,并根据实际情况进行适当调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值