小男孩‘自慰网亚洲一区二区,亚洲一级在线播放毛片,亚洲中文字幕av每天更新,黄aⅴ永久免费无码,91成人午夜在线精品,色网站免费在线观看,亚洲欧洲wwwww在线观看

分享

linux下配置nginx

 昵稱10383208 2012-07-12

linux下Nginx配置

為了確保能在 Nginx 中使用正則表達(dá)式進(jìn)行更靈活的配置,

安裝之前需要確定系統(tǒng)是否安裝有 PCRE(Perl Compatible Regular Expressions)包。您可以到 下載最新的 PCRE 源碼包,

使用下面命令下載編譯和安裝 PCRE 包:


./configure
make
make install

修改 objs/Makefile 注釋掉以下內(nèi)容:

./configure --disable-shared

mkdir -p /usr/local/lib/.libs/
cp /usr/local/lib/libpcre.a /usr/local/lib/.libs/libpcre.a


./configure --prefix=/usr/local/nginx \
--with-pcre=/usr/local/lib \
--with-http_stub_status_module \
--with-http_stub_status_module \
--with-http_addition_module \
--with-http_realip_module \
--with-http_flv_module \
--with-debug

make

make install

啟動(dòng)

/usr/local/nginx/sbin/nginx 其中參數(shù) --with-http_stub_status_module 是為了啟用 nginx 的 NginxStatus 功能,用來監(jiān)控 Nginx 的當(dāng)前狀態(tài)。

安裝成功后 /opt/nginx 目錄下有四個(gè)子目錄分別是:conf、html、logs、sbin 。

其中 Nginx 的配置文件存放于 conf/nginx.conf,Nginx 只有一個(gè)程序文件位于 sbin 目錄下的 nginx 文件。確保系統(tǒng)的 80 端口沒被其他程序占用,運(yùn)行 sbin/nginx 命令來啟動(dòng) Nginx,

打開瀏覽器訪問此機(jī)器的 IP,如果瀏覽器出現(xiàn) Welcome to nginx! 則表示 Nginx 已經(jīng)安裝并運(yùn)行成功。

常用的 Nginx 參數(shù)和控制程序運(yùn)行參數(shù)

Nginx 安裝后只有一個(gè)程序文件,本身并不提供各種管理程序,

它是使用參數(shù)和系統(tǒng)信號(hào)機(jī)制對(duì) Nginx 進(jìn)程本身進(jìn)行控制的。 Nginx 的參數(shù)包括有如下幾個(gè):

-c <path_to_config>:使用指定的配置文件而不是 conf 目錄下的 nginx.conf 。

-t:測試配置文件是否正確,在運(yùn)行時(shí)需要重新加載配置的時(shí)候,此命令非常重要,

用來檢測所修改的配置文件是否有語法錯(cuò)誤。

-v:顯示 nginx 版本號(hào)。-V:顯示 nginx 的版本號(hào)以及編譯環(huán)境信息以及編譯時(shí)的參數(shù)。例如我們要測試某個(gè)配置文件是否書寫正確,我們可以使用以下命令 sbin/nginx – t – c conf/nginx2.conf 通過信號(hào)對(duì) Nginx 進(jìn)行控制Nginx 支持下表中的信號(hào):信號(hào)名作用描述TERM, INT快速關(guān)閉程序,中止當(dāng)前正在處理的請(qǐng)求QUIT處理完當(dāng)前請(qǐng)求后,關(guān)閉程序HUP重新加載配置,并開啟新的工作進(jìn)程,關(guān)閉就的進(jìn)程,此操作不會(huì)中斷請(qǐng)求USR1重新打開日志文件,用于切換日志,例如每天生成一個(gè)新的日志文件USR2平滑升級(jí)可執(zhí)行程序WINCH從容關(guān)閉工作進(jìn)程

有兩種方式來通過這些信號(hào)去控制 Nginx,第一是通過 logs 目錄下的 nginx.pid 查看當(dāng)前運(yùn)行的 Nginx 的進(jìn)程 ID,

通過 kill – XXX <pid> 來控制 Nginx,其中 XXX 就是上表中列出的信號(hào)名。、

如果您的系統(tǒng)中只有一個(gè) Nginx 進(jìn)程,那您也可以通過 killall 命令來完成,例如運(yùn)行 killall – s HUP nginx 來讓 Nginx 重新加載配置。

配置 Nginx先來看一個(gè)實(shí)際的配置文件:user nobody;# 工作進(jìn)程的屬主
worker_processes 4;# 工作進(jìn)程數(shù),一般與 CPU 核數(shù)等同

#error_log logs/error.log;
#error_log logs/error.log notice;
#error_log logs/error.log info;

