編譯LNMP之nginx+php-fpm

来源:http://www.cnblogs.com/f-ck-need-u/archive/2017/10/12/7657493.html
-Advertisement-
Play Games

本文目錄:1 編譯nginx2 編譯php3 配置nginx和php-fpm交互 1. 編譯nginx rpm包格式的nginx地址:http://nginx.org/packages/源碼包下載地址:http://nginx.org/en/download.html 。本文下載的是最新穩定版ngi ...


本文目錄:
1 編譯nginx
2 編譯php
3 配置nginx和php-fpm交互

1. 編譯nginx

rpm包格式的nginx地址:http://nginx.org/packages/
源碼包下載地址:http://nginx.org/en/download.html 。本文下載的是最新穩定版nginx-1.12.1。

shell> groupadd -r nginx
shell> useradd -r -g nginx nginx
shell> wget http://nginx.org/download/nginx-1.12.1.tar.gz
shell> tar xf nginx-1.12.1.tar.gz
shell> cd nginx-1.12.1
shell> ./configure \
  --user=nginx \
  --group=nginx \
  --prefix=/usr/local/nginx-1.12.1 \
  --error-log-path=/var/log/nginx/error.log \
  --http-log-path=/var/log/nginx/access.log \
  --pid-path=/var/run/nginx/nginx.pid  \
  --lock-path=/var/lock/subsys/nginx \
  --with-http_ssl_module \
  --with-http_flv_module \
  --with-http_stub_status_module \
  --with-http_gzip_static_module \
  --with-pcre \
  --with-threads 

shell> make && make install
shell> ln -s /usr/local/nginx-1.12.0 /usr/local/nginx

./configure過程中,--with-XX_module的表示啟用某模塊即功能,--without-XX_module表示禁用模塊即功能。在./configure --help的結果中,出現--with-XX_module的表示XX模塊預設是禁用的,需要手動啟用,出現--without-XX_module表示XX模塊預設是啟用的,需要手動禁用。以下是一些常見選項的說明:

--prefix=/usr/local/nginx-1.12.0             # 定義安裝路徑,不寫時預設為/usr/local/nginx
--sbin-path=                                 # 定義應用程式存放路徑,不寫時預設為<prefix>/sbin/nginx
--conf-path=                                 # 定義配置文件路徑,不寫時預設為<prefix>/conf/nginx.conf
--error-log-path=/var/log/nginx/error.log    # 在配置文件中沒有指定error log時的錯誤日誌路徑,不寫時預設為<prefix>/logs/error.log
--http-log-path=/var/log/nginx/access.log    # 在配置文件中沒有指定access log時的訪問日誌路徑, 不寫時預設為<prefix>/logs/access.log
--pid-path=/var/run/nginx/nginx.pid          # pid文件路徑,沒指定時預設為<prefix>/logs/nginx.pid
--lock-path=/var/lock/subsys/nginx           # 鎖文件路徑
--user=nginx                                 # 在配置文件中沒有指定user指定時,worker進程的運行身份,不寫時預設為nobody
--group=nginx                                # 在配置文件中沒有指定user(不是group,配置文件中沒有group指令)指定時,worker進程的運行組

--with-select_module       # 啟用select方法模型,當找不到epoll時自動啟用select
--without-select_module   
--with-poll_module         # 啟用poll方法模型,當找不到epoll時自動啟用poll
--without-poll_module  

