systemd-nspawn虚拟化方案&网卡桥接方案

systemd-nspawn虚拟化方案&网卡桥接方案

参考:

① 在Arch Linux 上通过systemd配置桥接网络

Link : https://www.imuo.com/a/f5e141748a8159c78caaa5c8f56d7c25257f7019a8de14bd3741ecedf57afd4a

② 实例讲解虚拟机的3种网络模式

Link : https://www.cnblogs.com/ggjucheng/archive/2012/08/19/2646007.html

③ systemd-nspawn 快速指南

Link : https://linux.cn/article-4678-1.html

④ chroot 命令

Link : http://man.linuxde.net/chroot


systemd-nspawn 创建容器


创建一个linux容器, 需要的是一个使用systemd作为init的Linux发行版系统。以下为使用Ubuntu 16.04 和 CentOS 7。

创建Ubuntu容器

    mkdir -p machines/ubuntu1604
    wget http://mirrors.ustc.edu.cn/ubuntu-cdimage/ubuntu-base/releases/16.04.3/release/ubuntu-base-16.04.1-base-amd64.tar.gz -O /tmp/rootfs.tgz
    tar -zxvf /tmp/roots.tzg -C machines/ubuntu1604 

至此就得到了可以被systemd-nspawn启动的rootfs, 接下来增加一些配置

    chroot machines/ubuntu1604 /usr/bin/passwd root
    echo ubuntu > machines/ubuntu1604/ect/hostname

以上两条命令的作用分别为,1, chroot命令用来在自定的根目录下运行指令, chroot, 即change root directory (更改root目录)。 2, 更改虚拟主机的 hostname

    chroot target /bin/ls 

即将target作为切换到的目录, 然后使用 target/bin/ls 执行, 执行过程中的结果更改也以 target 作为其根目录。

启动ubuntu(具体的参数见systemd-nspawn启动容器)

systemd-nspawn -b -D /var/lib/machines/ubuntu1604 --bind=/lib/firmware

这里的容器的内核以及网络还是宿主机的, 如何使用桥接网络的功能见下面

创建CentOS容器

由于centos 没有提供上面提到的rootfs, 所以需要从ISO中解压安装。

目前按照教程没有成功~~~

systemd-nspawn启动容器


systemd-nspawn (spawn有大量生产的含义, 这里暗示了这种虚拟化方案快速高效, 可以快速产生大量容器么)

用于启动一个容器, 最简单的模式可以像chroot那样运行,默认情况下自动配置容器所需要的开销如 /dev

, /tmp 等等, 通过一些选项可以配置其他的挂载点。容器退出后所有的挂载点全部会被清除。

  • 最简单的启动方式
    $ sudo systemd-nspawn -D /var/lib/machines/ubuntu1604                     
  • 添加一些挂载点的启动方式
    $ sudo systemd-nspawn -D /var/lib/machines/ubuntu1604 --bind /tmp
    Spawning container ubuntu1604 on /var/lib/machines/ubuntu1604.
    Press ^] three times within 1s to kill container.
    Failed to create directory /var/lib/machines/ubuntu1604/sys/fs/selinux: Read-only file system
    Failed to create directory /var/lib/machines/ubuntu1604/sys/fs/selinux: Read-only file system
    root@ubuntu1604:~# ls /tmp/
    +~JF160288929779634565.tmp   file_in_machine.txt
    ...
    root@ubuntu1604:~# cat /tmp/file_in_machine.txt 
    can you read this content in the virtual environment.

使用 --bind 来设置需要挂载的目录, 这里将物理主机的目录/tmp挂载到了虚拟主机的/tmp目录下。

  • 使得容器具有init功能并可以在内部运行
    $ sudo systemd-nspawn -D /var/lib/machines/ubuntu1604 --bind /tmp -b

添加 -b 选项来启动, 这样便可以在 container 来使用init 0关机

machinectl 如何使用???

虚拟机模式网络


虚拟机有三种网络模式: 1,桥接 2, NAT 3, Host-Only(这里是虚拟机的讲解, 和虚拟化比较类似)

桥接: 桥接网络指的是本地物理网卡和虚拟网卡通过VMnet0虚拟交换机进行桥接,物理网卡和虚拟网卡在拓扑图上处于同等地位,那么物理网卡和虚拟网卡就相当于处于同一网段, 虚拟交换机相当于现实网络中的交换机, 两个网卡的IP地址要设置为同一网段。

