使用LNMP架構建設Discuz實例

使用LNMP架構建設Discuz實例

LNMP表明的就是:Linux系統下Nginx+MySQL+PHP這種網站服務器架構。php

Linux 是一類Unix計算機操做系統的統稱,是目前最流行的免費操做系統。表明版本有:debian、centos、ubuntu、fedora、gentoo等。html

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

Mysql 是一個小型關係型數據庫管理系統。nginx

PHP 是一種在服務器端執行的嵌入HTML文檔的腳本語言。c++

這四種軟件均爲免費開源軟件,組合到一塊兒,成爲一個免費、高效、擴展性強的網站服務系統。sql

本次實驗大致步驟爲:

​ 安裝nginx→安裝mysql數據庫→安裝php工具→架設Discuz論壇shell

1、安裝nginx服務

事先將本次實驗須要的軟件包進行遠程掛載數據庫

[root@localhost ~]# mount.cifs //192.168.10.171/rpm /mnt
Password for root@//192.168.10.171/rpm:  
[root@localhost ~]# df -h
wen件系統              容量  已用  可用 已用% 掛載點
/dev/sda2              20G   13G  7.9G   61% /
devtmpfs              7.8G     0  7.8G    0% /dev
tmpfs                 7.8G     0  7.8G    0% /dev/shm
tmpfs                 7.8G  9.0M  7.8G    1% /run
tmpfs                 7.8G     0  7.8G    0% /sys/fs/cgroup
/dev/sda5              10G   53M   10G    1% /home
/dev/sda1             6.0G  174M  5.9G    3% /boot
tmpfs                 1.6G   24K  1.6G    1% /run/user/0
/dev/sr0              4.3G  4.3G     0  100% /run/media/root/CentOS 7 x86_64
//192.168.10.171/rpm  288G   74G  215G   26% /mnt       //實驗所需

解壓並安裝環境包ubuntu

[root@localhost ~]# cd /mnt
[root@localhost mnt]# tar zxf nginx-1.12.0.tar.gz -C /opt/       //解壓軟件包
[root@localhost mnt]# useradd -M -s /sbin/nologin nginx        //建立程序用戶,不設家目錄
[root@localhost mnt]# yum -y install \
gcc \
gcc-c++ \
pcre-devel \
zlib-devel \
expat-devel \
pcre

其中,vim

gcc、gcc-c++ :底層C語言支持包

pcre、pcre-devel :pcre語言的開發、編譯器

zlib-devel :支持壓縮

expat-devel :使新建的網站可以解析xml格式的文件

編譯安裝

完成後,移動進文件夾中

[root@localhost mnt]# cd /opt/nginx-1.12.0/
[root@localhost nginx-1.12.0]# ./configure \          //配置
--user=nginx \
--group=nginx \
--prefix=/usr/local/nginx \
--with-http_stub_status_module
[root@localhost nginx-1.12.0]# make && make install    //手工編譯&安裝
[root@localhost nginx-1.12.0]# ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/
//方便計算機可以識別

其中,

--user=nginx :指定控制服務的用戶

--group=nginx :指定控制服務的組

--prefix=/usr/local/nginx :指定安裝路徑

--with-http_stub_status_module:狀態統計模塊

創建配置文件,方便Systemctl & Service進行控制(二選一便可)

Systemctl

[root@localhost nginx-1.12.0]# vim /lib/systemd/system/nginx.service
#手動輸入如下內容:
[Unit]
Description=nginx
After=network.target
[Service]
Type=forking
PIDFile=/usr/local/nginx/logs/nginx.pid
ExecStart=/usr/local/nginx/sbin/nginx
ExecReload=/usr/bin/kill -s HUP $MAINPID
ExecStop=/usr/bin/kill -s QUIT $MAINPID
PrivateTmp=true
[Install]
WantedBy=multi-user.target
wq保存退出
[root@localhost nginx-1.12.0]# cd /lib/systemd/system/
[root@localhost system]# chmod 754 nginx.service     //給予控制權限

Service

[root@localhost nginx-1.12.0]# vim /etc/init.d/nginx
#輸入如下內容:
#!/bin/bash
wenjian="/usr/local/nginx/sbin/nginx"
pid="/usr/local/nginx/logs/nginx.pid"
case $1 in
start)
    $wenjian ;;
stop)
    kill -s QUIT $(cat $pid) ;;
restart)
    $0 stop
    $0 start
;;
reload)
    kill -s HUP $(cat $pid) ;;
*)
    echo "Please,try again"
    exit 1 ;;
