LNMP編譯安裝配置+discuz

餘二五發表於2017-11-15
    什麼是LNMP呢?就是Linux+Nginx+mysql+php的開源組合。
    Nginx是什麼呢?
    Nginx是一個高效能的HTTP和反向代理的伺服器,也是一個IMAP,POP3,SMTP的代理伺服器。Nginx由Lgor Sysoev為俄羅斯訪問量第二的Rambler.ru站點開發。lgor將
Nginx的原始碼以類BSD許可證的形式釋出。Nginx因其的文件性,豐富的功能集,低系統資源消耗而聞名,目前國內的許多大入口網站都已經部署了Nginx,如新浪,網易,騰訊等。可以說,Nginx是一個後起之秀,效能優越。
 
Linux + Nginx + mysql + php 的安裝過程:
首先,我們要配置好yum源,可以把安裝光碟作為yum倉庫。
過程:
一、安裝Nginx:
二、安裝mysql-5.5.20
三、編譯安裝php-5.3.10
四、整合nginx和php5
五、安裝xcache,為php加速:
六,建站工具discuz的安裝:
七,Nginx虛擬主機的配置:
 
 
一、安裝Nginx:
 
1、解決依賴關係
 
編譯安裝Nginx需要事先需要安裝開發包組”Development Tools”和 “Development 
 Libraries”。同時,還需要安裝pcre-devel包:
#yum -y groupinstall “Development Tools” “Development Libraries” 
# yum -y install pcre-devel
 
2、安裝
 
首先新增使用者nginx,實現用其執行nginx服務程式:
# groupadd -r nginx
# useradd -r -g nginx -s /bin/false -M nginx
 
接著開始編譯和安裝:
#tar xf nginx-1.0.13.tar.gz
#cd /nginx-1.0.13
# ./configure
  –prefix=/usr              指定安裝目錄
  –sbin-path=/usr/sbin/nginx    指定可執行檔案的安裝路徑
  –conf-path=/etc/nginx/nginx.conf   指定配置檔案安裝路徑
  –error-log-path=/var/log/nginx/error.log  指定錯誤日誌存放位置
  –http-log-path=/var/log/nginx/access.log 指定訪問日誌存放位置
  –pid-path=/var/run/nginx/nginx.pid    指定pid檔案的存放位置
  –lock-path=/var/lock/nginx.lock  指定鎖檔案的存放位置
  –user=nginx  指定以哪個使用者執行Nginx
  –group=nginx  指定以哪個組執行Nginx
  –with-http_ssl_module  支援ssl功能
  –with-http_flv_module  支援flv功能
  –with-http_stub_status_module  可以檢視Nginx的工作狀態
  –with-http_gzip_static_module 開啟壓縮傳輸功能
  –http-client-body-temp-path=/var/tmp/nginx/client/ 指定http客戶端請求快取檔案存放目錄的路徑
  –http-proxy-temp-path=/var/tmp/nginx/proxy/ 指定http反向代理快取檔案的位置
  –http-fastcgi-temp-path=/var/tmp/nginx/fcgi/ 指定fcgi快取檔案的位置
  –http-uwsgi-temp-path=/var/tmp/nginx/uwsgi 指定uwsgi快取檔案的位置
  –http-scgi-temp-path=/var/tmp/nginx/scgi 指定scgi快取檔案的位置
  –with-pcre   支援pcre,即遠端過程呼叫
# make
# make install
 
3、為nginx提供SysV init指令碼,使其能使用servcie命令:
 
#vim /etc/rc.d/init.d/nginx
新增內容如下:
#!/bin/sh
#
# nginx – this script starts and stops the nginx daemon
#
# chkconfig:   – 85 15 
# description:  Nginx is an HTTP(S) server, HTTP(S) reverse
#               proxy and IMAP/POP3 proxy server
# processname: nginx
# config:      /etc/nginx/nginx.conf
# config:      /etc/sysconfig/nginx
# pidfile:     /var/run/nginx.pid
 
# Source function library.
. /etc/rc.d/init.d/functions
 
# Source networking configuration.
. /etc/sysconfig/network
 
# Check that networking is up.
[ “$NETWORKING” = “no” ] && exit 0
 
nginx=”/usr/sbin/nginx”
prog=$(basename $nginx)
 
NGINX_CONF_FILE=”/etc/nginx/nginx.conf”
 
