Now that ingress-nginx is being retired, people are looking for alternatives. haproxy-ingress is a choice. In a previous post I had showed how one could have an Ingress object that is not linked to any service (leaving any required processing to the ingress controller)
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: not-nginx
annotations:
nginx.ingress.kubernetes.io/server-snippet: |
return 302 https://new_web_server_here$request_uri;
spec:
ingressClassName: nginx
tls:
- hosts:
- old_name_here
secretName: secret_name_here
rules:
- host: old_name_here
Unfortuneately, in the case of the haproxy-ingress the above won’t work. The Ingress object needs to be linked with a service, even if this service does not exist:
apiVersion: networking.k8s.io/v1
kind: Ingress
metadata:
name: not-nginx
annotations:
haproxy-ingress.github.io/redirect-to: https://new_web_server_here
spec:
ingressClassName: haproxy
tls:
- hosts:
- old_name_here
secretName: secret_name_here
rules:
- host: old_name_here
http:
paths:
- path: /
pathType: Prefix
backend:
service:
name: no-service
port:
number: 80
You may want to user redirect-code-to if you want to set the 3xx code also.