利用lnmp架構搭建論壇Discuz

實驗環境:rhel6.5
實驗主機:server1 172.25.70.1
一、mysql源碼安裝
1.安裝編譯mysql的cmake工具
所需軟件包:cmake-2.8.12.2-4.el6.x86_64.rpm

[root@server1 ~]# yum install cmake-2.8.12.2-4.el6.x86_64.rpm -y

2.安裝mysql源碼包
所需軟件包:mysql-boost-5.7.11.tar.gz

[root@server1 ~]# tar -zxf mysql-boost-5.7.11.tar.gz 

檢查編譯環境

[root@server1 ~]# cd mysql-5.7.11/
[root@server1 mysql-5.7.11]# 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 -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DEXTRA_CHARSETS=all -DWITH_BOOST=/root/mysql-5.7.11/boost/boost_1_59_0/

出現下面報錯,需要刪除CMakeCache.txt緩存
這裏寫圖片描述
執行

[root@server1 mysql-5.7.11]# rm -rf remove CMakeCache.txt

在檢查過程中,需要安裝下面依賴包


[root@server1 mysql-5.7.11]# yum install -y gcc gcc-c++ make ncurses-devel bison openssl-devel zlib-devel

再次檢查,直至通過,如下圖
這裏寫圖片描述
編譯和安裝

[root@server1 mysql-5.7.11]# make && make install

3.mysql的配置

[root@server1 ~]# vim /etc/my.cnf #更改mysql的data路徑和sock路徑
datadir=/usr/local/lnmp/mysql/data
socket=/usr/local/lnmp/mysql/data/mysql.sock
[root@server1 ~]# vim ~/.bash_profile  #指定位置到全局變量中
PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin  
[root@server1 ~]# source ~/.bash_profile #重新生效

創建mysql用戶

[root@server1 ~]# groupadd -g 27 mysql
[root@server1 ~]# useradd -u 27 -g 27 -s /sbin/nologin -M -d /usr/local/lnmp/mysql/ mysql
[root@server1 ~]# id mysql
uid=27(mysql) gid=27(mysql) groups=27(mysql)

初始化之前更改/usr/local/lnmp/mysql/下所有文件的所屬用戶和所屬組爲mysql

[root@server1 mysql]# cd /usr/local/lnmp/mysql/
[root@server1 mysql]# chown mysql:mysql . -R
[root@server1 mysql]# ll   #更改至如下
total 56
drwxr-xr-x  2 mysql mysql  4096 Feb 23 16:20 bin
-rw-r--r--  1 mysql mysql 17987 Feb  2  2016 COPYING
drwxr-xr-x  2 mysql mysql  4096 Feb 23 16:19 docs
drwxr-xr-x  3 mysql mysql  4096 Feb 23 16:19 include
drwxr-xr-x  4 mysql mysql  4096 Feb 23 16:20 lib
drwxr-xr-x  4 mysql mysql  4096 Feb 23 16:19 man
drwxr-xr-x 10 mysql mysql  4096 Feb 23 16:21 mysql-test
-rw-r--r--  1 mysql mysql  2478 Feb  2  2016 README
drwxr-xr-x 28 mysql mysql  4096 Feb 23 16:21 share
drwxr-xr-x  2 mysql mysql  4096 Feb 23 16:21 support-files 

將啓動腳本移到特定位置

[root@server1 mysql]# cd support-files/
[root@server1 support-files]# ls
magic  my-default.cnf  mysqld_multi.server  mysql-log-rotate  mysql.server
[root@server1 support-files]# cp mysql.server /etc/init.d/mysqld
[root@server1 support-files]# chmod +x /etc/init.d/mysqld 

mysql的初始化

[root@server1 support-files]# mysqld --initialize --user=mysql

這裏寫圖片描述
初始化密碼待用
更改/usr/local/lnmp/mysql下的文件的所屬用戶爲root(除了data目錄下的所有文件)

