千家信息网

基于lnmp的Discuz论坛

发表于:2025-01-20 作者:千家信息网编辑
千家信息网最后更新 2025年01月20日,------------- LNMP + Discuz -------------系统环境: RHEL6 x32 selinux and iptables disabled主机角色: 172.25.4
千家信息网最后更新 2025年01月20日基于lnmp的Discuz论坛


------------- LNMP + Discuz -------------



系统环境: RHEL6 x32 selinux and iptables disabled

主机角色: 172.25.46.1 nginx+mysql+php+Discuz



  • Mysql安装


软件包依赖性:

yum install -y gcc gcc-c++make ncurses-devel bison openssl-devel zlib-devel cmake


解压:

tar zxf mysql-5.5.12.tar.gz

cd mysql-5.5.12

编译:

cmake-DCMAKE_INSTALL_PREFIX=/usr/local/lnmp/mysql\ #安装目录

-DMYSQL_DATADIR=/usr/local/lnmp/mysql/data\ #数据库存放目录

-DMYSQL_UNIX_ADDR=/usr/local/lnmp/mysql/data/mysql.sock\ #Unix socket文件路径

-DWITH_MYISAM_STORAGE_ENGINE=1\ #安装Myisam存储引擎

-DWITH_INNOBASE_STORAGE_ENGINE=1\ #安装Innodb存储引擎

-DDEFAULT_CHARSET=utf8\ #使用Utf8字符

-DDEFAULT_COLLATION=utf8_general_ci\ #校验字符

-DEXTRA_CHARSETS=all #安装所有扩展字符集


安装:

make && makeinstall

注意:这一步若有报错,清除旧的对象文件和缓存信息,重新编译(先make clean,再rm -f CmakeCache.txt,之后再开始编译)


进入到/root/,添加环境变量:

vi .bash_profile

PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin

使更改生效:

source .bash_profile


查看刚刚添加的环境变量:

which mysql

/usr/local/lnmp/mysql/bin/mysql


创建mysql用户:

groupadd -g 27 mysql

useradd -u 27 -g 27 -s/sbin/nologin -d /usr/local/lnmp/mysql/ -M mysql


初始化数据库:

cd /usr/local/lnmp/mysql/

scripts/mysql_install_db--user=mysql --basedir=/usr/local/lnmp/mysql

--datadir=/usr/local/lnmp/mysql/data

显示2个ok表示安装成功


更改权限:

chown root . -R

chgrp mysql . -R

chown mysql data/ -R


复制配置文件及启动脚本到指定位置:

cpsupport-files/my-medium.cnf /etc/my.cnf

cpsupport-files/mysql.server /etc/init.d/mysqld


启动mysql服务:

/etc/init.d/mysqld start

安装mysql:

mysql_secure_installation

Enter current password for root (enter for none):

Change the root password? [Y/n] n #若当前root有数据库的密码则输入,没有按回车

... skipping.

Remove anonymous users? [Y/n] y #移除匿名用户

... Success!

Disallow root login remotely? [Y/n] y #不允许root远程登录

... Success!

Remove test database and access to it? [Y/n] y #移除test数据库

Reload privilege tables now? [Y/n] y #重新加载数据库权限

... Success!


登录mysql验证:

mysql

Welcome to the MySQL monitor. Commands end with ; or \g.

..........

mysql> show databases;

+--------------------+

| Database |

+--------------------+

| information_schema |

| mysql |

| performance_schema |

| test |

+--------------------+

5 rows in set (0.04 sec)


  • Nginx安装


安装开发包:

yum install -y pcre-devel openssl-devel


解压源码包并编辑文件隐藏nginx版本:

tar zxvf nginx-1.8.0.tar.gz

cd nginx-1.8.0

vim auto/cc/gcc

#CFLAGS="$CFLAGS -g" #注释掉这行,去掉debug模式编译,编译以后程序只有几百k

vim src/core/nginx.h

#define NGINX_VERSION "1.8.0"

#defineNGINX_VER "nginx" #修改此行,去掉后面的"NGINX_VERSION",为了安全,这样编译后外界无法获取nginx的版本号


编译并安装:

./configure --prefix=/usr/local/lnmp/nginx --with-http_ssl_module --with-http_stub_status_module

