Discuz! Board

 找回密码
 立即注册
搜索
热搜: 活动 交友 discuz
查看: 227|回复: 0
打印 上一主题 下一主题

CentOS6.4 安装OpenResty和Redis 并在Nginx中利用lua简单读取Redis数据

[复制链接]

85

主题

89

帖子

600

积分

管理员

Rank: 9Rank: 9Rank: 9

积分
600
跳转到指定楼层
楼主
发表于 2016-3-15 17:15:41 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
[size=13.9200000762939px]1、下载OpenResty和Redis
[size=13.9200000762939px]OpenResty下载地址:wget http://openresty.org/download/ngx_openresty-1.4.3.6.tar.gz
[size=13.9200000762939px]Redis下载地址:wget http://download.redis.io/releases/redis-2.8.6.tar.gz
[size=13.9200000762939px]2、安装依赖包
yum install -y gcc gcc-c++ readline-devel pcre-devel openssl-devel tcl perl
[size=13.9200000762939px]3、安装OpenResty
[size=13.9200000762939px]首先安装LuaJIT
wget http://luajit.org/download/LuaJIT-2.0.2.tar.gztar zxvf LuaJIT-2.0.2.tar.gzmakemake installexport LUAJIT_LIB=/usr/local/libexport LUAJIT_INC=/usr/local/include/luajit-2.0
[size=13.9200000762939px]安装OpenResty
tar zxvf ngx_openresty-1.4.3.6.tar.gzcd ngx_openresty-1.4.3.6./configure --with-luajitmakemake install
[size=13.9200000762939px]lua和redis等相关模块就已经安装完成,利用下面命令查看
/usr/local/openresty/nginx/sbin/nginx -V
[size=13.9200000762939px]
[size=13.9200000762939px]设置Nginx为服务和开机启动
vi /etc/rc.d/init.d/nginx
[url=][/url]
#!/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.confnginxd=/usr/local/openresty/nginx/sbin/nginxnginx_config=/usr/local/openresty/nginx/conf/nginx.confnginx_pid=/usr/local/openresty/nginx/logs/nginx.pidRETVAL=0prog="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 ];thenecho "tengine already running...."exit 1fiecho -n $"Starting $prog: "daemon $nginxd -c ${nginx_config}RETVAL=$?echo[ $RETVAL = 0 ] && touch /var/lock/subsys/nginxreturn $RETVAL}# Stop nginx daemons functions.stop() {echo -n $"Stopping $prog: "killproc $nginxdRETVAL=$?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 -HUPRETVAL=$?echo}# See how we were called.case "$1" instart)start;;stop)stop;;reload)reload;;restart)stopstart;;status)status $progRETVAL=$?;;*)echo $"Usage: $prog {start|stop|restart|reload|status|help}"exit 1esacexit $RETVAL[url=][/url]

[size=13.9200000762939px] 保存退出
chmod 775 /etc/rc.d/init.d/nginx   #赋予文件执行权限chkconfig  --level 012345 nginx on   #设置开机启动service nginx start
[size=13.9200000762939px]4、安装Redis
tar zxvf redis-2.8.6.tar.gz
mv redis-2.8.6 redis
cd redis
make MALLOC=libc
make install

[size=13.9200000762939px]设置Redis的配置文件
vi /usr/local/redis/redis.conf
[url=][/url]
#是否作为守护进程运行daemonize yes#如以后台进程运行,则需指定一个pid,默认为/var/run/redis.pidpidfile redis.pid#绑定主机IP,默认值为127.0.0.1#bind 127.0.0.1#Redis默认监听端口port 6379#客户端闲置多少秒后,断开连接,默认为300(秒)timeout 300#日志记录等级,有4个可选值,debug,verbose(默认值),notice,warningloglevel verbose#指定日志输出的文件名,默认值为stdout,也可设为/dev/null屏蔽日志logfile stdout#可用数据库数,默认值为16,默认数据库为0databases 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.rdbdbfilename dump.rdb#本地数据库存放路径,默认值为 ./dir ./[url=][/url]

