kubernetes yaml文件访问外部变量

kubernetes yaml文件访问外部变量
 

1、在 shell脚本里 使用export为变量赋值

    export REGISTRY_HOST=$1
    export IMAGE_MYSQL_VERSION=$2

2、在yaml中编辑如下,红色部分就是变量引用了

    spec:
      containers:
        - name: mysql
          image: $REGISTRY_HOST/mysql:$IMAGE_MYSQL_VERSION
          imagePullPolicy: Always

3、启动时使用如下命令,不能使用 kubectl create -f mysql.yaml

envsubst < mysql.yaml | kubectl apply -f -

4、后记
还有其它的方式可以变相解决变量传输的问题,但是这些都比较麻烦,不推荐
1、使用 替换命令,比如sed,在create之前进行替换
2、使用cat eof 来动态生成yaml文件
 

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
将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.
评论 1
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值