容器基础(五): 实现一个简单容器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 ...
随机推荐
- vue watch数组或者对象
1.普通的watch data() { return { frontPoints: 0 } }, watch: { frontPoints(newValue, oldValue) { console. ...
- data-ng-disabled指令
<!DOCTYPE html><html><head><meta http-equiv="Content-Type" content=&q ...
- Django-rest-framework(六)filter,ordering,search
filter queryset 使用request.user相关的queryset class PurchaseList(generics.ListAPIView): serializer_class ...
- js事件委托代码优化【感悟总结】
前两天接手了同事的一个项目,是一个网站首页,其中有段代码很累赘,要实现的功能就是, 通过给父元素添加鼠标移入移出事件,来控制子元素显示隐藏. html代码,一共有四个父元素div,每个父元素嵌套一个子 ...
- 设置全局导航栏颜色,标题大小和UIBarButtonItem字体大小
设置全局导航栏颜色,标题大小和UIBarButtonItem字体大小 在appdelegate里面设置 swift: UINavigationBar.appearance().barTintColor ...
- jwplayer
将JW Player嵌入到网页中非常的简单,只需要进行如下3个步骤: 1.解压mediaplayer-viral.zip文件,将jwplayer.js和player.swf文件拷贝到工程中: 2.在页 ...
- Lucene 工作原理
Lucene 简介 Lucene 是一个基于 Java 的全文信息检索工具包,它不是一个完整的搜索应用程序,而是为你的应用程序提供索引和搜索功能.Lucene 目前是 Apache Jakarta 家 ...
- mysql5.7 本地计算机上的mysql 服务启动后停止 的问题解决
mysql5.7 本地计算机上的mysql 服务启动后停止. 问题: 在cmd 下mysql服务mysql服务无法启动任何错误法启动 服务没有报告任何错误 在服务里面启动是 早上来了发现项 ...
- 访问本地方站出现EOF的分析和解决
每天早晨打开电脑运行本地项目的时候,有时候浏览器上会出现EOF 之前都都能正常访问,所以我猜想本地的项目本身肯定是没有问题的. Google了下,发现有人说是代理的问题,于是关闭代理试过后,发现可以访 ...
- springboot 集成kaptcha验证码Demo
验证码(CAPTCHA)是“Completely Automated Public Turing test to tell Computers and Humans Apart”(全自动区分计算机和人 ...