容器基础(五): 实现一个简单容器sdocker
在前面几部分的基础上, 我们更新一下代码,实现一个简单容器 sdocker.
sdocker目录构成
linux: # tree
.
├── Makefile
├── cpu-test.c # 由cpu.c重命名
├── memory-test.cpp # 由memory.cpp重命名
├── resource.c # 新增用于资源管理
├── resource.h
├── sdocker_exec.c # 模拟 docker exec
└── sdocker_run.c # 由namespace.c更新而来, 模拟 docker run directories, files
linux: #
修改点
. 更新rootfs:
a) 拷贝cpu-test/memory-test到rootfs/bin目录下, 对应的依赖库也按照先前文章介绍的方法拷贝到rootfs对应路径,方便后续进行cpu和memory测试;
b) rootfs增加拷贝top命令, 方便查看cpu使用率;
c) 增加rootfs/root/.bashrc, 用于设置容器的提示符, 内容如下所示:
linux:~ # cat /var/lib/sdocker/rootfs/root/.bashrc
export PS1="\h:\w $ "
linux:~ # sdocker启动后的终端提示符如下所示(主机名@容器id: 路径):
sdocker@:/ $ . 增加sdocker_run程序:
a) 增加cgroup资源管理文件resource.c, 可以设置memory.limit_in_bytes, memory.swappiness, cpu.cfs_period_us, cpu.cfs_quota_us.
资源管理会在启动容器进程后在/sys/fs/cgroup/{cpu,memory}下建立目录名为容器id的目录, 程序结束后删除.
b) 增加信号量和共享内存, 用于主进程和容器进程间传递数据(比如容器id和rootfs路径);
c) 把proc, sys, dev, dev/pts这些都挂载到容器;
d) 默认启动的容器mount-propagation type是MS_SHARED, 容器进程mount操作在主机可见, 为了让容器mount操作主机不可见, 设置容器的propagation type为MS_PRIVATE; . 增加sdocker_exec程序, 通过注入namespace方式实现类似docker exec功能
基础验证
########### 启动容器, 默认执行bash ###########
linux: # ./sdocker_run -h Usage: sdocker [OPTIONS] IMAGE Start a container using bash default Options:
-c, --cpu-test start cpu test with high cpu program
-m, --memory-test start memory test with high memory program
-n, --hostname string docker hostname, default is sdocker
--memory-limit bytes Memory limit, file: memory.limit_in_bytes
--memory-swappiness int Tune container memory swappiness ( to ) , file: memory.swappiness
--cpu-period int Limit CPU CFS (Completely Fair Scheduler) period, file: cpu.cfs_period_us
--cpu-quota int Limit CPU CFS (Completely Fair Scheduler) quota, file: cpu.cfs_quota_us
-h, --help show help linux: # ./sdocker_run /var/lib/sdocker/rootfs/
[+] start container with id
sdocker@:/ $ ps -ef
UID PID PPID C STIME TTY TIME CMD
: pts/ :: /bin/bash
: pts/ :: ps -ef
sdocker@:/ $ ########### 启动另一个终端查看 ###########
linux: # ls /sys/fs/cgroup/{cpu,memory}
/sys/fs/cgroup/cpu:
cpu.cfs_period_us cpu.shares cpuacct.usage_percpu
cgroup.clone_children cpu.cfs_quota_us cpu.stat notify_on_release
cgroup.procs cpu.rt_period_us cpuacct.stat release_agent
cgroup.sane_behavior cpu.rt_runtime_us cpuacct.usage tasks /sys/fs/cgroup/memory:
memory.low_limit_in_bytes memory.swappiness
cgroup.clone_children memory.max_usage_in_bytes memory.usage_in_bytes
cgroup.event_control memory.move_charge_at_immigrate memory.use_hierarchy
cgroup.procs memory.numa_stat notify_on_release
cgroup.sane_behavior memory.oom_control release_agent
memory.failcnt memory.pressure_level tasks
memory.force_empty memory.soft_limit_in_bytes
memory.limit_in_bytes memory.stat
linux: # ./sdocker_exec /var/lib/sdocker/rootfs/
sdocker@:/ $ ps -ef
UID PID PPID C STIME TTY TIME CMD
: pts/ :: /bin/bash
: pts/ :: bash
: pts/ :: ps -ef
sdocker@:/ $ exit
exit
linux: #
无资源限制测试cpu-test
########### 启动容器执行cpu-test, 理论cpu占用要到100% ###########
linux: # ./sdocker_run -c /var/lib/sdocker/rootfs/
[+] start container with id ########### 启动另一个终端查看 ###########
linux: # ./sdocker_exec /var/lib/sdocker/rootfs/
sdocker@:/ $ ps -ef
UID PID PPID C STIME TTY TIME CMD
: pts/ :: /bin/cpu-test
: pts/ :: bash
: pts/ :: ps -ef
$sdocker@:/ $ top
top - :: up day, min, users, load average: 0.96, 0.47, 0.19
Tasks: total, running, sleeping, stopped, zombie
%Cpu(s): 0.1 us, 0.0 sy, 0.0 ni, 99.9 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem: total, used, free, buffers
KiB Swap: total, used, free. cached Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
R 100.00 0.001 :03.84 cpu-test
S 0.000 0.009 :00.00 bash
R 0.000 0.006 :00.00 top
sdocker@:/ $ exit
exit
linux: #
有资源限制测试cpu-test, 限制cpu使用率20%
########### 启动容器执行cpu-test, 设置cpu占用率不超过20% ###########
linux: # ./sdocker_run -c --cpu-quota /var/lib/sdocker/rootfs/
[+] start container with id ########### 启动另一个终端查看 ###########
linux: # ./sdocker_exec /var/lib/sdocker/rootfs/
sdocker@:/ $ ps -ef
UID PID PPID C STIME TTY TIME CMD
: pts/ :: /bin/cpu-test
: pts/ :: bash
: pts/ :: ps -ef
sdocker@:/ $ top
top - :: up day, min, users, load average: 0.31, 0.66, 0.40
Tasks: total, running, sleeping, stopped, zombie
%Cpu(s): 1.2 us, 0.0 sy, 0.0 ni, 98.7 id, 0.0 wa, 0.0 hi, 0.0 si, 0.0 st
KiB Mem: total, used, free, buffers
KiB Swap: total, used, free. cached Mem PID USER PR NI VIRT RES SHR S %CPU %MEM TIME+ COMMAND
R 20.333 0.001 :06.46 cpu-test
S 0.000 0.009 :00.00 bash
R 0.000 0.006 :00.00 top
sdocker@:/ $ exit
exit
linux: #
有资源限制测试memory-test, 设置内存使用上限10M, 并关闭 swap
########### 启动容器执行memory-test, 设置memory使用不超过10M, 一段时间后容器触发oom退出 ###########
linux: # ./sdocker_run --memory-test --memory-limit --memory-swappiness /var/lib/sdocker/rootfs/
[+] start container with id
[+] malloc size:
[+] malloc size:
[+] malloc size:
[+] malloc size:
[+] malloc size:
[+] malloc size:
[+] malloc size:
[+] malloc size:
[+] malloc size:
linux: # ps -ef | grep sdocker | grep -v grep
linux: # ########### 启动另一个终端查看, 一段时间后容器退出 ###########
linux: # ./sdocker_exec /var/lib/sdocker/rootfs/
sdocker@:/ $ ps -ef
UID PID PPID C STIME TTY TIME CMD
: pts/ :: /bin/memory-test
: pts/ :: bash
: pts/ :: ps -ef
sdocker@:/ $
容器基础(五): 实现一个简单容器sdocker的更多相关文章
- 《Entity Framework 6 Recipes》翻译系列 (3) -----第二章 实体数据建模基础之创建一个简单的模型
第二章 实体数据建模基础 很有可能,你才开始探索实体框架,你可能会问“我们怎么开始?”,如果你真是这样的话,那么本章就是一个很好的开始.如果不是,你已经建模,并在实体分裂和继承方面感觉良好,那么你可以 ...
- [安卓基础] 005.创建一个简单的UI
*:first-child { margin-top: 0 !important; } body > *:last-child { margin-bottom: 0 !important; } ...
- Win32编程API 基础篇 -- 2.一个简单的窗口 根据英文教程翻译
一个简单的窗口 例子:简单的窗口 有时人们在IRC提问,”我应该怎样制作一个窗口”...嗯,这恐怕不是完全这么简单好回答!其实这并不难一旦你明白你在做什么,但在你得到一个可展示的窗口之前还有一些事情需 ...
- [转贴]从零开始学C++之STL(二):实现一个简单容器模板类Vec(模仿VC6.0 中 vector 的实现、vector 的容量capacity 增长问题)
首先,vector 在VC 2008 中的实现比较复杂,虽然vector 的声明跟VC6.0 是一致的,如下: C++ Code 1 2 template < class _Ty, cl ...
- Objective-C ,ios,iphone开发基础:快速实现一个简单的图片查看器
新建一个single view 工程: 关闭ARC , 在.xib视图文件上拖放一个UIImageView 两个UIButton ,一个UISlider ,布局如图. 并为他们连线, UIImage ...
- Away3d 基础 1 ---对一个简单类的解释
转自:http://www.cnblogs.com/nooon/archive/2009/05/16/1458334.html 原英文地址: http://www.flashmagazine.com/ ...
- 【opencv学习笔记五】一个简单程序:图像读取与显示
今天我们来学习一个最简单的程序,即从文件读取图像并且创建窗口显示该图像. 目录 [imread]图像读取 [namedWindow]创建window窗口 [imshow]图像显示 [imwrite]图 ...
- mxnet:基础知识和一个简单的示例
NDArray与NumPy的多维数组类似,但NDArray提供了更多的功能:GPU和CPU的异步计算:自动求导.这使得NDArray能更好地支持机器学习. 初始化 from mxnet import ...
- 03-运行第一个docker容器
环境选择 容器需要管理工具.runtime 和操作系统,我们的选择如下: 1.管理工具 - Docker Engine因为 Docker 最流行使用最广泛. 2.runtime - runc Dock ...
随机推荐
- 开始重学java【门头沟2017年12月6日】
现在从struts2开始重新学习java, 想找个人一起学习java/php都可以. 学习时间大概是两个月,就是年前这段时间. 下一个阶段就是做项目进行练习.(时间为:一个月时间) 不管是学习java ...
- py faster rcnn的lib编译出错问题
真是好事多磨啊,计算机系统依然是14.04,而cuda依然是8.0,唯一不同的是时间不一样,下载的各种库版本有差别,GPU的driver不一样. 但是这样就出问题了,py-faster rcnn的li ...
- redis介绍及常见问题总结
1.redis c语言编写的一个开源软件,使用字典结构存储数据,支持多种类型数据类型 数据类型:字符串,字典,列表,集合,有序集合 2.redis特点 速度快:c语言实现的,所有数据都存储在计算机内存 ...
- 优雅的QSignleton (四) 通过属性器实现MonoSingleton
大家都出去过周六了,而我却在家写代码T.T... 接下来介绍通过属性器实现MonoSingleton. 代码如下: MonoSingletonProperty.cs namespace QFr ...
- 一个logstash引发的连环案,关于logstash提示:Reached open files limit: 4095, set by the 'max_open_files' option or default, files yet to open: 375248
不多说,直接上问题.版本logstash-2.4.0,启动后提示错误: !!! Please upgrade your java version, the current version '1.7.0 ...
- 从 React 的组件更新谈 Immutable 的应用
在介绍 Immutable 如何在 React 中应用之前,先来谈谈 React 组件是如何更新的. React 是基于状态驱动的开发,可以将一个组件看成是一个有限状态机,组件要更新,必须更新状态. ...
- 嵌入式:指针的指针、链表、UCOS 的 OSMemCreate 。
初看,UCOS 的 OSMemCreate 代码,感觉有点怪怪的,比如,把 指针指向的地址 强制转换成 指针的指针的指向地址 ?那转换后 指针的指针 又是什么? void OSMemCreate (O ...
- 新疆大学ACM-ICPC程序设计竞赛五月月赛(同步赛)-B-杨老师游戏
题目链接:杨老师游戏 题目分析:将9个数字分成3块,分块枚举,话句话说,9个数字的所有排列组合,如果满足N=a*b-c就是一个答案,暴力枚举Orz. 代码如下: #include<iostre ...
- harbor中碰到的问题
harbor部署整体比较简单,但是就是这么简单的东西稍微改变点配置文件就会有不小的问题 1.问题1 部署harbor1.6发现web界面删除的镜像在push一遍上去后,镜像大小为0 且无法删除,这个问 ...
- 搭建两个节点的大数据集群-1.hdfs集群
0.规划 两个节点: ip 部署的程序 备注 192.168.56.2/bigdata.lzf namenode,datanode,NodeManager,hive,presto,mysql, ...