- html - 出于某种原因,IE8 对我的 Sass 文件中继承的 html5 CSS 不友好?
- JMeter 在响应断言中使用 span 标签的问题
- html - 在 :hover and :active? 上具有不同效果的 CSS 动画
- html - 相对于居中的 html 内容固定的 CSS 重复背景?
我是 docker/k8s 世界的新手......有人问我是否可以使用 args 部署容器来修改行为(通常如果应用程序在“主”或“从”版本中工作),我做到了。也许不是最佳解决方案,但它有效:
这是一个简单的测试来验证。我制作了一个带有脚本的自定义图像:
角色.sh:
#!/bin/sh
ROLE=$1
echo "You are running "$ROLE" version of your app"
FROM centos:7.4.1708
COPY ./role.sh /usr/local/bin
RUN chmod a+x /usr/local/bin/role.sh
ENV ROLE=""
ARG ROLE
ENTRYPOINT ["role.sh"]
CMD ["${ROLE}"]
docker run -dit --name test docker.local:5000/test master
You are running master version of your app
apiVersion: v1
kind: Pod
metadata:
name: master-pod
labels:
app: test-master
spec:
containers:
- name: test-master-container
image: docker.local:5000/test
command: ["role.sh"]
args: ["master"]
- name: test-master-container
image: docker.local:5000/test
env:
- name: ROLE
value: master
- name: test-master-container
image: docker.local:5000/test
args:
- master
最佳答案
在具体领域方面:
command:
符合 Docker 的“入口点”概念,这里指定的任何内容都作为容器的主进程运行。您不需要指定 command:
在 pod 规范中,如果您的 Dockerfile 具有正确的 ENTRYPOINT
已经。 args:
匹配 Docker 的“命令”概念,这里指定的任何内容都作为命令行参数传递给入口点。 ARG
指定图像的构建时配置设置。 expansion rules and interaction with environment variables有点奇怪。根据我的经验,这有几个有用的用例(“我实际上想要针对哪个 JVM 版本构建?”),但是从镜像构建的每个容器都将具有相同的继承 ARG
值(value);这不是运行时配置的好机制。 ENV
变量, EXPOSE
d 端口,默认值 CMD
,尤其是 VOLUME
),没有特别需要在 Dockerfile 中“声明”它们以能够在运行时设置它们。 docker run
语法。)可能最灵活的方法是使用
ROLE
设置为环境变量;当您运行入口点脚本时,您可以假设
$ROLE
有一个值(value),但值得检查。
#!/bin/sh
# --> I expect $ROLE to be set
# --> Pass some command to run as additional arguments
if [ -z "$ROLE" ]; then
echo "Please set a ROLE environment variable" >&2
exit 1
fi
echo "You are running $ROLE version of your app"
exec "$@"
docker run --rm -e ROLE=some_role docker.local:5000/test /bin/true
ROLE
如果需要,可以在 Dockerfile 中。
FROM centos:7.4.1708
COPY ./role.sh /usr/local/bin
RUN chmod a+x /usr/local/bin/role.sh
ENV ROLE="default_role"
ENTRYPOINT ["role.sh"]
#!/bin/sh
# --> pass a role name, then a command, as parameters
ROLE="$1"
if [ -z "$ROLE" ]; then
echo "Please pass a role as a command-line option" >&2
exit 1
fi
echo "You are running $ROLE version of your app"
shift # drops first parameter
export ROLE # makes it an environment variable
exec "$@"
docker run --rm docker.local:5000/test some_role /bin/true
CrashLoopBackOff
状态。对于您现在正在尝试做的事情,请不要担心并查看
kubectl logs
pod 的。考虑设置 pod 规范的
restart policy如果这困扰你。
关于docker - 将 args 传递给容器时 Kubernetes pod/部署?,我们在Stack Overflow上找到一个类似的问题: https://stackoverflow.com/questions/54256980/
我有这个代码。为了让它工作,我必须使用 Args&&... 而不是 Args... 或 Args&... 我注意到 args 从 & 转换为 const& 或 && 转换为 &。 Args...Arg
当我定义类时,我总是去 Class A(object): def __init__(self, arg): self.arg = arg def print_arg(s
假设我想定义两个 {Type} 类的变量。构造函数采用 1 个参数。下面两种方式是否完全等价(编译成相同的目标代码)? Type a(arg), b(arg); 和 Type a(arg); Type
(旁白:我是一名 Perl 程序员,正如您所知,这是我的第一个重要的 Java 程序。简单的术语将不胜感激。) 我有以下启动器作为编码工作: import java.lang.reflect.*; i
Math.nextUp(arg) 始终与 arg + Math.ulp(arg) 相同,还是我遗漏了什么? System.out.println( 0.5 + Math.ulp(0.5));
今天我在学习完美转发,我创建了这个代码示例 #include #include template auto toStdFun(Function&& fun, Args&&...ar
我想知道你会选择哪个选项? putStrLn (show randomNum) putStrLn $ show randomNum (putStrLn . show) randomNum 所有选项在语
我试图在 visual studio 2012 中编译一个库,它最初是用 c++ 为 visual studio 2015 编写的。我有一个错误说 'class' missing tag。 错误消息的
我在下面的代码中遇到了运行时异常ArrayIndexOutOfBoundException,行中: if ( args[0].equals("t") || args[0].equals("time")
我有以下代码 import React, { Component } from "react"; import { Accounts } from "meteor/accounts-base"; ex
这个问题已经有答案了: Difference between Arrays and 3 dots (Varargs) in java (3 个回答) 已关闭 5 年前。 受学校线性代数 I 和 II
所以我定义了一个函数: def getDistnace(self, strings, parentD, nodeName, nodeDistance): 我用它来调用: Node.getDistnac
这个问题在这里已经有了答案: subprocess.call() arguments ignored when using shell=True w/ list [duplicate] (2 个答案
我想将参数传递给 java 应用程序,但喜欢 linux 应用程序风格。 java 中的main 方法对所有参数使用一个String 数组。在 Linux 中,大多数应用程序接受如下参数:ls -l
这是我的代码片段 #include void change(int a[]){ printf("%p\n",&a); } int main(){
我需要使用 python 3.6 subprocess.run() 函数发出以下命令: gsettings set org.gnome.shell enabled-extensions "['appl
这两个函数是否有任何有意义的不同?有什么理由通常更喜欢一个而不是另一个吗? void foo(auto x, auto &... y) { /* ... */ } template void foo(
例如: def m(arg, ...args) { println "arg: $arg" println "args: $args" } m('arg', k:'v') 输出: ar
我对 Java 还很陌生。目前正在尝试将 args[] 中给出的文件名传递给此 FileReader,但当我编译时,它说找不到指定的文件。如果我对文件名进行硬编码,它就可以正常工作。这应该如何运作?
为什么这是一个语法错误??做这件事的合适方法是什么? >>> def f(*args, option=None): File "", line 1 def f(*args, option=
我是一名优秀的程序员,十分优秀!