Azure 尝试在AKS中应用Yaml文件时出现有效错误

Azure 尝试在AKS中应用Yaml文件时出现有效错误,azure,kubernetes,azure-aks,azure-container-registry,Azure,Kubernetes,Azure Aks,Azure Container Registry,我跟随教程。我正处于使用以下命令进行部署的阶段: kubectl apply -f azure-vote-all-in-one-redis.yaml YAML文件如下所示: version: '3' services: azure-vote-back: image: redis container_name: azure-vote-back ports: - "6379:6379" azure-vote-front: build: ./

我跟随教程。我正处于使用以下命令进行部署的阶段:

kubectl apply -f azure-vote-all-in-one-redis.yaml
YAML文件如下所示:

version: '3'
services:
  azure-vote-back:
    image: redis
    container_name: azure-vote-back
    ports:
        - "6379:6379"

  azure-vote-front:
    build: ./azure-vote
    image: azure-vote-front
    container_name: azure-vote-front
    environment:
      REDIS: azure-vote-back
    ports:
        - "8080:80"
apiVersion: v1
kind: Pod
但是,我得到了一个错误:

error validating data: [apiVersion not set, kind not set]; if you choose to ignore these errors, turn validation off with --validate=false
error validating data: ValidationError(Pod): unknown field "services" in io.k8s.api.core.v1.Pod
如果我添加一个apiVersion和一个种类,如下所示:

version: '3'
services:
  azure-vote-back:
    image: redis
    container_name: azure-vote-back
    ports:
        - "6379:6379"

  azure-vote-front:
    build: ./azure-vote
    image: azure-vote-front
    container_name: azure-vote-front
    environment:
      REDIS: azure-vote-back
    ports:
        - "8080:80"
apiVersion: v1
kind: Pod
然后我得到一个错误:

error validating data: [apiVersion not set, kind not set]; if you choose to ignore these errors, turn validation off with --validate=false
error validating data: ValidationError(Pod): unknown field "services" in io.k8s.api.core.v1.Pod

我遗漏了什么吗?

因此,首先,每个yaml定义都应该遵循AKMS规范:apiVersion、kind、metadata、spec。此外,您应该避免pod并使用部署。因为部署自己处理吊舱

下面是一个示例投票后退\前面定义:

apiVersion: apps/v1beta1
kind: Deployment
metadata:
  name: azure-vote-back
spec:
  replicas: 1
  template:
    metadata:
      labels:
        app: azure-vote-back
    spec:
      containers:
      - name: azure-vote-back
        image: redis
        ports:
        - containerPort: 6379
          name: redis
---
apiVersion: v1
kind: Service
metadata:
  name: azure-vote-back
spec:
  ports:
  - port: 6379
  selector:
    app: azure-vote-back
---
apiVersion: apps/v1beta1
kind: Deployment
metadata:
  name: azure-vote-front
spec:
  replicas: 3
  strategy:
    rollingUpdate:
      maxSurge: 60%
      maxUnavailable: 60% 
  template:
    metadata:
      labels:
        app: azure-vote-front
    spec:
      containers:
      - name: azure-vote-front
        image: aksrg.azurecr.io/azure-vote-front:voting-dev
        ports:
        - containerPort: 80
        env:
        - name: REDIS
          value: "azure-vote-back"
        - name: MY_POD_NAMESPACE
          valueFrom: {fieldRef: {fieldPath: metadata.namespace}}
      imagePullSecrets:
      - name: k8s
---
apiVersion: v1
kind: Service
metadata:
  name: azure-vote-front
spec:
  type: LoadBalancer
  ports:
  - port: 80
  selector:
    app: azure-vote-front

看起来您正试图将Docker Swarm/Compose YAML文件应用于Kubernetes群集。如果没有转换,这将无法直接工作

使用像Kompose这样的工具将Docker YAML转换为k8s YAML是从一个迁移到另一个的有用步骤


有关更多信息,请参见

在我的案例中,我将通过Travis在GKE上部署我的项目。在我的travis文件中,我调用了一个shell文件deploy.sh

在deploy.sh文件中,我编写了创建kubernetes资源的所有步骤:

### Deploy

# Apply k8s config
kubectl apply -f .

在这里,我替换了kubectl apply-f。单个文件名如下所示:

### Deploy

# Apply k8s config
kubectl apply -f namespace.yaml
kubectl apply -f deployment.yaml
kubectl apply -f service.yaml
kubectl apply -f ingress.yaml

然后,错误被修复了

您提供的文件是的类型,不适用于AKS。