Docker学习(三):Docker如何修改容器的系统时间

以普通方式运行docker容器

docker run -it --rm --name centos centos /bin/bash

参数说明:

-it: 表示启用一个伪终端,并以交互方式运行
--rm: 表示退出之后立马删除该容器
--name: 表示给容器起一个名字
centos: 表示镜像名称
/bin/bash: 表示运行于bash程序

此时进入容器之后执行修改容器时间的指令

date -s 08/24/2006
date -s 13:02:00

会给出date: cannot set date: Operation not permitted的错误

那么如何才能修改容器的时间呢 主要是因为有时候需要测试一些定时任务的场景

退出之前的容器, 以如下方式重新进入容器:

docker run -it --cap-add SYS_TIME --rm --name centos centos /bin/bash

进入容器再使用指令

date -s 08/24/2006
date -s 13:02:00

修改时间, 此时就可以修改成功了.

这个和之前的方式有什么区别呢多了--cap-add SYS_TIME参数

由于docker容器的隔离是基于Linux的Capability机制实现的, Linux的Capability机制允许你将超级用户相关的高级权限划分成为不同的小单元. 目前Docker容器默认只用到了以下的Capability.

CHOWN, 
DAC_OVERRIDE, 
FSETID, 
FOWNER, 
MKNOD, 
NET_RAW, 
SETGID,  
SETUID, 
SETFCAP, 
SETPCAP, 
NET_BIND_SERVICE, 
SYS_CHROOT, 
KILL, 
AUDIT_WRITE

而要修改系统时间需要有SYS_TIME权限.
使用--cap-add,--cap-drop可以添加或禁用特定的权限.

--privileged参数也可以达到开放权限的作用, 与--cap-add的区别就是,--privileged是将所有权限给容器.

docker使用--privileged,--cap-add,--cap-drop来对容器本身的能力进行开放或限制.

    原文作者:普通网友
    原文地址: https://blog.csdn.net/m0_67393295/article/details/123872466
    本文转自网络文章,转载此文章仅为分享知识,如有侵权,请联系博主进行删除。
点赞