写点什么

Docker 安全性探讨与实践:探讨篇

  • 2014-09-09
  • 本文字数:1768 字

    阅读完需:约 6 分钟

Daniel Walsh 是计算机安全领域的专家,有 30 余年的从业经验,非常熟悉容器技术。他 2001 年加入红帽公司,自 2013 年 8 月期任 RHEL Docker 增强开发团队主管。著名的 SELinux 项目就出自他手,该项目关注应用的运行空间和部署策略。Dan 还组织开发了安全虚拟化软件 sVirt,并创造了 SELinux 沙盒、Xguest 用户以及 Secure Kiosk。Dan 在今年七月参加 Docker 大会的时候做了一个主题演讲,解释了SELinux 的工作原理,Docker 如何在SELinux 下运行以及强制访问控制是如何增强Docker 安全性的。之后,基于这次演讲的视频,他又在开源网站上发表了两篇文章,一篇讨论Docker 的安全性,另一篇则着重介绍了RHEL 如何对Docker 的安全性进行了大量的增强。本文即是Dan 这两篇文章的梳理与讨论。

一、 容器的隔离能力不是万能的,应对才是王道

相信很多开发者都默认Docker 这样的容器是一种沙盒(sandbox)应用,也就是说他们可以用root 权限在Docker 中运行随便什么应用,而Docker 有安全机制能保护宿主系统。比如,有些人觉得Docker 容器里面的进程跟虚拟机里面的进程一样安全;还有的人随便找个源就下载没有验证过的Docker 镜像,看都不看内容就在宿主机器上尝试、学习和研究;还有一些提供PaaS 服务的公司竟然允许用户向多租户系统中提交自己定制的Docker 镜像。请读者注意,上述行为均是不安全的。

难怪有人说:“Docker 其实就是从网上不知什么地方下载一堆随机的代码,然后用root 权限运行。”现在Docker 镜像遇到的情景,跟1999 年Linux 兴起的时候类似:一个管理员觉得一个Linux 命令挺酷,就随便从网上什么地方找到这个命令的rpm 包,看都不看就安装运行。这显然是自取灭亡的典范。没过几天这个命令就爆出有bug,直接导致整个系统的瘫痪。

这种自取其辱的事情数不胜数,Dan 的团队乃至整个红帽公司,就在致力减少类似事件发生的概率。比如一定要从可信源下载软件,定期进行安全更新,长期维护一个安全应急小组以及验证系统安全性的一整套规程。

二、 我们需要在乎容器的安全性么?出乎意料但是显然需要

Dan 的团队近期不断提醒开发者,容器内外的权限基本没什么差别。如果开发者不是在多租户系统上运行 Docker,并且对 Docker 里面运行的服务都采取了很好的安全措施,那他们可能的确不用担心 Docker 爆出什么安全性问题,因为他们把 Docker 镜像内部和宿主环境同等对待了,这两者之间的安全性确实没什么差别。

但是难免有挺多开发者从直觉出发,觉得 Docker 容器的安全性就高,这些人往往会把 Docker 容器机制当作一种更快速部署虚拟机的方法。这时候就需要提醒他们安全性的问题了。从安全角度来看,容器的安全性非常弱。正常来讲,Docker 容器机制应该被当作一种服务来看待,就是说跑在 Docker 镜像上的 Apache 的安全措施,应该跟跑在自己服务器上的安全措施没什么区别才可以。比如,应该尽可能少的赋予软件各种权限,还应该总是用非 root 模式运行软件,以及万一在 Docker 内部用到了 root 权限,需要谨慎一如在宿主机上一样。

三、 是什么导致了安全漏洞?NameSpace

那么究竟是什么地方导致了 Docker 容器机制的安全问题呢?简单一句话,Linux 系统中不是所有东西都有命名空间(Namespace)。最新版本的 Docker 有五个命名空间:进程、网络、挂载、宿主和共享内存。如此简单的命名空间显然无法给开发者提供复杂的安全保护。比如在类似 KVM 的环境里,虚拟机根本无法直接和宿主的内核交互,它没有任何方式可以访问内核文件系统中如 /sys 和 /sys/fs 这样的地方。在这种情况下,想要脱离虚拟机来攻击宿主,比如要找到 HyperVisor 的弱点,攻克 SELinux 控制(这是个挺难的事情),然后才能够染指宿主的文件系统。而在 Docker 这样的容器里,原生就可以访问宿主的内核,安全性从何而来?

Dan 在文章中列举了主流的没有命名空间的内核,有:

  • SELinux
  • Cgroups
  • file systems under /sys
  • /proc/sys, /proc/sysrq-trigger, /proc/irq, /proc/bus

没有命名空间的设备有:

  • /dev/mem
  • /dev/sd* file system devices
  • Kernel Modules

如果开发者能访问或者攻击任何一个,就可以获得整个系统的控制权。


感谢郭蕾对本文的审校。

给InfoQ 中文站投稿或者参与内容翻译工作,请邮件至 editors@cn.infoq.com 。也欢迎大家通过新浪微博( @InfoQ )或者腾讯微博( @InfoQ )关注我们,并与我们的编辑和其他读者朋友交流。

2014-09-09 07:273392
用户头像

发布了 268 篇内容, 共 135.3 次阅读, 收获喜欢 24 次。

关注

评论

发布
暂无评论
发现更多内容

直击灵魂!美团大牛手撸并发原理笔记,由浅入深剖析JDK源码

Java 并发编程 多线程 jdk源码

内部开发者平台|自建还是购买,企业应如何选择?

SEAL安全

平台工程 企业号 5 月 PK 榜 内部开发平台

CloudQuery v2.0.0 发布 新增数据保护、数据变更、连接管理等功能

BinTools图尔兹

数据库 国产数据库 版本发布

深度学习基础入门篇-序列模型:[11]:循环神经网络 RNN、长短时记忆网络LSTM、门控循环单元GRU原理和应用详解

汀丶人工智能

人工智能 深度学习 RNN LSTM GRU

ps vs top:CPU占用率统计的两种不同方式

极限实验室

Linux 运维 监控系统 INFINI Console

以敏捷性为目标,构建良好企业生态

智达方通

数据驱动 数据孤岛 智达方通 全面预算管理 数据分析系统

深度学习进阶篇-预训练模型[1]:预训练分词Subword、ELMo、Transformer模型原理;结构;技巧以及应用详解

汀丶人工智能

人工智能 深度学习 预训练模型 Transformer ELMo

红旗软件正式发布龙蜥社区版国产高可靠操作系统

OpenAnolis小助手

Linux 开源 龙蜥社区 红旗软件 社区版操作系统

PoseiSwap IDO在Bounce上启动在即,如何参与?

鳄鱼视界

PoseiSwap IDO在Bounce上启动在即,如何参与?

西柚子

Velocity不用愁!Velocity系统的前端工程化之路 | 京东云技术团队

京东科技开发者

Java 前端工程化 Web H5 Velocity.js 企业号 5 月 PK 榜

WorkPlus AI助理 | 将企业业务场景与ChatGPT结合

BeeWorks

全新一代小度智能屏X9焕新上市 正式开启预售

极客天地

企业研发效能度量利器,华为云发布CodeArts Board看板服务

华为云开发者联盟

云计算 后端 华为云 华为云开发者联盟 企业号 5 月 PK 榜

Scrum的三个工件(产品Backlog、Sprint Backlog、产品增量 )

顿顿顿

Scrum 敏捷 敏捷开发管理 敏捷开发管理工具

云图说丨初识商标注册服务

华为云开发者联盟

云计算 后端 华为云 华为云开发者联盟 企业号 5 月 PK 榜

胜面试官半子!阿里SpringBoot全栈笔记首发,源码实战齐飞

Java spring 微服务 Spring Boot 框架

基于 Log 的通用增量 Checkpoint 在美团的进展

Apache Flink

大数据 flink 实时计算

SpringBoot + Docker 实现一次构建到处运行

Java你猿哥

Java Docker Spring Boot ssm 容器化部署

Flutter三棵树系列之详解各种Key | 京东云技术团队

京东科技开发者

flutter key 企业号 5 月 PK 榜 localkey

龙博机电:90后“厂二代”,靠伙伴云零代码让中小制造业实现数字化“逆袭”

联营汇聚

有哪些好用的企业即时通讯软件值得推荐?

BeeWorks

常用的表格检测识别方法——表格结构识别方法(上)

合合技术团队

人工智能 深度学习 算法 人工智能文字识别 表格检测

3天速成!阿里人私用的Netty速成实战手册,3天Github星标11.5k

Java你猿哥

Java 源码 Netty ssm netty内存管理

最高奖金100万!第二届广州·琶洲算法大赛火热报名中

飞桨PaddlePaddle

百度飞桨 算法大赛

浅谈财务共享未来发展趋势

用友BIP

业财融合 财务共享

1.5万字+30张图盘点程序员面试必会MySQL索引常见的11个知识点

Java你猿哥

Java MySQL 数据 ssm 索引

Elasticsearch与Clickhouse数据存储对比 | 京东云技术团队

京东科技开发者

数据库 elasticsearch Clickhouse 企业号 5 月 PK 榜

混沌演练实践(二)-支付加挂链路演练 | 京东云技术团队

京东科技开发者

微服务 混沌工程 混沌工程实践 企业号 5 月 PK 榜

Docker安全性探讨与实践:探讨篇_语言 & 开发_张天雷_InfoQ精选文章