[问题已处理]-在k8s中通过nginx部署前端 发布后遇到无法访问和启动失败的问题

导语:在k8s中通过nginx部署前端 发布后遇到无法访问和启动失败的问题

  1. 要求api-server-svc这个service要先创建,否则nginx启动时会因为无法解析api-server-svc而启动失败
  2. nginx服役期间,如果后端服务重启,svc ip改变了,代理会失败,因为nginx缓存了旧ip
  # dns设置缓存时间5s,解决问题2
  resolver kube-dns.kube-system.svc.cluster.local valid=5s;
  # 使用变量方式,解决后端还未启动时前端nginx会报错
  set $apiserver api-server-svc.对应namespace.svc.cluster.local;  


            location /api {
                proxy_set_header   X-Forwarded-Proto $scheme;
                proxy_set_header   Host              $http_host;
                proxy_set_header   X-Real-IP         $remote_addr;
                rewrite /api/(.*) /$1 break;
                proxy_pass http://$apiserver:8080;
            }


            location /aiconsole/ {
                proxy_set_header Host $host;
                proxy_set_header X-Real-Ip $remote_addr;
                proxy_set_header REMOTE-HOST $remote_addr;
                proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;
                # 代理后端真实地址
                proxy_pass http://platform:11380/aiconsole/;
            }

至于namespace的获取 可以通过添加脚本来实现。

#!/usr/bin/env bash

echo "################################## Run nginx"
export DOLLAR='$'
envsubst '${SVRSHELL_PORT}' < /etc/nginx/conf.d/default.conf.template > /etc/nginx/conf.d/default.conf # /etc/nginx/conf.d/default.conf

NS=`cat /var/run/secrets/kubernetes.io/serviceaccount/namespace`
sed -i  's/namespace/$NS/g' /etc/nginx/conf.d/default.conf


echo "Generate nginx.conf"
cat /etc/nginx/conf.d/default.conf
echo "################################## Start server"
nginx -g "daemon off;"

参考

https://blog.csdn.net/u010837612/article/details/123275026

  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
要在 Kubernetes部署 Nginx,你可以按照以下步骤进行操作: 1. 首先,确保你已经安装了 Kubernetes 集群,并且你的 kubectl 命令可以正常工作。 2. 创建一个名为 `nginx-deployment.yaml` 的 YAML 文件,并在其定义 Nginx 的 Deployment。示例文件内容如下: ```yaml apiVersion: apps/v1 kind: Deployment metadata: name: nginx-deployment spec: replicas: 3 selector: matchLabels: app: nginx template: metadata: labels: app: nginx spec: containers: - name: nginx image: nginx:latest ports: - containerPort: 80 ``` 在上述示例,我们定义了一个名为 `nginx-deployment` 的 Deployment,它将在集群创建 3 个副本。Nginx 容器使用 `nginx:latest` 镜像,并将容器端口映射到主机的 80 端口。 3. 使用 kubectl 命令来创建 Deployment: ```shell kubectl apply -f nginx-deployment.yaml ``` 4. 验证 Deployment 是否成功创建,并查看 Pod 的状态: ```shell kubectl get deployments kubectl get pods ``` 你应该能够看到名为 `nginx-deployment` 的 Deployment 和对应的 Pod。 5. 如果一切正常,你可以使用 Service 来公开 Nginx Pod。创建一个名为 `nginx-service.yaml` 的 YAML 文件,并在其定义 Service。示例文件内容如下: ```yaml apiVersion: v1 kind: Service metadata: name: nginx-service spec: selector: app: nginx ports: - protocol: TCP port: 80 targetPort: 80 type: LoadBalancer ``` 在上述示例,我们定义了一个名为 `nginx-service` 的 Service,它将流量转发到具有 `app=nginx` 标签的 Pod 上,并将容器端口 80 映射到主机的 80 端口。 6. 使用 kubectl 命令来创建 Service: ```shell kubectl apply -f nginx-service.yaml ``` 7. 验证 Service 是否成功创建,并查看服务的 EXTERNAL-IP: ```shell kubectl get services ``` 你应该能够看到名为 `nginx-service` 的 Service,并且 EXTERNAL-IP 字段将显示一个 IP 地址或者 LoadBalancer 的外部地址。 现在,你应该能够通过通过浏览器访问 Nginx 服务的 IP 地址来访问部署Kubernetes 上的 Nginx。注意,这可能需要一些时间来分配外部 IP 地址和加载 Nginx 容器镜像。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

爷来辣

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值