基于Nginx Lua 和Netflix Eureka的微服务网关
依赖:lua-resty-http 基于Nginx&Lua 和Netflix Eureka的微服务网关。
重新架构了内部组件,采用插件模式。
- 服务发现
- Eureka Discovery
- 抽象discovery,用来支持多种服务发现?规划中…
- 动态路由
- 负载均衡
- 加权轮询
- 基于响应时间的动态权重轮询?开发中…
- 简单监控
- 隔离降级
- 限流
- metrics
- 认证安全?规划中。。。
- 监控页面?开发中…
架构图:
使用方法
基于Nginx和Lua module。需要安装Nginx Lua环境或者直接下载openresty编译安装。
安装和配置ngx-lua-zuul
下载代码到/path/to/nginx/lua/lib/
git clone http://github.com/tietang/ngx-lua-zuul –depth=1
例子Eureka 服务
如果没有Eureka环境,也可以编译安装本例子中的EurekaDemo服务,参考编译和运行eureka-demo服务中的相关内容。
部署dicovery例子服务:
下载代码后:
cd /path/to/ngx_lua-zuul/demo/java mvn clean install
将下载的代码中的lua文件夹放到部署目录/path/to/nginx
,修改/path/to/nginx/lua/ngx_conf/lua.ngx_conf
文件中的lua_package_path
为你的真实路径:
lua_package_path "/path/to/nginx/lua/lib/?.lua;;";
修改/path/to/nginx/conf/nginx.conf
文件
http 节点中添加
1
|
include "/path/to/lua/ngx_conf/ngx_inlude_http.conf"; |
server节点中添加
1
|
include "/path/to/nginx/lua/ngx_conf/ngx_inlude_server.conf"; |
参考配置
1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 |
#user nobody; worker_processes 2; |
运行测试
启动所有的demo服务:discovery,api,zuul;
启动nginx;
打开浏览器:http://127.0.0.1:8000/api/test/0/0
其测试api参考编译和运行eureka-demo服务中的相关内容。