Ingress — JupyterHub
A exposição do JupyterHub via Ingress permite acesso à interface web via hostname dedicado.
Ingress vs Gateway API
TDPConfiguration.gateway.ingress e TDPConfiguration.gateway.gatewayApi são mutuamente exclusivos. Habilite apenas um deles.
Pré-requisitos
- Ingress Controller instalado no cluster (ex.: NGINX).
- Hostname configurado no DNS ou em
/etc/hosts. - TLS é opcional.
Exemplo de configuração
TDPConfiguration:
gateway:
ingress:
enabled: true
ingress:
ingressClassName: <ingress-class>
hosts:
- host: jupyter.tdp.local
paths:
- path: /
pathType: Prefix
tls: []
Substitua <ingress-class> pelo nome do Ingress Controller do ambiente (verifique com kubectl get ingressclass).
Acesso
- Obtenha o IP externo do Ingress Controller:
Terminal input
kubectl get svc -A -l app.kubernetes.io/name=ingress-nginx \
-o jsonpath='{.items[0].status.loadBalancer.ingress[0].ip}' - Adicione o hostname no DNS ou no arquivo
/etc/hosts:<INGRESS_IP> jupyter.tdp.local - Acesse
http://jupyter.tdp.local(ouhttps://se TLS estiver configurado).
Resolução de Problemas
| Problema | Causa | Solução |
|---|---|---|
| Ingress não criado | TDPConfiguration.gateway.ingress.enabled: false ou ingressClassName incorreto | Verificar ambas as configurações |
| Host não resolve | DNS ou /etc/hosts não configurado | Ajustar resolução no cliente |
| 502 Bad Gateway | Pod do JupyterHub não está pronto | Verificar kubectl get pods -n <namespace> |