make && makeinstall


链接方便调用和修改:

cd/usr/local/lnmp/nginx/sbin

ln -s/usr/local/lnmp/nginx/sbin/nginx /usr/local/sbin

检测语法,开启nginx服务,加载配置文件:

nginx -t

nginx

nginx -s reload

查看80端口是否打开并检测(此时要确保httpd服务是关闭的)

netstat -antlp

tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 7060/nginx


curl -I localhost

HTTP/1.1 200 OK

Server: nginx/1.8.0

Date: Wed, 13 Jan 2016 08:42:21 GMT

Content-Type: text/html

Content-Length: 612

Last-Modified: Wed, 13 Jan 2016 08:31:20 GMT

Connection: keep-alive

ETag: "56960b58-264"

Accept-Ranges: bytes


此时可以使用浏览器访问,我在实验中访问的是:172.25.46.1,显示页面如下:


更改用户及进程数:

cd /usr/local/lnmp/nginx/conf/

vi nginx.conf

#user nginx; #更改用户为nginx

worker_processes 2; #进程数改为2


重载文件并查看端口:

nginx -s reload

netstat -antlp

tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 7060/nginx


开启了2个进程:

ps -ax

7104 ? S 0:00 nginx: worker process

7105 ? S 0:00 nginx: worker process


生成key:

cd /etc/pki/tls/certs/

make nginx.pem

Country Name (2 letter code) [XX]:CN #国家,大写

State or Province Name (full name) []:Shanxi #省

Locality Name (eg, city) [Default City]:xi'an #市

Organization Name (eg, company) [Default CompanyLtd]:westos #组织名

Organizational Unit Name (eg, section) []:Linux #组织单元

