k8s 中传递参数给docker容器

文章目录

  • docker启动时传递参数
  • [使用k8s env传递](#使用k8s env传递)
  • [完全覆盖 ENTRYPOINT 和 CMD](#完全覆盖 ENTRYPOINT 和 CMD)

在 Kubernetes 中,可以通过多种方式将参数传递给 Dockerfile 或其运行的容器,常见的方式包括使用环境变量、命令行参数、配置文件等。以下是一些常用的方法:

docker启动时传递参数

dockerfile 文件如下:

shell 复制代码
FROM ubuntu:22.04

# 设置工作目录
ENV WORKDIR_PATH=/home/test

# 设置时区
ENV TZ Asia/Shanghai

# 防止交互式提示
ENV DEBIAN_FRONTEND=noninteractive

# 默认选择开发环境的启动脚本
ENV ENTRYPOINT_PATH=$WORKDIR_PATH/start-dev.sh

WORKDIR $WORKDIR_PATH

# 复制启动脚本
COPY ./app/start-prod.sh $WORKDIR_PATH/start-prod.sh
COPY ./app/start-dev.sh $WORKDIR_PATH/start-dev.sh

# 给脚本赋予可执行权限
RUN chmod +x $WORKDIR_PATH/start-prod.sh $WORKDIR_PATH/start-dev.sh

# 确保 $ENTRYPOINT_PATH 解析是通过 shell 启动
ENTRYPOINT ["/bin/sh", "-c", "exec $ENTRYPOINT_PATH $@"]

CMD ["--help"]

start-prod.sh

shell 复制代码
#!/bin/bash

echo "start prd sh"
echo $@
echo $1
echo $2
echo $MESSAGE

start-dev.sh

shell 复制代码
#!/bin/bash

echo "start dev sh"

echo $@

构建镜像:

shell 复制代码
docker build -t test:v1 . -f Dockerfile

启动容器:

shell 复制代码
docker run -it --rm  test:v1 /bin/bash

指定prd脚本执行,启动容器

复制代码
docker run -it --rm  -e ENTRYPOINT_PATH="/home/test/start-prod.sh" test:v1 /bin/bash

使用k8s env传递

pod.yaml

yaml 复制代码
apiVersion: v1
kind: Pod
metadata:
  name: my-pod
spec:
  containers:
    - name: my-container
      image: test:v1
      env:
        - name: ENTRYPOINT_PATH
          value: "/home/test/start-prod.sh"
        - name: MESSAGE
          value: "hello world!"

运行pod:

复制代码
kubectl apply -f pod.yaml

完全覆盖 ENTRYPOINT 和 CMD

yaml 复制代码
apiVersion: v1
kind: Pod
metadata:
  name: my-pod2
spec:
  containers:
    - name: my-container
      image: test:v1
      command: [ "/bin/sh" ]
      args: [ "/home/test/start-prod.sh", "--param", "some_value" ]
相关推荐
java_logo1 天前
Docker 部署 WordPress 全流程
运维·docker·容器·word·php·1024程序员节
武子康1 天前
Java-159 MongoDB 副本集容器化 10 分钟速查卡|keyfile + –auth + 幂等 init 附 docker-compose
java·数据库·mongodb·docker·性能优化·nosql·1024程序员节
wodongx1231 天前
从一开始部署Android项目Sonarqube的自动化扫码+通知+增量扫描功能(Win环境、Docker,基于Jenkins)
运维·docker·jenkins·1024程序员节
java_logo1 天前
Docker 部署 Elasticsearch 全流程手册
大数据·运维·mongodb·elasticsearch·docker·容器
Stay Passion1 天前
Docker 组件:Docker Swarm
运维·docker·容器
路過的好心人1 天前
Docker + Rabbitmq 集群部署
docker·容器·rabbitmq
青0721松1 天前
千云低代码平台ETMS-k8s实施部署
低代码·云原生·容器
源来猿往1 天前
基于window/ubuntu安装rknn-toolkit2【docker】
docker·1024程序员节·rknn-toolkit2
小小的木头人1 天前
基于Docker 搭建 Prometheus & Grafana 环境
运维·docker·容器·grafana·prometheus
睡不醒的猪儿1 天前
k8s部署自动化工具jenkins
云原生·kubernetes·自动化·jenkins