资讯专栏INFORMATION COLUMN

使用Docker保护软件供应链安全

Jeffrrey / 3396人阅读

摘要:软件供应链几乎跟实际产品的供应链是相同的。确保软件供应链也十分相似。确保该扫描不止一次地发生,并在爆出新漏洞时,及时通知使用镜像的系统管理员或应用程序开发者。结论在软件生命周期的每个环节,平台都允许企业将安全纳入其中。

在Docker内部,我们花了很多时间讨论一个话题:如何将运行时安全和隔离作为容器架构的一部分?然而这只是软件流水线的一部分。

我们需要的不是一次性的标签或设置,而是需要将安全放到软件生命周期的每个阶段。

由于软件供应链上的人、代码和基础设施一直在改变,交互也越来多,组织(公司)必须将安全纳入供应链的核心部分。

考虑一个实际存在的产品:如电话,仅仅考虑到最终产品的安全性是不够的。除了决定使用什么样的防盗包装,你可能也想知道材料的来源,以及他们是如何组装,包装,运输。因为,重要的是我们还要确保手机不被改造或运输途中被盗。

软件供应链几乎跟实际产品的供应链是相同的。你必须能够识别和信任原材料(代码、依赖、打包),把它们组装在一起后,将它们从海上、陆上或空中(网络)运输到一个存储地(存储库),以便将项目(应用)出售(部署)给终端用户。

确保软件供应链也十分相似。你需要:

● 确定流水线中的所有东西,从人,代码,依赖关系,到基础设施

● 确保一个一致和优质的构建过程

● 在存储和运输中保护产品

● 对材料清单的交付保证并验证最终产品
在这篇文章中,我们将诠释Docker的安全特性如何为软件供应链提供持续的安全。

身份

整个流水线构建在身份验证和访问控制之上 。从根本上说,你需要知道谁可以访问什么资产,可以使用哪些操作。

Docker 架构中的身份认证理念很清晰,它隐藏在软件供应链策略中:加密密钥允许发布者对镜像进行签名,以保证其来源的真实性。

一致的构建:好的输入= 好的输出

确定一致的构建允许你创建一个可重复的过程,并控制你的应用程序依赖和组件,以便使它更容易测试出缺陷和漏洞。当你对你的组件有一个清晰认识的时候,它变得更容易识别异常的组件。

要获得一致的构建,你必须确保你添加了优质的组件:

● 评价依赖的质量,确保它是最新/兼容的版本,并用你的软件进行测试

● 验证组件来自于你期望的来源,并且在传输过程中没有损坏或改变

● 确定依赖后不要轻易改变,确保后续重建是一致的,因此如果一个缺陷是由代码或依赖的变化引起的,很容易被发现

● 使用Docker Content Trust ,从可信的、有标识的基础镜像中构建你的镜像

使用签名”密封”构建结果

应用程序签名是从构建进行有效“密封”的一步。通过镜像签名,可以确保任何在接收端(docker pull)的签名验证与镜像发布者建立一个安全链。

这种关系保证了镜像在传输过程中不被改变、添加、或删除。此外,签名表明发布者“赞同”你拉取的该镜像是没问题的 。

在构建机器和运行环境上启用 Docker Content Trust后,一个策略就会生效:只有签名镜像才可以被拉取并运行在那些 Docker 主机上。

在组织中,签名的镜像向其他人传递一个信号:发布者(构建者)声明镜像是没问题的。

安全扫描和风控

CI系统和开发者都需要确认一件事情:构建工具与依赖一起工作,操作你的应用程序时,无论在成功还是失败,都有预期的行为。

但他们审查过依赖的漏洞吗?审查过子依赖或捆绑系统库的依赖吗?他们知道依赖的许可证吗?这种审查很难通过常规的方式来完成,因为提供错误修正和功能上是一个巨大的开销。

Docker 安全扫描有助于镜像的自动化扫描。因为这是发生在镜像被推送到registry之前,在容器被部署进生产环境之前的最后一次检查。

该功能目前在Docker Cloud 中可用,并且很快延伸到Docker Datacenter。安全扫描创建了一个清单,清单中包括镜像每一层的打包信息和版本信息。

这份材料清单被用于连续监测各种 CVE 数据库。确保该扫描不止一次地发生,并在爆出新漏洞时,及时通知使用镜像的系统管理员或应用程序开发者。

多重签名-- 把签名绑在一起

安全保证最强大的一点来自Docker Content Trust 签名,它允许多个签名者参与容器的签名过程。要了解这一点,想象一个简单的 CI 过程,通过以下步骤移动容器镜像:

自动化CI

Docker 安全扫描

推送到 staging环境

推送到 production 环境

这里有四个阶段,每个阶段完成后,都可以添加一个签名,从而CI/CD 过程的每一个阶段都有验证。

1、镜像通过CI 吗?添加签名!

2、Docker Security Scanning 确定镜像没有漏洞?添加签名!

3、staging阶段中构建成功?添加签名!

4、验证所有3个签名的镜像并将其部署到生产中
现在构建被部署到生产集群之前,它可以加密验证,CI / CD过程各阶段已经签订了一个镜像。

结论

在软件生命周期的每个环节,Docker 平台都允许企业将安全纳入其中。从与用户建立信任,到基础设施和代码,docker模型给了开发者以及 IT团队足够的自由和控制力。

从构建安全的基础镜像,到扫描每一个镜像验证签名,每个特性都允许IT人员将信任植入到应用中。

当应用沿着正常的生命周期不断前行,安全信息也能够动态维护和更新,并在部署到生产环境之前通过风控检查。

本文由时速云翻译,如若转载,需注明转载自“时速云”

原文链接:https://blog.docker.com/2016/...

文章版权归作者所有,未经允许请勿转载,若此文章存在违规行为,您可以联系管理员删除。

转载请注明本文地址:https://www.ucloud.cn/yun/26700.html

相关文章

  • 企业云计算战略中混合搭配至关重要的5个原因

    摘要:主要的云计算基础设施提供商具有个人优势,精心规划的多云战略使企业能够选择为每个应用程序提供技术特性定价和性能的最佳组合的云平台。企业不希望在进入新的云计算环境并采用新的应用程序时损害自己的安全态势。云计算的兴起解决了关于IT团队是否应该从各种提供商中选择特殊技术,还是从单一供应商那里选择完全集成的应用程序的争论。借助云计算,企业可以拥有最好的应用程序,以及最好的云平台用于处理IT任务。而且不...

    Rindia 评论0 收藏0
  • AWS市场份额已达到51.8% 2019云计算厂商机会在哪里?

    摘要:数据显示,云计算市场被三大巨头把持近的市场份额,未来其他云服务商的市场份额将进一步被挤压。称,到年全球云计算市场规模将达亿美元。云计算市场格局在亚马逊举行的Invent 2018大会上,AWS CEO Andy Jassy展示出研究机构Gartner出品的全球公共云计算份额报告,报告指出,亚马逊AWS、微软Azure和阿里云继续位居全球市场前三,份额分别为51.8%、13.3%和4.6%,并...

    ky0ncheng 评论0 收藏0
  • 如何有效地同多个云提供商合作

    摘要:在同多个云提供商合作之前,请评估他们在计算存储和安全等方面的服务。企业必须在多个云供应商中做出抉择。在与多个云供应商合作时有一些策略和技巧,能够得到其优点同时限制了重复劳动和其他额外的工作。 在同多个云提供商合作之前,请评估他们在计算、存储和安全等方面的服务。企业必须在多个云供应商中做出抉择。亚马逊网络服务是行业巨头,而微软Azure则提供了一整套越来越有竞争力的服务。还有谷歌云平台对于那些...

    xavier 评论0 收藏0
  • 云端的人工智能将如何提高云计算性能

    摘要:由此产生的企业人工智能状况调查报告指出,的组织已经部署了某种人工智能。在这个调查中,的受访者预计人工智能将遇到障碍。基于人工智能的云计算到目前为止,本文主要关注基础架构即服务或平台即服务产品,以便企业部署人工智能的功能。对于大多数企业来说,基于云计算的人工智能为人工智能技术的试点和部署提供了最简单的途径。 显然,人工智能和云计算的结合将为那些利用它的公司提供一个关键优势。而人们面临的挑...

    tylin 评论0 收藏0
  • 云端的人工智能将如何提高云计算性能

    摘要:由此产生的企业人工智能状况调查报告指出,的组织已经部署了某种人工智能。在这个调查中,的受访者预计人工智能将遇到障碍。基于人工智能的云计算到目前为止,本文主要关注基础架构即服务或平台即服务产品,以便企业部署人工智能的功能。 对于大多数企业来说,基于云计算的人工智能为人工智能技术的试点和部署提供了最简单的途径。 ...

    Tonny 评论0 收藏0

发表评论

0条评论

Jeffrrey

|高级讲师

TA的文章

阅读更多
最新活动
阅读需要支付1元查看
<