1. 程式人生 > >LNMP部署論壇Discuz

LNMP部署論壇Discuz

Discuz

yum -y install \pcre-devel \zlib-devel //安裝Nginx必備插件useradd -M -s /sbin/nologin nginx //創建程序用戶nginx,不能登錄,沒有家目錄
tar xzvf nginx-1.13.9.tar.gzcd nginx-1.13.9
./configure \ --prefix=/usr/local/nginx \ --user=nginx \ --group=nginx \ --with-http_stub_status_module //日誌分析模塊
make && make install 編譯及安裝

ln -s /usr/local/nginx/sbin/nginx /usr/local/sbin/ //為nginx可執行程序做軟連接,讓系統可識別nginx -t //檢查nginx配置文件語法nginx //啟動服務killall -1 nginx //安全重啟killall -3 nginx //停止服務
下面制作nginx系統服務管理腳本vi /etc/init.d/nginx#!/bin/bash# chkconfig: 35 99 20 //3,5級別自動運行,第99個進程開啟,第20個進程結束# description: Nginx Service Control Script
PROG="/usr/local/nginx/sbin/nginx" PIDF="/usr/local/nginx/logs/nginx.pid"case "$1" in start) $PROG ;; stop) kill -s QUIT $(cat $PIDF) ;; restart) $0 stop $0 start ;; reload) kill -s HUP $(cat $PIDF) ;; *) echo "Usage: $0 {start|stop|restart|reload}"
exit 1esacexit 0
chmod +x /etc/init.d/nginx //給管理腳本添加執行權限chkconfig --add nginx //將nginx添加到chkconfig系統管理工具中
下面對nginx配置文件進行初始配置vi /usr/local/nginx/conf/nginx.confuser nginx nginx; //修改nginx啟動進程的屬主和屬組worker_processes 1; //CPU核數,幾核便設為幾error_log logs/error.log info; //修改錯誤日誌的級別日誌級別共有這幾種:debug info notice warn error crit 其中規則是向上記錄,即info級別的日誌會涵蓋notice warn error crit,低級的包涵高級的events { use epoll; //新增此行,使用epoll模式運行,默認使用的是select/poll模式 worker_connections 1024; //表示1個進程允許1024個連接,如果設置超過1024則需要修改ulimit上限,否則報錯}log_format main //定義日誌格式 把前面的#號去掉配置完之後重啟,現在nginx服務器已經可以支持訪問

技術分享圖片