[root@server1 mysql]# chown root . -R
[root@server1 mysql]# chown mysql data/ -R
[root@server1 mysql]# ll   #更改至如下
total 60
drwxr-xr-x  2 root  mysql  4096 Feb 23 16:20 bin
-rw-r--r--  1 root  mysql 17987 Feb  2  2016 COPYING
drwxr-x---  5 mysql mysql  4096 Feb 23 17:01 data
drwxr-xr-x  2 root  mysql  4096 Feb 23 16:19 docs
drwxr-xr-x  3 root  mysql  4096 Feb 23 16:19 include
drwxr-xr-x  4 root  mysql  4096 Feb 23 16:20 lib
drwxr-xr-x  4 root  mysql  4096 Feb 23 16:19 man
drwxr-xr-x 10 root  mysql  4096 Feb 23 16:21 mysql-test
-rw-r--r--  1 root  mysql  2478 Feb  2  2016 README
drwxr-xr-x 28 root  mysql  4096 Feb 23 16:21 share
drwxr-xr-x  2 root  mysql  4096 Feb 23 16:21 support-files

啓動服務

[root@server1 mysql]# /etc/init.d/mysqld start
Starting MySQL. SUCCESS! 

由於初始化密碼不好記,我們可以更改密碼(需要用到前面保存的初始化密碼)

[root@server1 mysql]# mysql_secure_installation

成功進入mysql
這裏寫圖片描述

二、php源碼安裝
所需軟件包:libmcrypt-2.5.8-9.el6.x86_64.rpm libmcrypt-devel-2.5.8-9.el6.x86_64.rpm gd-devel-2.0.35-11.el6.x86_64.rpm php-5.6.20.tar.bz2
1.安裝編譯環境所需要的依賴包

yum install curl-devel openssl-devel libxml2-devel libmcrypt-2.5.8-9.el6.x86_64.rpm libmcrypt-devel-2.5.8-9.el6.x86_64.rpm gd-devel-2.0.35-11.el6.x86_64.rpm gmp-devel bison  net-snmp-devel -y

2.對php包進行解包,在檢查通過後,源碼安裝
解包

tar jxf  php-5.6.20.tar.bz2

檢查編譯環境

[root@server1 php-5.6.20]# ./configure --prefix=/usr/local/lnmp/php --with-config-file-path=/usr/local/lnmp/php/etc --enable-mysqlnd --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --with-openssl --with-snmp --with-gd --with-zlib --with-curl --with-libxml-dir --with-png-dir --with-jpeg-dir --with-freetype-dir --with-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-mcrypt --with-mhash

這裏寫圖片描述
檢查環境通過!!!
創建nginx用戶

[root@server1 local]# useradd -u 800 -M -d /usr/local/lnmp/php -s /sbin/nologin  nginx  #-M表示不要自動建立用戶的登入目錄 -d用來指定nginx用戶的主目錄 -s用來指定nginx的用戶登錄shell
[root@server1 local]# id nginx
uid=800(nginx) gid=800(nginx) groups=800(nginx)

編譯和安裝

[root@server1 php-5.6.20]# make && make install

3.對php配置文件的修改
將配置文件放在指定位置

[root@server1 php-5.6.20]# cd /usr/local/lnmp/php/etc/
[root@server1 etc]# ls
pear.conf  php-fpm.conf.default
[root@server1 etc]# cp php-fpm.conf.default php-fpm.conf
[root@server1 etc]# cd /root/php-5.6.20
[root@server1 php-5.6.20]# cp php.ini-production /usr/local/lnmp/php/etc/php.ini
[root@server1 php-5.6.20]# cd /usr/local/lnmp/php/etc/
[root@server1 etc]# ls
pear.conf  php-fpm.conf  php-fpm.conf.default  php.ini
[root@server1 etc]# vim php.ini  #更改時區

這裏寫圖片描述

[root@server1 etc]# vim php-fpm.conf

這裏寫圖片描述
加服務的啓動腳本放到/etc/init.d/下,並加上x權限