Common Name (eg, your name or your server's hostname)[]:server1.example.com #主机名

Email Address []:742019722@qq.com #邮箱

将key加入配置文件:

mv nginx.pem/usr/local/lnmp/nginx/conf/

cd/usr/local/lnmp/nginx/conf/

vim nginx.conf

http{

.......

# HTTPS server

#

server {

listen 443 ssl;

server_name localhost;

ssl_certificate nginx.pem; #更改此处

ssl_certificate_key nginx.pem; #更改此处

ssl_session_cache shared:SSL:1m;

ssl_session_timeout 5m;

ssl_ciphers HIGH:!aNULL:!MD5;

ssl_prefer_server_ciphers on;

location/ {

root html;

index index.html index.htm;

}

}

}


重载文件查看端口:

nginx -s reload

netstat -antlp

tcp 0 0 0.0.0.0:443 0.0.0.0:* LISTEN 7060/nginx

此时可使用浏览器访问,实验中我访问的是:https://172.25.46.1,显示页面如下

选择I Understand the Risks,进入如下页面:


  • Php安装


安装软件包依赖:

yum install -y pcre-devel openssl-devel libxml2-devel curl-devel libjpeg-turbo-devel.x86_64 libpng-devel gpm.h mcrypt.hnet-snmp-devel freetype-devel gmp-devel-* libjpeg-*


解压源码包并编译安装:

tar jxf php-5.4.36.tar.bz2

cd php-5.4.36

./configure --prefix=/usr/local/lnmp/php--with-config-file-path=/usr/local/lnmp/php/etc--with-mysql=/usr/local/lnmp/mysql/--with-mysqli=/usr/local/lnmp/mysql/bin/mysql_config --with-openssl --with-snmp --with-gd--with-zlib --with-curl --with-libxml-dir --with-png-dir --with-jpeg-dir --with-freetype-dir --without-pear--with-gettext --with-gmp --enable-inline-optimization --enable-soap--enable-ftp --enable-sockets --enable-mbstring --enable-fpm -- --with-fpm-user=nginx--with-fpm-group=nginx --with-mhash

make && make install

复制配置文件及启动脚本到指定位置:

cpphp.ini-production /usr/local/lnmp/php/etc/php.ini

cd sapi/fpm

cp init.d.php-fpm /etc/init.d/fpm

chmod +x /etc/init.d/fpm


编辑php-fpm.conf文件打开php运行pid

cd /usr/local/lnmp/php/etc/

cp php-fpm.conf.default php-fpm.conf

vim php-fpm.conf

...........

[global]

; Pid file

; Note: the default prefix is/usr/local/lnmp/php/var

; Default Value: none

pid = run/php-fpm.pid #打开php运行pid

..........


更改时区为亚洲上海:

vim php.ini

..........

[Date]

; Defines the default timezone used by thedate functions

; http://php.net/date.timezone

;date.timezone=Asia/Shanghai


此时开启php服务时可能会有报错:

/etc/init.d/fpm start

Starting php-fpm [14-Jan-2016 15:52:53]ERROR: [pool www] cannot get uid for user 'nginx'

[14-Jan-2016 15:52:53] ERROR: FPMinitialization failed


删除id为48的用户和组(因为apache默认id也为48,这样会有冲突),新建nginx用户:

groupadd -g 48 nginx

useradd -u 48-g 48 -s /sbin/nologin -d /usr/local/lnmp/nginx/ -M nginx

id nginx

uid=48(nginx) gid=48(nginx) groups=48(nginx)

再次开启php服务便可以成功:

/etc/init.d/fpm start

Starting php-fpm done

/etc/init.d/fpmreload

Reload service php-fpm done


编写php测试页:

cd /usr/local/lnmp/nginx/html

vim index.php

phpinfo()

?>


检测语法并重载:

nginx -t

nginx -s reload


添加cgi支持php:

vim /usr/local/lnmp/nginx/conf/nginx.conf #行号大致如下,不一定与你的完全一样

48 location / {

49 root html;

50 index index.php index.htmlindex.htm; #添加index.php为首页

51 }

..........

70 location ~ \.php$ {

71 root html;

72 fastcgi_pass 127.0.0.1:9000;

73 fastcgi_index index.php;

74 #fastcgi_param SCRIPT_FILENAME /scripts$fastcgi_script_name; #注释此行

75 include fastcgi.conf; #更改文件后缀为.conf

76 }


检测语法查看端口:

nginx -t

nginx -s reload

netstat -antlp

tcp 0 0 0.0.0.0:443 0.0.0.0:* LISTEN 1354/nginx

tcp 0 0 0.0.0.0:80 0.0.0.0:* LISTEN 1354/nginx


此时可使用浏览器访问,我在实验中访问的是:172.25.46.1,页面显示如下:



  • 基于lnmp的Discuz论坛


将压缩包解压至nginx的发布目录下:

yum install -y unzip

unzip Discuz_X2.5_SC_UTF8.zip -d /usr/local/lnmp/nginx/html/


重命名upload目录为bbs,便于访问:

mv /usr/local/lnmp/nginx/html/upload /usr/local/lnmp/nginx/html/bbs

此时可使用浏览器访问,实验中我访问的是:172.25.46.1/bbs,显示页面如下:

选择我同意进入下一步,设置运行环境:

看到目录文件的当前状态显示为不可写,需更改目录及文件权限:

cd /usr/local/lnmp/nginx/html/bbs

chmod 777 config/ -R

chmod 777 data/ -R

chmod 777 data/ uc_server/ -R

chmod 777 data/ uc_client/ -R


此时更新一次显示为可写,可进入下一步,创建数据库:

在填写信息之前要设置root用户密码及创建数据库discuz


mysql_secure_installation

Enter current password for root (enter fornone): #回车,因为刚开始我没有设置root密码

OK, successfully used password, movingon...

Set root password? [Y/n] y

New password: #输入密码

Re-enter new password: #确认密码

Password updated successfully!

Remove anonymous users? [Y/n] y

...Success!

Disallow root login remotely? [Y/n] y

...Success!

Remove test database and access to it?[Y/n] y

-Dropping test database...

Reload privilege tables now? [Y/n] y

...Success!


mysql -p+密码

mysql> create database discuz;

Query OK, 1 row affected (0.00 sec)

mysql> show databases;

+--------------------+

| Database |

+--------------------+

| information_schema |

| discuz |

| mysql |

| performance_schema |

| test |

+--------------------+

5 rows in set (0.00 sec)


设置好以上信息之后可进行创建数据库,页面如下:


填写完信息后进入下一步,显示论坛界面如下:

至此完成了基于lnmp的Discuz论坛的搭建!


0