C06S02-Docker网络和资源限制

一、Docker网络模式

1. 桥接模式

Docker的默认网络模式,工作在第二层,也就是数据链路层。

  1. 启动Docker的时候会在宿主机上创建一个虚拟的网桥,工作方式类似于交换机。
  2. 创建容器的时候,会分配一个和网桥相同网段的IP地址给容器使用,网桥IP地址作为这个网段的网关。容器被删除时,IP地址会被回收。
  3. 容器运行时,会生成一对Veth Pair虚拟网络接口设备。一端连在网桥上,一端连在容器上,从而实现容器和主机之间的通信。
  4. 容器之间通过IP地址直接通信,不同的容器在同一个网段,通过Veth Piar连接在同一个网桥上。

2. Host模式

容器和宿主机共享一个Network命名空间,容器不会生成虚拟的网卡、也不会配置IP地址,而是与宿主机共享网络端口和IP地址。

配置Host模式的基本命令如下。

docker run -itd --network host 镜像名称[:镜像标签] 
  • –network:用于配置容器的网络模式,这里是host模式。

3. Container模式

所有容器共享一个Network命名空间,新建的容器不会创建自己的虚拟网卡和IP地址,而是和已有的容器共享网络端口和IP地址,除网络外,其他资源也还是互相隔离的。

配置Container模式的基本命令如下。

docker run -itd --network container 镜像名称[:镜像标签] 

4. None模式

容器有单独的命名空间,但是没有虚拟网卡、IP地址等网络配置,只有一个回环地址。也就是说,不能访问外部网络,也不能被外部网络访问,这种模式常用于测试。

配置Container模式的基本命令如下。

docker run -itd --network none 镜像名称[:镜像标签] 

5. 自定义模式

用户可以自定义创建一个虚拟网桥,指定网桥的网段范围。只有先创建了自定义网桥,才能够给容器分配指定的IP地址。

配置自定义模式的基本流程如下。

# 先自定义网络,设置IP范围
docker network create --subnet=子网范围 --opt "com.docker.network.bridge.name"="网卡名称" 网络名称# 在创建并运行容器的同时,指定容器的IP
docker run -itd --network 网络名称 --ip 自定义IP地址 镜像名称[:镜像标签] 
  • –subnet:用于设置自定义网络的子网范围,采用CIDR写法。
  • –opt:用于设置自定义网络的特定配置。这里的com.docker.network.bridge.name是用于设置自定义网络的虚拟网卡名称。如果不设置,Docker会自动生成一个。

二、Docker资源限制

1. Cgroups概述

Cgroups是Linux内核实现资源限制的一种机制,而Docker正是通过Cgroups来进行资源的限制,主要限制包括CPU资源限制、内存资源限制、磁盘资源限制,其中最为常用的是CPU和内存的资源限制。

2. CPU资源限制

2.1 设置CPU使用率

Linux通过CFS (Completely Fair Scheduler, 完全公平调度器)来调度各个进程对CPU的使用,默认的CPU调度时间是100000微秒(100毫秒)。CFS的调度时间范围是1毫秒至1秒,也就是1000微秒至1000000微秒,CPU的使用时间不得小于1000微秒。

  • –cpu-period:设置CFS调度CPU的时间,单位是微秒,范围是1000—1000000。
  • –cpu-quota:设置容器对CPU的使用时间,单位是微秒,常用限制配置。数值不小于1000,不大于调度时间。
docker run -itd --name 容器名称 --cpu-quota 使用时间 镜像名称[:镜像标签]

2.2 设置CPU资源权重

通过–cpu-share来设置容器对CPU的使用权重,通常是1024的倍数,默认值是1024。只有多个容器同时设置了权重才能够生效。

docker run -itd --name 容器名称 --cpu-share 使用权重 镜像名称[:镜像标签]

2.3 设置指定CPU核

通过–cpuset-cpus来设置容器所使用的CPU核,CPU的核索引从0开始,指定多个核则用逗号分隔。

docker run -itd --name 容器名称 --cpuset-cpus 核索引 镜像名称[:镜像标签]

3. 内存资源限制

3.1 设置容器内存大小

通过–memory来设置容器的内存大小,数值后需要带单位,比如M表示MB、G表示GB。

