openstry lua redis实现负载均衡
需求:
通过URI地址http://10.0.0.148/test2?uuid=123的uuid参数值的第一位,去实现redis的负载均衡
若uuid第一位为1,那么去10.0.0.148的redis,若uuid第一位为2,那么去10.0.0.248的redis
测试的时候148的redis里给foo赋值kkk(./redis-cli set foo kkk),248的不赋值
这里10.0.0.148既是nginx服务器,也是redis服务器
方法一:通过加载lua文件的方式
test2.lua
--使用require来加载模块名--
local redis = require "resty.redis" --创建一个对象--
local cache = redis.new() --获取URI里的参数uuid
local arg = ngx.var.arg_uuid --截取参数值的第一个字符
local uuid_f = string.sub(arg,,) --将第一个参数值转换为整形
uuid_f=tonumber(uuid_f) --通过列表定义redis的IP
local numbers = {[]="10.0.0.148",[]="10.0.0.248"} --根据uuid的不同参数值去连接不同的redis服务器
local ok,err = cache.connect(cache,numbers[uuid_f],'') --判断是否能连接上
if not ok then
ngx.say("failed to connect:",err)
return
end --测试获取redis的foo变量的值
local res = cache:get("foo")
if res==ngx.null then
ngx.say("This is null")
else
ngx.say(res)
end cache:close()
在nginx.conf中添加如下配置:
location /test2 {
default_type text_plain;
content_by_lua_file /usr/local/test2.lua;
}
测试结果:
#user nobody;
worker_processes ; #pid logs/nginx.pid; events {
worker_connections ;
} http {
include mime.types;
default_type application/octet-stream; sendfile on; keepalive_timeout ; init_by_lua '
redis = require "resty.redis"
numbers = {[""]="10.0.0.148",[""]="10.0.0.248"}
'; server {
listen ;
server_name localhost; location / {
root html;
index index.html index.htm;
} location /echo {
default_type text/plain;
echo hello lua;
} location /test {
default_type text_plain;
content_by_lua 'ngx.say("Hi lile")';
}
location /re {
default_type text_plain;
content_by_lua '
local headers = ngx.req.get_headers()
local ip = headers["X-REAL-IP"] or headers["X_FORWARDED_FOR"] or ngx.var.remote_addr or "0.0.0.0"
ngx.say(ip.."#"..os.time().."")
';
} location /test2 {
#default_type application/json;
default_type text_plain;
content_by_lua '
local redis_client = redis.new()
local arg = ngx.var.arg_uuid
local uuid_f = string.sub(arg,,)
local ok,err=redis_client.connect(redis_client,numbers[uuid_f],"")
if not ok then
ngx.say("failed to connect:",err)
return
end local res = redis_client:get("foo") if res==ngx.null then
ngx.say("This is null")
else
ngx.say(res)
end redis_client:close()
';
} error_page /50x.html;
location = /50x.html {
root html;
}
}
}
总结:
从昨天开始弄这个的时候,完全没接触过啊,redis 是数据库都不知道,只知道这个名字,lua也是第一次听啊,nginx一直想好好研究一下,但是都没行动过,然后就使劲的在网上找资料,发现基本上都一样,弄的很复杂很复杂,今天早上来,不知道为啥,突然就大脑很清醒,想的很简单,没想到反而这样可以,可能是昨晚睡得比较好,精神也好,最近被达康书记给迷倒了,每天熬夜追剧,话说真的睡眠真的可以让你精神倍儿好,心情也会好。nginx通过lua,根据自己的规则去访问redis服务器,首先我肯定得用lua实现nginx与redis的连接,所以就有那个加载模块,创建对象,连接这几个步骤,这相当于只有你想连上redis,你就得这么做,然后我要根据参数来定规则,我肯定得获取这个参数的值,然后进行转换....当然,这只是事后的想法,现在都不相信我居然弄了这个,虽然过两天,这些又忘了,但是至少我知道有这个东西,知道怎么分析问题,而不是一个劲的去搜怎么做。
openstry lua redis实现负载均衡的更多相关文章
- Nginx+Tomcat+Redis实现负载均衡、资源分离、session共享
Nginx+Tomcat+Redis实现负载均衡.资源分离.session共享 CentOS安装Nginx http://centoscn.com/CentosServer/www/2013/0910 ...
- keepalived+nginx+tomcat+redis实现负载均衡和session共享(原创)
keepalived+nginx+tomcat+redis实现负载均衡和session共享 直接上链接,码了一天,就不再重写了,希望能帮到大家,有问题欢迎留言交流.
- Nginx+Tomca+Redis实现负载均衡、资源分离、session共享
目标实现:Nginx作为负载均衡后端多Tomcat实例,通过Redis实现Session共享. 操作系统环境:CentOS 6.8 SSH:SecureCRT 其中 Nginx服务:80端口 Tomc ...
- 如何运用PHP+REDIS解决负载均衡后的session共享问题
一.为什么要使用Session共享? 稍大一些的网站,通常都会有好几个服务器,每个服务器运行着不同功能的模块,使用不同的二级域名,而一个整体性强的网站,用户系统是统一的,即一套用户名.密码在整个网站的 ...
- windows系统下nginx+tomcat+redis做负载均衡和session粘滞附整套解决方案
Nginx: 在nginx-1.8.0\conf目录下找到nginx.conf文件,打开文件修改文件中http{}中的内容,在http{}中加入 upstream localhost { serve ...
- logstash+redis收集负载均衡模式下多台服务器的多个web日志
一.logstash的简介 一般我们看日志来解决问题的时候要么 tail+grep 要么 把日志下载下来再搜索,可以应付不多的主机和应用不多的部署场景.但对于多机多应用部署就不合适了.这里的多机多应用 ...
- asp.net core 实战之 redis 负载均衡和"高可用"实现
1.概述 分布式系统缓存已经变得不可或缺,本文主要阐述如何实现redis主从复制集群的负载均衡,以及 redis的"高可用"实现, 呵呵双引号的"高可用"并不是 ...
- net core 实战之 redis 负载均衡和"高可用"实现
net core 实战之 redis 负载均衡和"高可用"实现 1.概述 分布式系统缓存已经变得不可或缺,本文主要阐述如何实现redis主从复制集群的负载均衡,以及 redis的& ...
- Redis多服务器负载均衡的实现
集群是一组相互独立的.通过高速网络互联的计算机,它们构成了一个组,并以单一系统的模式加以管理.一个客户与集群相互作用时,集群像是一个独立的服务器.集群配置是用于提高可用性和可缩放性. 上图是三个主服务 ...
随机推荐
- grade配置添加java库导致报 java.lang.RuntimeException: java.lang.RuntimeException: com.android.builder.dexing.DexArchiveMerger
原因是导入的第三方库中也引入了项目中存在的相同名称的库,导致产生冲突
- [Struts2] <s:property>标签
调用类中的属性,通过get方法调用,而非其属性名调用. 比如A类中有属性a1,a1的get方法是getA1Method(); 相应Action类中的get方法是getA1Action(). 那么需要通 ...
- [数据结构]P2.1 二叉搜索树
二叉树就是每个节点最多有两个分叉的树.这里我们写一写一个典型的例子二叉搜索树,它存在的实际意义是什么呢? 在P1.1链表中,我们清楚了链表的优势是善于删除添加节点,但是其取值很慢:数组的优势是善于取值 ...
- 雷林鹏分享:jQuery EasyUI 数据网格 - 启用行内编辑
jQuery EasyUI 数据网格 - 启用行内编辑 可编辑的功能是最近添加到数据网格(datagrid)的.它可以使用户添加一个新行到数据网格(datagrid).用户也可以更新一个或多个行. 本 ...
- mysql 常用sql语句
权限 撤销权限revoke all on *.* from 'root'@'192.168.0.197' ; 撤销权限revoke all on *.* from 'xx_db' @'%'; 给指定用 ...
- 菜鸟脱壳之脱壳的基础知识(三)——寻找OEP
这节我们来讲讲如何寻找一个程序的OEP,即Original Entry Point.一些PE加壳程序在被加密的程序上面加了一个区段(有的壳也会合并区段),当外壳代码执行完毕以后,会跳到程序的本身的代码 ...
- 基于FPGA的1553B通信模块的设计(转)
reference:http://www.21ic.com/app/eda/201808/798483.htm https://www.milstd1553.com/ [导读] 摘 要: 提出一种将F ...
- 一、JAVA变量类型:①类变量与实例变量的异同点
在JAVA中,变量使用前必须声明,格式如下: int a; //单个变量声明 int b, c, d; //多个变量一起声明 int e = 1, f = 2, g = 3; //声明时同时赋值(初始 ...
- 关于win10安装javaJDK时遇到的问题
昨天晚上装了一下javaJDK1.8,在安装成功并且按照教程设置完环境变量之后进入了cmd界面,输入java,java -version都正常显示,但是输入javac却报错:javac不是内部或外部命 ...
- json&pickle序列化和软件开发规范
json和pickle 用于序列化的两个模块 json 用于字符串和python数据类型间进行转换,json只支持列表,字典这样简单的数据类型 但是它不支持类,函数这样的数据类型转换 pickle ...