继续浏览精彩内容
慕课网APP
程序员的梦工厂
打开
继续
感谢您的支持,我会继续努力的
赞赏金额会直接到老师账户
将二维码发送给自己后长按识别
微信支付
支付宝支付

基于Nginx&Lua 和Netflix Eureka的微服务网关

富国沪深
关注TA
已关注
手记 450
粉丝 41
获赞 158

依赖: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服务

部署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 节点中添加

include "/path/to/lua/ngx_conf/ngx_inlude_http.conf";

server节点中添加

include "/path/to/nginx/lua/ngx_conf/ngx_inlude_server.conf";

参考配置

 #user  nobody;worker_processes  2;#error_log  logs/error.log;#error_log  logs/error.log  notice;#error_log  logs/error.log  info;#pid        logs/nginx.pid;events {
    worker_connections  1024;
}


http {    include       mime.types;
    default_type  application/octet-stream;    #log_format  main  '$remote_addr - $remote_user [$time_local] "$request" '
    #                  '$status $body_bytes_sent "$http_referer" '
    #                  '"$http_user_agent" "$http_x_forwarded_for"';

    #access_log  logs/access.log  main;

    sendfile        on;    #tcp_nopush     on;

    #keepalive_timeout  0;
    keepalive_timeout  65;    #gzip  on;
    include "/Users/tietang/nginx/nginx/lua/ngx_conf/ngx_inlude_http.conf";


    server {        include "/Users/tietang/nginx/nginx/lua/ngx_conf/ngx_inlude_server.conf";        #error_page  404              /404.html;

        # redirect server error pages to the static page /50x.html
        #

        location = / {
            set $dir $document_root;
            root   $dir/html;
            index  index.html index.htm;
        }

        error_page   500 502 503 504  /50x.html;
        location = /50x.html {
            root   html;
        }

        
    }


   

}

运行测试

启动所有的demo服务:discovery,api,zuul;

启动nginx;



作者:铁汤
链接:https://www.jianshu.com/p/cf5ed38a6fc3


打开App,阅读手记
0人推荐
发表评论
随时随地看视频慕课网APP