网络虚拟化基本操作

[toc]

环境准备

  • 物理服务器

    ip:192.168.110.175/24 192.168.110.1

  • 两台虚机

    • vm1: 10.0.1.1/24 10.0.1.254
    • vm2: 10.0.1.2/24 10.0.1.254
  • 使用镜像

使用镜像由cirros-0.3.5-x86_64-disk.img 分别复制出两份vm1.qcow2vm2.qcow2来使用。

# ls -l /images/cirros
total 38880
-rw-r--r-- 1 root root 13267968 Sep  4 12:55 cirros-0.3.5-x86_64-disk.img
-rw-r--r-- 1 root root 13267968 Sep  4 13:13 vm1.qcow2
-rw-r--r-- 1 root root 13267968 Sep  4 13:13 vm2.qcow2
网络虚拟化.png

安装KVM

# modprobe kvm
# yum install qemu-kvm

创建软链接

# ln -sv /usr/libexec/qemu-kvm /usr/bin
‘/usr/bin/qemu-kvm’ -> ‘/usr/libexec/qemu-kvm’

编辑接口启动脚本

# cat /etc/qemu-ifup
#!/bin/bash
#
bridge=br-in

if [ -n "$1" ]; then
    ip link set $1 up
    brctl addif $bridge $1
    [ $? -eq 0 ] && exit 0 || exit 1
else
    echo "Error: no interface specified."
    exit 1
fi

语法检测正常,再加执行权限

# bash -n /etc/qemu-ifup
# chmod +x /etc/qemu-ifup

添加物理桥br-ex并启用

# brctl addbr br-ex
# ip link set br-ex up

撤去物理网卡的ip配置到网桥,并将物理网卡加入到网桥

# ip addr del 192.168.110.175/24 dev ens33; ip addr add 192.168.88.129/24 dev br-ex; brctl addif br-ex ens33;

再创建br-in桥并启用

# brctl addbr br-in
# ip link set br-in up

添加一个网络名称空间r1

# ip netns add r1

创建一对网卡,同时启用

# ip link add rinr type veth peer name rins
# ip link set rinr up
# ip link set rins up

将rinr网卡推送到网络名称空间r1中并改名激活

# ip link set rinr netns r1
# ip netns exec r1 ip link set rinr name eth0
# ip netns exec r1 ifconfig eth0 10.0.1.254/24 up

将rins网卡添加到br-in网桥

# brctl addif br-in rins

永久开启路由转发功能

# echo "net.ipv4.ip_forward = 1" >> /etc/sysctl.conf
# sysctl -p
net.ipv4.ip_forward = 1

再创建一对网卡

# ip link add rexr type veth peer name rexs

rexs加入到br-ex并启用

# brctl addif br-ex rexs
# ip link set rexs up

对rexr网卡推送到r1名称空间并改名为eth1,同时设置ip 并启用:

# ip link set rexr netns r1
# ip netns exec r1 ip link set rexr name eth1
# ip netns exec r1 ifconfig eth1 192.168.110.176/24 up

虚机配置

新开一个终端,创建vm1:

# qemu-kvm -m 128 -smp 1 -name vm1 -drive file=/images/cirros/vm1.qcow2,if=virtio,media=disk -net nic,macaddr=52:54:00:aa:bb:cc -net tap,ifname=vif1.0,script=/etc/qemu-ifup --nographic

再开一个终端,创建vm2:

# qemu-kvm -m 128 -smp 1 -name vm2 -drive file=/images/cirros/vm2.qcow2,if=virtio,media=disk -net nic,macaddr=52:54:00:aa:bb:dd -net tap,ifname=vif2.0,script=/etc/qemu-ifup --nographic

启动登录vm主机,使用默认的用户名cirros,密码cubswin:) 登录,再执行 sudo su -切换到root 用户。
使用ifconfig命令确认mac等信息正常。

配置vm1的ip和默认路由

# ifconfig eth0 10.0.1.1/24 up
# route add default gw 10.0.1.254

配置vm2的ip和默认路由

# ifconfig eth0 10.0.1.2/24 up
# route add default gw 10.0.1.254

最后操作

此时vm虚机中是可以ping通192.168.110.176这个地址的,但无法ping通192.168.110.175 这个地址,这是由于icmp报文可以到达192.168.110.175,但报文无法送回。这个时候就需要在路由器上加SNAT规则。

# ip netns exec r1 iptables -t nat -A POSTROUTING -s 10.0.1.0/24 ! -d 10.0.1.0/24 -j MASQUERADE
或者
# ip netns exec r1 iptables -t nat -A POSTROUTING -s 10.0.1.0/24 ! -d 10.0.1.0/24 -j SNAT --to-source 192.168.110.176

此时,vm虚机上就能ping通外部网络地址了,也可以抓包进行查看:

# tcpdump -i rins -nn icmp

配置dhcp功能

在host主机安装dnsmasq:

# yum install dnsmasq

启动dnsmasq

# ip netns exec r1 dnsmasq -F 10.0.1.151,10.0.1.160 --dhcp-option option:router,10.0.1.254

可以对启动进程进行查看:

# ip netns exec r1 ps aux | grep dnsmasq

注意:这个进程在host主机执行时,也能看到,但它只作用于名称空间r1.

在vm节点测试dns服务

# udhcpc -R

正常情况下是可以获取到ip和网关地址的,但由于cirros 系统的问题,此处报错:

# udhcpc -R
udhcpc (v1.20.1) started
WARN: '/usr/share/udhcpc/default.script' should not be used in cirros. Replaced by cirros-dhcpc.
Sending discover...
Sending select for 10.0.1.151...
Lease of 10.0.1.151 obtained, lease time 3600
WARN: '/usr/share/udhcpc/default.script' should not be used in cirros. Replaced by cirros-dhcpc.

发现并没有获取到地址,但我们的操作过程是正确的。

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

推荐阅读更多精彩内容