[docker]Kubernetes的yaml文件

yaml是一种专门用来写配置的语言,简洁强大

它的规则:

1、大小写敏感

2、使用缩进表示层级关系,但不支持tab缩进,只支持空格

3、缩进的数量不重要但至少一个空格,只要相同层级使用相同数量的空格即可

4、“#”表示注释,从这个字符开始,直到行末,都会被解析器无视

在Kubernetes中,我们只需要知道两种yaml格式即可满足大部分需求:

Map: 就是一个字典,即Key:Value的键值对

Lists:就是一个列表,

args
 -beijing
 -shanghai
 -shenzhen
 -guangzhou

Maps的子项可以是Lists,Lists的子项也可以是Maps

一般用于创建pod的yaml文件会包含如下几个基本参数

    • apiServer 接口版本,现在一般都写v1,但它是随着安装Kubernetes和资源类型的变化而变化的
    • kind 创建Pod则写Pod,其它的参数还有Deployment、Job、Ingress、Service等
    • metadata 包含Pod的一些meta信息,比如名称、namespace、标签等等
    • spec 包含container\storage\volume或者其它kubernetes需要的参数,可在特定Kubernetes API找到完整的Kubernetes Pod的属性。
---
apiVersion: v1
kind: Pod
metadata:
  name: kube100-site
  labels:
    app: web
spec:
  containers:
    - name: front-end
      image: nginx
      ports:
        - containerPort: 80
    - name: flaskapp-demo
      image: jcdemo/flaskapp
      ports:
        - containerPort: 5000

 

参数也有指定复杂的属性,包括容器启动运行的命令、使用的参数、工作目录以及每次实例化是否拉取新的副本。 还可以指定更深入的信息,例如容器的退出日志的位置。容器可选的设置属性包括

name、image、command、args、workingDir、ports、env、resource、volumeMounts、livenessProbe、readinessProbe、livecycle、terminationMessagePath、imagePullPolicy、securityContext、stdin、stdinOnce、tty

 

转载于:https://www.cnblogs.com/baylorqu/p/9555677.html

将Milvus(一个开源的高性能矢量数据库)的Docker Compose YAML文件转换成Kubernetes (K8s) 的YAML文件,是为了让Milvus在Kubernetes环境中部署。下面是简单的步骤: 1. **了解差异**: - Docker Compose是用于本地开发环境的,而K8s YAML专注于集群管理。 - Docker Compose文件通常关注单机或多机配置,而K8s YAML涉及到服务发现、负载均衡和容器间通信。 2. **获取信息**: - 首先,你需要有一个有效的Milvus Docker Compose YAML文件,它会包含应用的镜像、端口映射、环境变量等信息。 3. **转换过程**: - 使用`kubectl create`命令创建资源通常不会直接从Docker Compose导入,但你可以手动逐项创建服务、 deployment、serviceaccount、pvc和configmap等。 - 分别创建对应的资源,比如Deployment用于定义Pod模板,Service用于外部访问,PersistentVolumeClaim用于持久化存储。 - 根据需要,将卷挂载、网络策略和资源请求/限制也添加到K8s YAML中。 4. **示例内容**: - Deployment示例:指定image、replicas、container ports和volume mounts。 ```yaml apiVersion: apps/v1 kind: Deployment metadata: name: milvus-deployment spec: replicas: 1 selector: matchLabels: app: milvus template: metadata: labels: app: milvus spec: containers: - name: milvus-container image: milvusdb/milvus:latest ports: - containerPort: 19530 name: grpc volumeMounts: - mountPath: /data name: milvus-storage ``` - Service示例:定义服务的名称、选择器标签以及暴露的端口。 ```yaml apiVersion: v1 kind: Service metadata: name: milvus-service spec: selector: app: milvus ports: - protocol: TCP port: 19530 targetPort: grpc type: ClusterIP ``` 5. **完成并验证**: - 编辑完成后,检查K8s YAML是否语法正确,并通过`kubectl apply -f your-file.yaml`命令将其部署到运行Kubernetes的环境中。 6.
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值