本文通过模拟真实的调用链路,为您演示如何自动实现Serverless应用引擎SAE(Serverless App Engine)本地开发环境与测试环境的流量隔离,方便您快速开发联调,提高开发效率。
前提条件
- 在IntelliJ IDEA中安装和配置Cloud Toolkit
- 在应用所在VPC内创建一台可使用SSH登录的ECS,用于建立端云互联通道。更多信息,请参见通过控制台使用ECS实例(快捷版)云服务器ECS快速入门。
注意
- ECS与应用必须处于同一VPC内。
- SSH通道需要使用密码方式登录,暂不支持使用密钥对登录。
- 如果操作系统配置代理,可能会导致连接端云互联通道失败。请关闭代理后重试。
背景信息
以下图中Spring Cloud框架的微服务应用为例,您无需修改任何业务代码,只需设置流量标签(Tag),通过端云联调,将流量通过不同的路径分配到SAE测试环境或本地开发环境,自动实现流量隔离。
步骤一:将应用部署至SAE测试环境
部署Demo应用,分别命名为spring-cloud-zuul、spring-cloud-a、spring-cloud-b、spring-cloud-c。具体操作,请参见将Spring Cloud应用托管到SAE。
说明 建议使用镜像方式或JAR包方式部署应用,并配置启动参数
-Dnacos.use.endpoint.parsing.rule=false
和-Dnacos.use.cloud.namespace.parsing=false
才能使用已购买的注册中心。
步骤二:配置端云互联
更多信息,请参见使用Cloud Toolkit实现端云互联(IntelliJ IDEA)。
步骤三:发起流量调用进行测试
如果您发往云原生网关的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]