我在GKE上有一个Kubernetes集群,它有一个nginx入口控制器,位于顶部,用于映射/ rstudio /下的RStudio Server端点。这非常有效。
不幸的是,我的一个部署(RStudio Server)无法正常工作,因为它在登录/注销期间使用客户端重定向,在尝试访问/ auth-login时最终导致404错误(应该是/ rstudio / auth-登录)
在过去,当使用非容器化的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;
}
我可以在入口控制器上使用注释来获得相同的结果吗?
虽然这不会以相同的nginx.conf
内容结束,但似乎有效。但我不知道它是否会引起一些副作用(只用一个豆荚进行测试)。
也许其他人会帮助评论关于...的答案
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