esac
exit 0
wq保存退出
[root@localhost nginx-1.12.0]# cd /etc/init.d/
[root@localhost init.d]# chmod 754 nginx     //給予控制權限

啓動nginx服務,並驗證

[root@localhost init.d]# systemctl stop firewalld.service     //關閉防火牆
[root@localhost init.d]# setenforce 0                       //關閉加強性安全功能
[root@localhost init.d]# systemctl start nginx.service      //開啓nginx服務
[root@localhost init.d]# systemctl enable nginx.service     //設置nginx服務開機自啓
[root@localhost init.d]# netstat -atnp | egrep "(80|nginx)"    //查看服務是否啓動
tcp        0      0 0.0.0.0:80              0.0.0.0:*               LISTEN      1075/nginx: master

2、安裝MySQL數據庫

解壓並安裝環境包

[root@localhost init.d]# cd /mnt
[root@localhost mnt]# yum -y install \
cmake \
ncurses \
ncurses-devel \
bison \
expect
[root@localhost mnt]# tar zxf /mnt/mysql-boost-5.7.20.tar.gz -C /opt
[root@localhost mnt]# useradd  -s /sbin/nologin mysql       //創建程序用戶

其中,

cmake :編譯器

ncurses、ncurses-devel :客戶字符終端處理工具

bison :語法分析器

編譯安裝

[root@localhost mnt]# cd /opt/mysql-5.7.20
[root@localhost mysql-5.7.20]# 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 
[root@localhost mysql-5.7.20]# make && make install     //編譯&安裝

其中,

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql :指定安裝路徑

-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock :定義sock文件路徑

-DSYSCONFDIR=/etc/ :配置文件目錄

-DSYSTEMD_PID_DIR=/usr/local/mysql :PID文件路徑

-DDEFAULT_CHARSET=utf8 :指定字符集(支持中文)

-DDEFAULT_COLLATION=utf8_general_ci :指定默認字符集

-DWITH_INNOBASE_STORAGE_ENGINE=1 :存儲引擎

-DMYSQL_DATADIR=/usr/local/mysql/data :數據庫數據文件目錄

-DWITH_BOOST=boost :底層運行庫

-DWITH_SYSTEMD=1:主從參數

配置MySQL

[root@localhost mysql-5.7.20]# chown -R mysql:mysql /usr/local/mysql/   ##數據庫目錄進行權限調整
[root@localhost mysql-5.7.20]# 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
##支持模塊
[root@localhost mysql-5.7.20]# chown mysql:mysql /etc/my.cnf    ##給配置文件mysql屬主屬組
[root@localhost mysql-5.7.20]# echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile
##將MySQL寫到本地環境配置中
[root@localhost mysql-5.7.20]# echo 'export PATH' >> /etc/profile    ##設置全局環境配置
[root@localhost mysql-5.7.20]# source /etc/profile    ##重啓配置文件

初始化數據庫,爲數據庫設定初識密碼

[root@localhost mysql-5.7.20]# cd /usr/local/mysql/
[root@localhost mysql]# bin/mysqld \
> --initialize-insecure \        ##初始化
> --user=mysql \                 ##用戶
> --basedir=/usr/local/mysql \      ##安裝目錄
> --datadir=/usr/local/mysql/data   ##數據庫數據文件目錄
[root@localhost mysql]# cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/ 
##便於systemctl管理
[root@localhost mysql]# systemctl enable mysqld   ##開機自啓動
[root@localhost mysql]# systemctl start mysqld.service     ##開啓數據庫
[root@localhost mysql]# netstat -ntap | grep 3306              ##查看MySQL端口號開啓狀況
tcp6  0  0 :::3306    :::*       LISTEN   59464/mysqld   
[root@localhost mysql]# mysqladmin -u root -p password
Enter password:               ##空格
New password:                ##新密碼
Confirm new password:   ##確認密碼

3、安裝PHP工具

解壓&安裝環境包

[root@localhost mysql]# cd /mnt     ##切換到掛載點
[root@localhost mnt]# tar jxvf php-7.1.10.tar.bz2 -C /opt     ##解壓源碼包到/opt
[root@localhost mnt]# yum install -y \
> libjpeg \
> libjpeg-devel \
> libpng libpng-devel \
> freetype freetype-devel \
> libxml2 \
> libxml2-devel \
> zlib zlib-devel \
> curl curl-devel \
> openssl openssl-devel

其中,

libjpeg、ibjpeg-devel :支持jpeg圖片格式和開發包