--with-http_ssl_module            # 啟用ssl功能
--with-http_flv_module            # 啟用flv視頻流功能
--with-http_stub_status_module    # 啟用nginx狀態監控功能,在啟動後在瀏覽器使用root/status顯示狀態信息
--with-http_gzip_static_module    # 啟用gzip壓縮功能壓縮web伺服器響應客戶端的響應報文
--http-client-body-temp-path=/var/tmp/nginx/client   # 定義客戶端請求報文主體的臨時文件存放路徑,不寫為<prefix>/client_body_temp
--http-proxy-temp-path=/var/tmp/nginx/proxy          # 定義從代理伺服器收到的臨時文件存放路徑,不寫為<prefix>/proxy_temp
--http-fastcgi-temp-path=/var/tmp/nginx/fcgi         # 定義從fastcgi伺服器收到的臨時文件存放路徑,不寫為<prefix>/fastcgi_temp
--http-uwsgi-temp-path=/var/tmp/nginx/uwsgi          # 定義從uwsgi伺服器收到的臨時文件存放路徑,不寫為<prefix>/uwsgi_temp
--http-scgi-temp-path=/var/tmp/nginx/scgi            # 定義從scgi伺服器收到的臨時文件存放路徑,不寫為<prefix>/scgi_temp
--with-pcre                                          # 設置pcre庫的路徑,yum安裝的pcre-devel可以不寫路徑
--with-threads                                       # 設置nginx支持多線程

在前面的編譯選項中,安裝路徑使用了版本號,且未指定程式目錄和配置文件路徑,雖說提供了它們很方便,但是在升級nginx版本有些麻煩。所以,通過最後一步建立軟鏈接的方式,讓一切都變得簡單,可以將新舊版本的nginx分離開來。這種方式安裝nginx,配置文件預設為/conf/nginx.conf,應用程式路徑為/sbin/nginx。

提供服務管理腳本/etc/rc.d/init.d/nginx。

#!/bin/sh
#
# nginx - this script starts and stops the nginx daemon
#
# chkconfig:   - 85 15
# description:  Nginx is an HTTP(S) server, HTTP(S) reverse \
#               proxy and IMAP/POP3 proxy server

# Source function library.
. /etc/rc.d/init.d/functions

# Source networking configuration.
. /etc/sysconfig/network

# Check that networking is up.
[ "$NETWORKING" = "no" ] && exit 0

nginx="/usr/local/nginx/sbin/nginx"
prog=$(basename $nginx)

sysconfig="/etc/sysconfig/$prog"
lockfile="/var/lock/subsys/nginx"
pidfile="/var/run/nginx/nginx.pid"

NGINX_CONF_FILE="/usr/local/nginx/conf/nginx.conf"

[ -f $sysconfig ] && . $sysconfig


start() {
    [ -x $nginx ] || exit 5
    [ -f $NGINX_CONF_FILE ] || exit 6
    echo -n $"Starting $prog: "
    daemon $nginx -c $NGINX_CONF_FILE
    retval=$?
    echo
    [ $retval -eq 0 ] && touch $lockfile
    return $retval
}

stop() {
    echo -n $"Stopping $prog: "
    killproc -p $pidfile $prog
    retval=$?
    echo
    [ $retval -eq 0 ] && rm -f $lockfile
    return $retval
}

restart() {
    configtest_q || return 6
    stop
    start
}

reload() {
    configtest_q || return 6
    echo -n $"Reloading $prog: "
    killproc -p $pidfile $prog -HUP
    echo
}

configtest() {
    $nginx -t -c $NGINX_CONF_FILE
}

configtest_q() {
    $nginx -t -q -c $NGINX_CONF_FILE
}

rh_status() {
    status $prog
}

rh_status_q() {
    rh_status >/dev/null 2>&1
}

# Upgrade the binary with no downtime.
upgrade() {
    local oldbin_pidfile="${pidfile}.oldbin"

    configtest_q || return 6
    echo -n $"Upgrading $prog: "
    killproc -p $pidfile $prog -USR2
    retval=$?
    sleep 1
    if [[ -f ${oldbin_pidfile} && -f ${pidfile} ]];  then
        killproc -p $oldbin_pidfile $prog -QUIT
        success $"$prog online upgrade"
        echo 
        return 0
    else
        failure $"$prog online upgrade"
        echo
        return 1
    fi
}

# Tell nginx to reopen logs
reopen_logs() {
    configtest_q || return 6
    echo -n $"Reopening $prog logs: "
    killproc -p $pidfile $prog -USR1
    retval=$?
    echo
    return $retval
}