[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx
 
lockfile=/var/lock/subsys/nginx
 
make_dirs() {
   # make required directories
   user=`nginx -V 2>&1 | grep “configure arguments:” | sed `s/[^*]*–user=
([^ ]*).*/1/g` -`
   options=`$nginx -V 2>&1 | grep `configure arguments:“
   for opt in $options; do
       if [ `echo $opt | grep `.*-temp-path“ ]; then
           value=`echo $opt | cut -d “=” -f 2`
           if [ ! -d “$value” ]; then
               # echo “creating” $value
               mkdir -p $value && chown -R $user $value
           fi
       fi
   done
}
 
start() {
    [ -x $nginx ] || exit 5
    [ -f $NGINX_CONF_FILE ] || exit 6
    make_dirs
    echo -n $”Starting $prog: “
    daemon $nginx -c $NGINX_CONF_FILE
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}
 
stop() {
    echo -n $”Stopping $prog: “
    killproc $prog -QUIT
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}
 
restart() {
    configtest || return $?
    stop
    sleep 1
    start
}
 
reload() {
    configtest || return $?
    echo -n $”Reloading $prog: “
    killproc $nginx -HUP
    RETVAL=$?
    echo
}
 
force_reload() {
    restart
}
 
configtest() {
  $nginx -t -c $NGINX_CONF_FILE
}
 
rh_status() {
    status $prog
}
 
rh_status_q() {
    rh_status >/dev/null 2>&1
}
 
case “$1” in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart|configtest)
        $1
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    force-reload)
        force_reload
        ;;
    status)
        rh_status
        ;;
    condrestart|try-restart)
        rh_status_q || exit 0
            ;;
    *)
        echo $”Usage: $0 {start|stop|status|restart|condrestart|try-
 
restart|reload|force-reload|configtest}”
        exit 2
esac
 
而後為此指令碼賦予執行許可權:
# chmod +x /etc/rc.d/init.d/nginx
 
新增至服務管理列表,並讓其開機自動啟動:
# chkconfig –add nginx
# chkconfig nginx on
 
而後就可以啟動服務並測試了:
# service nginx start
 
網頁存放的位置:/usr/html
 
 
二、安裝mysql-5.5.20
 
1、準備資料存放的檔案系統
在企業應用中,由於資料庫中的資料變化量是很大的,為了方便管理,我們可以把資料庫放在一個邏輯捲上,可以很方便的擴充套件或縮減其空間大小,利用管理。
 
首先進行分割槽,用作物理卷的分割槽的id為8e,大小為10G,我們這裡以建立分
區/dev/sda3為例:
 
#fdisk /dev/sda
 
讓kernel識別新建的分割槽:
#partprobe /dev/sda
 
建立物理卷:
#pvcreate /dev/sda3
 
建立卷組:
#vgcreate myvg /dev/sda3
 
建立邏輯卷;
#lvcreate -L 5G -n lv_mydata myvg
 
格式化邏輯卷:
#mke2fs -j /dev/myvg/lv_mydata
 
邏輯卷的掛載目錄為/mydata,/mydata/data目錄來存放mysql的資料:
#mkdir -p /mydata/data
 
使邏輯捲開機自動掛載:
#vim /etc/fstab
新增如下行:
/dev/myvg/lv_mydata     /mydata    ext3    defaults     0 0
 
掛載/etc/fstab中的檔案系統:
#mount -a
 
 
2、新建使用者以安全方式執行程式:
 
# groupadd -r mysql
# useradd -g mysql -r -s /sbin/nologin -M  mysql
 
資料庫的資料放在/mydata/data中,故要改其屬主屬組:
# chown -R mysql:mysql /mydata/data
 
3、安裝並初始化mysql-5.5.20
 
首先下載平臺對應的mysql版本至本地,這裡是32位平臺,因此,選擇的為mysql-
 
5.5.20-linux2.6-i686.tar.gz
 
# tar xf mysql-5.5.20-linux2.6-i686.tar.gz -C /usr/local
# cd /usr/local/
# ln -sv mysql-5.5.20-linux2.6-i686  mysql
# cd mysql 
 
# chown -R mysql:mysql  .
 
初始化mysql資料庫:
# scripts/mysql_install_db –user=mysql –datadir=/mydata/data
# chown -R root  .
 
4、為mysql提供主配置檔案:
 
# cd /usr/local/mysql
# cp support-files/my-large.cnf  /etc/my.cnf
 
