docker run -u和--entrypoint的学习

今天理解了两个用法

docker 和 uid

动机: 部署在docker容器的算法输出的图片总是带有root权限,删除或者后续操作很麻烦。

产生该现象的原因是我在docker run和dockerfile中都未指定user给docker,在此情况下docker会默认使用root用户。这篇文章描述了详细的原因和解决方案。

提炼一些关键点:docker和host通过同一个内核来管理和uid和gid,内核只认识uid和gid,而username和uid之间的映射由外部文件记录(如etc/passwd)。

可在docker run时用–user 指定uid ---- 这样因为容器内找不到1001对应的username,所以在username的位置显示“I have no name!”

marc@server:~$ docker run -d --user 1001 ubuntu:latest sleep infinity
84f436065c90ac5f59a2256e8a27237cf8d7849d18e39e5370c36f9554254e2b
marc@server$ ps aux | grep sleep
marc     17058 0.1 0.0 4380 664 ? Ss 21:23 0:00 sleep infinity
marc@server:~$ docker exec -it 84f43 /bin/bash
I have no name!@84f436065c90:/$

或在dockerfile中指定user和uid:

FROM ubuntu:latest
RUN useradd -r -u 1001 -g appuser appuser
USER appuser
ENTRYPOINT [“sleep”, “infinity”]
marc@server:~$ docker run -d test
8ad0cd43592e6c4314775392fb3149015adc25deb22e5e5ea07203ff53038073
marc@server:~$ ps aux | grep sleep
marc 16507 0.3 0.0 4380 668 ? Ss 20:02 0:00 sleep infinity
marc@server:~$ docker exec -it 8ad0 /bin/bash
appuser@8ad0cd43592e:/$ ps aux | grep sleep
appuser 1 0.0 0.0 4380 668 ? Ss 20:02 0:00 sleep infinity

那么在本地查到sleep的发起者是marc; 而在容器里查到sleep的发起者是appuser。

解决方案就是在docker run或dockerfile中都指定uid给docker。

entrypoint

在构建dockerfile时,CMD如果和ENTRYPOINT一起使用,则会被当成ENTRYPOINT中命令的额外参数。这篇博客提供了一个例子。
如果指定了ENTRYPOINT命令,那么生成容器和重启容器的时候都为默认调用该命令,docker run 所指定的命令会被当做这条命令的额外参数(效果同CMD)。 这时可以用 --entrypoint 来覆盖这条命令。

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
您提到的命令是"docker run -d -p 80:90 nginx"。根据引用,您提到将"-d"参数放在末尾,避免了其他参数找不到的错误。同时,根据引用,使用"-v"参数可以挂载宿主机的文件或文件夹到容器内部,方便修改配置和查看日志。而根据引用,在Mounts的Mode属性中,可以指定挂载的方式,例如读写("rw")或只读("ro")。所以,如果您想要在容器内将宿主机的80端口映射到容器的90端口,并使用Nginx作为镜像,可以尝试以下命令: "docker run -d -p 80:90 -v /Users/wangjing/Documents/docker/nginx/html:/usr/share/nginx/html nginx"。 这样,您就可以通过访问宿主机的80端口来访问Nginx容器的90端口,并且还可以通过挂载宿主机的文件夹到容器内,方便进行配置文件的修改和日志的查看。123 #### 引用[.reference_title] - *1* [docker run后 logs报/docker-entrypoint.sh: 38: exec: -p: not found](https://blog.csdn.net/weixin_43895897/article/details/127944602)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] - *2* *3* [Docker run -v 的 rw 和 ro 模式](https://blog.csdn.net/wang_jing_jing/article/details/122437083)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v92^chatsearchT3_1"}} ] [.reference_item] [ .reference_list ]

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值