【Linux】Centos之安裝Nginx及注意事項


相關內容鏈接

【Linux】nginx常用命令

【nginx】詳細配置說明

1.Nginx的簡單說明

  a.  Nginx是一個高性能的HTTP和反向代理服務器,也是一個IMAP/POP3/SMTP服務器,期初開發的目的就是為了代理電子郵件服務器室友:Igor Sysoev開發,源代碼符合BSD開源。其特點就是占用內存少並發能力強,在天朝使用Nginx的大型網站已經有很多:百度、淘寶、騰訊等等...。

  b.Nginx作為Http服務器,有以下幾項基本特征:

    b.1 處理靜態文件,索引文件以及自動索引,打開文件描述符緩沖。

    b.2 無緩存的反向代理加速,簡單的負載均衡和容錯

    b.3 模塊化的結構,包括gzipping,byte ranges,chunked responses以及SSI-filter等filter,如果由FastCGI或其它代理服務器處理蛋液中存在的多個SSI,則這項處理可以並行運行,而不需要相互等待。

    b.4 支持SSL和TLSSNI。

  c.Nginx官網:http://nginx.org/

  d.Nginx推薦學習網址:http://dreamfire.blog.51cto.com/418026/1140965

2.准備工作

  a.上面簡單介紹了一下Nginx,大家如果想要了解更多關於Nginx的知識,請自行通過網絡學習。

  b.工欲善其事必先利其器,下面我們就在Linux下面簡單安裝一下Niginx,在安裝過程中需要了一些問題,同步都會在博客中說出來。

  c.Nginx的安裝依賴於以下三個包,意思就是在安裝Nginx之前首先必須安裝一下的三個包,安裝順序為我寫的順序:

    c.1 SSL功能需要openssl庫,下載地址:http://www.openssl.org/

    c.2 gzip模塊需要zlib庫,下載地址:http://www.zlib.net/

    c.3 rewrite模塊需要pcre庫,下載地址:http://www.pcre.org/

  d.Nginx的安裝包:下載地址為:http://nginx.org/en/download.html

  e.將上面下載的幾個軟件全部使用Xftp上傳到Linux系統中,上傳路徑和軟件如圖所示:

    

  f.操作需要的軟件以及系統如下:虛擬機(Vmware),虛擬機中安裝的Centos系統,Xshell,Xftp,以及上面的幾個包。

   g.下面開始按照上面說的按照順序開始安裝軟件。

3.安裝SSL功能需要openssl庫以及gzip模塊需要的zlib庫

  a(1).首先我們安裝SSL功能需要的openssl庫插件,注意:安裝過程是按照我在linux下設置的文件路徑來安裝的,命令如下:

    a.1   tar -zxvf  soft/openssl-SNAP-20160104

    a.2   cd cd openssl-SNAP-20160104/

    a.3   ./config

    a.4   make

    a.5   make install

  b(1).安裝gzip模塊需要zlib庫的安裝方法和openssl安裝的方法一模一樣,也是分為上面五個步驟,只不過是文件的名稱不一樣

  b.如果沒有報錯,則說明安裝完全完成了~。

4.安裝 rewrite模塊需要pcre庫

  a.安裝 rewrite模塊需要pcre庫的安裝方法和openssl安裝的方法一模一樣,也是分為上面五個步驟,只不過是文件的名稱不一樣,命令簡單如下:

    a.1   tar -zxvf soft/pcre-8.38.tar.gz

    a.2   cd pcre-8.38/

    a.3   ./configure 

    a.4   make

    a.5   make install

  b.在執行./configure的出現錯誤了,導致不能繼續往下執行,報錯內容為:

    error: You need a C++ compiler for C++ support,看到這句話我們就已經猜到了應該是c++包信息,而linux中沒有,那么首先安裝一下這個包信息即可,安裝命令為:

    b.1  yum install -y gcc gcc-c++

  c.當安裝完上面的c++包之后,在此運行,發現消息已經顯示安裝成功了,當基於上面的東西全部安裝完成之后,就需要安裝Nginx服務了。

