Nginx的安裝及配置

来源:https://www.cnblogs.com/lizhongren/archive/2020/03/25/12567758.html

Nginx Nginx是個web伺服器,常用作靜態文件伺服器,反向代理伺服器,郵件代理伺服器,負載均衡伺服器 Nginx安裝 1. 安裝淘寶nginx,編譯安裝,先解決模塊依賴 yum install gcc patch libffi-devel python-devel zlib-devel bz ...


Nginx

Nginx是個web伺服器,常用作靜態文件伺服器,反向代理伺服器,郵件代理伺服器,負載均衡伺服器

 

Nginx安裝

1. 安裝淘寶nginx,編譯安裝,先解決模塊依賴

 yum install gcc patch libffi-devel python-devel zlib-devel bzip2-devel openssl-devel ncurses-devel sqlite-devel readline-devel tk-devel gdbm-devel db4-devel libpcap-devel xz-devel openssl openssl-devel -y

2. 獲取淘寶nginx的源代碼

 wget http://tengine.taobao.org/download/tengine-2.3.2.tar.gz

3. 解壓縮源代碼包

 tar -zxvf tengine-2.3.2.tar.gz

4. 進入源代碼目錄開始編譯三部曲

 ①指定安裝路徑

  ./configure --prefix=/opt/tngx

 ②編譯且安裝

  make && make install

 ③安裝完成之後,進入Nginx的目錄

  [[email protected] tngx]#pwd

  /opt/tngx

  [[email protected] tngx]#ls

  conf html logs sbin

    • conf    存放配置文件
    • html    存放前端頁面
    • logs    nginx的運行日誌
    • sbin    nginx的可執行命令目錄

  進入sbin目錄

  [[email protected] tngx]#cd sbin

    • ./nginx    啟動Nginx
    • ./nginx -s stop    停止Nginx
    • ./nginx -t    檢查nginx.conf的語法是否正確
    • ./nginx -s reload    不重啟Nginx,重新載入Nginx配置

 

Nginx配置

配置文件為conf目錄下的nginx.conf

Nginx虛擬主機

http {
    #nginx支持多虛擬主機,只需要寫入多個server關鍵字即可
    #虛擬主機1
    server {
    #基於埠的虛擬主機區分
    listen       80;
    #基於功能變數名稱的虛擬主機區分
    server_name www.asdf.com;
    #charset koi8-r;
    #access_log logs/host.access.log main;
    #access_log "pipe:rollback logs/host.access_log interval=1d baknum=7 maxsize=2G" main;

    #這裡是nginx的url匹配,如同django的url一樣
    #當請求 http://192.168.182.130:80/abc.jpg 這樣的url時,就進入如下location匹配
    #這個是最低級的匹配,所有請求都會走到這裡
    location / {
        #root關鍵字定義虛擬主機的根目錄,這裡是可以修改的
        root   /opt/abc/;
        #index參數定義首頁文件的名字
        index index.html;
    }
  }

    #虛擬主機2
    server {
    #基於埠的虛擬主機區分
    listen       81;
    #基於功能變數名稱的虛擬主機區分
    server_name www.qwer.com;
    #charset koi8-r;
    #access_log logs/host.access.log main;
    #access_log "pipe:rollback logs/host.access_log interval=1d baknum=7 maxsize=2G" main;
    #這裡是nginx的url匹配,如同django的url一樣
    #當請求 http://192.168.182.130:81/xyz.jpg 這樣的url時,就進入如下location匹配
    #這個是最低級的匹配,所有請求都會走到這裡
    location / {
        #root關鍵字定義虛擬主機的根目錄, 這裡是可以修改的
        root   /opt/xyz/;
        #index參數定義首頁文件的名字
        index index.html;
    }
  }
}

Nginx錯誤頁面404優化

server {
    listen 80;
    server_name www.asdf.com;  
    #通過error_page參數定義即可
    #404.html文件的相對路徑為root定義的目錄
    error_page 404             /404.html;
    location / {
        root   /opt/abc/;
        index index.html;
    }
  }

