使用Consul接入
背景说明
Shenyu提供了Shenyu-Sdk方便让服务能够快速接入shenyu网关, 客户端服务只需要依赖该sdk, 并做些简单配置, 即可类似调用本地接口一样调用网关暴露的API。
客户端接入网关的注册中心支持(nacos、eureka、etcd、zookeeper、consul),下面为shenyu-bootstrap及应用客户端使用Zookeeper注册中心时的相关指引。
环境准备
需要参考 运维部署 , 选择一种方式启动shenyu-admin及shenyu-bootstrap.
shenyu-bootstrap
添加Maven依赖
在网关的pom.xml文件中引入如下依赖.
<dependency>
<groupId>org.apache.shenyu</groupId>
<artifactId>shenyu-spring-boot-starter-registry</artifactId>
<version>${project.version}</version>
</dependency>
配置文件调整
在网关的yml配置文件中添加如下配置.
shenyu:
register:
enabled: true
registerType: consul
serverLists: localhost
props:
delay: 1
wait-time: 55
instanceId: shenyu-gateway
hostName: localhost
tags: test1,test2
preferAgentAddress: false
enableTagOverride: false
# registerType: 服务注册类型,填写 consul
# serverLists: consul client agent地址(sidecar模式部署(单机或者集群),也可以是consul server agent的地址(只能连接一个consul server agent节点,如果是集群,那么会存在单点故障问题))
# delay: 对Metadata的监控每次轮询的间隔时长,单位为秒,默认1秒
# wait-time: 对Metadata的监控单次请求的等待时间(长轮询机制),单位为秒,默认55秒
# instanceId: consul服务必填,consul需要通过instance-id找到具体服务
# name 服务注册到consul时所在的组 名
# hostName: 为 consul 注册类型时,填写 注册服务实例的 地址, 该注册中心注册的服务实例地址,并不会用于客户端的调用,所以该配置可以不填,port,preferAgentAddress同理
# port: 为 consul 注册类型时,填写 注册服务实例的 端口
# tags: 对应consul配置中的tags配置
# preferAgentAddress:使用consul客户端侧的agent对应的address作为注册服务实例的address,会覆盖hostName的手动配置
# enableTagOverride:对应consul配置中的enableTagOverride配置
# 详细参考`用户指南>属性配置>客户端接入配置`文档