How to get access from Service Mesh to services running on bare metal

consul (A), nomad (B) and vault © are installed on bare metal.

Any service (D) started with Nomad in a Service Mesh ( connect { sidecar_service { }} ) does not have access to those services on bare metal.

How to write a Nomad job for a service (D) so that it will have access to A, B, C?

Hi @pashinin, if consul, nomad, and vault are configured to only listen to a local address it won’t be possible to connect to them directly from inside the network namespace that the connect tasks run in. You could do something like make use of consul’s unix socket listener capability and volume mount the socket file into the allocation (Nomad actually does this for the Envoy sidecar’s xDS over gRPC connection to Consul), or do some iptables magic on the host to forward packets destined for a routable address.

A third option if possible would be to make your service Connect Native, which Nomad supports running in host networking mode rather than only bridge networking.

What about terminating gateways?

Can it help in this situation?

I saw Ingress Gateways in recent Nomad. But that’s for incoming traffic (into service mesh).
Can Nomad run terminating gateways?