我在GKE上有一个Kubernetes集群,在其顶部有一个nginx入口控制器,用于映射/ rstudio /下的RStudio Server端点。效果很好。
不幸的是,我的一个部署(RStudio Server)无法正常工作,因为它在登录/注销过程中使用了客户端重定向,在尝试访问/ auth-login时最终会出现404错误(应为/ rstudio / auth-login)
过去,当使用非容器化的RStudio Server安装时,我曾经在前面放置一个Apache反向代理来处理URL重写。
从official RStudio Server Pro guide中,我看到将此location
部分添加到nginx.conf
应该可以解决问题。
location /rstudio/ {
rewrite ^/rstudio/(.*)$ /$1 break;
proxy_pass http://localhost:8787;
proxy_redirect http://localhost:8787/ $scheme://$host/rstudio/;
proxy_http_version 1.1;
proxy_set_header Upgrade $http_upgrade;
proxy_set_header Connection $connection_upgrade;
proxy_read_timeout 20d;
}
我可以在入口控制器上使用注释来获得相同的结果吗?
答案 0 :(得分:1)
尽管最终不会得到相同的nginx.conf
内容,但它似乎可以正常工作。但是我不知道它是否会引起一些副作用(仅使用一个pod进行atm测试)。
也许其他人会帮助评论有关...的答案
apiVersion: extensions/v1beta1
kind: Ingress
metadata:
name: rstudio-ingress-nginx
annotations:
kubernetes.io/ingress.class: nginx
nginx.ingress.kubernetes.io/rewrite-target: /
nginx.ingress.kubernetes.io/ssl-redirect: "false"
nginx.ingress.kubernetes.io/add-base-url: "true"
nginx.ingress.kubernetes.io/proxy-redirect-from: "$scheme://$host/"
nginx.ingress.kubernetes.io/proxy-redirect-to: "$scheme://$host/rstudio/"
nginx.ingress.kubernetes.io/proxy-read-timeout: 20d
nginx.ingress.kubernetes.io/affinity: "cookie"
nginx.ingress.kubernetes.io/session-cookie-name: "route"
nginx.ingress.kubernetes.io/session-cookie-hash: "sha1"
spec:
rules:
- http:
paths:
- path: /rstudio/
backend:
serviceName: rstudio
servicePort: 8787