1、下載OpenResty和Redis
OpenResty下載地址:wget http://openresty.org/download/ngx_openresty-1.4.3.6.tar.gz
Redis下載地址:wget http://download.redis.io/releases/redis-2.8.6.tar.gz
2、安裝依賴包
3、安裝OpenResty
首先安裝LuaJIT
wget http://luajit.org/download/LuaJIT-2.0.2.tar.gz
tar zxvf LuaJIT-2.0.2.tar.gz make make install export LUAJIT_LIB=/usr/local/lib export LUAJIT_INC=/usr/local/include/luajit-2.0
安裝OpenResty
tar zxvf ngx_openresty-1.4.3.6.tar.gz cd ngx_openresty-1.4.3.6 ./configure --with-luajit make make install
lua和redis等相關模塊就已經安裝完成,利用下面命令查看。
/usr/local/openresty/nginx/sbin/nginx -V
設置Nginx為服務和開機啟動
vi /etc/rc.d/init.d/nginx
#!/bin/bash # Tengine Startup script# processname: nginx # chkconfig: - 85 15 # description: nginx is a World Wide Web server. It is used to serve # pidfile: /var/run/nginx.pid # config: /usr/local/nginx/conf/nginx.conf nginxd=/usr/local/openresty/nginx/sbin/nginx nginx_config=/usr/local/openresty/nginx/conf/nginx.conf nginx_pid=/usr/local/openresty/nginx/logs/nginx.pid RETVAL=0 prog="nginx" # Source function library. . /etc/rc.d/init.d/functions # Source networking configuration. . /etc/sysconfig/network # Check that networking is up. [ ${NETWORKING} = "no" ] && exit 0 [ -x $nginxd ] || exit 0 # Start nginx daemons functions. start() { if [ -e $nginx_pid ];then echo "tengine already running...." exit 1 fi echo -n $"Starting $prog: " daemon $nginxd -c ${nginx_config} RETVAL=$? echo [ $RETVAL = 0 ] && touch /var/lock/subsys/nginx return $RETVAL } # Stop nginx daemons functions. stop() { echo -n $"Stopping $prog: " killproc $nginxd RETVAL=$? echo [ $RETVAL = 0 ] && rm -f /var/lock/subsys/nginx /usr/local/nginx/logs/nginx.pid } reload() { echo -n $"Reloading $prog: " #kill -HUP `cat ${nginx_pid}` killproc $nginxd -HUP RETVAL=$? echo } # See how we were called. case "$1" in start) start ;; stop) stop ;; reload) reload ;; restart) stop start ;; status) status $prog RETVAL=$? ;; *) echo $"Usage: $prog {start|stop|restart|reload|status|help}" exit 1 esac exit $RETVAL
保存退出
chmod 775 /etc/rc.d/init.d/nginx #賦予文件執行權限 chkconfig --level 012345 nginx on #設置開機啟動 service nginx start
4、安裝Redis
mv redis-2.8.6 redis
cd redis
make MALLOC=libc
make install
設置Redis的配置文件
vi /usr/local/redis/redis.conf
#是否作為守護進程運行 daemonize yes #如以后台進程運行,則需指定一個pid,默認為/var/run/redis.pid pidfile redis.pid #綁定主機IP,默認值為127.0.0.1 #bind 127.0.0.1 #Redis默認監聽端口 port 6379 #客戶端閑置多少秒后,斷開連接,默認為300(秒) timeout 300 #日志記錄等級,有4個可選值,debug,verbose(默認值),notice,warning loglevel verbose #指定日志輸出的文件名,默認值為stdout,也可設為/dev/null屏蔽日志 logfile stdout #可用數據庫數,默認值為16,默認數據庫為0 databases 16 #保存數據到disk的策略 #當有一條Keys數據被改變是,900秒刷新到disk一次 save 900 1 #當有10條Keys數據被改變時,300秒刷新到disk一次 save 300 10 #當有1w條keys數據被改變時,60秒刷新到disk一次 save 60 10000 #當dump .rdb數據庫的時候是否壓縮數據對象 rdbcompression yes #本地數據庫文件名,默認值為dump.rdb dbfilename dump.rdb #本地數據庫存放路徑,默認值為 ./ dir ./
調整內存分配策略
查看一下內存分配策略 cat /proc/sys/vm/overcommit_memory 注意用vi或vim是不能修改里面的值的,需要使用下面的方法 (無需重啟服務器就可生效) echo "1" >>/proc/sys/vm/overcommit_memory
該文件指定了內核針對內存分配的策略,其值可以是0、1、2。
0,表示內核將檢查是否有足夠的可用內存供應用進程使用;如果有足夠的可用內存,內存申請允許;否則,內存申請失敗,並把錯誤返回給應用進程。
1,表示內核允許分配所有的物理內存,而不管當前的內存狀態如何。
2,表示內核允許分配超過所有物理內存和交換空間總和的內存。
Redis在dump數據的時候,會fork出一個子進程,理論上child進程所占用的內存和parent是一樣的,比如parent占用的內存為 8G,這個時候也要同樣分配8G的內存給child, 如果內存無法負擔,往往會造成redis服務器的down機或者IO負載過高,效率下降。所以這里比較優化的內存分配策略應該設置為 1(表示內核允許分配所有的物理內存,而不管當前的內存狀態如何)
啟動服務
redis-server /usr/local/redis/redis.conf
通過redis-cli命令來實際操作一下
關閉服務
redis-cli shutdown 如果端口變化可以指定端口 redis-cli -p 6380 shutdown
保存/備份
數據備份可以通過定期備份該文件實現。
因為redis是異步寫入磁盤的,如果要讓內存中的數據馬上寫入硬盤可以執行如下命令:
redis-cli save 或者 redis-cli -p 6380 save(指定端口)
注意,以上部署操作需要具備一定的權限,比如復制和設定內核參數等。
執行redis-benchmark命令時也會將內存數據寫入硬盤。
設置Redis開機自啟
vi /etc/rc.d/init.d/redis
#!/bin/bash # # redis - this script starts and stops the redis-server daemon # # chkconfig: - 80 12 # description: Redis is a persistent key-value database # processname: redis-server # config: /etc/redis/redis.conf # pidfile: /var/run/redis.pid source /etc/init.d/functions BIN="/usr/local/bin" CONFIG="/usr/local/redis/redis.conf" PIDFILE="/var/run/redis.pid" ### Read configuration [ -r "$SYSCONFIG" ] && source "$SYSCONFIG" RETVAL=0 prog="redis-server" desc="Redis Server" start() { if [ -e $PIDFILE ];then echo "$desc already running...." exit 1 fi echo -n $"Starting $desc: " daemon $BIN/$prog $CONFIG RETVAL=$? echo [ $RETVAL -eq 0 ] && touch /var/lock/subsys/$prog return $RETVAL } stop() { echo -n $"Stop $desc: " killproc $prog RETVAL=$? echo [ $RETVAL -eq 0 ] && rm -f /var/lock/subsys/$prog $PIDFILE return $RETVAL } restart() { stop start } case "$1" in start) start ;; stop) stop ;; restart) restart ;; condrestart) [ -e /var/lock/subsys/$prog ] && restart RETVAL=$? ;; status) status $prog RETVAL=$? ;; *) echo $"Usage: $0 {start|stop|restart|condrestart|status}" RETVAL=1 esac exit $RETVAL
保存退出
chmod 777 /etc/rc.d/init.d/redis chkconfig redis on service redis start #stop,restart
5、在Nginx中調用lua腳本簡單讀取Redis中的數據
vi /usr/local/openresty/nginx/conf/nginx.conf
在server配置節中增加
location /test { default_type text/plain; content_by_lua_file /usr/local/test.lua; }
保存退出,然后創建lua腳本文件
vi /usr/local/test.lua
local redis = require "resty.redis" local cache = redis.new() cache.connect(cache, '127.0.0.1', '6379') local res = cache:get("foo") if res==ngx.null then ngx.say("This is Null") return end ngx.say(res)
保存退出,重啟Nginx
service nginx restart
6、測試
修改Nginx中html目錄下的index.html文件來測試,增加JQuery引用和Ajax請求
<script type="text/javascript" src="jquery-1.8.3.min.js"></script> <script type="text/javascript"> $(function() { $.ajax({ type : "GET", url : "http://192.168.0.106/test", success : function(data) { alert(data); } }); }); </script>
訪問Nginx地址 http://192.168.0.106/,如果key值為foo沒有數據時會彈出
利用redis-cli命令向Redis中增加數據
redis-cli set foo test
再訪問地址會彈出