[root@server1 ~]# cd php-5.6.20/sapi/fpm/
[root@server1 fpm]# cp init.d.php-fpm /etc/init.d/php-fpm
[root@server1 fpm]# chmod +x /etc/init.d/php-fpm 

將php的路徑添加到環境變量中

[root@server1 fpm]# vim ~/.bash_profile
PATH=$PATH:$HOME/bin:/usr/local/lnmp/mysql/bin:/usr/local/lnmp/php/bin
[root@server1 ~]# source ~/.bash_profile #重新生效

啓動服務

[root@server1 bin]# /etc/init.d/php-fpm  start
Starting php-fpm  done
[root@server1 bin]# netstat -antlpe | grep 9000  #查看改服務的端口
tcp        0      0 127.0.0.1:9000              0.0.0.0:*                   LISTEN      0          111018     20722/php-fpm  

三、nginx源碼安裝和配置
1.安裝
所需軟件包:nginx-1.10.1.tar.gz

[root@server1 ~]# tar -zxf nginx-1.10.1.tar.gz
[root@server1 ~]# cd nginx-1.10.1
[root@server1 nginx-1.10.1]# vim src/core/nginx.h  #去掉版本號

這裏寫圖片描述

[root@server1 nginx-1.10.1]# vim auto/cc/gcc #關閉gcc編譯

這裏寫圖片描述
在編譯檢查過程中檢查到需要依賴包pcre-devel openssl-devel zlib-devel

yum install pcre-devel openssl-devel zlib-devel -y

編譯環境的檢查

[root@server1 nginx-1.10.1]# ./configure --prefix=/usr/local/lnmp/nginx/ --with-http_stub_status_module --with-http_ssl_module  --user=nginx --group=nginx

檢查通過
這裏寫圖片描述
編譯和安裝

[root@server1 nginx-1.10.1]# make && make install

安裝成功後,組啓動服務的軟鏈接

[root@server1 ~]# ln -s /usr/local/lnmp/nginx/sbin/nginx /usr/local/sbin/
[root@server1 ~]# nginx #啓動服務

2.配置nginx服務

[root@server1 ~]# vim /usr/local/lnmp/nginx/conf/nginx.conf

配置默認發佈文件爲index.php
這裏寫圖片描述
修改include爲 fastcgi.conf
這裏寫圖片描述

[root@server1 ~]# vim /usr/local/lnmp/nginx/html/index.php #編輯index.php頁面
<?php
phpinfo()
?>
[root@server1 ~]# vim /usr/local/lnmp/php/etc/php.ini  #添加mysql.sock文件位置

這裏寫圖片描述
這裏寫圖片描述
這裏寫圖片描述
重啓nginx服務

[root@server1 ~]# nginx -s reload

在客戶機上測試index.php頁面,顯示正常
這裏寫圖片描述
四、論壇Discuz的搭建
所需材料:Discuz_X3.2_SC_UTF8.zip
1.解Discuz論壇包

[root@server1 ~]# unzip Discuz_X3.2_SC_UTF8.zip 

將upload移到nginx的html發佈目錄裏

[root@server1 ~]# mv upload/ /usr/local/lnmp/nginx/html/

2.配置Discuz論壇包
在瀏覽器上
這裏寫圖片描述
點擊“我同意“
這裏寫圖片描述
由於權限問題,出現不可寫入的報錯

[root@server1 ~]# cd /usr/local/lnmp/nginx/html/upload
[root@server1 upload]# chmod 777 config/ data/ uc_client/ uc_server/ -R #更改這些目錄下的所有爲滿權限

刷新重試
這裏寫圖片描述
這裏寫圖片描述
這裏寫圖片描述
這裏寫圖片描述
出現數據庫連接錯誤,屬於權限問題,將數據庫的data目錄權限修改爲775

[root@server1 ~]# chmod 755 /usr/local/lnmp/mysql/data/

刷新重試
這裏寫圖片描述
成功進入Discuz論壇主頁
這裏寫圖片描述
接下來我們就可以自由使用我們搭建的這個小平臺了。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章