並修改此檔案中thread_concurrency的值為你的CPU個數乘以2,比如這裡使用如下行:
#vim /etc/my.cnf
thread_concurrency = 2
 
另外還需要新增如下行指定mysql資料檔案的存放位置:
datadir = /mydata/data
 
 
5、為mysql提供sysv服務指令碼,使其能使用service命令:
 
# cd /usr/local/mysql
# cp support-files/mysql.server  /etc/rc.d/init.d/mysqld
 
新增至服務列表:
# chkconfig –add mysqld
# chkconfig mysqld on
 
而後就可以啟動服務測試使用了:
#service mysqld start
 
 
為了使用mysql的安裝符合系統使用規範,並將其開發元件匯出給系統使用,這裡還需要進行如下步驟:
 
6、輸出mysql的man手冊至man命令的查詢路徑:
 
vim /etc/man.config
新增如下行即可:
MANPATH  /usr/local/mysql/man
 
7、輸出mysql的標頭檔案至系統標頭檔案路徑/usr/include:
 
這可以通過簡單的建立連結實現:
# ln -sv /usr/local/mysql/include  /usr/include/mysql
 
8、輸出mysql的庫檔案給系統庫查詢路徑:
檔案只要是在/etc/ld.so.conf.d/下並且字尾是.conf就可以
# echo `/usr/local/mysql/lib` > /etc/ld.so.conf.d/mysql.conf
 
而後讓系統重新載入系統庫:
# ldconfig
 
9、修改PATH環境變數,讓系統所有使用者可以直接使用mysql的相關命令:
#vim /etc/profile
PATH=$PATH:/usr/local/mysql/bin  (重新登入系統即可生效)
 
 
三、編譯安裝php-5.3.10
 
1、解決依賴關係:
 
請配置好yum源(可以是本地系統光碟)後執行如下命令:
# yum -y groupinstall “X Software Development” 
 
如果想讓編譯的php支援mcrypt、mhash擴充套件和libevent,需要安裝相應的軟體包,有兩種安裝方式:(這些都是可選的)
第一種:rpm包安裝(需要下載或自己製作定義的rpm包)
# rpm -Uvh  libmcrypt-2.5.8-4.el5.centos.i386.rpm
# rpm -Uvh libmcrypt-devel-2.5.8-4.el5.centos.i386.rpm
# rpm -Uvh mhash-0.9.9-1.el5.centos.i386.rpm
# rpm -Uvh mhash-devel-0.9.9-1.el5.centos.i386.rpm
# rpm -Uvh libevent-2.0.17-2.i386.rpm 
# rpm -Uvh libevent-devel-2.0.17-2.i386.rpm
# rpm -Uvh mcrypt-2.6.8-1.el5.i386.rpm
 
第二種:原始碼編譯安裝
 
libevent的安裝:
# tar zxvf libevent-1.4.14b-stable.tar.gz
# cd libevent-1.4.14b-stable
# ./configure
# make && make install
# make verify
 
mcrypt的安裝
# tar zxvf libmcrypt-2.5.8.tar.gz
# cd libmcrypt-2.5.8
# ./configure
# make && make install
# ldconfig -v
# cd libltdl
# ./configure –with-gmetad –enable-gexec –enable-ltdl-install
# make && make install
 
mhash的安裝:
# tar jxvf mhash-0.9.9.9.tar.bz2
# cd mhash-0.9.9.9 
# ./configure
# make && make install
 
# ln -sv /usr/local/lib/libmcrypt* /usr/lib/
# ln -sv /usr/local/lib/libmhash.* /usr/lib/
 
2、編譯安裝php-5.3.10
 
首先下載原始碼包至本地目錄:
 
# tar xf php-5.3.10.tar.bz2
# cd php-5.3.10
#  ./configure –prefix=/usr/local/php –with-mysql=/usr/local/mysql      –with-openssl –enable-fpm –enable-sockets –enable-sysvshm            –with-mysqli=/usr/local/mysql/bin/mysql_config –enable-mbstring –with-freetype-dir –with-jpeg-dir –with-png-dir –with-zlib-dir –with-libxml-dir=/usr –enable-xml  –with-mhash –with-mcrypt  –with-config-file-path=/etc/php –with-config-file-scan-dir=/etc/php –with-bz2 –with-curl
 
