1.Nginx的簡單說明 a. Nginx是一個高性能的HTTP和反向代理伺服器,也是一個IMAP/POP3/SMTP伺服器,期初開發的目的就是為了代理電子郵件伺服器室友:Igor Sysoev開發,源代碼符合BSD開源。其特點就是占用記憶體少併發能力強,在天朝使用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.1 tar -zxvf soft/openssl-SNAP-20160104
b.2 cd openssl-SNAP-20160104/
b.3 ./configure
b.4 make
b.5 make install
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.安裝 rewrite模塊需要pcre庫的安裝方法和openssl安裝的方法一模一樣,也是分為上面五個步驟,只不過是文件的名稱不一樣,命令簡單如下:
a.1 tar -zxvf soft/nginx-1.9.9.tar.gz
a.2 cd nginx-1.9.9/
a.3 ./configure --with-pcre=../pcre-8.38/ --with-zlib=../zlib-1.2.8/ --with-openssl=../openssl-SNAP-20160104/
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是否安裝成功。
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
e.開放80埠,讓其外部環境可以訪問(如果不開放80埠,外部環境訪問不了),命令以及截圖如下:
vim /etc/sysconfig/iptables
備註:這裡我使用vim更改防火強信息之後,在重新啟動防火牆的時候出現了錯誤,錯誤信息為:Try `iptables-restore -h' or 'iptables-restore --help' for more information,這個錯誤信息提示我們不能重新啟動防火牆,那怎麼辦呢?測試了一下已寫命令的方式去更改,發現更改成功了,如圖所示:
f.當上面的工作完成之後,我們在外部瀏覽器中瀏覽: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.腳本代碼如下所示:
1 #!/bin/sh 2 # 3 # nginx - this script starts and stops the nginx daemon 4 # 5 # chkconfig: - 85 15 6 # description: Nginx is an HTTP(S) server, HTTP(S) reverse \ 7 # proxy and IMAP/POP3 proxy server 8 # processname: nginx 9 # config: /etc/nginx/nginx.conf 10 # config: /etc/sysconfig/nginx 11 # pidfile: /var/run/nginx.pid 12 # Source function library. 13 . /etc/rc.d/init.d/functions 14 # Source networking configuration. 15 . /etc/sysconfig/network 16 # Check that networking is up. 17 [ "$NETWORKING" = "no" ] && exit 0 18 nginx="/usr/local/nginx/sbin/nginx" 19 prog=$(basename $nginx) 20 NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf" 21 [ -f /etc/sysconfig/nginx ] && . /etc/sysconfig/nginx 22 lockfile=/var/lock/subsys/nginx 23 24 start() { 25 [ -x $nginx ] || exit 5 26 [ -f $NGINX_CONF_FILE ] || exit 6 27 echo -n $"Starting $prog: " 28 daemon $nginx -c $NGINX_CONF_FILE 29 retval=$? 30 echo 31 [ $retval -eq 0 ] && touch $lockfile 32 return $retval 33 } 34 35 stop() { 36 echo -n $"Stopping $prog: " 37 killproc $prog -QUIT 38 retval=$? 39 echo 40 [ $retval -eq 0 ] && rm -f $lockfile 41 return $retval 42 killall -9 nginx 43 } 44 45 restart() { 46 configtest || return $? 47 stop 48 sleep 1 49 start 50 } 51 52 reload() { 53 configtest || return $? 54 echo -n $"Reloading $prog: " 55 killproc $nginx -HUP 56 RETVAL=$? 57 echo 58 } 59 60 force_reload() { 61 restart 62 } 63 64 configtest() { 65 $nginx -t -c $NGINX_CONF_FILE 66 } 67 68 rh_status() { 69 status $prog 70 } 71 72 rh_status_q() { 73 rh_status >/dev/null 2>&1 74 } 75 76 case "$1" in 77 start) 78 rh_status_q && exit 0 79 $1 80 ;; 81 stop) 82 rh_status_q || exit 0 83 $1 84 ;; 85 restart|configtest) 86 $1 87 ;; 88 reload) 89 rh_status_q || exit 7 90 $1 91 ;; 92 force-reload) 93 force_reload 94 ;; 95 status) 96 rh_status 97 ;; 98 condrestart|try-restart) 99 rh_status_q || exit 0 100 ;; 101 *) 102 echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload|configtest}" 103 exit 2 104 esacserver命令的代碼
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
到這裡我們這片筆記就完成了,能幫助大家就幫到,幫不到大家,謝謝大家了,這隻是學習筆記,不用較真某些東西,謝謝~~~~
後面有機會我還會再說這塊的,如何將一個網站部署到nginx下去~~~~
每天的努力都是為了未來更夠更好~~~~~