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

相关文章

windows和Linux使用命令行计算文件的MD5值

《windows和Linux使用命令行计算文件的MD5值》在Windows和Linux系统中,您可以使用命令行(终端或命令提示符)来计算文件的MD5值,文章介绍了在Windows和Linux/macO... 目录在Windows上:在linux或MACOS上:总结在Windows上:可以使用certuti

Linux之systemV共享内存方式

《Linux之systemV共享内存方式》:本文主要介绍Linux之systemV共享内存方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录一、工作原理二、系统调用接口1、申请共享内存(一)key的获取(二)共享内存的申请2、将共享内存段连接到进程地址空间3、将

快速修复一个Panic的Linux内核的技巧

《快速修复一个Panic的Linux内核的技巧》Linux系统中运行了不当的mkinitcpio操作导致内核文件不能正常工作,重启的时候,内核启动中止于Panic状态,该怎么解决这个问题呢?下面我们就... 感谢China编程(www.chinasem.cn)网友 鸢一雨音 的投稿写这篇文章是有原因的。为了配置完

Java学习手册之Filter和Listener使用方法

《Java学习手册之Filter和Listener使用方法》:本文主要介绍Java学习手册之Filter和Listener使用方法的相关资料,Filter是一种拦截器,可以在请求到达Servl... 目录一、Filter(过滤器)1. Filter 的工作原理2. Filter 的配置与使用二、Listen

Linux命令之firewalld的用法

《Linux命令之firewalld的用法》:本文主要介绍Linux命令之firewalld的用法,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux命令之firewalld1、程序包2、启动firewalld3、配置文件4、firewalld规则定义的九大

Windows Docker端口占用错误及解决方案总结

《WindowsDocker端口占用错误及解决方案总结》在Windows环境下使用Docker容器时,端口占用错误是开发和运维中常见且棘手的问题,本文将深入剖析该问题的成因,介绍如何通过查看端口分配... 目录引言Windows docker 端口占用错误及解决方案汇总端口冲突形成原因解析诊断当前端口情况解

Linux之计划任务和调度命令at/cron详解

《Linux之计划任务和调度命令at/cron详解》:本文主要介绍Linux之计划任务和调度命令at/cron的使用,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教... 目录linux计划任务和调度命令at/cron一、计划任务二、命令{at}介绍三、命令语法及功能 :at

Linux下如何使用C++获取硬件信息

《Linux下如何使用C++获取硬件信息》这篇文章主要为大家详细介绍了如何使用C++实现获取CPU,主板,磁盘,BIOS信息等硬件信息,文中的示例代码讲解详细,感兴趣的小伙伴可以了解下... 目录方法获取CPU信息:读取"/proc/cpuinfo"文件获取磁盘信息:读取"/proc/diskstats"文

Linux内核参数配置与验证详细指南

《Linux内核参数配置与验证详细指南》在Linux系统运维和性能优化中,内核参数(sysctl)的配置至关重要,本文主要来聊聊如何配置与验证这些Linux内核参数,希望对大家有一定的帮助... 目录1. 引言2. 内核参数的作用3. 如何设置内核参数3.1 临时设置(重启失效)3.2 永久设置(重启仍生效

kali linux 无法登录root的问题及解决方法

《kalilinux无法登录root的问题及解决方法》:本文主要介绍kalilinux无法登录root的问题及解决方法,本文给大家介绍的非常详细,对大家的学习或工作具有一定的参考借鉴价值,... 目录kali linux 无法登录root1、问题描述1.1、本地登录root1.2、ssh远程登录root2、