封面
版权信息
序
前言
第一部分 云原生安全概述
第1章 云原生安全
1.1 云原生:云计算下半场
1.2 什么是云原生安全
1.2.1 面向云原生环境的安全
1.2.2 具有云原生特征的安全
1.2.3 原生安全:融合的云原生安全
1.3 面向云原生环境的安全体系
1.3.1 容器安全
1.3.2 编排系统安全
1.3.3 云原生应用安全
1.4 云原生安全的关键问题
1.4.1 如何防护短生命周期的容器
1.4.2 如何降低安全运营成本
1.4.3 DevSecOps
1.4.4 如何实现安全的云原生化
1.5 云原生安全现状
1.5.1 云原生新范式:Docker+Kubernetes
1.5.2 镜像安全问题仍然很突出
1.5.3 安全配置规范执行和密钥凭证管理不理想
1.5.4 运行时安全关注度上升,但依然很难
1.5.5 合规性要求依然迫切,但业界苦于无规可循
1.6 本章小结
第2章 云原生技术
2.1 容器技术
2.1.1 容器与虚拟化
2.1.2 容器镜像
2.1.3 容器存储
2.1.4 容器网络
2.1.5 容器运行时
2.2 容器编排
2.3 微服务
2.4 服务网格
2.5 Serverless
2.6 DevOps
2.7 本章小结
第二部分 云原生技术的风险分析
第3章 容器基础设施的风险分析
3.1 容器基础设施面临的风险
3.1.1 容器镜像存在的风险
3.1.2 活动容器存在的风险
3.1.3 容器网络存在的风险
3.1.4 容器管理程序接口存在的风险
3.1.5 宿主机操作系统存在的风险
3.1.6 无法根治的软件漏洞
3.2 针对容器化开发测试过程的攻击案例
3.2.1 背景知识
3.2.2 CVE-2018-15664:符号链接替换漏洞
3.2.3 CVE-2019-14271:加载不受信任的动态链接库
3.3 针对容器软件供应链的攻击案例
3.3.1 镜像漏洞利用
3.3.2 镜像投毒
3.4 针对运行时容器的攻击案例
3.4.1 容器逃逸
3.4.2 安全容器逃逸
3.4.3 资源耗尽型攻击
3.5 本章小结
第4章 容器编排平台的风险分析
4.1 容器编排平台面临的风险
4.1.1 容器基础设施存在的风险
4.1.2 Kubernetes组件接口存在的风险
4.1.3 集群网络存在的风险
4.1.4 访问控制机制存在的风险
4.1.5 无法根治的软件漏洞
4.2 针对Kubernetes组件不安全配置的攻击案例
4.2.1 Kubernetes API Server未授权访问
4.2.2 Kubernetes Dashboard未授权访问
4.2.3 Kubelet未授权访问
4.3 针对Kubernetes权限提升的攻击案例
4.3.1 背景知识
4.3.2 漏洞分析
4.3.3 漏洞复现
4.3.4 漏洞修复
4.4 针对Kubernetes的拒绝服务攻击案例
4.4.1 CVE-2019-11253:YAML炸弹
4.4.2 CVE-2019-9512/9514:HTTP/2协议实现存在问题
4.5 针对Kubernetes网络的中间人攻击案例
4.5.1 背景知识
4.5.2 原理描述
4.5.3 场景复现
4.5.4 防御策略
4.6 本章小结
第5章 云原生应用的风险分析
5.1 云原生应用风险概述
5.2 传统应用的风险分析
5.3 云原生应用的新风险分析
5.3.1 数据泄露的风险
5.3.2 未授权访问的风险
5.3.3 拒绝服务的风险
5.4 云原生应用业务的新风险分析
5.4.1 未授权访问的风险
5.4.2 API滥用的风险
5.5 Serverless的风险分析
5.5.1 Serverless特征带来的风险
5.5.2 Serverless应用风险
5.5.3 Serverless平台风险
5.5.4 Serverless被滥用的风险
5.6 本章小结
第6章 典型云原生安全事件
6.1 特斯拉Kubernetes挖矿事件
6.1.1 事件分析
6.1.2 总结与思考
6.2 微软监测到大规模Kubernetes挖矿事件
6.2.1 事件分析
6.2.2 总结与思考
6.3 Graboid蠕虫挖矿传播事件
6.3.1 事件分析
6.3.2 总结与思考
6.4 本章小结
第三部分 云原生安全防护思路和体系
第7章 云原生防护思路转变
7.1 变化:容器生命周期
7.2 安全左移
7.3 聚焦不变
7.4 关注业务
7.5 本章小结
第8章 云原生安全体系
8.1 体系框架
8.2 安全组件简介
第9章 左移的安全机制
9.1 开发安全
9.2 软件供应链安全
9.3 容器镜像安全
9.3.1 容器镜像安全现状
9.3.2 容器镜像安全防护
9.4 本章小结
第四部分 云原生可观测性
第10章 可观测性概述
10.1 为什么需要实现云原生可观测性
10.2 需要观测什么
10.3 实现手段
10.4 本章小结
第11章 日志审计
11.1 日志审计的需求与挑战
11.1.1 需求分析
11.1.2 面临的挑战
11.2 Docker日志审计
11.3 Kubernetes日志审计
11.3.1 应用程序日志
11.3.2 系统组件日志
11.3.3 日志工具
11.4 本章小结
第12章 监控
12.1 云原生架构的监控挑战
12.2 监控指标
12.3 监控工具
12.3.1 cAdvisor和Heapster
12.3.2 Prometheus
12.4 本章小结
第13章 追踪
13.1 动态追踪
13.2 eBPF
13.2.1 eBPF原理与架构
13.2.2 eBPF验证器
13.2.3 eBPF程序类型
13.2.4 eBPF工具
13.2.5 小结
13.3 基于BPFTrace实现动态追踪
13.3.1 探针类型
13.3.2 如何使用BPFTrace进行追踪
13.4 微服务追踪
13.4.1 微服务追踪概述
13.4.2 分布式追踪
13.4.3 微服务追踪实现示例
13.5 本章小结
第五部分 容器基础设施安全
第14章 Linux内核安全机制
14.1 隔离与资源管理技术
14.1.1 内核命名空间
14.1.2 控制组
14.2 内核安全机制
14.2.1 Capabilities
14.2.2 Seccomp
14.2.3 AppArmor
14.2.4 SELinux
14.3 本章小结
第15章 容器安全加固
15.1 概述
15.2 容器安全配置
15.3 本章小结
第16章 容器环境的行为异常检测
16.1 基于规则的已知威胁检测
16.1.1 检测系统设计
16.1.2 基于规则的检测实战:CVE-2019-5736
16.1.3 小结
16.2 基于行为模型的未知威胁检测
16.2.1 检测系统架构
16.2.2 学习与检测流程
16.2.3 基线设计
16.2.4 小结
16.3 本章小结
第六部分 容器编排平台安全
第17章 Kubernetes安全加固
17.1 API Server认证
17.1.1 静态令牌文件
17.1.2 X.509客户端证书
17.1.3 服务账号令牌
17.1.4 OpenID Connect令牌
17.1.5 身份认证代理
17.1.6 Webhook令牌身份认证
17.1.7 小结
17.2 API Server授权
17.3 准入控制器
17.4 Secret对象
17.5 网络策略
17.6 本章小结
第18章 云原生网络安全
18.1 云原生网络架构
18.1.1 基于端口映射的容器主机网络
18.1.2 基于CNI的Kubernetes集群网络
18.1.3 服务网格
18.2 基于零信任的云原生网络微隔离
18.2.1 什么是微隔离
18.2.2 云原生为什么需要微隔离
18.2.3 云原生网络的微隔离实现技术
18.2.4 云原生网络入侵检测
18.3 基于Cilium的网络安全方案示例
18.3.1 Cilium架构
18.3.2 Cilium组网模式
18.3.3 Cilium在Overlay组网下的通信示例
18.3.4 API感知的安全性
18.4 本章小结
第七部分 云原生应用安全
第19章 面向云原生应用的零信任安全
19.1 什么是信任
19.2 真的有零信任吗
19.3 零信任的技术路线
19.4 云化基础设施与零信任
19.5 云原生环境零信任架构
19.6 本章小结
第20章 传统应用安全
20.1 应用程序代码漏洞缓解
20.1.1 安全编码
20.1.2 使用代码检测工具
20.2 应用程序依赖库漏洞防护
20.2.1 使用受信任的源
20.2.2 使用软件组成分析工具
20.3 应用程序访问控制
20.4 应用程序数据安全防护
20.4.1 安全编码
20.4.2 使用密钥管理系统
20.4.3 使用安全协议
20.5 本章小结
第21章 API安全
21.1 传统API防护
21.2 API脆弱性检测
21.3 云原生API网关
21.4 本章小结
第22章 微服务架构下的应用安全
22.1 认证服务
22.1.1 基于JWT的认证
22.1.2 基于Istio的认证
22.2 访问控制
22.2.1 基于角色的访问控制
22.2.2 基于Istio的访问控制
22.3 数据安全
22.4 其他防护机制
22.4.1 Istio和API网关协同的全面防护
22.4.2 Istio与WAF结合的深度防护
22.5 本章小结
第23章 云原生应用业务和Serverless安全
23.1 云原生应用业务安全
23.2 Serverless应用安全防护
23.3 Serverless平台安全防护
23.3.1 使用云厂商提供的存储最佳实践
23.3.2 使用云厂商的监控资源
23.3.3 使用云厂商的账单告警机制
23.4 Serverless被滥用的防护措施
23.5 其他防护机制
23.5.1 Serverless资产业务梳理
23.5.2 定期清理非必要的Serverless实例
23.5.3 限制函数策略
23.6 本章小结
第24章 云原生应用场景安全
24.1 5G安全
24.2 边缘计算安全
24.3 工业互联网安全
24.4 本章小结
后记 云原生安全实践与未来展望
参考文献
更新时间:2021-11-04 18:13:27