ulimit -n 65500//查看和更改系統本地打開資源數ulimit -n 65500 >> /etc/rc.local
下面我們可以配置nginx自帶的日誌統計模塊 vi /usr/local/nginx/conf/nginx.conflocation ~ /status { stub_status on; //日誌統計模塊開啟 access_log off; } //在server 模塊裏的error_page 上面增加service nginx reloadhttp://IP/status //當前的活動連接數,已處理的連接數,成功的TCP握手次數,已處理的請求數。技術分享圖片



可以配置nginx的訪問控制功能了yum install httpd-tools //安裝apache的工具,借助工具創建訪問用戶htpasswd -c /usr/local/nginx/passwd.db jack //創建數據庫驗證文件,並把jack用戶添加進去chmod 400 /usr/local/nginx/passwd.db //提高數據安全性chown nginx /usr/local/nginx/passwd.db //更改屬主
vi /usr/local/nginx/conf/nginx.conf location / { root html; index index.html index.htm; allow 192.168.80.0/24; //允許80段的訪問該主頁 deny all; auth_basic "secret"; auth_basic_user_file /usr/local/nginx/passwd.db; //註意這邊的文件必須與上面創建的數據庫驗證文件統一 }
service nginx restart
技術分享圖片










再次訪問需要輸入用戶名和密碼
下面搭建虛擬主機1.基於域名的虛擬主機vi /usr/local/nginx/conf/nginx.conf //在最後一行上面插入server { listen 80; server_name www.aa.com; //虛擬主機名 charset utf-8; access_log logs/aa.access.log main; location / { root /var/www/aa; index index.html index.htm; error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } }}server { listen 80; server_name www.bc.com; charset utf-8; access_log logs/bc.access.log main; location / { root /var/www/bc; index index.html index.htm; error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } }}mkdir /var/www/aa -pmkdir /var/www/bcvi /var/www/aa/index.htmlvi /var/www/bc/index.html //編輯主頁測試在兩個虛擬主機的網站目錄添加主頁下面搭一個DNS服務器進行域名解析,這邊自己搭過,不做詳細說明下面進行測試技術分享圖片









2.基於端口的虛擬主機vi /usr/local/nginx/conf/nginx.conf listen 192.168.80.181:80; //修改虛擬主機的配置文件 listen 192.168.80.181:8080;http://192.168.80.181:80 //訪問技術分享圖片



http://192.168.80.181:8080/技術分享圖片




安裝PHPyum -y install \libjpeg \libjpeg-devel \libpng libpng-devel \freetype freetype-devel \libxml2 \libxml2-devel \zlib zlib-devel \curl curl-devel \openssl openssl-devel //安裝需要支持的插件

tar xjvf php-7.1.10.tar.bz2cd 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-mbstring \ --enable-xml \ --enable-session \ --enable-ftp \ --enable-pdo \ --enable-tokenizer \ --enable-zip \ //支持壓縮 --enable-fpm //支持動態頁面fpm功能
cp php.ini-development /usr/local/php/lib/php.ini //復制php配置文件模板作為php配置文件vi /usr/local/php/lib/php.ini //編輯php配置文件mysqli.default_socket = /usr/local/mysql/mysql.sock //編輯mysql的sock文件位置date.timezone = Asia/Shanghai //選擇時區
/usr/local/php/bin/php -m //驗證安裝的模塊
-----------配置及優化FPM模塊--------cd /usr/local/php/etc/cp php-fpm.conf.default php-fpm.conf //復制php的fpm模塊的配置文件模板為配置文件。php只識別php-fpm.conf為配置文件cd /usr/local/php/etc/php-fpm.d/cp www.conf.default www.conf //復制fpm的www配置文件模板為配置文件,fpm只識別www.conf的配置文件
cd /usr/local/php/etc/vi php-fpm.conf //配置fpm模塊pid = run/php-fpm.pid //將分號去掉;user = nginx;group = nginx //添加user和group
/usr/local/php/sbin/php-fpm -c /usr/local/php/etc/php.ini //啟動fpm模塊netstat -anpt | grep 9000ln -s /usr/local/php/bin/* /usr/local/bin/ //將php的可執行程序放到系統可識別環境中便於執行ps aux | grep -c "php-fpm" //統計進程數
-----更新啟動腳本,讓fpm模塊也可進行啟動管理vi /etc/init.d/nginx#!/bin/bash# chkconfig: 35 99 20# description: Nginx Service Control ScriptPROG="/usr/local/nginx/sbin/nginx"PIDF="/usr/local/nginx/logs/nginx.pid"PROG_FPM="/usr/local/php/sbin/php-fpm"PIDF_FPM="/usr/local/php/var/run/php-fpm.pid"case "$1" in start) $PROG $PROG_FPM ;; stop) kill -s QUIT $(cat $PIDF) kill -s QUIT $(cat $PIDF_FPM) ;; restart) $0 stop $0 start ;; reload) kill -s HUP $(cat $PIDF) ;; *) echo "Usage: $0 {start|stop|restart|reload}" exit 1esacexit 0
--------讓nginx支持PHP功能--------vi /usr/local/nginx/conf/nginx.conf
location ~ \.php$ { root /var/www/aa; fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /var/www/aa$fastcgi_script_name; //註意目錄名稱,為網站根目錄必須為絕對路徑 include fastcgi_params;}技術分享圖片
vi /var/www/aa/index.php<?phpphpinfo();?>service nginx restart 註意,為了防止幹擾,需要把虛擬主機配置刪除在網頁測試“http://192.168.80.193/index.php”
--------下面測試數據庫工作是否正常-----mysql -u root -p
CREATE DATABASE bbs; //創建數據庫為bbsGRANT all ON bbs.* TO 'bbsadm'@'%' IDENTIFIED BY 'admin123'; //將數據庫所有權限給bbsadm,密碼為admin123GRANT all ON bbs.* TO 'bbsadm'@'localhost' IDENTIFIED BY 'admin123'; //允許flush privileges; //刷新權限
vi /var/www/aa/index.php
<?php$link=mysqli_connect('192.168.80.181','bbsadm','admin123');if($link) echo "<h1>Success!!</h1>";else echo "Fail!!";?>
在網頁測試“http://192.168.80.193/index.php” 技術分享圖片


--以下安裝論壇--unzip Discuz_X3.4_SC_UTF8_0101.zip //解壓縮cd dir_SC_UTF8/ //進入解壓目錄cp -r upload/ /var/www/aa/bbs cd /var/www/aa/bbschown -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 777 ./uc_client/chmod -R 777 ./uc_server/
訪問http://IP/bbs/install/index.php //安裝論壇技術分享圖片







按照提示安裝即可rm -rf install/ 刪除安裝頁面才能正常訪問技術分享圖片




















訪問地址為http://IP/bbs/index.phphttp://IP/bbs/admin.php //管理後臺這樣訪問很不友好,我們可以做一個首頁跳轉vi /usr/local/nginx/html/index.html技術分享圖片


service nginx restart再去訪問www.aa.com直接能跳轉了技術分享圖片








LNMP部署論壇Discuz