美文网首页
网络虚拟化基本操作

网络虚拟化基本操作

作者: 追阳_41 | 来源:发表于2017-09-05 10:00 被阅读0次

[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.

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

相关文章

  • 网络虚拟化基本操作

    [toc] 环境准备 物理服务器ip:192.168.110.175/24 192.168.110.1 两台虚机v...

  • virsh常用命令

    一、virsh 基本管理操作 列出虚拟机:# virsh list --all 列出虚拟网络 :# virsh n...

  • 虚拟化技术

    虚拟化技术 分类 按虚拟对象 操作系统虚拟化 平台虚拟化 按方案 软件虚拟化 硬件虚拟化 虚拟机管理器 虚拟化技术...

  • kvm虚拟化

    KVM 虚拟化技术 CPU虚拟化技术 内存虚拟化技术 IO虚拟化技术 网络IO虚拟化技术 磁盘IO虚拟化技术 虚拟...

  • Docker初识之基本概念和安装(一)

    虚拟化技术与Docker区别1、虚拟化技术:将服务,网络,内存,存储等硬件抽象出来运行的一整套完整操作系统。运行进...

  • 20171207 虚拟化

    虚拟化技术概览KVM简介KVM的管理操作 一、虚拟化技术概览 (一)虚拟化技术类型: 主机虚拟化:xen, kvm...

  • Docker概念理解

    容器技术 简单介绍 容器技术又称为容器虚拟化 首先是一种虚拟化技术 虚拟化技术包括硬件虚拟化 半虚拟化 操作系统虚...

  • 网络功能虚拟化NFV简介

    目录:1、NFV相关基本概念2、NFV 架构 1、NFV相关基本概念: NFV即网络功能虚拟化(Network F...

  • 网络虚拟化

  • 第三章 大数据平台的架构体系

    大数据基础设施 1.虚拟化服务器虚拟化,存储虚拟化,网络虚拟化,桌面虚拟化2.云计算私有云,社区云,公共云,混合云...

网友评论

      本文标题:网络虚拟化基本操作

      本文链接:https://www.haomeiwen.com/subject/ltcujxtx.html