libpng、libpng-devel :支持png格式和對應放入開發包

freetype、freetype-devel :字體庫

libxml二、libxml2-devel :xml文件庫

zlib、zlib-devel :壓縮庫

curl、curl-devel :支持數據文件下載工具

openssl openssl-devel:安全訪問鏈接

編譯安裝

[root@localhost mnt]# cd /opt/php-7.1.10/
[root@localhost php-7.1.10]# ./configure \
--prefix=/usr/local/php \
--with-mysql-sock=/usr/local/mysql/mysql.sock \
--with-zlib \
--with-mysqli \
--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
[root@localhost php-7.1.10]# make && make install      //編譯&安裝

其中,

--prefix=/usr/local/php :指定安裝路徑

--with-mysql-sock=/usr/local/mysql/mysql.sock :指定sock文件路徑

--with-zlib :支持壓縮

--with-mysqli :支持上傳下載

--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壓縮格式

修改php核心配置文件

​ 共有三個:php.ini核心配置文件,php-fpm.conf進程服務配置文件,www.conf擴展配置文件

php.ini

[root@localhost php-7.1.10]# cp php.ini-development /usr/local/php/lib/php.ini   ##複製到安裝目錄lib庫中
[root@localhost php-7.1.10]# vim /usr/local/php/lib/php.ini   ##配置核心配置文件

mysqli.default_socket = /usr/local/mysql/mysql.sock     ##默認鏈接文件
date.timezone = Asia/Shanghai                                      ##時間

php-fpm.conf、www.conf

[root@localhost php-7.1.10]# cd /usr/local/php/etc/
[root@localhost etc]# cp php-fpm.conf.default php-fpm.conf   ##優化複製默認進程服務配置文件
[root@localhost etc]# cd /usr/local/php/etc/php-fpm.d/
[root@localhost php-fpm.d]# cp www.conf.default www.conf   ##優化複製擴展配置文件
[root@localhost php-fpm.d]# cd /usr/local/php/etc/  
[root@localhost etc]# vim php-fpm.conf      ##開啓fpm.pid進程
pid = run/php-fpm.pid
[root@localhost etc]# /usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini
[root@localhost etc]# netstat -ntap | grep 9000     ##查看端口信息
tcp   0 0 127.0.0.1:9000   0.0.0.0:*    LISTEN   69104/php-fpm: mast 
[root@localhost etc]# ln -s /usr/local/php/bin/* /usr/local/bin/   ##建立軟鏈接便於系統識別

讓nginx支持PHP功能

[root@localhost etc]# 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;
    }
[root@localhost etc]# vim /usr/local/nginx/html/index.php               ##測試php網頁
在網頁中添加以下內容
<?php
phpinfo();
?>

創建bbs數據庫

[root@localhost etc]# 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 'zhy'@'%' IDENTIFIED BY 'zhy94666';  
##提權數據庫用戶bbsuser爲管理員並設定密碼
Query OK, 0 rows affected, 1 warning (0.00 sec)       

mysql> GRANT all ON bbs.* TO 'zhy'@'localhost' IDENTIFIED BY 'zhy94666';
Query OK, 0 rows affected, 1 warning (0.00 sec)

mysql> flush privileges;         ##刷新數據庫
Query OK, 0 rows affected (0.00 sec)

mysql> quit       ##退出

[root@localhost etc]# systemctl restart nginx.service     ##重啓服務

4、安裝Discuz論壇

解壓

[root@localhost etc]# cd  /mnt/
[root@localhost mnt]# unzip Discuz_X3.4_SC_UTF8.zip -d /tmp
[root@localhost mnt]# cd /tmp/dir_SC_UTF8/
[root@localhost dir_SC_UTF8]# cp -r upload/ /usr/local/nginx/html/bbs/

對文件進行提權

[root@localhost dir_SC_UTF8]# cd /usr/local/nginx/html/bbs/
[root@localhost bbs]# chown -R root:nginx ./config/
[root@localhost bbs]# chown -R root:nginx ./data/
[root@localhost bbs]# chown -R root:nginx ./uc_client/
[root@localhost bbs]# chown -R root:nginx ./uc_server/
[root@localhost bbs]# chmod -R 777 ./config/
[root@localhost bbs]# chmod -R 777 ./data/
[root@localhost bbs]# chmod -R 777 ./uc_client/
[root@localhost bbs]# chmod -R 777 ./uc_server/

訪問

在瀏覽器中輸入192.168.116.171/bbs/install/index.php便可進行安裝流程。

相關文章
相關標籤/搜索