[size=13.9200000762939px]调整内存分配策略
查看一下内存分配策略cat /proc/sys/vm/overcommit_memory 注意用vi或vim是不能修改里面的值的,需要使用下面的方法echo "1" >>/proc/sys/vm/overcommit_memory
[size=13.9200000762939px]该文件指定了内核针对内存分配的策略,其值可以是0、1、2。
0,表示内核将检查是否有足够的可用内存供应用进程使用;如果有足够的可用内存,内存申请允许;否则,内存申请失败,并把错误返回给应用进程。
1,表示内核允许分配所有的物理内存,而不管当前的内存状态如何。
2,表示内核允许分配超过所有物理内存和交换空间总和的内存。
Redis在dump数据的时候,会fork出一个子进程,理论上child进程所占用的内存和parent是一样的,比如parent占用的内存为 8G,这个时候也要同样分配8G的内存给child, 如果内存无法负担,往往会造成redis服务器的down机或者IO负载过高,效率下降。所以这里比较优化的内存分配策略应该设置为 1(表示内核允许分配所有的物理内存,而不管当前的内存状态如何)
[size=13.9200000762939px]启动服务
redis-server /usr/local/redis/redis.conf
[size=13.9200000762939px]通过redis-cli命令来实际操作一下
[size=13.9200000762939px]
[size=13.9200000762939px]关闭服务
redis-cli shutdown如果端口变化可以指定端口redis-cli -p 6380 shutdown
[size=13.9200000762939px]保存/备份
数据备份可以通过定期备份该文件实现。
因为redis是异步写入磁盘的,如果要让内存中的数据马上写入硬盘可以执行如下命令:
redis-cli save 或者 redis-cli -p 6380 save(指定端口)
注意,以上部署操作需要具备一定的权限,比如复制和设定内核参数等。
执行redis-benchmark命令时也会将内存数据写入硬盘。
[size=13.9200000762939px]设置Redis开机自启
vi /etc/rc.d/init.d/redis
[url=][/url]
#!/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.pidsource /etc/init.d/functionsBIN="/usr/local/bin"CONFIG="/usr/local/redis/redis.conf"PIDFILE="/var/run/redis.pid"### Read configuration[ -r "$SYSCONFIG" ] && source "$SYSCONFIG"RETVAL=0prog="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=1esacexit $RETVAL[url=][/url]

[size=13.9200000762939px]保存退出
chmod 777 /etc/rc.d/init.d/redischkconfig redis onservice redis start    #stop,restart
[size=13.9200000762939px]5、在Nginx中调用lua脚本简单读取Redis中的数据
vi /usr/local/openresty/nginx/conf/nginx.conf
[size=13.9200000762939px]在server配置节中增加
location /test {            default_type text/plain;            content_by_lua_file /usr/local/test.lua;        }
[size=13.9200000762939px]保存退出,然后创建lua脚本文件
vi /usr/local/test.lua
[url=][/url]
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")    returnendngx.say(res)[url=][/url]

[size=13.9200000762939px]保存退出,重启Nginx
service nginx restart
[size=13.9200000762939px]6、测试
[size=13.9200000762939px]修改Nginx中html目录下的index.html文件来测试,增加JQuery引用和Ajax请求
[url=][/url]
<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>[url=][/url]

[size=13.9200000762939px]访问Nginx地址 http://192.168.0.106/,如果key值为foo没有数据时会弹出
[size=13.9200000762939px]利用redis-cli命令向Redis中增加数据
redis-cli set foo test
[size=13.9200000762939px]再访问地址会弹出


[size=13.9200000762939px]


回复

使用道具 举报

您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

Archiver|手机版|小黑屋|Comsenz Inc.

GMT+8, 2024-12-16 07:09 , Processed in 0.051232 second(s), 20 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表