#pid logs/nginx.pid;

events {
use epoll;#Linux 下性能最好的 event 模式
worker_connections 2048;# 每個(gè)工作進(jìn)程允許最大的同時(shí)連接數(shù)
}

http {
include mime.types;
default_type application/octet-stream;

#log_format main '$remote_addr - $remote_user [$time_local] $request '
# '"$status" $body_bytes_sent "$http_referer" '
# '"$http_user_agent" "$http_x_forwarded_for"';

#access_log off;
access_log logs/access.log;# 日志文件名

sendfile on;
#tcp_nopush on;
tcp_nodelay on;

keepalive_timeout 65;

include gzip.conf;

# 集群中的所有后臺(tái)服務(wù)器的配置信息
upstream tomcats {
server 192.168.0.11:8080 weight=10;
server 192.168.0.12:8081 weight=10;
server 192.168.0.13:8080 weight=10;
server 192.168.0.14:8081 weight=10;
server 192.168.0.15:8080 weight=10;
server 192.168.0.16:8081 weight=10;
}

server {
listen 80;#HTTP 的端口
server_name localhost;

charset utf-8;

#access_log logs/host.access.log main;

location ~ ^/NginxStatus/ {
stub_status on; #Nginx 狀態(tài)監(jiān)控配置
access_log off; auth_basic "NginxStatus";auth_basic_user_file /usr/local/nginx/conf/htpasswd;
}

location ~ ^/(WEB-INF)/ {
deny all;
}


location ~ \.(htm|html|asp|php|gif|jpg|jpeg|png|bmp|ico|rar|css|js|
zip|java|jar|txt|flv|swf|mid|doc|ppt|xls|pdf|txt|mp3|wma)$ {
root /opt/webapp;
expires 24h;
}

location / {
proxy_pass [url]http://tomcats;#[/url] 反向代理
include proxy.conf;
}

error_page 404 /html/404.html;

# redirect server error pages to the static page /50x.html
#
error_page 502 503 /html/502.html;
error_page 500 504 /50x.html;
location = /50x.html {
root html;
}
}
}
Nginx 監(jiān)控

我們必需生成一個(gè)htppasswd文件,這時(shí)候我們得用到 的htpasswd 工具了,

我們這臺(tái)服務(wù)器上沒有Apache,

現(xiàn)在只能依靠服務(wù)器的了,去那生成一個(gè)復(fù)制過來。
生成htppasswd文件的方法:
#htpasswd -c /tmp/htpassswd user
輸入兩次密碼就完成了,然后把生成好的htpasswd文件拷貝到proxy的機(jī)器的/usr/local/etc/nginx/conf目錄下就行了。

上面是一個(gè)實(shí)際網(wǎng)站的配置實(shí)例。上述配置中,

首先我們定義了一個(gè) location ~ ^/NginxStatus/,

這樣通過 [url]http://localhost/NginxStatus/[/url] 就可以監(jiān)控到 Nginx 的運(yùn)行信息,顯示的內(nèi)容如下:

Active connections: 70
server accepts handled requests
14553819 14553819 19239266
Reading: 0 Writing: 3 Waiting: 67
NginxStatus 顯示的內(nèi)容意思如下:
  • active connections – 當(dāng)前 Nginx 正處理的活動(dòng)連接數(shù)。
  • server accepts handled requests -- 總共處理了 14553819 個(gè)連接 , 成功創(chuàng)建 14553819 次握手 ( 證明中間沒有失敗的 ),
  • 總共處理了 19239266 個(gè)請(qǐng)求 ( 平均每次握手處理了 1.3 個(gè)數(shù)據(jù)請(qǐng)求 )。
  • reading -- nginx 讀取到客戶端的 Header 信息數(shù)。
  • writing -- nginx 返回給客戶端的 Header 信息數(shù)。
  • waiting -- 開啟 keep-alive 的情況下,
  • 這個(gè)值等于 active - (reading + writing),意思就是 Nginx 已經(jīng)處理完正在等候下一次請(qǐng)求指令的駐留連接。
靜態(tài)文件處理通過正則表達(dá)式,我們可讓 Nginx 識(shí)別出各種靜態(tài)文件,例如 images 路徑下的所有請(qǐng)求可以寫為: location ~ ^/images/ {
root /opt/webapp/images;
}
而下面的配置則定義了幾種文件類型的請(qǐng)求處理方式。 location ~ \.(htm|html|gif|jpg|jpeg|png|bmp|ico|css|js|txt)$ {
root /opt/webapp;
expires 24h;
}

對(duì)于例如圖片、靜態(tài) HTML 文件、js 腳本文件和 css 樣式文件等,

