十分钟写一个简单的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,如需转载请自行联系原作者

相关文章
|
前端开发 JavaScript 应用服务中间件
花十分钟将vue3前端项目一步一步自动化部署到linux的docker上
可以理解成镜像是 Docker 生命周期中的构建或者打包阶段,而容器则是启动或者执行阶段。
2093 0
|
存储 缓存 安全
|
Linux API 数据库
十分钟带你入门Docker容器引擎
Docker 是一个开源的应用容器引擎,让开发者可以打包他们的应用以及依赖包到一个可移植的镜像中,然后发布到任何流行的 Linux或Windows操作系统的机器上,也可以实现虚拟化。容器是完全使用沙箱机制,相互之间不会有任何接口。Docker采用 C/S架构 Docker daemon 相当于服务端接受来自客户的请求,并处理这些请求(创建、运行、分发容器)。 客户端和服务端既可以运行在一个机器上,也可通过 socket 或者RESTful API 来进行通信。
十分钟带你入门Docker容器引擎
|
7天前
|
Kubernetes Cloud Native Docker
云原生时代的容器化实践:Docker和Kubernetes入门
【10月更文挑战第37天】在数字化转型的浪潮中,云原生技术成为企业提升敏捷性和效率的关键。本篇文章将引导读者了解如何利用Docker进行容器化打包及部署,以及Kubernetes集群管理的基础操作,帮助初学者快速入门云原生的世界。通过实际案例分析,我们将深入探讨这些技术在现代IT架构中的应用与影响。
30 2
|
5天前
|
运维 Cloud Native 虚拟化
一文吃透云原生 Docker 容器,建议收藏!
本文深入解析云原生Docker容器技术,涵盖容器与Docker的概念、优势、架构设计及应用场景等,建议收藏。关注【mikechen的互联网架构】,10年+BAT架构经验倾囊相授。
一文吃透云原生 Docker 容器,建议收藏!
|
13天前
|
关系型数据库 MySQL API
|
9天前
|
运维 持续交付 Docker
深入理解Docker容器化技术
深入理解Docker容器化技术
|
6天前
|
缓存 监控 开发者
掌握Docker容器化技术:提升开发效率的利器
在现代软件开发中,Docker容器化技术成为提升开发效率和应用部署灵活性的重要工具。本文介绍Docker的基本概念,并分享Dockerfile最佳实践、容器网络配置、环境变量和秘密管理、容器监控与日志管理、Docker Compose以及CI/CD集成等技巧,帮助开发者更高效地利用Docker。
|
7天前
|
监控 持续交付 Docker
Docker 容器化部署在微服务架构中的应用有哪些?
Docker 容器化部署在微服务架构中的应用有哪些?
|
7天前
|
监控 持续交付 Docker
Docker容器化部署在微服务架构中的应用
Docker容器化部署在微服务架构中的应用