case "$1" in
    start)
        rh_status_q && exit 0
        $1
        ;;
    stop)
        rh_status_q || exit 0
        $1
        ;;
    restart|configtest|reopen_logs)
        $1
        ;;
    force-reload|upgrade) 
        rh_status_q || exit 7
        upgrade
        ;;
    reload)
        rh_status_q || exit 7
        $1
        ;;
    status|status_q)
        rh_$1
        ;;
    condrestart|try-restart)
        rh_status_q || exit 7
        restart
        ;;
    *)
        echo $"Usage: $0 {start|stop|reload|configtest|status|force-reload|upgrade|restart|reopen_logs}"
        exit 2
esac

如果是systemd管理,則提供/usr/lib/systemd/system/nginx.service。

[Unit]
Description=The nginx HTTP and reverse proxy server
After=network.target remote-fs.target nss-lookup.target

[Service]
Type=forking
PIDFile=/var/run/nginx/nginx.pid
# Nginx will fail to start if /run/nginx.pid already exists but has the wrong
# SELinux context. This might happen when running `nginx -t` from the cmdline.
# https://bugzilla.redhat.com/show_bug.cgi?id=1268621
ExecStartPre=/usr/bin/rm -f /var/run/nginx/nginx.pid
ExecStartPre=/usr/local/nginx/sbin/nginx -t -c /usr/local/nginx/conf/nginx.conf
ExecStart=/usr/local/nginx/sbin/nginx -c /usr/local/nginx/conf/nginx.conf
ExecReload=/bin/kill -s HUP $MAINPID
KillSignal=SIGQUIT
TimeoutStopSec=5
KillMode=process
PrivateTmp=true

[Install]
WantedBy=multi-user.target

最後,將nginx命令加入環境變數。

shell> echo 'export PATH=/usr/local/nginx/sbin:$PATH' > /etc/profile.d/nginx.sh
shell> . /etc/profile.d/nginx.sh

2. 編譯PHP

此處只給編譯步驟,具體編譯細節和編譯選項說明見:編譯php

yum install -y bzip2-level libmcrypt-devel openssl-devel libxml2-devel

tar xf php-5.5.38.tar.bz2 -C /tmp
cd /tmp/php-5.5.38
./configure --prefix=/usr/local/php --with-openssl --enable-mbstring --enable-sockets --with-freetype-dir --with-jpeg-dir --with-png-dir --with-libxml-dir=/usr --enable-xml --with-zlib --with-mcrypt --with-bz2 --with-mhash --with-config-file-path=/etc --with-config-file-scan-dir=/etc/php.d --with-mysql=mysqlnd --with-mysqli=mysqlnd --with-pdo-mysql=mysqlnd --enable-fpm

make
make install

# 提供php配置文件
cp php.ini-production /etc/php.ini

# 提供php-fpm服務管理腳本
cp sapi/fpm/init.d.php-fpm /etc/init.d/php-fpmd
chmod +x /etc/init.d/phpfpmd

# 提供php-fpm配置文件
cd /usr/local/php/
cp etc/php-fpm.conf.default etc/php-fpm.conf

# 修改php-fpm配置文件(做實驗的話改不改隨意)
vim etc/php-fpm.conf
pm.max_children = 50
pm.start_servers = 5
pm.min_spare_servers = 2
pm.max_spare_servers = 8

# 啟動php-fpm
service php-fpmd start

3. 配置nginx和php-fpm交互

在nginx配置文件中加入類似如下location容器。

location ~ \.php$ {
    root           /php/;
    fastcgi_pass   192.168.100.16:9000;
    fastcgi_index  index.php;
    fastcgi_param  SCRIPT_FILENAME  $document_root$fastcgi_script_name;
    include        fastcgi_params;
}

該location表示當請求的url能匹配以.php結尾時,將以該容器的指令進行處理。root指令將此容器的document_root設置為/php/,fastcgi_pass指令表示將該url請求代理至192.168.100.16主機上運行的php-fpm,由於此處設置了SCRIPT_FILENAME,所以當請求的uri為/a/a.php時,$document_root=/php/,$fastcgi_script_name=/a/a.php,這表示轉發請求至192.168.100.16主機上的/php/a/a.php。所以,在php-fpm所在主機192.168.100.16上必須將a.php放在事先已創建好的/php/目錄下,這和nginx主機上是否有/php/目錄無關。

