容器基础(五): 实现一个简单容器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 ...
随机推荐
- Openresty最佳案例 | 第2篇:Lua入门
转载请标明出处: http://blog.csdn.net/forezp/article/details/78616622 本文出自方志朋的博客 什么是lua Lua 是一种轻量小巧的脚本语言,用标准 ...
- mysql快速导入导出数据
--导入 select * from inhos_genoperation(表名) where UPLOAD_ORG_CODE='***' into outfile '/tmp/inhos_genop ...
- 从 React 的组件更新谈 Immutable 的应用
在介绍 Immutable 如何在 React 中应用之前,先来谈谈 React 组件是如何更新的. React 是基于状态驱动的开发,可以将一个组件看成是一个有限状态机,组件要更新,必须更新状态. ...
- zepto 基础知识(4)
61.prev prev() 类型:collection prev(selector) 类型:collection 获取对相集合中每一个元素的钱一个兄弟节点,通过选择器来进行过滤 62.prev pr ...
- 魔板 Magic Squares(广搜,状态转化)
题目背景 在成功地发明了魔方之后,鲁比克先生发明了它的二维版本,称作魔板.这是一张有8个大小相同的格子的魔板: 1 2 3 4 8 7 6 5 题目描述 我们知道魔板的每一个方格都有一种颜色.这8种颜 ...
- Linux性能监控工具 gtop
给大家介绍一款性能监控工具,个人对比界面比top美观,常用指标比较清晰毕竟top上的指标不是每个人都能熟悉,也不是所有指标参数都需要看,对于新手也不便查找,好了说的再多先上图大家参观一下. 1.安装需 ...
- Percona-Tookit工具包之pt-kill
Preface Sometimes,we are determined to kill some MySQL connections which are occupying huge ...
- LeetCode 删除链表倒数第N个节点
基本思路 定义两个指示指针a b 让a先行移动n+1个位置 若a指向了NULL的位置,则删除的是头节点(由于走过了n+1个节点刚好指在尾部的NULL上) 否则让b与a一起移动直至a->next, ...
- 如何安全地跨窗体调用Timer控件 从一个窗体调用控制另外一个窗体的控件
具体的情况是Form1中有一个Timer2时钟,Timer2时钟事件弹出Warning窗体,点击Warning窗体上面的按钮,重新激活一下Form1中的Timer2.从而实现了从一个窗体调用另外一个窗 ...
- 用 jQuery 实现表单验证(转载)
jQuery 官方 API 地址: http://api.jquery.com/ 在线引用 jQuery:http://code.jquery.com/ ——选自<锋利的jQuery>(第 ...