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。