上一篇文章中我们通过使用一个空的sidecar_service来创建了自动sideCar代理,使用consul connect proxy -service指定了upstream,这篇文章将通过配置文件对其进行设定。
事前准备
使用socat启动一个用于验证的服务
可以使用socat,也可以使用其他的任何服务均可,只要可以验证操作即可,执行如下命令在8181端口提供一个基于socat的可以进行结果回显的服务。
执行命令:socat -v tcp-l:8181,fork exec:"/bin/cat"
配置文件
liumiaocn:consul.d liumiao$ cat socat.json
{
"service":{
"name":"socat",
"port":8181,
"connect":{
"sidecar_service":{
}
}
}
}
liumiaocn:consul.d liumiao$ cat web.json
{
"service":{
"name":"web",
"port":8080,
"connect":{
"sidecar_service":{
"proxy":{
"upstreams":[
{
"destination_name":"socat",
"local_bind_port":9191
}
]
}
}
}
}
}
liumiaocn:consul.d liumiao$
启动Consul并注册服务
执行如下命令启动并注册服务
执行命令:consul agent -dev -enable-script-checks -config-dir=.
执行日志示例如下所示:
liumiaocn:consul.d liumiao$ consul agent -dev -enable-script-checks -config-dir=.
==> Starting Consul agent...
Version: 'v1.7.1'
Node ID: '6cd30b34-bdfe-ed34-5e84-01a9cb5360f5'
Node name: 'liumiaocn'
Datacenter: 'dc1' (Segment: '<all>')
Server: true (Bootstrap: false)
Client Addr: [127.0.0.1] (HTTP: 8500, HTTPS: -1, gRPC: 8502, DNS: 8600)
Cluster Addr: 127.0.0.1 (LAN: 8301, WAN: 8302)
Encrypt: Gossip: false, TLS-Outgoing: false, TLS-Incoming: false, Auto-Encrypt-TLS: false
省略...
连接socat服务
执行如下命令连接socat服务
执行命令:consul connect proxy -sidecar-for socat
liumiaocn:consul.d liumiao$ consul connect proxy -sidecar-for socat
==> Consul Connect proxy starting...
Configuration mode: Agent API
Sidecar for ID: socat
Proxy ID: socat-sidecar-proxy
==> Log data will now stream in as it occurs:
2021-03-01T17:43:32.293+0800 [INFO] proxy: Proxy loaded config and ready to serve
2021-03-01T17:43:32.293+0800 [INFO] proxy: Parsed TLS identity: uri=spiffe://ba7c4c87-0d9a-d6a5-3de0-6a3a72598360.consul/ns/default/dc/dc1/svc/socat roots=[pri-1j5dmyo.consul.ca.ba7c4c87.consul]
2021-03-01T17:43:32.294+0800 [INFO] proxy: Starting listener: listener="public listener" bind_addr=0.0.0.0:21000
连接web服务
执行如下命令连接web服务
执行命令:consul connect proxy -sidecar-for web
liumiaocn:~ liumiao$ consul connect proxy -sidecar-for web
==> Consul Connect proxy starting...
Configuration mode: Agent API
Sidecar for ID: web
Proxy ID: web-sidecar-proxy
==> Log data will now stream in as it occurs:
2021-03-01T17:44:31.665+0800 [INFO] proxy: Starting listener: listener=127.0.0.1:9191->service:default/socat bind_addr=127.0.0.1:9191
2021-03-01T17:44:31.675+0800 [INFO] proxy: Proxy loaded config and ready to serve
2021-03-01T17:44:31.675+0800 [INFO] proxy: Parsed TLS identity: uri=spiffe://ba7c4c87-0d9a-d6a5-3de0-6a3a72598360.consul/ns/default/dc/dc1/svc/web roots=[pri-1j5dmyo.consul.ca.ba7c4c87.consul]
2021-03-01T17:44:31.675+0800 [INFO] proxy: Starting listener: listener="public listener" bind_addr=0.0.0.0:21001
注意:由于本示例中使用的官方的内容8080的端口在本地没有服务,可能会出现connection refused的信息,但对于本文示例并不影响。
结果确认
此时即可使用nc确认9191端口的回显功能了
liumiaocn:~ liumiao$ nc localhost 9191
hello, this is greetings from web upstream proxy
hello, this is greetings from web upstream proxy
而从socat服务中也可以同样对结果进行确认。
liumiaocn:~ liumiao$ socat -v tcp-l:8181,fork exec:"/bin/cat"
> 2021/03/01 17:45:47.948710 length=49 from=0 to=48
hello, this is greetings from web upstream proxy
< 2021/03/01 17:45:47.949273 length=49 from=0 to=48
hello, this is greetings from web upstream proxy
来源:https://blog.csdn.net/liumiaocn/category_9752887.html