我正在使用一个Docker映像,它是使用USER命令构建的,以使用一个称为dev的非根用户。 在容器中,我是“dev”,但我想编辑/etc/hosts文件。
所以我需要是根。我正在尝试su命令,但要求我输入根密码。
Docker容器中root用户的默认密码是什么?
我正在使用一个Docker映像,它是使用USER命令构建的,以使用一个称为dev的非根用户。 在容器中,我是“dev”,但我想编辑/etc/hosts文件。
所以我需要是根。我正在尝试su命令,但要求我输入根密码。
Docker容器中root用户的默认密码是什么?
当前回答
当使用-u选项时,您可以使用root用户(ID = 0)而不是提供的默认用户登录Docker容器。如。
docker exec -u 0 -it mycontainer bash
Root (id = 0)是容器中的默认用户。图像 开发人员可以创建其他用户。可以访问这些用户 的名字。当传递数字ID时,用户不必存在于 的容器中。
摘自Docker文档
更新:当然你也可以使用Docker容器管理命令来运行这个:
Docker容器exec -u 0 -它mycontainer bash
其他回答
在某些情况下,您需要能够在用户下使用sudo做这样的事情(例如,在容器中运行的应用程序为用户提供了一个shell)。简单地添加到你的Dockerfile:
RUN apt-get update # If necessary
RUN apt-get install sudo # If your base image does not contain sudo.
RUN useradd -m -N -s /bin/bash -u 1000 -p '$1$miTOHCYy$K.c4Yw.edukWJ7z9rbpTZ0' user && \
usermod -aG sudo user # Grant sudo to the user
USER user
现在,在默认映像用户user下,您将能够使用第3行设置的密码sudo。
查看如何为useradd生成密码哈希在这里或这里。
默认情况下,docker容器以root用户运行。
如果您仍在使用容器,可以使用exit命令返回root(默认用户)用户,而不是再次运行容器。
的例子,
[dev@6c4c86bccf93 ~]$ ls
[dev@6c4c86bccf93 ~]$ other-commands..
[dev@6c4c86bccf93 ~]$ exit
[root@6c4c86bccf93 /]# ls
为了避免重新构建容器,请执行以下步骤:
docker exec -u 0 -it containerName bash sudo visudo 在文件末尾添加如下内容:
your_username ALL=(ALL:ALL) ALL
在我的例子中,我使用ubuntu作为我的用户名,所以它是这样的:
ubuntu ALL=(ALL) NOPASSWD: ALL
保存文件,重新连接到docker容器,并将sudo连接到您的hearts大陆。
好处:如果你想更新docker镜像,你可以做以下事情:
docker commit containerName NewImage
你也可以这样使用它(如果你需要确认密码)
(echo 'myrootpassword'; echo 'myrootpassword') | passwd root
在运行的容器中创建/更改根密码
docker exec -itu 0 {container} passwd