linux vlan配置详解

本文主要给大家介绍了关于linux虚拟网络设备之vlan配置的相关资料,文中通过示例代码介绍的非常详细,对大家的学习或者工作具有一定的参考学习价值,希望能帮助到大家。

简介

VLAN是网络栈的一个附加功能,且位于下两层。首先来学习Linux中网络栈下两层的实现,再去看如何把VLAN这个功能附加上去。下两层涉及到具体的硬件设备,日趋完善的Linux内核已经做到了很好的代码隔离,对网络设备驱动也是如此,如下图所示:

linux vlan配置详解

这里要注意的是,Linux下的网络设备net_dev并不一定都对应实际的硬件设备,只要注册一个struct net_device{}结构体(netdevice.h)到内核中,那么这个网络设备就存在了。该结构体很庞大,其中包含设备的协议地址(对于IP即IP地址),这样它就能被网络层识别,并参与路由系统,最有名的当数loopback设备。不同的设备(包括硬件和非硬件)的ops操作方法各不相同,由驱动自己实现。一些通用性的、与设备无关的操作流程(如设备锁定等)则被Linux提炼出来,我们称为驱动框架。

linux虚拟网络设备之vlan配置

我们通过一个网桥两个设备对,来连接两个网络名字空间,每个名字空间中创建两个vlan

linux vlan配置详解

借助vconfig来配置vlan:

#创建网桥brctl addbr br-test-vlan #创建veth对儿ip link add veth01 type veth peer name veth10ip link add veth02 type veth peer name veth20 #将veth对儿的一段添加到网桥brctl addif br-test-vlan veth01brctl addif br-test-vlan veth02 #启动设备ip link set dev br-test-vlan upip link set dev veth01 upip link set dev veth02 upip link set dev veth10 upip link set dev veth20 up #创建网络名字空间ip netns add test-vlan-vm01ip netns add test-vlan-vm02 #将设备对儿的另一端添加到另个名字空间(其实在一个名字空间也能玩,只是两个名字空间更加形象)ip link set veth10 netns test-vlan-vm01ip link set veth20 netns test-vlan-vm02 #分别进入两个名字空间创建vlan和配置ip#配置名字空间test-vlan-vm01ip netns exec test-vlan-vm01 bash#配置vlan 3001 和 vlan 3002vconfig add veth10 3001vconfig add veth10 3002#启动两个vlan的设备ip link set veth10.3001 upip link set veth10.3002 up #分别在两个vlan上配置ip (这里简单起见,使用了同一个网段了IP,缺点是,需要了解一点儿路由的知识)ip a add 172.16.30.1/24 dev veth10.3001ip a add 172.16.30.2/24 dev veth10.3002 #添加路由route add 172.16.30.21 dev veth10.3001route add 172.16.30.22 dev veth10.3002 #配置名字空间test-vlan-vm02ip netns exec test-vlan-vm02 bash#配置vlan 3001 和 vlan 3002vconfig add veth20 3001vconfig add veth20 3002#启动两个vlan的设备ip link set veth20.3001 upip link set veth20.3002 up#分别在两个vlan上配置ip (这里简单起见,使用了同一个网段了IP,缺点是,需要了解一点儿路由的知识)ip a add 172.16.30.21/24 dev veth20.3001ip a add 172.16.30.22/24 dev veth20.3002 #添加路由route add 172.16.30.1 dev veth20.3001route add 172.16.30.2 dev veth20.3002

查看一下vlan配置:

# cat /proc/net/vlan/config VLAN Dev name | VLAN IDName-Type: VLAN_NAME_TYPE_RAW_PLUS_VID_NO_PADveth10.3001 | 3001 | veth10veth10.3002 | 3002 | veth10

现在,我们可以分别在两个名字空间来ping另外一个名字空间的两个IP,虽然两个IP都能ping通,但是使用的源IP是不同的,走的vlan也是不同的,我们可以在veth01/veth10/veth02/veth20/br-test-vlan 任意一个上抓包,会看到vlan信息:

# tcpdump -i veth10 -nn -etcpdump: verbose output suppressed, use -v or -vv for full protocol decodelistening on veth10, link-type EN10MB (Ethernet), capture size 262144 bytes15:38:18.381010 82:f7:0e:2d:3f:62 > 9e:58:72:fa:11:15, ethertype 802.1Q (0x8100), length 102: vlan 3001, p 0, ethertype IPv4, 172.16.30.1 > 172.16.30.21: ICMP echo request, id 19466, seq 1, length 6415:38:18.381183 9e:58:72:fa:11:15 > 82:f7:0e:2d:3f:62, ethertype 802.1Q (0x8100), length 102: vlan 3001, p 0, ethertype IPv4, 172.16.30.21 > 172.16.30.1: ICMP echo reply, id 19466, seq 1, length 6415:38:19.396796 82:f7:0e:2d:3f:62 > 9e:58:72:fa:11:15, ethertype 802.1Q (0x8100), length 102: vlan 3001, p 0, ethertype IPv4, 172.16.30.1 > 172.16.30.21: ICMP echo request, id 19466, seq 2, length 6415:38:19.396859 9e:58:72:fa:11:15 > 82:f7:0e:2d:3f:62, ethertype 802.1Q (0x8100), length 102: vlan 3001, p 0, ethertype IPv4, 172.16.30.21 > 172.16.30.1: ICMP echo reply, id 19466, seq 2, length 6415:38:23.162052 82:f7:0e:2d:3f:62 > 9e:58:72:fa:11:15, ethertype 802.1Q (0x8100), length 102: vlan 3002, p 0, ethertype IPv4, 172.16.30.2 > 172.16.30.22: ICMP echo request, id 19473, seq 1, length 6415:38:23.162107 9e:58:72:fa:11:15 > 82:f7:0e:2d:3f:62, ethertype 802.1Q (0x8100), length 102: vlan 3002, p 0, ethertype IPv4, 172.16.30.22 > 172.16.30.2: ICMP echo reply, id 19473, seq 1, length 64

如果试图从veth10.3001 去ping 172.16.30.22 是不能通的,因为是不同的vlan呀:

琅琅配音 琅琅配音

全能AI配音神器

琅琅配音 208 查看详情 琅琅配音

# ping -I veth10.3001 172.16.30.22PING 172.16.30.22 (172.16.30.22) from 172.16.30.1 veth10.3001: 56(84) bytes of data.^C--- 172.16.30.22 ping statistics ---9 packets transmitted, 0 received, 100% packet loss, time 8231ms

不适用vconfig的解法:

ip link add link veth10 name veth10.3001 type vlan id 3001

另: vlan 一般以  设备名.vlanid 来命名,不过并非强制,如下命名为 vlan3003也是没问题的

# ip link add link veth10 name vlan3003 type vlan id 3003

注意:一个主设备上相同vlan好的子设备最多只能有一个

# ip link add link veth10 name vlan3001 type vlan id 3001 RTNETLINK answers: File exists

所以,正常来讲,一般是这样的:

linux vlan配置详解

相关推荐:

动手实践 Linux VLAN

VLAN学习总结

交换机VLAN配置

以上就是linux vlan配置详解的详细内容,更多请关注创想鸟其它相关文章!

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。
如发现本站有涉嫌抄袭侵权/违法违规的内容, 请发送邮件至 chuangxiangniao@163.com 举报,一经查实,本站将立刻删除。
发布者:程序猿,转转请注明出处:https://www.chuangxiangniao.com/p/284270.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2025年11月4日 17:47:53
下一篇 2025年11月4日 17:53:06

