10.Docker安全和https

news2025/1/24 14:56:59

文章目录

  • Docker安全
    • Docker存在的安全问题
    • Docker架构缺陷与安全机制
    • Docker 安全基线标准
    • Docker安全总结
  • HTTPS
    • HTTPS访问过程
    • 生成证书方式
    • openssL生成证书过程

Docker安全

  • 容器的安全性问题的根源在于容器和宿主机共享内核。
  • 如果容器里的应用导致Linux内核崩溃,那么整个系统可能都会崩溃。
  • 与虚拟机是不同的,虚拟机并没有与主机共享内核,虚拟机崩溃一般不会导致宿主机崩溃。

Docker存在的安全问题

  1. Docker自身的漏洞
    • 作为一款应用 Docker 本身实现上会有代码缺陷
    • 黑客常用的攻击手段主要有代码执行、权限提升、信息泄露、权限绕过等。目前 Docker 版本更迭非常快,Docker 用户可将 Docker 升级为最新版本。
  2. Docker镜像问题
    • Docker 提供了 Docker hub,可以让用户上传创建的镜像,以便其他用户下载,快速搭建环境。但同时也带来了一些安全问题
    • 黑客上传恶意镜像:黑客在制作的镜像中植入木马、后门等恶意软件
    • 镜像使用有漏洞的软件:DockerHub上能下载的镜像里面,75%的镜像都安装了有漏洞的软件
    • 中间人攻击篡改镜像:镜像在传输过程中可能被篡改

Docker架构缺陷与安全机制

  1. 容器之间的局域网攻击
    • 主机上的容器之间可以构成局域网,因此针对局域网的ARP欺骗、端口扫描、广播风暴等攻击方式便可以用上。所以,在一个主机上部署多个容器需要合理的配置网络安全,比如设置 iptables 规则。
  2. DDoS 攻击耗尽资源
    • Cgroups 安全机制就是要防止此类攻击的,不要为单一的容器分配过多的资源即可避免此类问题
  3. 有漏洞的系统调用
    • Docker 与虚拟机的一个重要的区别就是 Docker 与宿主机共用一个操作系统内核。
    • 一旦宿主内核存在可以越权或者提权漏洞,尽管Docker使用普通用户执行,在容器被入侵时,攻击者还可以利用内核漏洞跳到宿主机做更多的事情
  4. 共享root用户权限
    • 如果以 root 用户权限运行容器(docker run --privileged),容器内的 root 用户也就拥有了宿主机的root权限