使用桥接的方式,局域网类的其他PC可以直接的访问,例如可以提供ftp, ssh, http服务

NAT: 让虚拟机借助NAT(网络地址转换 Network Address Translation)功能,通过宿主机器所在的网络访问公网。

nat模式, 过个虚拟主机之间可以相互访问,但是局域网中的其他用户无法访问,优点是无需配置, 只要宿主机可以上网, 虚拟主机就可以上网。

Host-Only : 虚拟网络是一个全封闭的网络, 能够唯一访问的就是主机, 提高内网的安全性, 无法连接到Internet。

通过systemd配置桥接方案


可能用到的文件说明

.network 文件设置网卡的IP等各项属性

.netdev 文件,新建一个虚拟网卡

查看有线网网络的接口名称 enp0s31f6 , 设置桥接网络的接口为 br0。

  • 创建配置文档 /etc/systemd/network/20-wired.network 已有接口的网络
    [Match]
    Name=enp0s31f6
    [Network]
    Bridge=br0

name指定网络接口的名称, Bridge后指定要桥接的网络接口名称 ,[Match] 表示了段内的所有的条件都匹配时, 后面的配置项才会被激活。

  • 通过创建配置文档 /etc/systemd/network/br0.netdev 生成桥接网络 br0```
    [NetDev]
    Name=br0
    Kind=bridge

Name 指定了接口的名称, Kind指定了接口的类型

  • 接着通过创建配置文档 /etc/systemd/netwirk/br0.network 配置br0接口的网络
    [Match]
    Name=br0
    [Network]
    DHCP=yes
    [Link]
    MACAddress=30:9c:23:a9:dc:28

DHCP字段通过配置为yes来表示这个网络接口启用DHCP服务, 这样虚拟机就可以在桥接之通过DHCP获取IP地址了, MACAddress字段表示这个接口的MAC地址, 这里将接口的MAC地址enp0s31f6给了br0。

启动system-networkd 和 systemd-resolved服务

    # systemctl start systemd-networkd
    # systemctl enable systemd-networkd
    # systemctl start systemd-resolved
    # systemctl enable systemd-resolved

编辑/etc/sysctl.conf配置内核参数:

    net.bridge.bridge-nf-call-ip6tables = 0
    net.bridge.bridge-nf-call-iptables = 0
    net.bridge.bridge-nf-call-arptables = 0

最后执行sudo sysctl -p来使内核参数立即生效, 将这三项设置为0表示了禁用桥接网络接口上的 net filter

虚拟主机ssh登录

由于物理机和虚拟机使用的都是22号端口, 这样会产生冲突,所以更换虚拟机中ssh端口为2222, 然后使用sudo systemd-nspawn -b /var/lib/machines/ubuntu1604 --bind=/lib/firmware --port=2222来开启虚拟机, 在登录虚拟主机的时候需要使用-p port来指定端口。

因为不同的markdown标准的原因么, 原先的格式很美观~~~

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 205,132评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 87,802评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,566评论 0 338
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,858评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,867评论 5 368
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,695评论 1 282
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,064评论 3 399
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,705评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 42,915评论 1 300
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,677评论 2 323
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,796评论 1 333
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,432评论 4 322
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,041评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,992评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,223评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,185评论 2 352
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,535评论 2 343

推荐阅读更多精彩内容

  • 转载自 http://blog.opskumu.com/docker.html 一、Docker 简介 Docke...
    极客圈阅读 10,468评论 0 120
  • docker之容器通信 这节属于了解学习,算是烂尾,最后我也没找到合适的方式去固定容器ip,然后作为正式环境去跑,...
    道无虚阅读 5,473评论 1 7
  • 在Internet上的每台主机指定的地址称为IP地址。IP地址是唯一的,它具有固定、规范的格式。每个IP地址含32...
    sunny奥特曼阅读 117评论 0 0
  • 我的世界,便是你的痕迹,在你走过的小路细细评味你的喜怒哀乐,开心着你的开心,纵然不知你的欢乐是源自哪里,即使不知你...
    么么哒小白阅读 251评论 0 0
  • 前几日看了一部电影 ,名字一点也不文艺,还有点呢市井,它就叫《狗13》。 故事讲的主人公李玩和一只叫做爱因斯坦的狗...
    兔子不吃阅读 689评论 0 0