Nginx反向代理

  • 環境準備

    • 機器1 192.168.182.130,代理伺服器

    • 機器2 192.168.182.131,資源伺服器

  • 反向代理伺服器配置如下

    在代理伺服器的配置文件中,找到server{}虛擬主機,在location內設置proxy_pass參數

    server {
        listen       80;
        server_name www.asdf.com;
        #charset koi8-r;
        #access_log logs/host.access.log main;
        #access_log "pipe:rollback logs/host.access_log interval=1d baknum=7 maxsize=2G" main;
        location / {
            #實現反向代理的功能參數
            #實現反向代理的功能參數
            #實現反向代理的功能參數
            proxy_pass http://192.168.182.131;
        }
    }

Nginx負載均衡

  • 環境準備

    • 1台負載均衡伺服器

      • 192.168.182.130 負載均衡伺服器

    • 2台資源伺服器

      • 192.168.182.131 資源伺服器1

      • 192.168.182.132 資源伺服器2

  • 在負載均衡伺服器配置文件中,定義upstream負載均衡池

    #預設輪詢方式
    upstream test {
        server 192.168.182.131;
        server 192.168.182.132;
    }

    #權重方式
    upstream test {
        server 192.168.182.131 weight=4;
        server 192.168.182.132 weight=1;
    }

    #ip哈希方式,根據用戶的來源ip計算出哈希值,永遠只指派給一個伺服器去解析
    #ip哈希不得與權重共同使用
    upstream test {
        server 192.168.182.131;
        server 192.168.182.132;
        ip_hash;
    }
  • server{}虛擬主機在location內設置proxy_pass參數,將請求轉發給負載均衡池

    server {
        listen       80;
        server_name www.asdf.com;
        #charset koi8-r;
        #access_log logs/host.access.log main;
        #access_log "pipe:rollback logs/host.access_log interval=1d baknum=7 maxsize=2G" main;
        location / {
            #root   /opt/abc/;
            #index index.html;
            #請求轉發給負載均衡池
            #請求轉發給負載均衡池
            #請求轉發給負載均衡池
            proxy_pass http://test;
        }
    }

 


您的分享是我們最大的動力!

更多相關文章
  • 下麵的操作基於mac OS Catalina(v10.15.3),抓包攔截工具基於Burp Suite v2.1.05。 下載證書 將Burp Suite 的證書下載到本地任意一個路徑下。如果使用其它抓包工具,自行搜索一下。 mac OS導入證書 1. 打開 2. 導入 3. 設置信任 這一步一定要 ...
  • 關機重啟命令shutdown選項與參數:shutdown [-krhc] [時間] [警告信息]-k:不要真的關機,只是發送警告信息出去-r:在將系統的服務停掉之後就重新啟動(常用)-h:將系統的服務停掉後,立即關機(常用)-c:取消已經在進行的shutdown命令內容時間:指定系統關機的時間,若沒... ...
  • 一、安裝準備工作 1、查看 Linux 相關信息(Linux 命令行操作) (1)查看 Linux 版本,用於下載對應的 mysql。 【查看 Linux 信息:】 uname -a (2)檢查是否已經安裝過 mysql。 【檢查 mysql 是否被安裝】 rpm -qa | grep -i mys ...
  • 使用方法: 使用示例: ...
  • 看煩了windows系統自帶滑鼠指針,是不是想要換掉它的衝動呢? 如果是的,請跟我一起把windows系統指針換成呆萌可愛胖嘟嘟的小手指。 先看效果 首先獲得資源再說 點擊此處獲取萌萌手指 //1.打開運行界面 win + R //2.打開控制面板,在運行界面輸入control control 3. ...
  • 一 共用存儲 1.1 共用存儲作用 Kubernetes對於有狀態的容器應用或者對數據需要持久化的應用,不僅需要將容器內的目錄掛載到宿主機的目錄或者emptyDir臨時存儲捲,而且需要更加可靠的存儲來保存應用產生的重要數據,以便容器應用在重建之後仍然可以使用之前的數據。 1.2 共用存儲資源 為了能 ...
  • 1、安裝git sudo apt-get install git-core git-gui git-doc 2、在客戶端安全登陸 cd ~/.ssh 如果提示“沒有文件目錄”,說明原來沒有生成過SSH KEY,直接第4步,否則保存原來的SSH KEY ls mkdir key_backup cp i ...
  • 1. 昨天在工作的時候,由於需要查找日誌內容,但是我不清楚是哪個日誌文件,所有百度了一波,怎麼在一個目錄下查找包含某個字元串的所有文件的方法,記錄一下。 2. 目錄下的所有文件中查找字元串: grep -ri "字元串" . 字元串就是你要查找的內容,結果會顯示此路徑下,所有包含“字元串”的文件相對 ...
