在线时间:8:00-16:00
迪恩网络APP
随时随地掌握行业动态
扫描二维码
关注迪恩网络微信公众号
开源软件名称(OpenSource Name):Igalia/pflua开源软件地址(OpenSource Url):https://github.com/Igalia/pflua开源编程语言(OpenSource Language):Lua 97.4%开源软件介绍(OpenSource Introduction):pflua
Getting started$ git clone --recursive https://github.com/Igalia/pflua.git
$ cd pflua; make # Builds embedded LuaJIT
$ make check # Run builtin basic tests Using pfluaPflua is a library; you need an application to drive it. The most simple way to use pflua is filtering packets from a file
captured by
See the source of pflua-filter for more information. Pflua was made to be integrated into the Snabb Switch user-space networking toolkit, also written in Lua. A common deployment environment for Snabb is within the host virtual machine of a virtualized server, with Snabb having CPU affinity and complete control over a high-performance 10Gbit NIC, which it then routes to guest VMs. The administrator of such an environment might want to apply filters on the kinds of traffic passing into and out of the guests. To this end, we plan on integrating pflua into Snabb so as to provide a pleasant, expressive, high-performance filtering facility. Given its high performance, it is also reasonable to deploy pflua on gateway routers and load-balancers, within virtualized networking appliances. ImplementationPflua can compile pflang filters in two ways. The default compilation pipeline is pure Lua. First, a custom parser produces a high-level AST of a pflang filter expression. This AST is lowered to a primitive AST, with a limited set of operators and ways in which they can be combined. This representation is then exhaustively optimized, folding constants and tests, inferring ranges of expressions and packet offset values, hoisting assertions that post-dominate success continuations, etc. We then lower to A-normal form to give names to all intermediate values, perform common subexpression elimination, then inline named values that are only used once. We lower further to Static single assignment to give names to all blocks, which allows us to perform control-flow optimizations. Finally, we residualize Lua source code, using the control flow analysis from the SSA phase. The resulting Lua function is a predicate of two parameters: the packet
as a The other compilation pipeline starts with bytecode for the Berkeley
packet filter
VM.
Pflua can load up the We like the independence and optimization capabilities afforded by the
native pflang pipeline. However, though pflua does a good job in
implementing pflang, it is inevitable that there may be bugs or
differences of implementation relative to what See the doc subdirectory for some examples of the Lua code generated for some simple pflang filters using these two pipelines. PerformanceTo our knowledge, pflua is the fastest implementation of pflang out there. See https://github.com/Igalia/pflua-bench for our benchmarking experiments and results. Pflua can beat other implementations because:
API documentationNone yet. See
pf.lua for the
high-level BugsCheck our issue tracker for known bugs, and please file a bug if you find one. Cheers :) AuthorsPflua was written by Katerina Barone-Adesi, Andy Wingo, Diego Pino, and Javier Muñoz at Igalia, S.L., as well as Peter Melnichenko. Development of pflua was supported by Luke Gorrie at Snabb Gmbh, purveyors of fine networking solutions. Thanks, Snabb! Feedback is very welcome! If you are interested in pflua in a Snabb
context, probably the best thing is to post a message to the
snabb-devel
group. Or, if you like, you can contact Andy directly at
|
2023-10-27
2022-08-15
2022-08-17
2022-09-23
2022-08-13
请发表评论