5.安裝 Nginx服務

  a.命令簡單如下:

    a.1   tar -zxvf soft/nginx-1.9.9.tar.gz

    a.2   cd nginx-1.9.9/

    a.3  

./configure --prefix=/opt/soft/nginx --with-pcre=/usr/local/src/pcre-8.38 --with-zlib=/usr/local/src/zlib-1.2.11 --with-openssl=/usr/local/src/openssl-1.1.0e

    a.4   make

    a.5   make install

6.監測Nginx是否安裝成功

  a.當上面的所有步驟完成之后,則說明Nginx安裝已經完成,那么我們如何來確定是否安裝成功了呢?通過以下命令來確定即可。

    a.1  cd /usr/local/nginx/sbin/

    a.2 ./nginx -t

  b. 當我執行第二個命令(./nginx -t)的時候出錯了,報沒有權限的錯誤。如圖所示:

    

    備注:根據錯誤提示,我們就能夠看出來,是說/usr/local/nginx下沒有權限,解決辦法也很簡單,我們給文件賦值權限。

  c.如下圖所示,配置權限(配置權限需要切換到root用戶下)之后,執行上面兩個步驟,如果linux中如下圖所示:則說明安裝已成功。

    

  d.當確認安裝完成之后,首先就需要啟動和查看Nginx默認安裝的端口是多少,兩個命令分別如下:

    (1)  ./nginx

    (2)  netstat -ntlp  ,  Nginx默認端口為80

      firewall-cmd --permanent --zone=public --add-port=80/tcp
      firewall-cmd --permanent --zone=public --add-port=80/udp
      firewall-cmd --reload 

  e.當上面的工作完成之后,我們在外部瀏覽器中瀏覽:http://IP,出現如圖所示,則說明安裝已完全完成。

    

7.將Nginx設置為開機自動啟動

 

  a.當上面6步完成之后,說明安裝已經完全成功了,但是每次開機我們面臨的一個問題,就是每次都要執行命令(1: cd /usr/local/nginx/sbin/   2:./nginx -t),那么這時候有這個需要,設置開機自啟動,開機自動啟動的命令為:將Nginx的啟動命令添加到/etc/rc.local,命令如下:

    echo "/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf" >> /etc/rc.local

  b.然后將Linux關機重啟測試一下,如果http://IP還能夠訪問,則說明配置成功了,我這邊已測試,配置完全成功。

 

8.使用server命令啟動nginx服務

   a.  現在覺得啟動命令太麻煩,雖然開機可以自啟動,但是每次改動要重新啟動nginx的話,要么輸入命令,要么開機,都還不是很好,那么我們能不能創造一個更好的方式呢?當然可以,我們可以通過設置System V腳本。

  b.腳本代碼如下所示:

#!/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/local/nginx/sbin/nginx" 
    prog=$(basename $nginx) 
    NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf" 
[ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx 
    lockfile=/var/lock/subsys/nginx 
 
start() { 
    [ -x $nginx ] || exit 5 
    [ -f $NGINX_CONF_FILE ] || exit 6 
    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 
    killall -9 nginx 
} 
 
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 

server命令的代碼

 

  c.創建命令如下,手先跳轉到/etc/init.d下創建nginx啟動腳本文件,命令如下;

    c.1 cd /etc/init.d/

    c.2 vim nginx  創建一個新的nginx文件,將上面的命令代碼copy到里面,然后保存

  d.修改腳本權限,命令如下:chmod 755 nginx

  e.將腳本文件加入到chkconfig中  chkconfig --add nginx

 

  f.設置nginx開機在3和5級別自動啟動  chkconfig --level 35 nginx on

  g.測試nginx腳本文件是否能夠正常使用,命令如下,我均已測試,全部可以使用。

    g.1  /etc/init.d/nginx restart

    g.2  /etc/init.d/nginx reload

    g.3   /etc/init.d/nginx stop 

     

    到這里我們這片筆記就完成了,能幫助大家就幫到,幫不到大家,謝謝大家了,這只是學習筆記,不用較真某些東西,謝謝~~~~


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM