目的
- 搭建对应的环境,学习一下seastar,看看大佬们写的框架
- seastar是目前为数不多的活跃的DPDK user_level stack,star多且社区活跃,其它的还有F-Stack,VPP,gazelle。时间真快,mtcp都快老掉牙了😶,很难移植到新版的DPDK上了。
- 额,看了一下它们写的C++代码,感觉和他们不在同一个世界,哈哈哈哈哈哈哈太牛了,封装了很多库后感觉和高级语言没差了。
虚拟机准备
- 安装ubuntu22.04 server,换清华源
- 给虚拟机加入一张网卡,该网卡对应的虚拟网络最好配置DHCP服务器(Seastar可以用DHCP自动获取IP)
- 为了支持DPDK,打开虚拟机的VMX文件,将上述网卡类型从e1000改为vmxnet3
seastar 安装
- 选择稳定的版本:
git clone -b seastar-22.11-branch https://gitee.com/mirrors/seastar.git
cd seastar
- #获取DPDK源码,这个版本使用的DPDK是19.05,有亿点点老,API名称和现在的版本差别太大了
git submodule update --init --recursive
- apt安装依赖:
./install-dependencies.sh
- configure build目录:
./configure.py --mode=release --enable-dpdk
- 编译并安装:
ninja -C build/release/ install
运行seastar的HTTPD
- 配置DPDK运行环境:
关闭网卡=》申请大页=》加载UIO驱动=》网卡绑定到UIO
ifconfig ens160 down
echo 512 > /sys/kernel/mm/hugepages/hugepages-2048kB/nr_hugepages
modprobe uio_pci_generic
python3 seastar/dpdk/usertools/dpdk-devbind.py -b uio_pci_generic ens160 - 运行seastar httpd:
seastar/build/release/apps/httpd/httpd --network-stack native --dpdk-pmd --csum-offload off --hw-fc off
可能遇到的问题:
- 之前装了很多版本的都没有跑成功:
- DHCP申请不到对应的IP
- 用静态IP也不能ping和curl通
- wireshark抓包发现IP检验和为0,协议栈没有计算,即使关闭了检验和卸载(vm哪来的卸载能力😶?)
- 解决方案:自己算一下校验和吧。。。晕😵
-
打开
src/net/dpdk.cc
文件,找到rte_eth_tx_burst
这一行,在上面加入如下代码,记得引入rte_ip.h
和rte_ether.h
-
重新编译
ninja -C build/release/ install
,问题解决
-