成人免费xxxxx在线视频软件_久久精品久久久_亚洲国产精品久久久_天天色天天色_亚洲人成一区_欧美一级欧美三级在线观看

我們為什么不允許非root用戶在CentOS直接運行Docker命令

云計算
這篇文章介紹了不用sudo而直接運行Docker命令所存在的安全漏洞,并強烈建議通過設置sudo規則作為暫時的解決方法。

容器技術***的弱點是安全性不足,Docker也不例外。因此,如何加強Docker的安全性是每一個Docker用戶必須慎重考慮的問題。這篇文章介紹了不用sudo而直接運行Docker命令所存在的安全漏洞,并強烈建議通過設置sudo規則作為暫時的解決方法。

[[145457]]

我經常會收到用戶反饋的Bug,他們問我們『為什么默認情況下不能使用非root用戶直接運行Docker命令』。

Docker能夠將/run/docker.socket的文件訪問權限設為660,并將其所屬的用戶組設為docker。 這使得非root用戶只要加入docker用戶組,就無需使用sudo,或者通過su命令切換到root用戶的情況下運行Docker命令。這聽起來很不錯。

 

  1. ls -l /var/run/docker.sock  
  2. srw-rw----. 1 root docker 0 Aug  3 13:02 /var/run/docker.sock 

 

但是,在RHEL、Fedora和CentOS上,我們更喜歡將doker.socket設置為:

 

  1. ls -l /var/run/docker.sock  
  2. srw-rw----. 1 root root 0 Aug  3 13:02 /var/run/docker.sock 

 

為什么呢?原因很簡單:如果用戶可以與Docker Socket通信,他們就能夠執行以下命令:

 

  1. docker run -ti --privileged -v /:/host fedora chroot /host 

這時用戶將擁有主機的完全控制權。這就相當于將sudoers文件修改為以下內容(譯者注:dwalsh為用戶名):

 

  1. grep dwalsh /etc/sudoers 
  2. dwalsh  ALL=(ALL)   NOPASSWD: ALL 

 

這將允許(dwalsh)用戶無密碼運行所有命令,獲得主機的完全控制權。但是這有一個很大的安全漏洞。Docker命令沒有內置的審計和日志功能,但是sudo有。

Docker目前會記錄事件,但是Docker daemon重啟時事件會消失。Docker目前沒有審計功能。

從安全性的角度,紅帽已經表達了允許非root用戶在沒有審計(auditing)和適當的日志的情況下訪問Docker Daemon的顧慮。我們已經在PR14446實現了這些控制,它依靠了一個認證機制,但這個機制還在討論中。在我們實現了審計和日志功能之前,我們推薦通過設置sudo規則來訪問Docker Daemon。這將允許sudo來提供審計和日志功能。

設置sudo規則

如果你希望非root用戶能夠直接執行Docker命令,我們推薦通過設置sudo規則來實現。下面是設置Docker規則的簡單教程。

在/ect/sudoers中添加以下內容: [譯者注:使用visudo命令修改]

 

  1. grep dwalsh /etc/sudoers 
  2. dwalsh        ALL=(ALL)       NOPASSWD: /usr/bin/docker 

 

這允許特定用戶無需密碼直接執行Docker命令。

注意:我并不推薦使用NOPASSWD,這可能會導致你的系統中的任意進程都能獲取root權限。如果你要求使用密碼,則用戶在運行Docker命令時需要輸入密碼,這將使得系統稍微安全一點。如果執行命令時輸入了一次密碼,則sudo將允許你在5分鐘內再次運行Docker命令時不再需要輸入密碼。

緊接著,為Docker命令設置別名。

 

  1. alias docker="sudo /usr/bin/docker" 

現在,非root用戶將被允許直接執行Docker命令(譯者注:不需要使用sudo),并且記錄了日志。

 

  1. docker run -ti --privileged -v /:/host fedora chroot /host 

查看journal日志或者/var/log信息:

 

  1. journalctl -b | grep docker.*privileged 
  2. Aug 04 09:02:56 dhcp-10-19-62-196.boston.devel.redhat.com sudo[23422]:   dwalsh : TTY=pts/3  

 

