f-stack/README.md

186 lines
10 KiB
Markdown
Raw Permalink Normal View History

2017-09-11 03:04:19 +00:00
[![Build Status](https://travis-ci.org/F-Stack/f-stack.svg?branch=master)](https://travis-ci.org/F-Stack/f-stack)
2017-04-14 02:28:07 +00:00
# F-Stack
2017-04-21 10:43:26 +00:00
![](F-Stack.png)
## Introduction
2017-09-14 10:57:37 +00:00
2018-04-19 12:45:35 +00:00
With the rapid development of Network Interface Cards the poor performance of data packet processing with the Linux kernel has become the bottleneck in modern network systems. Yet, the increasing demands of the Internet's growth demand a higher performant network processing solution. Kernel bypass has emerged to catch more and more attention. There are various similar technologies such as: DPDK, NETMAP and PF_RING. The main idea of kernel bypass is that Linux is only used to deal with control flow; all data streams are processed in user space. Therefore, kernel bypass can avoid performance bottlenecks caused by kernel packet copying, thread scheduling, system calls, and interrupts. Furthermore, kernel bypass can achieve higher performance with multi-optimizing methods. Within various techniques, DPDK has been widely used because of it's more thorough isolation from kernel scheduling and active community support.
2017-04-21 10:43:26 +00:00
2018-04-19 12:45:35 +00:00
[F-Stack](http://www.f-stack.org/?from=github) is an open source high performant network framework based on DPDK with the following characteristics:
2017-04-21 10:43:26 +00:00
2018-04-19 12:45:35 +00:00
1. Ultra high network performance which the network card can achieve under full load: 10 million concurrent connections, 5 million RPS, 1 million CPS.
2. Transplant FreeBSD 11.01 user space stack, which provides a complete stack function, and cut a great amount of irrelevant features. This greatly enhances network performance.
3. Support Nginx, Redis, and other mature applications. Services can easily use F-Stack.
4. Easy to extend with multi-process architecture.
5. Provides micro thread interface. Various applications with stateful applications can easily use F-Stack to get high performance without processing complex asynchronous logic.
6. Provide an Epoll/Kqueue interface that allow many kinds of applications to easily use F-Stack.
2017-04-21 10:43:26 +00:00
## History
2018-04-19 12:45:35 +00:00
To deal with the increasingly severe DDoS attacks the authorized DNS server of Tencent Cloud DNSPod switched from Gigabit Ethernet to 10-Gigabit at the end of 2012. We faced several options: one is to continue to use the original network stack in the Linux kernel, another is to use kernel bypass techniques. After several rounds of investigation; we finally chose to develop our next generation of DNS server based on DPDK. The reason is DPDK provides ultra-high performance and can be seamlessly extended to 40G, or even 100G NIC, in the future.
2017-04-21 10:43:26 +00:00
After several months of development and testing, DKDNS, high-performance DNS server based on DPDK officially released in October 2013. It's capable of achieving up to 11 million QPS with a single 10GE port and 18.2 million QPS with two 10GE ports. And then we developed a user-space TCP/IP stack called F-Stack that can process 0.6 million RPS with a single 10GE port.
2018-04-20 19:25:22 +00:00
With the fast growth of Tencent Cloud more and more of our services needed higher network access performance. Meanwhile, F-Stack was continuing to improve, being driven by our business growth, and, ultimately developed into a general network access framework. But our initial TCP/IP stack couldn't meet the needs of these services. Continuing to develop and maintain a complete high performance network stack would have been too expensive. After evaluating several plans; we finally determined to port FreeBSD's (11.0 stable) TCP/IP stack into F-Stack. Not only does this allow us to stop reinventing the wheel, we can take advantage of the the improvements the FreeBSD community will bring in the future. Thanks to [libplebnet](https://gitorious.org/freebsd/kmm-sandbox/commit/fa8a11970bc0ed092692736f175925766bebf6af?p=freebsd:kmm-sandbox.git;a=tree;f=lib/libplebnet;h=ae446dba0b4f8593b69b339ea667e12d5b709cfb;hb=refs/heads/work/svn_trunk_libplebnet) and [libuinet](https://github.com/pkelsey/libuinet) this work became a lot easier.
2017-04-21 10:43:26 +00:00
2018-04-20 17:58:32 +00:00
With the rapid development of all kinds of applications, in order to help different APPs quick and easily use F-Stack, F-Stack has integrated Nginx, Redis and other commonly used APPs, and a micro thread framework, and provides a standard Epoll/Kqueue interface.
2017-04-21 10:43:26 +00:00
Currently, besides authorized DNS server of DNSPod, there are various products in Tencent Cloud has used the F-Stack, such as HttpDNS (D+), COS access module, CDN access module, etc..
## Quick Start
2018-04-20 17:58:32 +00:00
# clone F-Stack
mkdir -p /data/f-stack
2017-04-21 10:43:26 +00:00
git clone https://github.com/F-Stack/f-stack.git /data/f-stack
# Install libnuma-dev
yum install numactl-devel # on Centos
#sudo apt-get install libnuma-dev # on Ubuntu
# Install dependencies (FreeBSD only)
#pkg install meson pkgconf py38-pyelftools
2017-04-21 10:43:26 +00:00
cd f-stack
# Compile DPDK
cd dpdk/usertools
2017-04-21 10:43:26 +00:00
./dpdk-setup.sh # compile with x86_64-native-linuxapp-gcc
# Set hugepage (Linux only)
2017-04-21 10:43:26 +00:00
# single-node system
echo 1024 > /sys/kernel/mm/hugepages/hugepages-2048kB/nr_hugepages
# or NUMA (Linux only)
2017-04-21 10:43:26 +00:00
echo 1024 > /sys/devices/system/node/node0/hugepages/hugepages-2048kB/nr_hugepages
echo 1024 > /sys/devices/system/node/node1/hugepages/hugepages-2048kB/nr_hugepages
# Using Hugepage with the DPDK (Linux only)
2017-04-21 10:43:26 +00:00
mkdir /mnt/huge
mount -t hugetlbfs nodev /mnt/huge
# Close ASLR; it is necessary in multiple process (Linux only)
echo 0 > /proc/sys/kernel/randomize_va_space
# Install python for running DPDK python scripts
sudo apt install python # On ubuntu
#sudo pkg install python # On FreeBSD
# Offload NIC
# For Linux:
2017-04-21 10:43:26 +00:00
modprobe uio
2017-04-24 04:12:53 +00:00
insmod /data/f-stack/dpdk/x86_64-native-linuxapp-gcc/kmod/igb_uio.ko
insmod /data/f-stack/dpdk/x86_64-native-linuxapp-gcc/kmod/rte_kni.ko carrier=on # carrier=on is necessary, otherwise need to be up `veth0` via `echo 1 > /sys/class/net/veth0/carrier`
2017-04-21 10:43:26 +00:00
python dpdk-devbind.py --status
ifconfig eth0 down
python dpdk-devbind.py --bind=igb_uio eth0 # assuming that use 10GE NIC and eth0
# For FreeBSD:
# Refer DPDK FreeBSD guide to set tunables in /boot/loader.conf
# Below is an example used for our testing machine
#echo "hw.nic_uio.bdfs=\"2:0:0\"" >> /boot/loader.conf
#echo "hw.contigmem.num_buffers=1" >> /boot/loader.conf
#echo "hw.contigmem.buffer_size=1073741824" >> /boot/loader.conf
#kldload contigmem
#kldload nic_uio
# Install DPDK
cd ../x86_64-native-linuxapp-gcc
make install
# On Ubuntu, use gawk instead of the default mawk.
#sudo apt-get install gawk # or execute `sudo update-alternatives --config awk` to choose gawk.
# Install dependencies for F-Stack
sudo apt install gcc make libssl-dev # On ubuntu
#sudo pkg install gcc gmake openssl pkgconf libepoll-shim # On FreeBSD
2017-04-21 10:43:26 +00:00
# Compile F-Stack
export FF_PATH=/data/f-stack
2017-04-21 12:29:05 +00:00
export FF_DPDK=/data/f-stack/dpdk/x86_64-native-linuxapp-gcc
2017-05-24 07:32:15 +00:00
cd ../../lib/
make # On Linux
#gmake # On FreeBSD
2017-04-21 10:43:26 +00:00
# Install F-STACK
# libfstack.a will be installed to /usr/local/lib
# ff_*.h will be installed to /usr/local/include
# start.sh will be installed to /usr/local/bin/ff_start
# config.ini will be installed to /etc/f-stack.conf
make install # On Linux
#gmake install # On FreeBSD
2017-04-21 10:43:26 +00:00
#### Nginx
cd app/nginx-1.16.1
bash ./configure --prefix=/usr/local/nginx_fstack --with-ff_module
2017-04-21 10:43:26 +00:00
make
make install
cd ../..
/usr/local/nginx_fstack/sbin/nginx
for more details, see [nginx guide](https://github.com/F-Stack/f-stack/blob/master/doc/F-Stack_Nginx_APP_Guide.md).
2017-04-21 10:43:26 +00:00
#### Redis
2019-11-23 03:08:39 +00:00
cd app/redis-5.0.5/
2017-04-21 10:43:26 +00:00
make
make install
2017-05-23 08:01:51 +00:00
 If KNI is enabled in the configuration file, you should create a virtual NIC after F-Stack started, and set the ipaddr, netmask, mac addr, route table, etc. These addrs must be same with F-Stack.
2017-09-14 10:57:37 +00:00
2017-05-23 08:01:51 +00:00
If you don't have another management port, you should execute a script like this.
2017-09-11 03:04:19 +00:00
/usr/local/nginx_fstack/sbin/nginx
2017-05-23 08:05:59 +00:00
sleep 10
ifconfig veth0 <ipaddr> netmask <netmask>  broadcast <broadcast> hw ether <mac addr>
route add -net 0.0.0.0 gw <gateway> dev veth0
echo 1 > /sys/class/net/veth0/carrier # if `carrier=on` not set while `insmod rte_kni.ko`
2017-05-23 08:05:59 +00:00
# route add -net ... # other route rules
2017-04-21 10:43:26 +00:00
2018-08-03 08:06:30 +00:00
## Binary Release
We provide a f-stack-binary-release package that you can use F-Stack directly without compiling. For more details, see [Binary_Release_Quick_Start](https://github.com/F-Stack/f-stack/blob/master/doc/F-Stack_Binary_Release_Quick_Start.md).
2017-09-14 10:57:37 +00:00
## Nginx Testing Result
2017-04-21 10:43:26 +00:00
Test environment
NIC:Intel Corporation Ethernet Controller XL710 for 40GbE QSFP+
2017-07-25 10:06:31 +00:00
CPU:Intel(R) Xeon(R) CPU E5-2670 v3 @ 2.30GHz(NUMA)
2017-04-21 10:43:26 +00:00
Memory128G
OS:CentOS Linux release 7.2 (Final)
Kernel3.10.104-1-tlinux2-0041.tl2
Nginx uses linux kernel's default config, all soft interrupts are working in the first CPU core.
2017-09-14 10:57:37 +00:00
Nginx si means modify the smp_affinity of every IRQ, so that the decision to service an interrupt with a particular CPU is made at the hardware level, with no intervention from the kernel.
2017-04-21 10:43:26 +00:00
2018-08-03 10:16:06 +00:00
Nginx Reuseport means enable "reuseport" in `nginx.conf`.
2017-08-09 09:41:58 +00:00
Nginx_FStack's 600 cache bytes' body was returned directly in nginx.conf.
2017-07-25 10:06:31 +00:00
All of these test cases use CPUs' physical cores.
2017-04-21 10:43:26 +00:00
2017-08-09 09:41:58 +00:00
2017-04-21 10:43:26 +00:00
CPS (Connection:close, Small data packet) test result
2018-08-03 10:16:06 +00:00
![](CPS.png)
CPS_Reuseport (Connection:close, Small data packet) test result, This test case runs in a different test environment
![](CPS_Reuseport.png)
2017-04-21 10:43:26 +00:00
RPS (Connection:Keep-Alive, Small data packet) test data
2018-08-03 10:16:06 +00:00
![](RPS.png)
2017-04-21 10:43:26 +00:00
Bandwidth (Connection:Keep-Alive, 3.7k bytes data packet) test data
2018-08-03 10:16:06 +00:00
![](Bandwidth.png)
2017-04-21 10:43:26 +00:00
## Licenses
See [LICENSE](LICENSE)
2017-05-07 09:23:30 +00:00
## Join us
Tencent Cloud F-Stack team developed F-Stack which is a general network framework based on DPDK and provides ultra high network performance. We are here looking for more and more talented people with great passion on technology to join us. You would have the chance to work with brightest minds on this planet and help Tencent cloud and F-stack continuously evolve. Send us your resume or refer your friend to us if you are interested in joining us.
Open Positions: Software engineer(C/C++), Web developer, IOS/Android developer, Product Manager, Operating Manager, etc.
2024-06-20 08:50:58 +00:00
Contact: Please send your resume to [us](mailto:fengbojiang@tencent.com)