Nginx初探究:安裝與簡單使用

nginx_logo

在學習淘淘商城的過程當中接觸到了nginx,今天就把使用它的過程記錄下來,做爲留存。html

1、什麼是Nginx

Nginx是一款高性能的http服務器/反向代理服務器及電子郵件(IMAP/POP3)代理服務器。由俄羅斯的程序設計師Igor Sysoev所開發,官方測試nginx可以支支撐5萬併發連接,而且cpu、內存等資源消耗卻很是低,運行很是穩定。linux

應用場景

  • http服務器。Nginx是一個http服務能夠獨立提供http服務。能夠作網頁靜態服務器。
  • 虛擬主機。能夠實如今一臺服務器虛擬出多個網站。例如我的網站使用的虛擬主機。
  • 反向代理,負載均衡。當網站的訪問量達到必定程度後,單臺服務器不能知足用戶的請求時,須要用多臺服務器集羣可使用nginx作反向代理。而且多臺服務器能夠平均分擔負載,不會由於某臺服務器負載高宕機而某臺服務器閒置的狀況。

2、nginx安裝

1.官網下載nginx源碼。

2.外部環境準備:

  • 須要安裝gcc的環境:yum install gcc-c++
  • 第三方的開發包:
    ① PCRE(Perl Compatible Regular Expressions)是一個Perl庫,包括 perl 兼容的正則表達式庫。nginx的http模塊使用pcre來解析正則表達式,因此須要在linux上安裝pcre庫。
yum install -y pcre pcre-devel

②zlib庫提供了不少種壓縮和解壓縮的方式,nginx使用zlib對http包的內容進行gzip,因此須要在linux上安裝zlib庫。nginx

yum install -y zlib zlib-devel

③OpenSSL 是一個強大的安全套接字層密碼庫,囊括主要的密碼算法、經常使用的密鑰和證書封裝管理功能及SSL協議,並提供豐富的應用程序供測試或其它目的使用。nginx不只支持http協議,還支持https(即在ssl協議上傳輸http)c++

yum install -y openssl openssl-devel

3.正式安裝

第一步:把nginx的源碼包上傳到linux系統
第二步:解壓縮正則表達式

tar zxf nginx-1.8.0.tar.gz

第三步:使用configure命令建立一makeFile文件。
./configure \
--prefix=/usr/local/nginx \
--pid-path=/var/run/nginx/nginx.pid \
--lock-path=/var/lock/nginx.lock \
--error-log-path=/var/log/nginx/error.log \
--http-log-path=/var/log/nginx/access.log \
--with-http_gzip_static_module \
--http-client-body-temp-path=/var/temp/nginx/client \
--http-proxy-temp-path=/var/temp/nginx/proxy \
--http-fastcgi-temp-path=/var/temp/nginx/fastcgi \
--http-uwsgi-temp-path=/var/temp/nginx/uwsgi \
--http-scgi-temp-path=/var/temp/nginx/scgi
注意:以上都是一些安裝時配置nginx的一些參數,具體含義能夠自行百度。另外在啓動nginx以前,上邊將臨時文件目錄指定爲/var/temp/nginx,須要在/var下建立temp及nginx目錄算法

mkdir /var/temp/nginx/client -p

第四步:編譯,運行make命令
第五步:安裝運行make install命令
第六步:測試
進入安裝目錄下的sbin文件,運行./nginx後,打開瀏覽器訪問主機ip。
注意:①默認是80端口。②是否關閉防火牆。
nginx_1
若是出現上圖,恭喜你,nginx安裝成功。
相關命令:vim

./nginx -s stop ##關閉nginx
./nginx -s quit ##關閉nginx(推薦使用)
./nginx -s reload ##重啓nginx

3、配置虛擬主機

1.經過端口號區分虛擬主機

打開nginx的配置文件瀏覽器

vim /usr/local/nginx/conf/nginx.conf

能夠看到一個server節點,這個就是咱們配置虛擬主機的關鍵,每個此節點表明一臺主機。tomcat

server {
        listen       80;    ##端口號
        server_name  localhost;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html;    ##nginx安裝目錄下的html目錄
            index  index.html index.htm; ##每臺主機對應的頁面
        }
    }

當咱們配置了多個server,就至關於配置了多個虛擬主機。這時咱們就能夠經過不一樣的端口號來進行訪問。安全

2.經過域名區分虛擬主機

首先咱們要知道當咱們打開瀏覽器訪問每個域名的時候,每個域名對應的是一個ip地址。而且一個ip地址能夠被多個域名綁定。當咱們在本地hosts文件(C:WindowsSystem32driversetc)中配置了域名與ip的對應的映射關係時,瀏覽器就不會再去走DNS服務器
爲了方便測試,咱們先在本地hosts文件配置一下測試所用數據

192.168.71.121 www.taobao.com
192.168.21.121 www.baidu.com

而後配置兩個server節點

server {
        listen       80;
        server_name  www.taobao.com; ##不一樣域名配置

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html-taobao; ##不一樣域名訪問的不一樣文件夾
            index  index.html index.htm;
        }
    }
    server {
        listen       80;
        server_name  www.baidu.com; ##不一樣域名配置

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            root   html-baidu; ##不一樣域名訪問的不一樣文件夾
            index  index.html index.htm;
        }
    }

而後在瀏覽器上訪問這兩個地址就能夠訪問到咱們配置的兩臺虛擬主機。

4、反向代理

1.什麼是反向代理

兩個域名指向同一臺nginx服務器,用戶訪問不一樣的域名顯示不一樣的網頁內容。
兩個域名是www.sian.com.cn和www.sohu.com
nginx服務器使用虛擬機192.168.101.3

2.實現反向代理

第一步:安裝兩個tomcat,分別運行在8080和8081端口。
第二步:啓動兩個tomcat。
第三步:反向代理服務器的配置

upstream tomcat1 {
    server 192.168.25.148:8080;
    }
    server {
        listen       80;
        server_name  www.sina.com.cn;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            proxy_pass   http://tomcat1;
            index  index.html index.htm;
        }
    }
    upstream tomcat2 {
    server 192.168.25.148:8081;
    }
    server {
        listen       80;
        server_name  www.sohu.com;

        #charset koi8-r;

        #access_log  logs/host.access.log  main;

        location / {
            proxy_pass   http://tomcat2;
            index  index.html index.htm;
        }
    }

第四步:nginx從新加載配置文件
第五步:配置域名
在hosts文件中添加域名和ip的映射關係

192.168.71.121 www.sina.com.cn
192.168.71.121 www.sohu.com

5、負載均衡

若是一個服務由多條服務器提供,須要把負載分配到不一樣的服務器處理,須要負載均衡。

upstream tomcat2 {
    server 192.168.71.121:8081;
    server 192.168.71.121:8082;
  }

能夠根據服務器的實際狀況調整服務器權重。權重越高分配的請求越多,權重越低,請求越少。默認是都是1

upstream tomcat2 {
    server 192.168.71.121:8081;
    server 192.168.71.121:8082 weight=2;
    }

本文做者: catalinaLi
本文連接: http://catalinali.top/2017/he...版權聲明: 原創文章,有問題請評論中留言。非商業轉載請註明做者及出處。

相關文章
相關標籤/搜索