2019-05-27 ovs-dpdk

相关链接

源码安装

编译依赖


  • yum install make gcc libpcap libpcap-devel kernel-devel kernel-headers kernel.x86_64 -y
  • git
  • yum install git
  • gcc
  • yum install gcc
  • libssl/openssl(recommended)
  • libcap-ng(recommended, Run OVS daemons as a non-root user)
  • python2.7
  • python six library
  • pip install six
  • ubound(recommended,DNS)
  • autoreconf
  • yum install autoconf
  • aclocal
  • yum install automake
  • libtool
  • yum install libtool
  • 其他
  • yum install python-pip

安装依赖


  • 同编译依赖
  • libssl/openssl(recommended)
  • libcap-ng(recommended, Run OVS daemons as a non-root user)
  • python2.7 and six library
  • ubound(recommended,DNS)
  • linux kernel>=3.3
  • tc
  • numactl-devel

编译安装


userspace program(ovs-vswitchd/ovsdb)


  • download source code
  • git clone https://github.com/openvswitch/ovs.git
  • 切换分支:git branch -d origin/branch-2.9
  • 编译
  • ./boot.sh
  • ./configure --prefix=/usr --localstatedir=/var --sysconfdir=/etc
  • ./configure --with-dpdk=/usr/src/dpdk --prefix=/usr --localstatedir=/var --sysconfdir=/etc
  • make
  • 安装
  • install
  • make install
  • start(auto script)
  • export PATH=$PATH:/usr/share/openvswitch/scripts
  • ovs-ctl start
  • start(manually)
  • ovsdb-tool create /etc/openvswitch/conf.db vswitchd/vswitch.ovsschema
  • mkdir -p /var/run/openvswitch
  • ovsdb-server --remote=punix:/var/run/openvswitch/db.sock --remote=db:Open_vSwitch,Open_vSwitch,manager_options --private-key=db:Open_vSwitch,SSL,private_key --certificate=db:Open_vSwitch,SSL,certificate --bootstrap-ca-cert=db:Open_vSwitch,SSL,ca_cert --pidfile --detach --log-file
  • ovs-vsctl --no-wait init
  • ovs-vswitchd --pidfile --detach --log-file
  • config
  • ovs-vsctl set-controller br0 tcp:127.0.0.1:6633,remote on 6633
  • ovs-vsctl set-manager ptcp:6640,listen on 6640
  • uninstall
  • ovs-ctl stop
  • make uninstall
  • rm -rf /etc/openvswitch
  • rm -rf /usr/share/openvswitch
  • rm -rf /var/run/openvswitch/

userspace program with dpdk(ovs-vswitchd/ovsdb)


dpdk

  • yum install numactl-devel*x86_64
  • yum install kernel-devel.x86_64
  • cd /usr/src/
  • wget http://fast.dpdk.org/rel/dpdk-17.11.4.tar.xz
  • tar xf dpdk-17.11.4.tar.xz
  • export DPDK_DIR=/usr/src/dpdk-stable-17.11.4
  • cd $DPDK_DIR
  • export DPDK_TARGET=x86_64-native-linuxapp-gcc
  • export DPDK_BUILD=DPDK\_DIR/DPDK_TARGET
  • make install T=$DPDK_TARGET DESTDIR=install

