Docker学习(一):linux中的cgroups

2023-11-02 02:38
文章标签 linux 学习 docker cgroups

本文主要是介绍Docker学习(一):linux中的cgroups,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

在我职业生涯中第一个大项目做完之后(基于solaris的),我终于有点时间可以充充电,学习一些别的知识了。 

近几年随着虚拟化技术的发展,各种云计算,open stack等术语几乎霸占各个IT网站的首页。我平时只是跟着了解,并没有做太深入的跟进。借着这个机会,也是该进场了。但毕竟相关技术太多,我也只能寻找一个突破点,从点到线,从线到面地把整个知识网编织起来了。纵观各大网站,最近讨论最热的莫过于docker了,那就从这个开始吧。

Docker是什么?

Docker最初是Paas提供商dotCloud公司开源的一个基于LXC技术之上构建的Container容器引擎,源代码基于Go语言并且遵循Apache2.0协议开源,目前托管于GitHub上。它是基于64位的linux开发的,所以不能运行在windows,其他unix系统以及32位的linux系统。

既然它要依赖LXC技术,那么在了解它之前,有必要先起底一下LXC。LXC是Linux containers的简称,是linux上基于容器的操作系统级别的虚拟化技术。它可以在操作系统层次上为进程提供虚拟的执行环境,一个虚拟的执行环境就是一个容器。有了容器之后,就可以为容器绑定特定的系统资源(比如CPU,memory,network/disk bandwidth)并为其提供独立的namespace(网络、pid、ipc等)。

众所周知,linux kernel现在使用cgroups来实现系统资源的隔离和监控,所以还得先了解一下cgroups。好吧,真不容易。不过这就是学习一个新东西的过程,不断挖掘不断学习。说了这么多,才引出了这篇文章的重点,不要嫌我罗嗦啊。

Cgroups是Control Groups的缩写,它是由两个google的工程师在2006年开发的,并且在2007年加入到linux的kernel里。它提供一种在linux上方便管理和监控的资源划分的机制,这些资源可以是CPU,内存等,接着把划分后的资源放在不同的组里,然后为不同的组分配不同的可执行任务。从技术的角度来说,系统的资源是由不同的子系统来管理的(也称为controller),目前常见的子系统有

1)blkio——这个子系统针对物理磁盘(disk,ssd,USB等)的IO 进行限制。

2)cpu——这个系统通过系统的scheduler来调控隶属于不同groups上的tasks的cpu资源

3)memory——这个子系统限制了不同groups可以使用的内存。

4)net_cls——这个子系统可以为不同groups的网络包标记不同的id来允许Linux traffic controller(tc)来

5)  net_prio——该子系统可以动态的设置每个network interface的优先级。

6)ns——该子系统可以为不同的groups分配不同的命名空间(Process identifiers, UTS namesapce 允许修改hostname)。

说了这么多你可能还是不太了解,那么我来举个例子吧。假设你有一个server,上面跑着一些对内存,cpu等资源有要求的应用程序, 那么就可以创建两个groups,一个用于这个应用程序,另一个用于系统,并将相应的资源分配到这两个组里。


我们主要看一下group2,通常在我们创建一个group之前,我们一般会清楚需要为它分配什么资源, 比如在这个例子中,应用程序需要10GB的内存,80%的网络带宽,80%的磁盘带宽并且占用的CPU资源不能超过80%。


接下来,将接着介绍lxc。

参考资料:

  • Wikipedia: cgroups
  • kernel.org: cgroups.txt
  • kernel.org: cgroups folder
  • Red Hat: Introduction to Control Groups (Cgroups)

这篇关于Docker学习(一):linux中的cgroups的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/327512

相关文章

java实现docker镜像上传到harbor仓库的方式

《java实现docker镜像上传到harbor仓库的方式》:本文主要介绍java实现docker镜像上传到harbor仓库的方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地... 目录1. 前 言2. 编写工具类2.1 引入依赖包2.2 使用当前服务器的docker环境推送镜像2.2

Linux中SSH服务配置的全面指南

《Linux中SSH服务配置的全面指南》作为网络安全工程师,SSH(SecureShell)服务的安全配置是我们日常工作中不可忽视的重要环节,本文将从基础配置到高级安全加固,全面解析SSH服务的各项参... 目录概述基础配置详解端口与监听设置主机密钥配置认证机制强化禁用密码认证禁止root直接登录实现双因素

在Linux终端中统计非二进制文件行数的实现方法

《在Linux终端中统计非二进制文件行数的实现方法》在Linux系统中,有时需要统计非二进制文件(如CSV、TXT文件)的行数,而不希望手动打开文件进行查看,例如,在处理大型日志文件、数据文件时,了解... 目录在linux终端中统计非二进制文件的行数技术背景实现步骤1. 使用wc命令2. 使用grep命令

Linux如何快速检查服务器的硬件配置和性能指标

《Linux如何快速检查服务器的硬件配置和性能指标》在运维和开发工作中,我们经常需要快速检查Linux服务器的硬件配置和性能指标,本文将以CentOS为例,介绍如何通过命令行快速获取这些关键信息,... 目录引言一、查询CPU核心数编程(几C?)1. 使用 nproc(最简单)2. 使用 lscpu(详细信

linux重启命令有哪些? 7个实用的Linux系统重启命令汇总

《linux重启命令有哪些?7个实用的Linux系统重启命令汇总》Linux系统提供了多种重启命令,常用的包括shutdown-r、reboot、init6等,不同命令适用于不同场景,本文将详细... 在管理和维护 linux 服务器时,完成系统更新、故障排查或日常维护后,重启系统往往是必不可少的步骤。本文

基于Linux的ffmpeg python的关键帧抽取

《基于Linux的ffmpegpython的关键帧抽取》本文主要介绍了基于Linux的ffmpegpython的关键帧抽取,实现以按帧或时间间隔抽取关键帧,文中通过示例代码介绍的非常详细,对大家的学... 目录1.FFmpeg的环境配置1) 创建一个虚拟环境envjavascript2) ffmpeg-py

Linux脚本(shell)的使用方式

《Linux脚本(shell)的使用方式》:本文主要介绍Linux脚本(shell)的使用方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录概述语法详解数学运算表达式Shell变量变量分类环境变量Shell内部变量自定义变量:定义、赋值自定义变量:引用、修改、删

Linux链表操作方式

《Linux链表操作方式》:本文主要介绍Linux链表操作方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、链表基础概念与内核链表优势二、内核链表结构与宏解析三、内核链表的优点四、用户态链表示例五、双向循环链表在内核中的实现优势六、典型应用场景七、调试技巧与

Go学习记录之runtime包深入解析

《Go学习记录之runtime包深入解析》Go语言runtime包管理运行时环境,涵盖goroutine调度、内存分配、垃圾回收、类型信息等核心功能,:本文主要介绍Go学习记录之runtime包的... 目录前言:一、runtime包内容学习1、作用:① Goroutine和并发控制:② 垃圾回收:③ 栈和

详解Linux中常见环境变量的特点与设置

《详解Linux中常见环境变量的特点与设置》环境变量是操作系统和用户设置的一些动态键值对,为运行的程序提供配置信息,理解环境变量对于系统管理、软件开发都很重要,下面小编就为大家详细介绍一下吧... 目录前言一、环境变量的概念二、常见的环境变量三、环境变量特点及其相关指令3.1 环境变量的全局性3.2、环境变