這裡的include包含的文件都是一些fastcgi_param指令,fastcgi_param指令是nginx將相關參數賦值給php-fpm所需變數,並將它們傳遞給php-fpm,使得php-fpm知道處理哪個文件、如何處理、處理的環境是如何的。

此處額外定義了一個php-fpm所需的變數SCRIPT_FILENAME,因為該變數沒有包含在fastcgi_params文件中。如果是rpm包安裝的nginx,則在fastcgi.conf文件中已包含該變數,此時簡寫為如下配置即可:

location ~ \.php$ {
    root           /php/;
    fastcgi_pass   192.168.100.16:9000;
    fastcgi_index  index.php;
    include        fastcgi.conf;
}

還需註意,fastcgi_index在此處是多餘的。該指令表示的是當代理請求至php-fpm上時,如果uri以"/"結尾(嚴格地說,是$fastcgi_script_name的值以斜線結尾),則自動添加上此處指定的index.php。但註意,此處的location的匹配條件是以.php結尾,是不可能匹配以斜線結尾的,因此此處的fastcgi_index指令是多餘的。但如果修改為如下配置:

location ~ .*php {
    root           /php/;
    fastcgi_pass   192.168.100.16:9000;
    fastcgi_index  index.php;
    include        fastcgi.conf;
}

則fastcgi_index是能派上用場的,例如請求的uri為"/a/php/",則將執行192.168.100.16上的/php/a/php/index.php文件。

回到Linux系列文章大綱:http://www.cnblogs.com/f-ck-need-u/p/7048359.html

回到網站架構系列文章大綱:http://www.cnblogs.com/f-ck-need-u/p/7576137.html

回到資料庫系列文章大綱:http://www.cnblogs.com/f-ck-need-u/p/7586194.html

轉載請註明出處:http://www.cnblogs.com/f-ck-need-u/p/7657493.html

註:若您覺得這篇文章還不錯請點擊右下角推薦,您的支持能激發作者更大的寫作熱情,非常感謝!


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

