nginx啟動腳本
Ⅰ yum安裝Nginx是否還需要重寫啟動腳本
不需要的
Usage: /etc/init.d/nginx {start|stop|reload|configtest|status|force-reload|upgrade|restart|reopen_logs}
Ⅱ archlinux 怎麼啟動nginx
linux中nginx開機啟動設置
2015-1-24 16:20 發布者: admin 微博分享
1.新增shell腳本 vi /etc/rc.d/init.d/Nginx
bash代碼:
#! /bin/bash
# chkconfig: 35 85 15
# description: Nginx is an HTTP(S) server, HTTP(S) reverse
set -e
PATH=/usr/local/sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin
DESC="nginx daemon"
NAME=nginx
DAEMON=/usr/local/nginx/sbin/$NAME
SCRIPTNAME=/etc/init.d/$NAME
test -x $DAEMON || exit 0
d_start(){
$DAEMON || echo -n " already running"
}
d_stop() {
$DAEMON -s quit || echo -n " not running"
}
d_reload() {
$DAEMON -s reload || echo -n " counld not reload"
}
case "$1" in
start)
echo -n "Starting $DESC:$NAME"
d_start
echo "."
;;
stop)
echo -n "Stopping $DESC:$NAME"
d_stop
echo "."
;;
reload)
echo -n "Reloading $DESC configuration..."
d_reload
echo "reloaded."
;;
restart)
echo -n "Restarting $DESC: $NAME"
d_stop
sleep 2
d_start
echo "."
;;
*)
echo "Usage: $SCRIPTNAME {start|stop|restart|reload}" >&2
exit 3
;;
esac
exit 0
2.講改shell加入系統服務即可
chmod +x /etc/rc.d/init.d/nginx (設置可執行許可權)
chkconfig --add nginx (添加系統服務)
Ⅲ nginx除了php還能運行什麼腳本
lua 腳本。可以參考:
openresty, 一個 nginx + lua 的模塊插件。
Ⅳ nginx中lua腳本中=是什麼意思
Lua是一種跟JavaScript很像的語言,Ngix_Lua同樣使用非同步單線程,語法甚至比JS更加簡單,之前的評測指出,Ngix_lua的性能幾乎是Node.JS的一倍。
Nginx 特點
1.流行的高性能HTTP伺服器
2.事件驅動(非同步)架構
3.少量且可測內存佔用
4.聲明性配置語言
5.基於C的可擴展模塊
通過lua-nginx-mole即可在nginx上啟動lua腳本。
Ⅳ 如何修改lua腳本不重啟nginx
我把鏈接發到你消息裡面了。 下載完成後把lua程序解壓到任意文件夾假設是 d:\lua。 然後再修改系統環境變數PATH 在裡面添加一個d:\lua 用分號與其他路徑隔開。如何修改win環境變數你到網上搜搜。 隨後你啟動dos 輸入 lua52 abc.lua 就可以啟動lu...
Ⅵ nginx調用lua腳本,而lua腳本調用業務C程序里的函數,求大蝦貼個能運行的樣例出來,求解~~
不知道你說的 nginx 是啥
不過我可以幫你寫個 lua 調用 c函數的 事例
Ⅶ nginx 的配置文件用什麼腳本
本文詳細介紹了Nginx配置的一些參數說明,為以後的配置提供一定的幫助。有兩種方式來通過這些信號去控制
Nginx,第一是通過 logs 目錄下的 nginx.pid 查看當前運行的 Nginx 的進程 ID,通過 kill – XXX 來控制
Nginx。
AD:WOT2014課程推薦:實戰MSA:用開源軟體搭建微服務系統
檢測nginx配置文件是否正確
/usr/local/nginx/sbin/nginx -t -c nginx.conf
-c 配置文件路徑
-g Set global directives. (version >=0.7.4)
-t 檢測文件是否正確不執行
-v Print version.
-V Print nginx version, compiler version and configure parameters.
編譯時如果使用了–with-debug編譯,還可以使用error_log file [ debug_core| debug_http | debug_event …] 來獲得debug信息
通過信號對Nginx進行控制
Nginx支持下表中的信號:
信號名 作用描述
TERM, INT 快速關閉程序,中止當前正在處理的請求
QUIT 處理完當前請求後,關閉程序
HUP 重新載入配置,並開啟新的工作進程,關閉就的進程,此操作不會中斷請求
USR1 重新打開日誌文件,用於切換日誌,例如每天生成一個新的日誌文件
USR2 平滑升級可執行程序
WINCH 從容關閉工作進程
有兩種方式來通過這些信號去控制 Nginx,第一是通過 logs 目錄下的 nginx.pid 查看當前運行的 Nginx 的進程
ID,通過 kill – XXX <pid> 來控制 Nginx,其中 XXX 就是上表中列出的信號名。如果您的系統中只有一個
Nginx 進程,那您也可以通過 killall 命令來完成,例如運行 killall – s HUP nginx 來讓 Nginx
重新載入配置。
配置:
use [ kqueue | rtsig | epoll | /dev/poll | select | poll ];
FreeBSD使用kqueue,Linux選epoll.
worker_connections number 每個worker的最大連接數
Maxclient = work_processes *worker_connections
nginx的upstream目前支持4種方式的分配
1、輪詢(默認)
每個請求按時間順序逐一分配到不同的後端伺服器,如果後端伺服器down掉,能自動剔除。
2、weight
指定輪詢幾率,weight和訪問比率成正比,用於後端伺服器性能不均的情況。
2、ip_hash
每個請求按訪問ip的hash結果分配,這樣每個訪客固定訪問一個後端伺服器,可以解決session的問題。
3、fair(第三方)
按後端伺服器的響應時間來分配請求,響應時間短的優先分配。
4、url_hash(第三方)
按訪問url的hash結果來分配請求,使每個url定向到同一個後端伺服器,後端伺服器為緩存時比較有效。
代理
只需要在nginx的配置文件中增加虛擬主機,然後加入
\proxy_pass http://localhost:8000;
負載均衡:
只需要在http中增加
upstream tgcluster {#定義負載均衡設備的Ip及設備狀態
ip_hash;
server 127.0.0.1:9090 down;
server 127.0.0.1:8080 weight=2;
server 127.0.0.1:6060;
server 127.0.0.1:7070 backup;
}
在需要使用負載均衡的server中增加
proxy_pass http://tgcluster/;
每個設備的狀態設置為:
1.down 表示單前的server暫時不參與負載
2.weight 默認為1.weight越大,負載的權重就越大。
3.max_fails :允許請求失敗的次數默認為1.當超過最大次數時,返回proxy_next_upstream 模塊定義的錯誤
4.fail_timeout:max_fails次失敗後,暫停的時間。
5.backup: 其它所有的非backup機器down或者忙的時候,請求backup機器。所以這台機器壓力會最輕。
nginx支持同時設置多組的負載均衡,用來給不用的server來使用。
client_body_in_file_only 設置為On 可以講client post過來的數據記錄到文件中用來做debug
client_body_temp_path 設置記錄文件的目錄 可以設置最多3層目錄
location 對URL進行匹配.可以進行重定向或者進行新的代理 負載均衡
FASTCGI配置:
請將以下內容保存為fastcgi_params文件,保存於/usr/local/nginx/conf下(Ubuntu可保存於/etc/nginx下),他為我們的FastCGI模塊設置了基本的環境變數:
#fastcgi_params
fastcgi_param GATEWAY_INTERFACE CGI/1.1;
fastcgi_param SERVER_SOFTWARE nginx;
fastcgi_param QUERY_STRING $query_string;
fastcgi_param REQUEST_METHOD $request_method;
fastcgi_param CONTENT_TYPE $content_type;
fastcgi_param CONTENT_LENGTH $content_length;
fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name;
fastcgi_param SCRIPT_NAME $fastcgi_script_name;
fastcgi_param REQUEST_URI $request_uri;
fastcgi_param DOCUMENT_URI $document_uri;
fastcgi_param DOCUMENT_ROOT $document_root;
fastcgi_param SERVER_PROTOCOL $server_protocol;
fastcgi_param REMOTE_ADDR $remote_addr;
fastcgi_param REMOTE_PORT $remote_port;
fastcgi_param SERVER_ADDR $server_addr;
fastcgi_param SERVER_PORT $server_port;
fastcgi_param SERVER_NAME $server_name;
# PHP only, required if PHP was built with –enable-force-cgi-redirect
fastcgi_param REDIRECT_STATUS 200;
請特別注意加粗的一行,PHP-CGI特別需要此行信息來確定PHP文件的位置。
另外需要在PHP-CGI的配置文件(Ubuntu 上此配置文件位於/etc/php5/cgi/php.ini)中,打開cgi.fix_pathinfo選項:
cgi.fix_pathinfo=1;
這樣php-cgi方能正常使用SCRIPT_FILENAME這個變數。
接下來在nginx的配置中針對php文件配置其利用FastCGI進程來執行:
server {
index index.php;
root /usr/local/nginx/html;
location ~ .*.php$ {
include /usr/local/nginx/conf/fastcgi_params; #請根據自己保存的路徑進行設置
fastcgi_index index.php;
fastcgi_pass 127.0.0.1:9000; #請根據自己的FastCGI綁定的地址和埠進行配置
}
}
通知Nginx重新載入配置:
kill -HUP `cat /usr/local/nginx/logs/nginx.pid`
Ubuntu用戶可以使用init腳本:sudo /etc/init.d/nginx reload
然後啟動php-cgi -b 127.0.0.1:9000
如果出現No input file specified表示SCRIPT_FILENAME設置的有問題。
使用lighttpd的 spawn-fcgi
get http://www.lighttpd.net/download/lighttpd-1.4.18.tar.bz2 #獲取Lighttpd的源碼包
tar -xvjf lighttpd-1.4.18.tar.bz2
cd lighttpd-1.4.18
./configure #編譯
make
cp src/spawn-fcgi /usr/local/bin/spawn-fcgi #取出spawn-fcgi的程序
下面我們就可以使用 spawn-fcgi 來控制php-cgi的FastCGI進程了
/usr/local/bin/spawn-fcgi -a 127.0.0.1 -p 9000 -C 5 -u www-data -g www-data -f /usr/bin/php-cgi
參數含義如下
-f <fcgiapp> 指定調用FastCGI的進程的執行程序位置,根據系統上所裝的PHP的情況具體設置
-a <addr> 綁定到地址addr
-p <port> 綁定到埠port
-s <path> 綁定到unix socket的路徑path
-C <childs> 指定產生的FastCGI的進程數,默認為5(僅用於PHP)
-P <path> 指定產生的進程的PID文件路徑
-u和-g FastCGI使用什麼身份(-u 用戶 -g 用戶組)運行,Ubuntu下可以使用www-data,其他的根據情況配置,如nobody、apache等
Ⅷ nginx編譯安裝服務啟動腳本在哪
在你編譯是 --prefix=指定的目錄下有一個bin目錄,裡面有一個nginx啟動腳本,如果沒有指定,默認在/usr/local/nginx下,即/usr/local/nginx/sbin/nginx
Ⅸ nginx日誌切割腳本怎麼運行
第一步就是重命名日誌文件,不用擔心重命名後nginx找不到日誌文件而丟失日誌。在你未重新打開原名字的日誌文件前,nginx還是會向你重命名的文件寫日誌,linux是靠文件描述符而不是文件名定位文件。
第二步向nginx主進程發送USR1信號。
nginx主進程接到信號後會從配置文件中讀取日誌文件名稱,重新打開日誌文件(以配置文件中的日誌名稱命名),並以工作進程的用戶作為日誌文件的所有者。
重新打開日誌文件後,nginx主進程會關閉重名的日誌文件並通知工作進程使用新打開的日誌文件。
工作進程立刻打開新的日誌文件並關閉重名名的日誌文件。
然後你就可以處理舊的日誌文件了。
二、腳本實現
nginx日誌按日期自動切割腳本如下:
復制代碼代碼如下:
#nginx日誌切割腳本
#!/bin/bash
#設置日誌文件存放目錄
logs_path="/usr/local/nginx/logs/"
#設置pid文件
pid_path="/usr/local/nginx/nginx.pid"
#重命名日誌文件
mv ${logs_path}access.log ${logs_path}access_$(date -d "yesterday" +"%Y%m%d").log
#向nginx主進程發信號重新打開日誌
kill -USR1 `cat ${pid_path}`
保存以上腳本nginx_log.sh,並設置定時切割任務