docker run -itd --name 容器名称 --memory 内存大小 镜像名称[:镜像标签]

3.2 设置容器交换空间大小

通过–memory-swap来设置容器的交换空间大小,要和–memory一起使用,并且设置的数值大小要包括容器的内存大小。比如–memory 512M --memory-swap 1G的含义是:容器的物理内存是512MB、可使用的交换空间是1GB-512MB=512MB。

docker run -itd --name 容器名称 --memory 内存大小 --memory-swap 交换空间大小 镜像名称[:镜像标签]
  • 如果两个设置的值相同,则表示容器无法使用交换空间。
  • —memory-swap的值设置为-1表示交换空间大小不受限,宿主机有多大交换空间,容器就可以使用多大的交换空间。

4. 磁盘资源限制

通常情况下,不会限制容器对磁盘资源的使用。通过–device-read-bps和–device-write-bps来设置对容器的读数据、写数据的速度。

docker run -itd --name 容器名称 -device-read-bps 磁盘设备:速度大小 --device-write-bps 磁盘设备:速度大小 镜像名称[:镜像标签]

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

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

相关文章

生产环境的 MySQL事务隔离级别

MySQL 数据库的默认隔离级别是 RR( 可重复读 ),但是很多大公司把隔离级别改成了 RC(读已提交),主要原因是为了提高并发和降低死锁概率 为了解决幻读的问题 RR 相比 RC 多了间隙锁( gap lock )和临键锁( next-keylock )。而 RC 中修改数据仅用行锁&#…

Oracle(windows安装遇到的ORA-12545、ORA-12154、ORA-12541、ORA-12514等问题)