查看審計日志:

  1. ausearch -m USER_ROLE_CHANGE -i 
  2. type=USER_ROLE_CHANGE msg=audit(08/04/2015 09:02:56.514:1460) : pid=23423 uid=root auid=dwalsh ses=1 subj=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023 msg='newrole: old-context=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023 
  3. new-context=unconfined_u:unconfined_r:unconfined_t:s0-s0:c0.c1023 exe=/usr/bin/sudo hostname=? addr=? terminal=/dev/pts/3 res=success' 

#p#

更強的安全性

如果你打算只允許用戶訪問一個特定的容器,你可以寫一個簡單的腳本:

 

  1. cat /usr/bin/docker-fedora 
  2. #!/bin/sh 
  3. docker run -ti --rm fedora /bin/sh 

 

寫好腳本之后,配置sudoers:

 

  1. grep dwalsh /etc/sudoers 
  2. dwalsh        ALL=(ALL)       NOPASSWD: /usr/bin/docker-fedora 

 

這個用戶將僅能在沒有權限限制下運行Fedora容器。

認證

我們還在開發其它程序補丁來增強Docker Daemon安全性,其中包括認證方面。我們有一個正在討論的問題#13697“為Docker增加kerberos支持”。

授權

我們還提議為Docker增加授權/RBAC(基于角色的訪問控制),這樣管理員就可以控制哪些用戶可以使用哪些容器/鏡像進行哪些活動。如果你想查看這個提議或者評論或者提出建議,提議地址為:GitHub: rhatdan/docker-rbac。

結論

如果需要支持非root用戶直接運行Docker命令之前,那Docker Daemon的安全性還需要很多改進。但在這些改進實現之前,設置sudo規則是***的選擇。我們正在開發更好的解決方案,暫時我們仍然強烈推薦使用sudo。

原文鏈接:dockone.io/article/589

責任編輯:Ophira 來源: dockone
相關推薦

2023-08-22 20:43:09

HashMap單線程null

2022-05-08 18:18:40

JDKValueHashMap

2024-09-03 09:45:36

2022-01-27 07:02:52

JavaHashMap單線程

2009-06-18 10:47:44

java接口定義變量

2022-02-13 20:31:26

SpringBootjarmanifests

2020-05-07 16:30:32

Spring BootJava

2020-08-20 11:12:14

iOS 13.6蘋果降級

2023-11-30 08:16:19

SpringjarTomcat

2024-04-03 09:01:34

SpringTomcat容器

2020-04-17 08:00:22

Docker命令普通用戶

2021-08-23 12:54:12

開發技能代碼

2010-11-11 16:53:28

SQL Server視

2014-06-30 14:53:49

Android定制google

2011-04-22 10:15:56

Novell專利

2010-06-28 15:27:54

SQL Server

2010-06-01 16:12:00

2010-11-02 15:08:40

設置db2主鍵

2011-03-01 14:12:12

FreebsdProftpd

2010-05-20 13:03:52

IIS父路徑
點贊
收藏

51CTO技術棧公眾號

主站蜘蛛池模板: 97精品一区二区 | 欧美精品一区二区三区四区 | 午夜在线免费观看视频 | 中文字幕一区在线观看视频 | 毛片区| 国产精品一区二区三区久久久 | 999免费网站 | 黄色小视频入口 | 久久久欧洲 | 国产精品一区二区av | 午夜a级理论片915影院 | 色天堂影院| 成人免费在线 | 日韩视频免费看 | 欧美色综合一区二区三区 | 精品久久一 | 亚洲一区二区三区免费观看 | 紧缚调教一区二区三区视频 | 国产精品a久久久久 | 午夜免费视频 | 免费在线观看av | 神马九九| 国产精品久久 | 国产日韩一区二区三区 | 久久久久久国产免费视网址 | 久久33| 天天射色综合 | 欧美自拍第一页 | 久久精品91久久久久久再现 | 成人免费三级电影 | 午夜色播| 天天av天天好逼 | 日韩中文一区二区三区 | 国产一区二区影院 | 欧美高清成人 | 日韩一区二区在线视频 | 欧美一级片黄色 | 国产7777| 中文字幕在线看第二 | 日韩精品在线免费观看 | 国产一级片在线观看视频 |