我现在尝试在Kubernetes集群上使用shell (/bin/bash)运行一个简单的容器。

我认为有一种方法可以通过使用伪tty和detach选项(Docker run命令上的-td选项)来保持容器在Docker容器上运行。

例如,

$ sudo docker run -td ubuntu:latest

Kubernetes中有这样的选项吗?

我尝试使用kubectl run-container命令运行一个容器,如下所示:

kubectl run-container test_container ubuntu:latest --replicas=1

但是容器会退出几秒钟(就像使用没有上面提到的选项的docker run命令启动一样)。ReplicationController会重复启动。

有没有办法让容器在Kubernetes上运行,比如docker run命令中的-td选项?


当前回答

我对这个问题的一些看法。假设kubectl正在工作,那么与您在问题中提到的docker命令等效的最接近的命令将是这样的。

$ kubectl run ubuntu --image=ubuntu --restart=Never --command sleep infinity

上面的命令将在默认的命名空间中创建一个Pod,它将执行带无限参数的sleep命令——这样你就有了一个在前台运行的进程,使容器保持活跃。

后续可以通过运行kubectl exec命令与Pod进行交互。

$ kubectl exec ubuntu -it -- bash

这种技术对于创建Pod资源和特别调试非常有用。

其他回答

容器在主进程退出时退出。做这样的事情:

docker run -itd debian

坦率地说,保持容器打开是一种只能用于快速测试和示例的hack。如果你只是想要一个容器来测试几分钟,我会这样做:

docker run -d debian sleep 300

它的优点是,如果你忘记它,容器将自动退出。或者,您可以在while循环中放入类似的内容以保持它永远运行,或者只运行诸如top之类的应用程序。所有这些在Kubernetes中都很容易做到。

真正的问题是你为什么要这么做?您的容器应该提供一个服务,该服务的进程将使容器在后台运行。

有许多不同的方法来实现这一点,但最优雅的方法之一是:

kubectl run -i --tty --image ubuntu:latest ubuntu-test --restart=Never --rm /bin/sh

我做了一个hack,把它放在后台:

[root@localhost ~]# kubectl run hello -it --image ubuntu -- bash &
[2] 128461

执行舱上,你好

[root@localhost ~]# kubectl exec -it hello -- whoami
root
[root@localhost ~]# kubectl exec -it hello -- hostname
hello

获得外壳

[root@localhost ~]# kubectl exec -it hello -- bash
root@hello:/# ls
bin  boot  dev  etc  home  lib  lib32  lib64  libx32  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var

最简单的命令,因为它可以为k8s pod manifest永远运行容器:

apiVersion: v1
kind: Pod
metadata:
  name: ubuntu
spec:
  containers:
  - name: ubuntu
    image: ubuntu:latest
    # Just sleep forever
    command: [ "sleep" ]
    args: [ "infinity" ]

添加这个:在模板->在规格->在集装箱->在港口和之后的集装箱港口线

    command: ["/bin/sh", "-ec", "while :; do echo '.'; sleep 6 ; done"]