相关推荐

  • Linux如何防止缓冲区溢出_Linux防止缓冲区溢出的安全措施

    缓冲区溢出可通过栈保护、ASLR、NX bit、安全编译选项和良好编码实践来防范。1. 使用-fstack-protector-strong插入canary检测栈破坏;2. 启用ASLR(kernel.randomize_va_space=2)随机化内存布局;3. 利用NX bit标记不可执行内存页…

    2025年12月6日 运维
    000
  • Linux如何优化系统性能_Linux系统性能优化的实用方法

    优化Linux性能需先监控资源使用,通过top、vmstat等命令分析负载,再调整内核参数如TCP优化与内存交换,结合关闭无用服务、选用合适文件系统与I/O调度器,持续按需调优以提升系统效率。 Linux系统性能优化的核心在于合理配置资源、监控系统状态并及时调整瓶颈环节。通过一系列实用手段,可以显著…

    2025年12月6日 运维
    000
  • Pboot插件数据库连接的配置教程_Pboot插件数据库备份的自动化脚本

    首先配置PbootCMS数据库连接参数,确保插件正常访问;接着创建auto_backup.php脚本实现备份功能;然后通过Windows任务计划程序或Linux Cron定时执行该脚本,完成自动化备份流程。 如果您正在开发或维护一个基于PbootCMS的网站,并希望实现插件对数据库的连接配置以及自动…

    2025年12月6日 软件教程
    000
  • Linux命令行中wc命令的实用技巧

    wc命令可统计文件的行数、单词数、字符数和字节数,常用-l统计行数,如wc -l /etc/passwd查看用户数量;结合grep可分析日志,如grep “error” logfile.txt | wc -l统计错误行数;-w统计单词数,-m统计字符数(含空格换行),-c统计…

    2025年12月6日 运维
    000
  • Linux如何进行系统备份_Linux系统备份的详细操作步骤

    Linux系统备份可通过rsync、tar、dd和Timeshift实现。①rsync支持增量备份,用-aAXv参数排除特殊目录并定期同步;②tar创建压缩镜像,-cvpzf参数打包系统并排除无关目录,恢复时解压至目标路径;③dd进行磁盘位级复制,if=源of=目标生成镜像,操作需谨慎;④Times…

    2025年12月6日 运维
    000
  • Linux命令行中crontab命令的详细用法

    crontab用于Linux系统周期性任务管理,通过crontab -e编辑、-l查看、-r删除任务,时间格式为分 时 日 月 周 命令,支持*、/、-、,等特殊字符,需注意脚本权限、绝对路径及输出重定向,确保任务正确执行。 在Linux系统中,crontab 是用于设置周期性执行任务的命令。它允许…

    2025年12月6日 运维
    000
  • 如何在Linux中使用cron和at定时任务?

    cron用于周期性任务,at用于一次性任务。例如:0 2 * /backup.sh每天凌晨2点备份;echo “shutdown” | at 11:00 PM设置晚上11点关机。使用crontab -e编辑、atq查看、atrm删除任务,注意使用绝对路径、重定向输出并确保at…

    2025年12月6日 运维
    000
  • Linux如何查看网络连接_Linux网络连接查看的实用方法

    优先使用ss命令查看网络连接,如ss -tuln可列出所有监听端口;netstat功能类似但需安装net-tools;lsof用于精准定位,如lsof -i:22查看SSH连接。 在Linux系统中,查看网络连接是日常运维和故障排查的重要环节。掌握几种常用命令能快速了解当前系统的网络状态,包括哪些服…

    2025年12月6日 运维
    000
  • Linux中如何查看磁盘空间_Linux磁盘空间查看的多种方式

    使用df、du、lsblk等命令可全面查看Linux磁盘空间。1. df -h查看文件系统使用情况,显示总容量、已用、可用空间及挂载点;df -i检查inode使用,df -T显示文件系统类型。2. du -sh查看指定目录总大小,du -h –max-depth=1分析子目录占用,结合…

    2025年12月6日 运维
    000
  • Linux命令行中fc命令的使用方法

    fc 是 Linux 中用于管理命令历史的工具,可查看、编辑并重新执行历史命令。输入 fc 直接编辑最近一条命令,默认调用 $EDITOR 打开编辑器修改后自动执行;通过 fc 100 110 或 fc -5 -1 可批量编辑指定范围的历史命令,保存后按序重跑;使用 fc -l 列出命令历史,支持起…

    2025年12月6日 运维
    000
  • Linux密码策略如何配置_Linux密码策略配置的详细指南

    答案:Linux密码策略通过PAM模块和配置文件设置密码复杂度、有效期、重复使用限制及账户锁定规则,提升系统安全。具体包括:1. 配置pam_pwquality.so实现最小长度8位、含大小写字母、数字、特殊字符,允许输错3次;2. 修改/etc/login.defs设置密码最长使用90天、最短7天…

    2025年12月6日 运维
    000
  • Linux进程调度策略与优先级设置

    Linux进程调度通过SCHED_OTHER、SCHED_FIFO、SCHED_RR等策略分配CPU资源,结合nice值与实时优先级调节进程执行顺序,合理配置可提升系统响应与效率。 Linux进程调度决定了CPU资源如何分配给各个进程,直接影响系统响应速度和运行效率。调度策略与优先级设置是核心机制,…

    2025年12月6日 运维
    000
  • Linux系统如何加固Apache_Linux加固Apache服务器的配置方法

    隐藏服务器版本信息,设置ServerTokens Prod和ServerSignature Off;2. 使用专用用户apache运行进程;3. 限制目录访问,禁用自动索引和不必要的模块;4. 配置SSL/TLS加密,禁用弱协议并强制HTTPS。定期更新与监控日志可提升安全性。 加固Apache服务…

    2025年12月6日 运维
    000
  • 如何在Linux中查看磁盘IO性能?

    iostat和iotop是Linux中诊断磁盘IO性能的核心工具,配合df、du和sar可全面分析IO瓶颈与空间压力。 在Linux中查看磁盘IO性能,主要依赖系统自带的命令行工具。这些工具能实时或历史性地展示磁盘读写情况、响应时间、利用率等关键指标,帮助判断是否存在IO瓶颈。 使用 iostat …

    2025年12月6日 运维
    000
  • Linux如何配置防火墙规则_Linux防火墙规则配置的实用方法

    Linux防火墙配置主要通过firewalld或iptables实现。CentOS 7及以上默认使用firewalld,Debian系多用iptables。firewalld支持区域管理,配置动态生效,常用命令包括启动服务(systemctl start firewalld)、查看状态(firewa…

    2025年12月6日 运维
    000
  • 如何在Linux中删除文件和目录?

    使用rm命令删除文件,如rm filename;2. rmdir仅删除空目录,如rmdir dirname;3. rm -r递归删除非空目录,rm -rf强制删除且无提示,需谨慎使用。 在Linux中删除文件和目录主要使用rm和rmdir命令,根据需求选择合适的方式操作。 删除文件(rm) 使用rm…

    2025年12月6日 运维
    000
  • 如何在Linux中设置守护进程?

    答案:Linux中设置守护进程推荐使用systemd。编写程序后创建.service文件,配置Unit、Service和Install字段,通过systemctl enable/start启动服务,并用status查看状态;手动实现需fork、setsid、chdir、umask及重定向IO,适用于…

    2025年12月6日 运维
    000
  • VSCode终端美化:功率线字体配置

    首先需安装Powerline字体如Nerd Fonts,再在VSCode设置中将terminal.integrated.fontFamily设为’FiraCode Nerd Font’等支持字体,最后配合oh-my-zsh的powerlevel10k等Shell主题启用完整美…

    2025年12月6日 开发工具
    000
  • Linux命令行中locate命令的快速查找方法

    locate命令通过查询数据库快速查找文件,使用-i可忽略大小写,-n限制结果数量,-c统计匹配项,-r支持正则表达式精确匹配,刚创建的文件需运行sudo updatedb更新数据库才能查到。 在Linux命令行中,locate 命令是快速查找文件和目录路径的高效工具。它不直接扫描整个文件系统,而是…

    2025年12月6日 运维
    000
  • Linux文件系统rsync命令详解

    rsync通过增量同步高效复制文件,支持本地及远程同步,常用选项包括-a、-v、-z和–delete,结合SSH可安全传输数据,配合cron可实现定时备份。 rsync 是 Linux 系统中一个非常强大且常用的文件同步工具,能够高效地在本地或远程系统之间复制和同步文件与目录。它以“增量…

    2025年12月6日 运维
    000

发表回复

登录后才能评论
关注微信