Docker 安全基线标准

  1. 内核级别
    1. 及时更新内核。
    2. User NameSpace(容器内的 root 权限在容器之外处于非高权限状态)。
    3. Cgroups(对资源的配额和度量),设置CPU、内存、磁盘 IO等资源限制。
    4. 通过启用 SELinux(控制文件访问权限)适当的强化系统来增加额外的安全性。
    5. Capability(权限划分),比如划分指定的CPU给容器。
    6. Seccomp(限定系统调用),限制不必要的系统调用。
    7. 禁止将容器的命名空间与宿主机进程命名空间共享,比如 host 网络模式。
  2. 主机级别
    1. 为容器创建独立分区,比如创建在分布式文件系统上。
    2. 仅运行必要的服务,注意尽量避免在容器中运行 ssh 服务 。
    3. 禁止将宿主机上敏感目录映射到容器,-v创建数据卷时需要注意。
    4. 对 Docker 守护进程、相关文件和目录进行审计,防止有病毒或木马文件生成。
    5. 设置适当的默认文件描述符数。
    6. 用户权限为 root 的 Docker 相关文件的访问权限应该为 644 或者更低权限。
    7. 周期性检查每个主机的容器清单,并清理不必要的容器。
  3. 网络级别
    1. 通过 iptables 设定规则实现禁止或允许容器之间网络流量。
    2. 允许 Docker 修改 iptables。
    3. 禁止将 Docker 绑定到其他已使用的 IP/Port 或者 Unix Socket。
    4. 禁止在容器上映射特权端口。
    5. 容器上只开放所需要的端口。
    6. 禁止在容器上使用 host 网络模式。
    7. 若宿主机有多个网卡,将容器进入流量绑定到特定的主机网卡上。
  4. 镜像级别
    1. 创建本地私有镜像仓库服务器。
    2. 镜像中软件都为最新版本,建议根据实际情况使用对应版本,业务稳定优先。
    3. 使用可信镜像文件,并通过安全通道下载。
    4. 重新构建镜像而非对容器和镜像打补丁,销毁异常容器重新构建。
    5. 合理管理镜像标签,及时移除不再使用的镜像。
    6. 使用镜像扫描。
    7. 使用镜像签名。
  5. 容器级别
    1. 容器最小化,操作系统镜像最小集。
    2. 容器以单一主进程的方式运行。
    3. 禁止 --privileged 标记使用特权容器。
    4. 禁止在容器上运行 ssh 服务,尽量使用 docker exec 进入容器。
    5. 以只读的方式挂载容器的根目录系统,-v 宿主机目录:容器目录:ro。
    6. 明确定义属于容器的数据盘符。
    7. 通过设置 on-failure 限制容器尝试重启的次数,容器反复重启容易丢失数据,–restart=on-failure:3。
    8. 限制在容器中可用的进程数,docker run -m 限制内存的使用,以防止 fork 炸弹。 (fork炸弹,迅速增长子进程,耗尽系统进程数量)
  6. 其他设置
    1. 定期对宿主机系统及容器进行安全审计。
    2. 使用最少资源和最低权限运行容器,此为 Docker 容器安全的核心思想。
    3. 避免在同一宿主机上部署大量容器,维持在一个能够管理的数量。
    4. 监控 Docker 容器的使用,性能以及其他各项指标,比如 zabbix。
    5. 增加实时威胁检测和事件报警响应功能,比如 zabbix。
    6. 使用中心和远程日志收集服务,比如 ELK 。

Docker安全总结

  • Docker容器安全注意点:
  • 尽量别做的事:
    • 尽量不用 --privileged 运行容器(会授权容器root用户拥有宿主机的root权限)
    • 尽量不在容器中运行ssh服务
    • 尽量不用 --network host运行容器(会使用host网络模式共享宿主机的网络命名空间)
  • 尽量要做的事:
    • 尽量使用最小化的镜像
    • 尽量以单一进程运行容器
    • 尽量以最低权限运行容器
    • 尽量下载使用官方的镜像或者自己构建镜像从私有仓库下载
    • 尽量使用只读的方式挂载数据卷 -v 宿主机目录:容器目录:ro
    • 尽量设置容器重启次数 --restart on-failure:N
    • 尽量使用最新版本的应用做镜像主进程
    • 尽量使用最新版本的docker
    • 尽量以资源限制的方式运行容器

HTTPS

HTTPS访问过程

在这里插入图片描述

  • https请求访问过程:
    1. 服务端会事先通过CA签发证书和私钥
    2. 客户端发送https请求到服务端的443端口
    3. 服务端发送包含公钥、证书有效期及CA机构等信息的证书给客户端
    4. 客户端会先通过CA验证证书的有效性
    5. 若证书有效,客户端会在本地随机生成会话密钥,并通过服务端发来的公钥加密后返回给服务端
    6. 服务端用私钥解密获取会话密钥,之后双方即可使用会话密钥加密/解密来实现密文通信

生成证书方式

  • 如何生成证书(获取证书):
    • 在阿里云、腾讯云、华为云等云服务商申请一年期的免费证书
    • 在服务器本地使用openssl、cfssl、mkcert、Let‘s Encrypt生成SSL

openssL生成证书过程

###关闭防火墙

systemctl stop firewalld
systemctl disable firewalld
setenforce 0
##安装opebssl

yum -y install openssl
###创建CA证书的私钥

openssl genrsa -out ca.key 4096

在这里插入图片描述

##基于CA私钥创建CA证书的自签名请求

