openresty+mysql动态路由设计原理

首先openresty是用lua对nginx做的二次开发。

解决问题:原来nginx都是需要将服务在nginx中配置完毕,每次新增或者删除服务都需要重启nginx,运维成本高,而通过        openresty+mysql便可实现动态路由的效果。

实现原理:1.在服务启动时将服务的路由地址动态注册到mysql的表中

                  2.当请求过来时openresty先去缓存中检查该服务是否已经加载了该服务的路由地址,如果有随机选择一个进行路由,如果没有需要先去mysql中查询该服务可路由的地址,加载到缓存中,缓存有效期设置五分钟。

                  3.设置健康检查,保证每次随机选择到的服务路由地址一定是健康的,至少服务是存在的

                  4.设置定时任务每2分钟去检测下mysql中的路由地址是否有不健康的,如果连续5次不健康当做该服务已经挂掉,在mysql中移除掉。

 

 

 

 

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值