美文网首页微服务架构与应用
[微服务实践之路]-网关设计方案

[微服务实践之路]-网关设计方案

作者: haishuiaa | 来源:发表于2018-04-24 18:08 被阅读58次

    无论是单体应用,SOA和微服务框架下,网关的存在是很必要。网关作为一个内网开发的入口。一些公共服务的建设,可以在网关层处理。
    我们希望网关需要满足的功能:

    • 路由转发
    • 请求鉴权和身份认证
    • 限流
    • 跨域
    • 流量监控
    • 请求日志记录
    • ACL控制

    第一版本

    使用nodejs代码自研实现,满足跨域,路由转发和请求鉴权,其他功能还未实现

    • 实现思路
      代码层实现路由转发,通过url的解析再封装实现。请求鉴权使用jwt实现
    • 缺点
      新功能都需要开发实现,响应需求慢

    第二版本

    使用kong作为所有服务的gateway

    • kong安装
      (1)安装数据库
    sudo docker run -d --name kong-database \
                  -p 5432:5432 \
                  -e "POSTGRES_USER=kong" \
                  -e "POSTGRES_DB=kong" \
                  postgres:9.5
    

    (2)迁移数据

    sudo docker run --rm \
        --link kong-database:kong-database \
        -e "KONG_DATABASE=postgres" \
        -e "KONG_PG_HOST=kong-database" \
        -e "KONG_CASSANDRA_CONTACT_POINTS=kong-database" \
        kong:latest kong migrations up
    

    (3)启动kong,安全考虑,限制只有本机访问admin

    sudo docker run -d --name kong \
     --link kong-database:kong-database \
     -e "KONG_DATABASE=postgres" \
     -e "KONG_PG_HOST=kong-database" \
     -e "KONG_CASSANDRA_CONTACT_POINTS=kong-database" \
     -e "KONG_PROXY_ACCESS_LOG=/dev/stdout" \
     -e "KONG_ADMIN_ACCESS_LOG=/dev/stdout" \
     -e "KONG_PROXY_ERROR_LOG=/dev/stderr" \
     -e "KONG_ADMIN_ERROR_LOG=/dev/stderr" \
     -e "KONG_ADMIN_LISTEN=0.0.0.0:8001" \
     -e "KONG_ADMIN_LISTEN_SSL=0.0.0.0:8444" \
     -p 8000:8000 \
     -p 8443:8443 \
     -p 127.0.0.1:8001:8001 \
     -p 127.0.0.1:8444:8444 \
     kong:latest
    

    (4)安装dashboard

    sudo docker run -d -p 8080:8080 pgbi/kong-dashboard:v2
    

    相关文章

      网友评论

        本文标题:[微服务实践之路]-网关设计方案

        本文链接:https://www.haomeiwen.com/subject/xsnjlftx.html