-Advertisement-
Play Games
更多相關文章
  • MongoDB資料庫基本用法 用戶相關 1、添加一個用戶 2、資料庫認證、安全模式 db.auth("userName", "123123"); 3、顯示當前所有用戶 show users; 4、刪除用戶 db.removeUser("userName"); show dbs:顯示資料庫列表 sho ...
  • fileclear.sh task.crontab task.null.crontab是一個沒有內容的空文件 開啟定時任務 停止定時任務 crontab [-u username] [-l|-e|-r] 參數: -u: 只有root才能進行這個任務,也即幫其他用戶新建/刪除crontab工作調度; ...
  • linux內核提供了一個container_of()巨集,可以根據結構體某個成員的地址找到父結構的地址。 而在Nginx也是效仿採用一樣的巨集獲取父結構地址。 ...
  • nginx可以在不停止服務的情況下,升級更新自己的bin文件,那這些是怎麼實現的呢,讓我們看一下nginx的源碼 ...
  • 前言:DNS,耳熟能詳的東西,內容太多,小編也不太好講清,只能寫幾個實驗詳解,供大家參考。 一、簡單介紹 1、DNS:通過主機名,最終得到該主機名對應的IP地址的過程叫做功能變數名稱解析(或主機名解析)。 埠號:53/udp, 53/tcp 2、等級 根域 :世界有13個ip地址管理,有10個在美國,1個 ...
  • 能在Linux中運行的文本編輯器很多,每個人喜歡的也不一樣。各種不同的Linux發行版一定會內置Vi編輯器,其它編輯器可能不會內置,需要自己安裝。所以必須學會Vi的使用,以應對在新的Linux環境。Vim編輯器是Vi編輯器的升級版,功能比Vi強大,並且相容Vi的操作。所以我就直接學習Vim編輯器。( ...
  • 在說明如何穩定安全地升級、降級已經在運行中的nginx之前,需要先瞭解nginx支持的幾種信號。以下幾種是主進程可以接收的信號,註意worker進程也可以接收一些信號,但和主進程的信號處理機制有些不一樣,且主進程支持的信號worker進程不一定支持。具體可見man nginx。 graceful s ...
  • 當程式在測試或者老化的時候很有用,只要程式有異常拋出,就能啟用windbg調試,這樣就能及時的保存現場。 程式崩潰時,windows系統會調用系統預設調試器,其設置在註冊表 HKEY_LOCAL_MACHINE\SOFTWARE\Microsoft\Windows NT\CurrentVersion ...
一周排行
    -Advertisement-
    Play Games
  • 移動開發(一):使用.NET MAUI開發第一個安卓APP 對於工作多年的C#程式員來說,近來想嘗試開發一款安卓APP,考慮了很久最終選擇使用.NET MAUI這個微軟官方的框架來嘗試體驗開發安卓APP,畢竟是使用Visual Studio開發工具,使用起來也比較的順手,結合微軟官方的教程進行了安卓 ...
  • 前言 QuestPDF 是一個開源 .NET 庫,用於生成 PDF 文檔。使用了C# Fluent API方式可簡化開發、減少錯誤並提高工作效率。利用它可以輕鬆生成 PDF 報告、發票、導出文件等。 項目介紹 QuestPDF 是一個革命性的開源 .NET 庫,它徹底改變了我們生成 PDF 文檔的方 ...
  • 項目地址 項目後端地址: https://github.com/ZyPLJ/ZYTteeHole 項目前端頁面地址: ZyPLJ/TreeHoleVue (github.com) https://github.com/ZyPLJ/TreeHoleVue 目前項目測試訪問地址: http://tree ...
  • 話不多說,直接開乾 一.下載 1.官方鏈接下載: https://www.microsoft.com/zh-cn/sql-server/sql-server-downloads 2.在下載目錄中找到下麵這個小的安裝包 SQL2022-SSEI-Dev.exe,運行開始下載SQL server; 二. ...
  • 前言 隨著物聯網(IoT)技術的迅猛發展,MQTT(消息隊列遙測傳輸)協議憑藉其輕量級和高效性,已成為眾多物聯網應用的首選通信標準。 MQTTnet 作為一個高性能的 .NET 開源庫,為 .NET 平臺上的 MQTT 客戶端與伺服器開發提供了強大的支持。 本文將全面介紹 MQTTnet 的核心功能 ...
  • Serilog支持多種接收器用於日誌存儲,增強器用於添加屬性,LogContext管理動態屬性,支持多種輸出格式包括純文本、JSON及ExpressionTemplate。還提供了自定義格式化選項,適用於不同需求。 ...
  • 目錄簡介獲取 HTML 文檔解析 HTML 文檔測試參考文章 簡介 動態內容網站使用 JavaScript 腳本動態檢索和渲染數據,爬取信息時需要模擬瀏覽器行為,否則獲取到的源碼基本是空的。 本文使用的爬取步驟如下: 使用 Selenium 獲取渲染後的 HTML 文檔 使用 HtmlAgility ...
  • 1.前言 什麼是熱更新 游戲或者軟體更新時,無需重新下載客戶端進行安裝,而是在應用程式啟動的情況下,在內部進行資源或者代碼更新 Unity目前常用熱更新解決方案 HybridCLR,Xlua,ILRuntime等 Unity目前常用資源管理解決方案 AssetBundles,Addressable, ...
  • 本文章主要是在C# ASP.NET Core Web API框架實現向手機發送驗證碼簡訊功能。這裡我選擇是一個互億無線簡訊驗證碼平臺,其實像阿裡雲,騰訊雲上面也可以。 首先我們先去 互億無線 https://www.ihuyi.com/api/sms.html 去註冊一個賬號 註冊完成賬號後,它會送 ...
  • 通過以下方式可以高效,並保證數據同步的可靠性 1.API設計 使用RESTful設計,確保API端點明確,並使用適當的HTTP方法(如POST用於創建,PUT用於更新)。 設計清晰的請求和響應模型,以確保客戶端能夠理解預期格式。 2.數據驗證 在伺服器端進行嚴格的數據驗證,確保接收到的數據符合預期格 ...