ingress-gateway.hcl ==> Protocol = “tcp” does not work as the destination "counting: service is http based. After changing it to ‘http’, I was able to write config.
However, I am getting 404 when I curl -v http://{vm-ip}:8080/
My ingress-gateway.hcl is as follows
Kind = "ingress-gateway"
Name = "ingress-service"
Listeners = [
{
Port = 8080
Protocol = "http"
Services = [
{
Name = "counting"
}
]
}
]
When an ingress is configured with an HTTP listener, applications must send an HTTP Host header with the configured (or default) hostname for the backend service in order for the request to be correctly routed. This is documented on the Hosts of the ingress gateway config entry.
Hosts(array<string>: <optional>) - A list of hosts that specify what requests will match this service. This cannot be used with a tcp listener, and cannot be specified alongside a * service name. If not specified, the default domain .ingress.* will be used to match services. Requests must send the correct host to be routed to the defined service.
Given the configuration you provided, you would need to use the following curl command to reach your backend service.
If your applications outside of the mesh are configured to use Consul for DNS resolution, then they can use an ingress service lookup to find the IP address of the gateway(s) associated with a given service. For example:
$ curl http://counting.ingress.consul:8080/
I hope this information is helpful. Let me know if you have any questions.
Thanks @blake . Your suggestions worked and I was able to CURL ingress controller using IP and host header as you suggested.
The example on learning site here suggests to set counting service url property using IP resolved by DNS query to "counting.ingress.dc1.consul". Based on what you are suggesting, the steps in the learning site are not accurate/correct.
Also, is envoy dependent on service name/id coming from host header or <service>.ingress.<domain> for all traffic? Is there any path based routing to avoid this requirement for applications outside mesh wanting to consume services hosted in a mesh?
A few of the sections on https://www.consul.io/docs/discovery/dns#standard-lookup document datacenter as being an optional parameter, but its not explicitly stated as being optional for all DNS sub-domains. I’ll look at updating the docs to clarify this.
HTTP header manipulation is only supported in Consul 1.11.0 and later. Are both your Consul CLI and Consul server versions using 1.11.0 or later?