openssl req -new -key ca.key -out ca.csr

在这里插入图片描述

##基于自签名请求创建CA证书

openssl x509 -req -in ca.csr -signkey ca.key -out ca.pem

在这里插入图片描述

###创建  server  的CA证书私钥

openssl genrsa -out server.key 4096

在这里插入图片描述

##创建自签名请求

openssl req -new -key server.key -out server.csr

在这里插入图片描述

##创建CA证书,使用CA签发证书文件

openssl x509 -req -days 3650 -in server.csr -signkey ca.key -out server.pem

在这里插入图片描述

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.coloradmin.cn/o/807621.html

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈,一经查实,立即删除!

相关文章

Spring Tool Suite 4

参考:Spring tool suite4 安装及配置_springtoolsuite4_猿界零零七的博客-CSDN博客 下载:Spring | Tools 将下载的JAR进行解压两次,直至解压出contents中的sts 双击启动 第一次打开需要指定工作区文件夹 配置Maven的config 安装插件

C++ new/delete的使用

1.虚拟地址空间 可执行程序(进程)的虚拟地址空间: 内核:操作系统 栈区:函数的形参,非静态的局部变量,函数现场保护数据等等,栈是向下增长的,栈顶是低地址,栈…

基于fpga_EP4CE6F17C8实现的呼吸灯

文章目录 前言实验手册(EP4CE6F17C8)一、实验目的二、实验原理理论原理 三、系统架构设计四、模块说明1.模块端口信号列表2.状态转移图3.时序图 五、仿真波形图六、引脚分配七、代码实现八、仿真代码九、板级验证效果 …

[CrackMe]damn.exe的逆向及注册机编写

1. 脱壳过程 这个crackme有2个文件 发现加了壳 先来脱壳, 使用ESP守恒, pushad后立马下硬件访问断点 F9直接运行, 立马到popad处 接着走几步就到了OEP 下面使用LordPE来转储映像, 为了防止别人修改PE中的ImageSize, 先尝试修正下ImageSize, 然后dump full即可 接着用x6…

《重构的时机和方法》——让你的代码更健壮、更易维护

👏作者简介:大家好,我是爱敲代码的小黄,独角兽企业的Java开发工程师,CSDN博客专家,阿里云专家博主📕系列专栏:Java设计模式、Spring源码系列、Netty源码系列、Kafka源码系列、JUC源码…

简述IO(BIO NIO IO多路复用)

在unix网络变成中的五种IO模型: Blocking IO(阻塞IO) NoneBlocking IO (非阻塞IO) IO mulitplexing(IO多路复用) signal driven IO (信号驱动IO) asynchronous IO (异步IO) BIO BIO(Blocking IO)是一种阻塞IO模型,也是传统的IO操作模型之一…

不管如何吐槽,购买iPhone的用户依然义无反顾,苹果继续增长

市调机构IDC公布的二季度数据显示,苹果成为前五名之中除华为之外第二家取得增长的手机品牌,而其他国产手机品牌的出货量都在下滑,显示出国内的消费者仍然在热烈追捧iPhone。 二季度苹果在国内市场的手机出货量同比增长6%,虽然增速…

查看详细的退货信息!亚马逊在卖家中心推出新页面!

亚马逊欧洲站发布公告称亚马逊在卖家中心推出了一个新页面,为卖家提供详细的退货信息,以下是公告内容: 我们在卖家中心推出了一个新页面,为卖家提供详细的退货信息。 现在卖家可以查看每个退货订单,其中包含有关 ASI…

sky-notes-01

1、DTO类 DTO(Data Transfer Object):数据传输对象,Service 或 Manager 向外传输的对象。 详见阿里巴巴Java开发手册中的DO、DTO、BO、AO、VO、POJO定义 当前端提交的数据和实体类中对应的属性差别比较大时,建议使用…

【信号去噪和正交采样】流水线过程的一部分,用于对L波段次级雷达中接收的信号进行降噪(Matlab代码实现)

💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜密,逻辑清晰,为了方便读者。 ⛳️座右铭&a…

信号的学习笔记二

文章目录 信号捕捉signal信号捕捉sigaction信号集未决信号集和阻塞信号集的工作过程 ![在这里插入图片描述](https://img-blog.csdnimg.cn/b896346af6f1462089779e513a7e237b.png)信号集相关函数sigemptysetsigfillsetsigaddsetsigdelsetsigismember应用 以下函数设置内核信号集…

上传图片到腾讯云对象存储桶cos 【腾讯云对象存储桶】【cos】【el-upload】【vue3】【上传头像】【删除】

1、首先登录腾讯云官网控制台 进入对象存储页面 2、找到跨越访问CIRS设置 配置规则 点击添加规则 填写信息 3、书写代码 这里用VUE3书写 第一种用按钮出发事件形式 <template><div><input type="file" @change="handleFileChange" /&…

[NLP]LLM高效微调(PEFT)--LoRA

LoRA 背景 神经网络包含很多全连接层&#xff0c;其借助于矩阵乘法得以实现&#xff0c;然而&#xff0c;很多全连接层的权重矩阵都是满秩的。当针对特定任务进行微调后&#xff0c;模型中权重矩阵其实具有很低的本征秩&#xff08;intrinsic rank&#xff09;&#xff0c;因…

labelme标签格式json转化成yolov8支持是数据集格式

我们用yolov8做实例分割时&#xff0c;需要制作标签&#xff0c;如果用labelme做&#xff0c;不能直接用模型训练&#xff0c;需要利用一个脚本文件进行转换。 import base64 import random import shutil from tqdm import tqdm import math import json import os import nu…

5.2.12.读写接口实践 copy_from_user copy_to_user

5.2.12.读写接口实践 5.2.12.1、完成write和read函数 (1)copy_from_user函数的返回值定义&#xff0c;和常规有点不同。返回值如果成功复制则返回0&#xff0c;如果 不成功复制则返回尚未成功复制剩下的字节数。 copy_from_user 函数&#xff1a;static inline unsigned long _…

【业务功能篇59】Springboot + Spring Security 权限管理 【下篇】

UserDetails接口定义了以下方法&#xff1a; getAuthorities(): 返回用户被授予的权限集合。这个方法返回的是一个集合类型&#xff0c;其中每个元素都是一个GrantedAuthority对象&#xff0c;表示用户被授予的权限。getPassword(): 返回用户的密码。这个方法返回的是一个字符…

第十二章:priority_queue类

系列文章目录 文章目录 系列文章目录前言priority_queue的介绍priority_queue的使用容器适配器什么是容器适配器STL标准库中stack和queue的底层结构 总结 前言 priority_queue是容器适配器&#xff0c;底层封装了STL容器。 priority_queue的介绍 priority_queue文档介绍 优先…

路由器工作原理

路由器原理 路由概述 路由&#xff1a;跨越从源主机到目标主机的一个互联网络来转发数据包的过程。&#xff08;为数据包选择路径的过程&#xff09; 作用&#xff1a;路由器是连接不同网段的。 转发依据&#xff1a; 路由表&#xff1a;路径选择全看路由表&#xff0c;根…

大数据课程D5——hadoop的Sink

文章作者邮箱&#xff1a;yugongshiyesina.cn 地址&#xff1a;广东惠州 ▲ 本章节目的 ⚪ 掌握Sink的HDFS Sink&#xff1b; ⚪ 掌握Sink的Logger Sink&#xff1b; ⚪ 掌握Sink的File Roll Sink&#xff1b; ⚪ 掌握Sink的Null Sink&#xff1b; ⚪ 掌握Si…

【前端知识】React 基础巩固(三十六)——RTK中的异步操作

React 基础巩固(三十六)——RTK中的异步操作 一、RTK中使用异步操作 引入RTK中的createAsyncThunk&#xff0c;在extraReducers中监听执行状态 import { createSlice, createAsyncThunk } from "reduxjs/toolkit"; import axios from "axios";export cons…