十分钟写一个简单的docker

我在这个视频(http://pan.baidu.com/s/1c0fKOtM)里介绍了容器虚拟化的原理,主要有三个方面:资源隔离,命名空间隔离,运行环境隔离。这些东西都是linux本身就有的功能,只需要写一个shell脚本,就能实现一个简单的虚拟机,和docker类似。

代码如下:

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
#!/bin/bash
#用法:mydocker.sh $root_dir $ip_addr $cpu_us(每秒钟CPU使用的us数)
 
#例如: sh mydocker.sh /images/fedora/ 192.168.1.10 10000
 
#上面的意思是,启动一个fedora虚拟机,ip地址为192.168.1.10,CPU最多10%
 
#需要事先创建一个网桥mydocker
#如果没有brctl命令,ubuntu使用apt-get install bridge-utils安装
#比如网桥的ip为192.168.1.1/24
#那么虚拟机的地址应该和这个网桥一个网段,自己控制IP不重复
#创建网桥的shell
#1. brctl addbr mydocker
#2. ip link set mydocker up
#3. ip addr add 192.168.1.1/24 dev mydocker 
 
#获取一个时间戳,用于为之后的各种变量命名
timestamp=` date  +%s`
 
 
################资源隔离#####################
#为父进程创建一个cgroup,仅对cpu做限制
cgroup=CG "$timestamp"
mkdir  -p  /sys/fs/cgroup/cpu/ $cgroup
echo  $3 >  /sys/fs/cgroup/cpu/ $cgroup /cpu .cfs_quota_us
echo  $$ >  /sys/fs/cgroup/cpu/ $cgroup /tasks
 
 
################命令空间隔离################
#创建一个新网络名字空间
namespace=NS "$timestamp"
ip netns add $namespace
#创建一对虚拟设备A,B
PEER_A=A "$timestamp"
PEER_B=B "$timestamp"
ip link add $PEER_A  type  veth peer name $PEER_B
#把B放到新的名字空间,改名为eth0,分配地址
ip link  set  $PEER_B netns $namespace
ip netns  exec  $namespace ip link  set  dev $PEER_B name eth0
ip netns  exec  $namespace ip link  set  eth0 up
ip netns  exec  $namespace ip addr add $2 /24  dev eth0
#把A连到主机的一个网桥上
brctl addif mydocker $PEER_A
ip link  set  $PEER_A up
 
 
###############运行环境隔离###################
#切换到新的root,并且执行新环境里的/bin/bash
ip netns  exec  $namespace chroot $1


资源隔离



test.py会占用100%CPU,但是启动一个虚拟机,cpu限制在10%,那就只能用10%了

wKioL1V-037gdPp7AAIzooU14z8616.jpg


指定该虚拟机每秒只能使用10000us CPU,就是10%

wKiom1V-0dHSg8yYAAJVG1JjIaU216.jpg


命名空间隔离


启动一个虚拟机,地址为192.168.1.100,并且启动一个redis-server,在主机里可以访问。

wKioL1V-036CLkjhAAJr0R46yy4928.jpg


运行环境隔离


我有一套ubuntu14.04的运行环境,切换进去后,test.py的pwd变成了/,并且这个环境里没有安装redis

wKiom1V-0dHQcUfNAAEVH4QTEG4709.jpg


本文转自nxlhero 51CTO博客,原文链接:http://blog.51cto.com/nxlhero/1662139,如需转载请自行联系原作者

优秀的个人博客,低调大师

微信关注我们

原文链接:https://yq.aliyun.com/articles/472214

转载内容版权归作者及来源网站所有!

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。

相关文章

发表评论

资源下载

更多资源
优质分享Android(本站安卓app)

优质分享Android(本站安卓app)

近一个月的开发和优化,本站点的第一个app全新上线。该app采用极致压缩,本体才4.36MB。系统里面做了大量数据访问、缓存优化。方便用户在手机上查看文章。后续会推出HarmonyOS的适配版本。

Apache Tomcat7、8、9(Java Web服务器)

Apache Tomcat7、8、9(Java Web服务器)

Tomcat是Apache 软件基金会(Apache Software Foundation)的Jakarta 项目中的一个核心项目,由Apache、Sun 和其他一些公司及个人共同开发而成。因为Tomcat 技术先进、性能稳定,而且免费,因而深受Java 爱好者的喜爱并得到了部分软件开发商的认可,成为目前比较流行的Web 应用服务器。

Eclipse(集成开发环境)

Eclipse(集成开发环境)

Eclipse 是一个开放源代码的、基于Java的可扩展开发平台。就其本身而言,它只是一个框架和一组服务,用于通过插件组件构建开发环境。幸运的是,Eclipse 附带了一个标准的插件集,包括Java开发工具(Java Development Kit,JDK)。

Java Development Kit(Java开发工具)

Java Development Kit(Java开发工具)

JDK是 Java 语言的软件开发工具包,主要用于移动设备、嵌入式设备上的java应用程序。JDK是整个java开发的核心,它包含了JAVA的运行环境(JVM+Java系统类库)和JAVA工具。