我們希望 Nginx 直接處理并返回給瀏覽器,這樣可以大大的加快網(wǎng)頁瀏覽時(shí)的速度。

因此對(duì)于這類文件我們需要通過 root 指令來指定文件的存放路徑,

同時(shí)因?yàn)檫@類文件并不常修改,通過 expires 指令來控制其在瀏覽器的緩存,

以減少不必要的請(qǐng)求。 expires 指令可以控制 HTTP 應(yīng)答中的“ Expires ”和“ Cache-Control ”的頭標(biāo)(起到控制頁面緩存的作用)。

您可以使用例如以下的格式來書寫 Expires:

expires 1 January, 1970, 00:00:01 GMT;
expires 60s;
expires 30m;
expires 24h;
expires 1d;
expires max;
expires off;
動(dòng)態(tài)頁面請(qǐng)求處理

Nginx 本身并不支持現(xiàn)在流行的 JSP、ASP、PHP、PERL 等動(dòng)態(tài)頁面,

但是它可以通過反向代理將請(qǐng)求發(fā)送到后端的服務(wù)器,

例如 Tomcat、Apache、IIS 等來完成動(dòng)態(tài)頁面的請(qǐng)求處理。

前面的配置示例中,我們首先定義了由 Nginx 直接處理的一些靜態(tài)文件請(qǐng)求后,

其他所有的請(qǐng)求通過 proxy_pass 指令傳送給后端的服務(wù)器(在上述例子中是 Tomcat)。最簡單的 proxy_pass 用法如下:

location / {
proxy_pass [url]http://localhost:8080;[/url]
proxy_set_header X-Real-IP $remote_addr;
}
這里我們沒有使用到集群,而是將請(qǐng)求直接送到運(yùn)行在 8080 端口的 Tomcat 服務(wù)上來完成類似 JSP 和 Servlet 的請(qǐng)求處理。

當(dāng)頁面的訪問量非常大的時(shí)候,往往需要多個(gè)應(yīng)用服務(wù)器來共同承擔(dān)動(dòng)態(tài)頁面的執(zhí)行操作,這時(shí)我們就需要使用集群的架構(gòu)。

Nginx 通過 upstream 指令來定義一個(gè)服務(wù)器的集群,

最前面那個(gè)完整的例子中我們定義了一個(gè)名為 tomcats 的集群,這個(gè)集群中包括了三臺(tái)服務(wù)器共 6 個(gè) Tomcat 服務(wù)。

而 proxy_pass 指令的寫法變成了:

location / {
proxy_pass [url]http://tomcats;[/url]
proxy_set_header X-Real-IP $remote_addr;
}

在 Nginx 的集群配置中,Nginx 使用最簡單的平均分配規(guī)則給集群中的每個(gè)節(jié)點(diǎn)分配請(qǐng)求。

一旦某個(gè)節(jié)點(diǎn)失效時(shí),或者重新起效時(shí),Nginx 都會(huì)非常及時(shí)的處理狀態(tài)的變化,以保證不會(huì)影響到用戶的訪問。

總結(jié)

盡管整個(gè)程序包只有五百多 K,但麻雀雖小、五臟俱全。 Nginx 官方提供的各種功能模塊應(yīng)有盡有,結(jié)合這些模塊可以完整各種各樣的配置要求,

例如:壓縮、防盜鏈、集群、FastCGI、流媒體服務(wù)器、 Memcached 支持、URL 重寫等等,

更關(guān)鍵的是 Nginx 擁有 Apache 和其他 HTTP 服務(wù)器無法比擬的高性能。

您甚至可以在不改變?cè)芯W(wǎng)站的架構(gòu)上,通過在前端引入 Nginx 來提升網(wǎng)站的訪問速度。

如果您的網(wǎng)站是運(yùn)行在 Linux 下,

如果您并沒有使用一些非常復(fù)雜的而且確定 Nginx 無法完成的功能,那您應(yīng)該試試 Nginx 。

    本站是提供個(gè)人知識(shí)管理的網(wǎng)絡(luò)存儲(chǔ)空間,所有內(nèi)容均由用戶發(fā)布,不代表本站觀點(diǎn)。請(qǐng)注意甄別內(nèi)容中的聯(lián)系方式、誘導(dǎo)購買等信息,謹(jǐn)防詐騙。如發(fā)現(xiàn)有害或侵權(quán)內(nèi)容,請(qǐng)點(diǎn)擊一鍵舉報(bào)。
    轉(zhuǎn)藏 分享 獻(xiàn)花(0

    0條評(píng)論

    發(fā)表

    請(qǐng)遵守用戶 評(píng)論公約

    類似文章 更多