1. 程式人生 > >mac下配置nginx

mac下配置nginx

nginx是一個高效能的HTTP和反向代理伺服器,也是一個IMAP/POP3/SMTP伺服器,下面我們來了解下nginx的用法。

安裝nginx

首先需要安裝homebrew,可以參考該篇博文的第一步,安裝好homebrew後,就可以使用brew安裝nginx了。

brew search nginx

如果已經安裝nginx,則上面會顯示一個對號,如圖所示:
檢視是否安裝nginx
如果沒有安裝,則可以繼續下一步:

brew install nginx

耐心等待nginx的安裝,安裝完成後我們就可以進行nginx的配置了。

配置nginx

mac下nginx的配置檔案在:

/usr/local
/etc/nginx/nginx.conf

開啟nginx.conf,就可以做相關的配置了。
nginx配置詳解:

#定義Nginx執行的使用者和使用者組,來指定Nginx Worker程序執行使用者以及使用者組,預設由nobody賬號執行
user ***;

#nginx程序數,建議設定為等於CPU總核心數。
worker_processes 4;

#全域性錯誤日誌定義型別,[ debug | info | notice | warn | error | crit ],其中debug輸出日誌最為最詳細,而crit輸出日誌最少
error_log logs/error.log info;

#程序檔案,用來指定程序id的儲存檔案位置
pid logs/nginx.pid; #一個nginx程序開啟的最多檔案描述符數目,理論值應該是最多開啟檔案數(系統的值ulimit -n)與nginx程序數相除,但是nginx分配請求並不均勻,所以建議與ulimit -n的值保持一致,可以使用命令“ulimit -n 65535”來設定其他值。 worker_rlimit_nofile 4864; #工作模式與連線數上限 events { #參考事件模型,use [ kqueue | rtsig | epoll | /dev/poll | select | poll ]; epoll模型是Linux 2.6以上版本核心中的高效能網路I/O模型,如果跑在FreeBSD上面,就用kqueue模型。
use epoll; #mac平臺用kqueue,對於Linux系統,epoll工作模式是首選 #worker_connections用於定義Nginx每個程序的最大連線數,即接收前端的最大請求數,預設是1024。最大客戶端連線數由worker_processes和worker_connections決定,即Max_clients=worker_processes*worker_connections,在作為反向代理時,Max_clients變為:Max_clients = worker_processes * worker_connections/4。 程序的最大連線數受Linux系統程序的最大開啟檔案數限制,在執行作業系統命令“ulimit -n 65536”後worker_connections的設定才能生效 worker_connections 1024; } #設定http伺服器 http { #來用設定檔案的mime型別,型別在配置檔案目錄下的mime.type檔案定義,來告訴nginx來識別檔案型別。 include mime.types; default_type application/octet-stream; #預設檔案型別 #charset utf-8; #預設編碼 #用於設定日誌的格式,和記錄哪些引數,這裡設定為main,剛好用於access_log來紀錄這種型別 #log_format main '$remote_addr - $remote_user [$time_local] "$request" ' #'$status $body_bytes_sent "$http_referer" ' #'"$http_user_agent" "$http_x_forwarded_for"'; sendfile on; #開啟高效檔案傳輸模式,sendfile指令指定nginx是否呼叫sendfile函式來輸出檔案,對於普通應用設為 on,如果用來進行下載等應用磁碟IO重負載應用,可設定為off,以平衡磁碟與網路I/O處理速度,降低系統的負載。注意:如果圖片顯示不正常把這個改成off。 autoindex on; #開啟目錄列表訪問,合適下載伺服器,預設關閉。 tcp_nopush on; #防止網路阻塞 tcp_nodelay on; #防止網路阻塞 keepalive_timeout 120; #長連線超時時間,單位是秒 #FastCGI相關引數是為了改善網站的效能:減少資源佔用,提高訪問速度。下面引數看字面意思都能理解。 fastcgi_connect_timeout 300; fastcgi_send_timeout 300; fastcgi_read_timeout 300; fastcgi_buffer_size 64k; fastcgi_buffers 4 64k; fastcgi_busy_buffers_size 128k; fastcgi_temp_file_write_size 128k; #gzip模組設定 gzip on; #開啟gzip壓縮輸出 gzip_min_length 1k; #最小壓縮檔案大小 gzip_buffers 4 16k; #壓縮緩衝區 gzip_http_version 1.0; #壓縮版本(預設1.1,前端如果是squid2.5請使用1.0) gzip_comp_level 2; #壓縮等級 gzip_types text/plain application/x-javascript text/css application/xml; #壓縮型別,預設就已經包含text/html,所以下面就不用再寫了,寫上去也不會有問題,但是會有一個warn。 gzip_vary on; #limit_zone crawler $binary_remote_addr 10m; #開啟限制IP連線數的時候需要使用 upstream blog.ha97.com { #upstream的負載均衡,weight是權重,可以根據機器配置定義權重。weigth引數表示權值,權值越高被分配到的機率越大。 server 192.168.80.121:80 weight=3; server 192.168.80.122:80 weight=2; server 192.168.80.123:80 weight=3; } #虛擬主機的配置 server { #監聽埠 listen 80; #域名可以有多個,用空格隔開 server_name www.***.com ***.com; index index.html index.htm index.php; #表示在這整個server虛擬主機內,全部的root web根目錄。注意要和locate {}下面定義的區分開來 root /data/www/***; location /mp/ { proxy_pass http://127.0.0.1:8080; proxy_set_header Host $host; } location / { proxy_pass http://192.168.200.248:80; proxy_set_header Host $host; } add_header Access-Control-Allow-Origin "*"; } }

後期補充nginx負載均衡和反向代理的詳解。

nginx常用命令

啟動nginx:

sudo nginx

判斷配置檔案是否正確

sudo nginx -t

停止nginx:

sudo nginx -s stop

重啟nginx:

sudo nginx -s reload