本文通过模拟真实的调用链路,为您演示如何自动实现Serverless应用引擎SAE(Serverless App Engine)本地开发环境与测试环境的流量隔离,方便您快速开发联调,提高开发效率。

前提条件

背景信息

以下图中Spring Cloud框架的微服务应用为例,您无需修改任何业务代码,只需设置流量标签(Tag),通过端云联调,将流量通过不同的路径分配到SAE测试环境或本地开发环境,自动实现流量隔离。dg_microservice_network_isolation

步骤一:将应用部署至SAE测试环境

部署Demo应用,分别命名为spring-cloud-zuulspring-cloud-aspring-cloud-bspring-cloud-c。具体操作,请参见将Spring Cloud应用托管到SAE

说明 建议使用镜像方式或JAR包方式部署应用,并配置启动参数-Dnacos.use.endpoint.parsing.rule=false-Dnacos.use.cloud.namespace.parsing=false才能使用已购买的注册中心。

步骤二:配置端云互联

更多信息,请参见使用Cloud Toolkit实现端云互联(IntelliJ IDEA)

  1. 启动IntelliJ IDEA。
  2. 在顶部菜单栏,选择Tools > Alibaba Cloud > Preferences...
  3. Settings对话框,选择Alibaba Cloud Toolkit > Microservice
  4. Microservice页面,配置端云互联的相关参数。
    1. Proxy:购买一台跟SAE应用在同一VPC下的ECS(带公网IP)作为代理机器,添加至Proxy页面。sc_idea_proxy_configuration
    2. Microservice:在Microservice页面,配置代理和已购买的MSE注册中心。sc_idea_microservice_configuration
    3. MSE:在MSE页面,配置相关参数。sc_idea_mse_configuration
      1. 输入License KeyApp Name
        您可以登录SAE的Webshell,执行以下命令获取License KeyApp Name。登录Webshell的具体操作,请参见查看Webshell
        env | grep java
        输出示例如下:
        JAVA_TOOL_OPTIONS=-javaagent:/home/admin/.opt/ArmsAgent/arms-bootstrap-1.7.0-SNAPSHOT.jar -Darms.licenseKey=iioe7jcnuk@a0bcdaec24f**** -Darms.appId=8641dbc9-8663-4c47-95f7-683fa6dd**** -Darms.agent.env=Serverless -Darms.agent.args=  -Dprofiler.micro.service.canary.enable=true -Dprofiler.micro.service.metadata.report.enable=true -Dprofiler.micro.service.http.server.enable=true -Dmsc.appName=cn-shenzhen-test-sc-gateway-****** -Dmsc.licenseKey=iioe7jcnuk@460d62050fa****
      2. 设置标签。在Tag栏,输入local
      3. 下载Agent到本地。
  5. 单击Apply,然后单击OK
  6. 启动本地应用,验证联调。
    Info对话框如果看到端云互联成功启用的提示,证明端云互联功能已生效。sc_idea_run_application

步骤三:发起流量调用进行测试

如果您发往云原生网关的Request是HTTP请求,您需要在请求的Header中添加x-mse-tag=[local],配置完成后流量会自动在指定的环境内完成闭环。

说明 此处的Key为x-mse-tag是固定值,其参数值需要和环境标签保持一致。
环境标签配置完成后,使用curl命令发起流量调用请求,返回结果如下:
  • 主链路:
    curl http://47.106.XX.XX:8080/A/a
  • 调用结果:
    A[10.0.1.160] -> B[10.0.1.161] -> C[10.0.1.162]
  • 分支链路:
    curl http://47.106.XX.XX:8080/A/a \--header 'x-mse-tag: local'
  • 调用结果:
    A[127.0.0.1] -> B[127.0.0.1] -> C[10.0.1.162]