当前位置: 首页 > article >正文

DPDK高性能处理框架VPP

VPP 环境安装

$ git clone -b stable/1801 https://github.com/FDio/vpp.git
在这里插入图片描述

$ ./extras/vagrant/build.sh && make
在这里插入图片描述

在编译成功以后,会生成上图红色的 deb 表
$ dpkg –i vpp-lib_18.01.2-1~g9b554f3_amd64.deb
$ dpkg –i vpp_18.01.2-1~g9b554f3_amd64.deb
$ dpkg –i vpp-dev_18.01.2-1~g9b554f3_amd64.deb
$ dpkg –i vpp-plugins_18.01.2-1~g9b554f3_amd64.deb
执行完成以后,在 /etc/vpp/startup.conf
在这里插入图片描述

在 /usr/lib/vpp_plugins/
在这里插入图片描述

在 conf 文件里面添加了三个 dev 网卡
在这里插入图片描述
Startup.conf 里面的 pci 地址
在这里插入图片描述

编写 Startup.conf
在这里插入图片描述
如果需要使用 vppctl,需要 cli-listen /run/vpp/cli.sock
在这里插入图片描述

再 dpdk 的运行环境准备就绪,
在这里插入图片描述

将 eth0/eth1/eth2 关闭
$ ifconfig eth0 down
$ ifconfig eth1 down
$ ifconfig eth2 down

启动 vpp,
$ vpp -c /etc/vpp/startup.conf
在这里插入图片描述

在这里插入图片描述
停止 vpp
$ service vpp stop
在这里插入图片描述

Vpp 命令操作

vpp# show int
在这里插入图片描述

vpp# set interface state GigabitEthernet13/0/0 up
在这里插入图片描述

vpp# set interface ip address GigabitEthernet13/0/0 192.168.0.119/24
在这里插入图片描述
配置 vlan
vpp# create bridge-domain 10
vpp# set interface l2 bridge GigabitEthernet3/0/0 10
vpp# create sub-interface GigabitEthernet3/0/0 10 dot1q 10
vpp# show bridge-domain 10 detail
在这里插入图片描述
在这里插入图片描述

配置 veth
$ ip link add name vpp1out type veth peer name vpp1host
$ ip addr show vpp1host
$ ip link set dev vpp1out up
$ ip link set dev vpp1host up
在这里插入图片描述
配置 vpp1host ip 地址
$ ip addr add 192.168.3.128/24 dev vpp1host
$ ip addr show vpp1host
在这里插入图片描述

VPP 添加插件 plugin

实现一个打印包头信息的插件,源代码如下:
在这里插入图片描述

修改 src/configure.ac修改 src/plugins/Makefile.am
在这里插入图片描述
在这里插入图片描述

# make wipe
# make build 
# make run

在这里插入图片描述
在这里插入图片描述
执行结果:
Windows 物理机 ping 192.168.0.120
在这里插入图片描述

插件 plugin 的原理

在这里插入图片描述


http://www.kler.cn/a/382811.html

相关文章:

  • 提升网站安全性 HTTPS的重要性与应用指南
  • 【华为云-云驻共创】UCS跨云多活容灾:让业务高可用不再是难题
  • 网络安全从入门到精通(特别篇II):应急响应之DDOS处置流程
  • 内网项目,maven本地仓库离线打包,解决Cannot access central in offline mode?
  • 光伏无人机踏勘,照亮光伏未来!
  • Qt入门基础分享
  • 力扣:225 用队列实现栈
  • 【JavaScript】V8,Nodejs 与浏览器
  • 【linux】的爱恨情仇
  • 机器学习—TensorFlow实现
  • C语言必做30道练习题
  • mysql-springboot netty-flink-kafka-spark(paimon)-minio
  • 笔记整理—linux驱动开发部分(8)framebuffer类设备
  • FlinkSql读取外部Mysql和HBase数据库的方法(scala)
  • AI笔筒操作说明及应用场景
  • Rust 图形界面开发——使用 GTK 创建跨平台 GUI
  • .NET 8 中 Entity Framework Core 的使用
  • 无人机无线电频谱侦测运行方式!
  • hf_transformers
  • 五、Java并发 Java Google Guava 实现
  • 解决CORS (跨源资源共享) 错误
  • RabbitMQ 实现消息队列负载均衡
  • 光纤定向耦合器
  • 基于vue框架的的冷链食品物流信息管理系统v81wb(程序+源码+数据库+调试部署+开发环境)系统界面在最后面。
  • postman入参file的接口测试
  • 初识CSS