ovs

  • download source code
  • git clone https://github.com/openvswitch/ovs.git
  • 切换分支:git branch -d origin/branch-2.9
  • 编译
  • ./boot.sh
  • ./configure --with-dpdk=/usr/src/dpdk --prefix=/usr --localstatedir=/var --sysconfdir=/etc
  • make
  • 安装
  • install
  • make install
  • start(auto script)
  • export PATH=$PATH:/usr/share/openvswitch/scripts
  • ovs-ctl start
  • start(manually)
  • ovsdb-tool create /etc/openvswitch/conf.db vswitchd/vswitch.ovsschema
  • mkdir -p /var/run/openvswitch
  • ovsdb-server --remote=punix:/var/run/openvswitch/db.sock --remote=db:Open_vSwitch,Open_vSwitch,manager_options --private-key=db:Open_vSwitch,SSL,private_key --certificate=db:Open_vSwitch,SSL,certificate --bootstrap-ca-cert=db:Open_vSwitch,SSL,ca_cert --pidfile --detach --log-file
  • ovs-vsctl --no-wait init
  • huge page
  • echo 'vm.nr_hugepages=2048' > /etc/sysctl.d/hugepages.conf
  • sysctl -w vm.nr_hugepages=2048
  • mount -t hugetlbfs none /dev/hugepages``
  • ovs-vswitchd --pidfile --detach --log-file
  • config
  • ovs-vsctl set-controller br0 tcp:127.0.0.1:6633,remote on 6633
  • ovs-vsctl set-manager ptcp:6640,listen on 6640
  • ovs-vsctl --no-wait set Open_vSwitch . other_config:dpdk-init=true
  • uninstall
  • ovs-ctl stop
  • make uninstall
  • rm -rf /etc/openvswitch
  • rm -rf /usr/share/openvswitch
  • rm -rf /var/run/openvswitch/

添加网卡

  • 查看dpdk网卡绑定情况
    • dpdk-devbind.py --status
  • dpdk绑定网卡
    • lspci | grep Eth
    • dpdk-devbind.py --bind=vfio_pci pci_id
    • dpdk-devbind.py --status
  • ovs
    • ovs-vsctl add-br br0 -- set bridge br0 datapath_type=netdev
    • ovs-vsctl add-port br0 myportnameone -- set Interface myportnameone type=dpdk options:dpdk-devargs=0000:00:08.0

常用命令

  • ovsdb-client dump
  • ovs-vsctl
  • ovs-vsctl add-br br0 -- set bridge br0 datapath_type=netdev
  • ovs-vsctl add-port br0 tap-1 -- set interface tap-1 type=tap ofport_request=1
  • ovs-vsctl set port tap-1 tag=100
  • ovs-vsctl add-port br0 vhost-user-1 -- set interface vhost-user-1 type=dpdkvhostuser ofport_request=6
  • ovs-vsctl add-port phy-br1 phy-br1-br0 -- set interface phy-br1-br0 type=patch options:peer=br0
  • ovs-vsctl add-port br0 br0-phy-br1 -- set interface br0-phy-br1 type=patch options:peer=phy-br1
  • ovs-vsctl --no-wait set Open_vSwitch . other_config:
  • ovs-ofctl
  • ovs-appctl
  • ovs-dpctl
  • ovs-dpctl-top

linux kernel module



OVS+DPDK

问题

  • optimized out:gcc -O0->gcc -O0

ovsdb-server分析

  • /etc/openvswitch/conf.db
  • json格式
  • ovsdb-client dump导出
  • 通过/ar/run/openvswitch/db.sock提供服务,ovs-vswitchd通过该socket获取配置信息
  • 通过配置的manager提供服务

涉及知识点

  • BUILD_BUG_ON
  • 定义位置:build_config.h
  • 定义内容:
    define BUILD_BUG_ON(condition) ((void)sizeof(char[1 - 2*!!(condition)])
    如果条件为真则引起一个编译时错误。
  • FIELD_SIZEOF
  • FIELD_SIZEOF获取成员大小
  • FIELD_SIZEOF用来获取成员大小。它需要两个参数,第一个指定结构体的类型,第二个则指明成员的名字。
  • define FIELD_SIZEOF(t, f) (sizeof(((t*)0)->f))

OVS代码分析

datapath

  • datapath/datapath.c
  • ovs_nsh_init方法:注册nsh(network service head) offload回调函数到offload_base
  • type:ETH_P_NSH
  • callbacks:.gso_segment = nsh_gso_segment
  • nsh_gso_segment处理流程-----------------------------------------undone
  • action_fifos_init方法:分配percpu变量
  • 数据结构数组
  • 系统的每个cpu对应数组的一个元素。一个cpu不应该访问与其它cpu对应的数组元素,另外,它可以随意读或修改它自己的元素而不用担心出现竞争条件,因为它是唯一有资格这么做的cpu。

ovs-vswitchd


进程启动


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