–with-mysql= 指定mysql的路徑,php有時要呼叫mysql中的資料
–with-openssl 支援ssl功能
–with-mysqli=/usr/local/mysql/bin/mysql_config 指定mysqli這個介面的路徑
–enable-fpm 開啟fpm功能
–enable-sockets 開啟套接字傳輸
–enable-sysvshm 支援共享記憶體
–enable-mbstring 支援多位元組串
–with-freetype-dir 要啟用freetype的功能,是一個繪相簿
–with-jpeg-dir 啟用jpeg功能,也是一個繪相簿
–with-png-dir 啟用png功能,也是一個繪相簿
–with-zlib 啟用zlib功能,是一個壓縮庫
–with-libxml-dir= 指定擴充套件標記語言的庫檔案的位置
–enable-xml 啟用xml功能
–with-mcrypt  支援mcrypt擴充套件
–with-mhash 支援雜湊加密演算法
–with-config-file-path= 指定配置檔案的位置
–with-config-file-scan-dir= 在哪個檔案中進行掃描
–with-bz2 支援bz2格式的傳輸
–with-curl 支援curl工具的使用
 
# make
# make test
# make intall
 
為php提供配置檔案:
#mkdir -p /etc/php/php.ini
# cp php.ini-production /etc/php/php.ini
 
由於我們的Nginx本身並不支援php功能,故php是獨立執行的,Nginx並不識別它。但
是php的php-fpm功能支援與Nginx通訊(我們編譯php的時候已經開啟php-fpm功能),
Nginx通過php-fpm和php進行通訊,處理動態網頁,由php-fpm來管理php。
 
為php-fpm提供Sysv init指令碼,並將其新增至服務列表:
# cp sapi/fpm/init.d.php-fpm  /etc/rc.d/init.d/php-fpm
#vim /etc/rc.d/init.d/php-fpm
修改pid檔案的位置:
php_fpm_PID=/var/run/php-fpm.pid
 
#chmod +x /etc/rc.d/init.d/php-fpm
# chkconfig –add php-fpm
# chkconfig php-fpm on
 
為php-fpm提供配置檔案:
# cp /usr/local/php/etc/php-fpm.conf.default /usr/local/php/etc/php-fpm.conf 
 
編輯php-fpm的配置檔案:
# vim /usr/local/php/etc/php-fpm.conf
配置pm.的相關選項為你所需要的值,並啟用pid檔案(如下最後一行):
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 2
pm.max_spare_servers = 8
pid = /var/run/php-fpm.pid 
 
接下來就可以啟動php-fpm了:
# service php-fpm start
 
使用如下命令來驗正(如果此命令輸出有中幾個php-fpm程式就說明啟動成功了):
# ps aux | grep php-fpm
 
 
四、整合Nginx和php5
 
1、編輯此檔案,啟用如下選項:
#vim /etc/nginx/nginx.conf
location ~ .php$ {
            root           html;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;
            include        fastcgi_params;
        }
 
並在所支援的主頁面格式中新增php格式的主頁,類似如下:
location / {
            root   html;
            index  index.php index.html index.htm;
        }
 
2、編輯此檔案,將其內容更改為如下內容:
#vim /etc/nginx/fastcgi_params
fastcgi_param  GATEWAY_INTERFACE  CGI/1.1;
fastcgi_param  SERVER_SOFTWARE    nginx;
fastcgi_param  QUERY_STRING       $query_string;
fastcgi_param  REQUEST_METHOD     $request_method;
fastcgi_param  CONTENT_TYPE       $content_type;
fastcgi_param  CONTENT_LENGTH     $content_length;
fastcgi_param  SCRIPT_FILENAME    $document_root$fastcgi_script_name;
fastcgi_param  SCRIPT_NAME        $fastcgi_script_name;
fastcgi_param  REQUEST_URI        $request_uri;
fastcgi_param  DOCUMENT_URI       $document_uri;
fastcgi_param  DOCUMENT_ROOT      $document_root;
fastcgi_param  SERVER_PROTOCOL    $server_protocol;
fastcgi_param  REMOTE_ADDR        $remote_addr;
fastcgi_param  REMOTE_PORT        $remote_port;
fastcgi_param  SERVER_ADDR        $server_addr;
fastcgi_param  SERVER_PORT        $server_port;
fastcgi_param  SERVER_NAME        $server_name;
 
 
        