其实出现该问题就是监听或者服务没有配好。 G:\xiaowangzhenshuai\software\Oracle\product\11.2.0\dbhome_1\NETWORK\ADMINlistener.ora SID_LIST_LISTENER (SID_LIST (SID_DESC (SID_NAME CLRExtProc)(ORACLE_HOME G:\xiaowangzhenshuai\software\Oracle\product\11.2.0\d…

Mac上搭建k8s环境——Minikube

1、在mac上安装Minikube可执行程序 brew cask install minikub 安装后使用minikube version命令查看版本 2、安装docker环境 brew install --cask --appdir/Applications docker #安装docker open -a Docker #启动docker 3、安装kubectl curl -LO https://storage.g…

OpenAI 实战进阶教程 - 第二节:生成与解析结构化数据:从文本到表格

目标 学习如何使用 OpenAI API 生成结构化数据(如 JSON、CSV 格式)。掌握解析数据并导出表格文件的技巧,以便适用于不同实际场景。 场景背景 假设你是一名开发人员,需要快速生成一批产品信息列表(如名称、价格、描述…

PostgreSQL 中进行数据导入和导出

在数据库管理中,数据的导入和导出是非常常见的操作。特别是在 PostgreSQL 中,提供了多种工具和方法来实现数据的有效管理。无论是备份数据,还是将数据迁移到其他数据库,或是进行数据分析,掌握数据导入和导出的技巧都是…

【Gitlab】虚拟机硬盘文件丢失,通过xx-flat.vmdk恢复方法

前言 由于近期过年回家,为了用电安全直接手动关闭了所有的电源,导致年后回来商上电开机后exsi上的虚拟机出现了问题。显示我的gitlab虚拟机异常。 恢复 开机之后虚拟机异常,通过磁盘浏览发现gitlab服务器下面的虚拟机磁盘文件只有一个xxx-f…

如何在自己mac电脑上私有化部署deep seek

在 Mac 电脑上私有化部署 DeepSeek 的步骤如下: 1. 环境准备 安装 Homebrew(如果尚未安装): Homebrew 是 macOS 上的包管理工具,用于安装依赖。 /bin/bash -c "$(curl -fsSL https://raw.githubusercontent.com…

DeepSeek服务器繁忙问题的原因分析与解决方案

一、引言 随着人工智能技术的飞速发展,DeepSeek 等语言模型在众多领域得到了广泛应用。然而,在春节这段时间的使用过程中,用户常常遭遇服务器繁忙的问题,这不仅影响了用户的使用体验,也在一定程度上限制了模型的推广和…

python的ruff简单使用

Ruff 是一个用 Rust 编写的高性能 Python 静态分析工具和代码格式化工具。它旨在提供快速的代码检查和格式化功能,同时支持丰富的配置选项和与现有工具的兼容性。ruff是用rust实现的python Linter&Formatter。 安装: conda install -c conda-forge…

第16章 Single Thread Execution设计模式(Java高并发编程详解:多线程与系统设计)

简单来说, Single Thread Execution就是采用排他式的操作保证在同一时刻只能有一个线程访问共享资源。 1.机场过安检 1.1非线程安全 先模拟一个非线程安全的安检口类,旅客(线程)分别手持登机牌和身份证接受工作人员的检查,示例代码如所示。…

C# 压缩图片并保存到本地

本文主要介绍如何使用C#将图片进行压缩并保存到本地。 接收一个原始图片的字节数组、需要保存的图片类型、输出路径和图片质量。方法首先将字节数组转换为一个内存流,然后使用Image.FromStream方法将内存流转换为一个Image对象。接下来,方法创建一个编码…

项目练习:重写若依后端报错cannot be cast to com.xxx.model.LoginUser

文章目录 一、情景说明二、解决办法 一、情景说明 在重写若依后端服务的过程中 使用了Redis存放LoginUser对象数据 那么,有存就有取 在取值的时候,报错 二、解决办法 方法1、在TokenService中修改如下 getLoginUser 方法中:LoginUser u…

操作系统和中间件的信息收集

在浏览器中收集操作系统与中间件信息时,主要通过客户端JavaScript(用于操作系统/浏览器信息)和服务器端脚本(用于中间件信息)实现。以下是分步指南: 一、客户端操作系统信息收集(JavaScript&am…

高级sql技巧 从复杂查询到性能优化 提升数据处理效率

在数据驱动的时代,SQL(结构化查询语言)是数据库管理和数据分析中不可或缺的工具。随着数据复杂度和数据量的增加,掌握 SQL 的高级技巧不仅能帮助我们高效处理复杂的数据查询,还能极大地提高数据库的性能和数据处理效率…

QT 窗口A覆盖窗口B时,窗口B接受不到鼠标事件

一、问题 在项目的需求中,地图A上面需要叠放一个任务窗口B,B覆盖了A,导致A接受不到鼠标及滚轮事件。 二、解决方案 1、Qt::WA_TransparentForMouseEvents 是 Qt 框架中的一个属性,用于使指定的控件及其子控件不响应鼠标事件。当启…

爱普生L3153打印机无线连接配置流程

家里使用的是移动宽带中兴路由器,有WPS功能,进入192.168.1.1管理员页面,用户名user,密码在路由器背面(可以登录后修改密码)。在网络-WLAN网络配置-WPS中,点击push button,激活路由器…

计算机网络知识速记:HTTP与HTTPS

计算机网络知识速记:HTTP与HTTPS 一、HTTP基础知识 HTTP(超文本传输协议)是一个无状态的协议,通常用于在客户端与服务器之间传输数据。HTTP采用的是一种请求-响应模型,客户端发出请求后,服务器返回数据。…

简述mysql 主从复制原理及其工作过程,配置一主两从并验证。

MySQL 主从复制工作过程 1、二进制日志记录(Binary Logging): 主服务器开启二进制日志记录功能,将所有更改数据的操作(如 INSERT、UPDATE、DELETE)记录到二进制日志文件中。 2、日志传输(Log…

Rust枚举(Enum)完全指南:用类型安全表达多样性

枚举(Enum)是Rust类型系统的核心特性之一,它不仅能够表示简单的选项集合,还能携带复杂数据,配合模式匹配实现强大的逻辑控制。本文将通过具体示例,深入解析Rust枚举的完整用法。 一、基础枚举定义 1.1 简单…

Python Pandas(3):DataFrame

1 介绍 DataFrame 是 Pandas 中的另一个核心数据结构,类似于一个二维的表格或数据库中的数据表。它含有一组有序的列,每列可以是不同的值类型(数值、字符串、布尔型值)。DataFrame 既有行索引也有列索引,它可以被看做由…