容器基础(五): 实现一个简单容器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 ...
随机推荐
- python 实现远程上传文件夹
python2 upload.py "ip" "root" "password" "22" "Only Pro ...
- windows 安装pear & PHP_CodeSniffer
1. download https://pear.php.net/go-pear.phar 2. install pear(http://pear.php.net/manual/en/installa ...
- SpringBoot非官方教程 | 第十九篇: 验证表单信息
转载请标明出处: 原文首发于:https://www.fangzhipeng.com/springboot/2017/07/11/springboot19/ 本文出自方志朋的博客 这篇文篇主要简述如何 ...
- oracle net manager 数据传输安全
oracle net manager来加密客户端与数据库之间或中间件与 数据库之间的网络传输数据 第一步:开始-->所有程序 -->oracle --> 配置和移植工具 --> ...
- setLocale的一个用处
setLocale是C库中的一个设置地域化信息的C函数. 函数原型为: char *setlocale(int category, const char *locale) 参数解释: category ...
- Linux环境中配置环境变量无效
1.在Linux系统中的[ ~/.baserc ]文件与[ /etc/profile ]配置环境变量后(可以使任意环境变量)无效的现象,如下为解决办法: 使用命令: vim ~/.zshrc 在 [# ...
- Mysqldump自定义导出n条记录
很多时候DBA需要导出部分记录至开发.测试环境,因数据量需求较小,如果原库的记录多,且表数量也多,在用mysqldump命令导出时可以添加一个where参数,自定义导出n条记录,而不必全量导出. 示例 ...
- lnmp配置支持thinkphp和nginx路由url重写
ThinkPHP3.2.3项目放到lnmp环境之后只能打开首页,或者通过传参方式打开控制器,否则就一直显示404页面.搞了一上午,终于解决了 step1: 修改php.ini cgi.fix_path ...
- YII2 不通过composer安装Ueditor编辑器
今天用composer安装Ueditor,一直下载失败,不知道为什么,所以就手动安装了一下.记录一下安装步骤 GitHub地址 https://github.com/BigKuCha/yii2-ued ...
- html 截图粘粘图片JS
web前端socket聊天室功能和在线编辑器上传编辑内容的时候经常会需要上传一些图文信息,但是很多编辑器不支持截图粘粘的功能,这里参考了网友分享的可用方法做一个记录. <html> < ...