而後重新載入nginx的配置檔案:
# service nginx reload
 
3、在/usr/html新建index.php的測試頁面,測試php是否能正常工作:
# cat > /usr/html/index.php << EOF
<?php
phpinfo();
?>
EOF
 
接著就可以通過瀏覽器訪問此測試頁面了。
 
 
五、安裝xcache,為php加速:
 
1、安裝
# tar xf xcache-1.3.2.tar.gz
# cd xcache-1.3.2
# /usr/local/php/bin/phpize
# ./configure –enable-xcache –with-php-config=/usr/local/php/bin/php-
config
 
# make && make install
 
安裝結束時,會出現類似如下行:
Installing shared extensions:     /usr/local/php/lib/php/extensions/no-
debug-non-zts-20090626/
 
2、編輯php.ini,整合php和xcache:
 
首先將xcache提供的樣例配置匯入php.ini
# cat xcache.ini >> /usr/local/php/lib/php.ini
 
說明:xcache.ini檔案在xcache的原始碼目錄中。
 
接下來編輯/usr/local/php/lib/php.ini,找到zend_extension開頭的行,修改為如下行:
zend_extension = /usr/local/php/lib/php/extensions/no-debug-non-zts-
 
20090626/xcache.so
 
注意:如果php.ini檔案中有多條zend_extension指令行,要確保此新增的行排在第一位。
 
3、重新啟動php-fpm
# service php-fpm restart
 
 
六,建站工具discuz的安裝:
 
建立資料庫discuz公其使用,並且建立此資料庫所屬使用者:
#mysql -uroot -p
>CREATE DATABASE discuz;
>GRANT ALL PRIVILEGES ON discuz.* TO dzuser@localhost IDENTIFIED BY `lee`;
>FLUSH PRIVILEGES;
 
新建一個存放discuz的目錄:
#mkdir /usr/html/discuz
cp Discuz_7.2_FULL_SC_GBK.zip /usr/html/discuz
#cd /usr/html/discuz
#unzip Discuz_7.2_FULL_SC_GBK.zip
 
#mv upload/* ./
 
修改配置檔案:
#vim config.inc.php
修改:
$dbhost = `localhost`;   
$dbuser = `dzuser`;        
$dbpw = `lee`;                          
$dbname = `discuz`; 
 
#vim /usr/local/php/lib/php.ini
更改:short_open_tag = On
 
更改一些檔案為可寫:
#chmod o+w config.inc.php attachments forumdata forumdata/cache/  
 
forumdata/templates/ forumdata/threadcaches/ forumdata/logs/ 
 
uc_client/data/cache/
 
http://web_ip/discuz/install  進行安裝
(如果有亂碼:vim /etc/httpd/httpd.conf
更改:把AddDefaultCharset UTF-8註釋掉,即可)
 
安裝完成之後,通過http://web_ip/discuz/ 即可訪問我們的網頁了
 
七,nginx虛擬主機的配置:
例:新增兩個基於FQDN的虛擬主機,可以通過www1.magedu.com和www2.magedu.com訪問:
#vim /etc/nginx/nginx.conf
修改如下:
worker_processes  1;
events {
    worker_connections  1024;
}
 
http {
 
include       mime.types;
default_type  application/octet-stream;
sendfile        on;
keepalive_timeout  65;
 
server {     定義預設虛擬主機,當用ip地址訪問的時候為這個網站(可選)
    listen          8080 default;
    server_name     _;
    index index.html;
     root  /usr/html;
        }
 
server {           

         listen 80;  監聽埠

         server_name www1.magedu.com;  伺服器名字,通過這個FQDN訪問

         index index.html;  指定預設首頁

         root /www/html/www1;  指定預設的根目錄,就是放網頁的目錄

         access_log /var/log/nginx/www1.access;  訪問日誌

         error_log /var/log/nginx/www1.err;  錯誤日誌

        }

 
server {

         listen 80;

         server_name www2.magedu.com;

         index index.html;

         root /www/html/www2;

         access_log /var/log/nginx/www2.access;

         error_log /var/log/nginx/www2.err;

         location / {           做訪問控制,僅允許172.16.0.0/16網段訪問
         allow 172.16.0.0/16;

         deny all;

                    }

             }
}

 

本文轉自 leejia1989 51CTO部落格,原文連結:http://blog.51cto.com/leejia/812569,如需轉載請自行聯絡原作者


相關文章