一周排行
  • 一、引言 按照專用隊列解釋: MachineName\Private$\QueueName,只針對於本機的程式才可以調用的隊列,有些情況下為了安全起見定義為私有隊列。所以剛開始的時候認為,要想訪問遠程消息隊列,只能使用公共隊列。但是後來發現,公共隊列依賴Domain Controller(域控),在 ...
  • 本文只對api介面,header請求參數進行簡單驗證,起到拋磚引玉使用,需要深入驗證,請自行擴展 項目目錄結構如圖 中間件類 using ApiMiddleware.Common.DataEnityModel; using ApiMiddleware.Common.DbContext; using ...
  • 前言:由於公司占時沒有運維,出於微服務的需要,Apollo只能先裝在windows 阿裡雲上跑起來,由於環境及網路等問題,在安裝過程中遇到很多坑,算是一個個坑填完後,最終實現。 一. java jdk環境 java jdk 1.8下載地址: https://www.oracle.com/java/t ...
  • 前言 nuget 是 .net 的常用包管理器,目前已經內置到 Visual Studio 2012 以後的版本。大多數 .net 包都托管在 nuget.org,包括 .net core 框架基礎包,得益於 .net core 的模塊化設計,很多非核心包都可以進行一定程度的獨立升級。 製作並上傳 ...
  • 簡單的介紹一下集合,通俗來講就是用來保管多個數據的方案。比如說我們是一個公司的倉庫管理,公司有一堆貨物需要管理,有同類的,有不同類的,總而言之就是很多、很亂。我們對照集合的概念對倉庫進行管理的話,那麼 數組就是將一堆貨整整齊齊的碼在倉庫的某個地方,普通列表也是如此;Set就是在倉庫里有這麼一個貨架, ...
  • 中間件分類 ASP.NET Core 中間件的配置方法可以分為以上三種,對應的Helper方法分別是:Run(), Use(), Map()。 Run(),使用Run調用中間件的時候,會直接返回一個響應,所以後續的中間件將不會被執行了。 Use(),它會對請求做一些工作或處理,例如添加一些請求的上下 ...
  • 字元串的常用操作 很好理解 字元串可以用 ' + ' 連接,或者乘一個常數重覆輸出字元串 字元串的索引操作 通過一對中括弧可以找到字元串中的某個字元 可以通過正負數雙向操作噢 用一個中括弧來實現 為什麼沒有-0??去清醒腦子想想 -0 和 0 有差嗎? 還有一個切片操作 就像切菜那樣簡單,同樣是中括 ...
  • title: Java基礎語法(3) 運算符 blog: "CSDN" data: "Java學習路線及視頻" 1.算術運算符 算術運算符的註意問題 如果對負數取模,可以把模數負號忽略不記,如:5% 2=1。 但被模數是負數則不可忽略。此外,取模運算的結果不一定總是整數。 對於除號“/”,它的整數除 ...
  • 下麵是互相轉換的代碼: 有想要瞭解更多關於python知識的請在下方評論或私信小編 ...
  • 引言 構建分散式系統並不容易。然而,人們日常所使用的應用大多基於分散式系統,在短時間內依賴於分散式系統的現狀並不會改變。ApacheZooKeeper旨在減輕構建健壯的分散式系統的任務。ZooKeeper基於 分散式計算的核心概念而設計,主要目的是給開發人員提供一套容易理解和開發的介面,從而簡化分佈 ...
x