2017-04-21 10:43:26 +00:00
# F-Stack Nginx APP Guide
F-Stack is an open source network framework based on DPDK. F-Stack supports standard Nginx as HTTP framework which means all web application based on HTTP can easily use F-Stack.
## How does Nginx use F-Stack?
2023-10-19 08:02:50 +00:00
Nginx APP is in `app/nginx-1.25.2` directory.
2017-04-21 10:43:26 +00:00
2017-08-23 08:54:32 +00:00
```
2017-09-05 12:24:51 +00:00
+--------+
+------------------------+ |
channel: socketpair |
+------------------------+ | signal(reload, quit..)
|
|
+---------v--------+
| |
+----------------+ master process +---------------+
| | | |
| channel +----------+-------+ |
| | channel |
| channel | |
| | |
+---------+----------+ +----------+--------+ +---------+--------+
first one to start | | | | | |
last one to exit< - + primary worker | | secondary worker | | secondary worker |
| | | | | |
+--------------------+ +-------------------+ +------------------+
2018-01-26 09:44:47 +00:00
+--------------------+ +-------------------+
| | | |
| fstack,kernel | | fstack,kernel |
| and channel | | and channel |
| loop thread | | loop thread |
| | | |
+--------------------+ +-------------------+
woker process cycle woker process cycle
2017-08-23 08:54:32 +00:00
```
2017-09-05 12:24:51 +00:00
- spawn primary worker firstly, and then wait for primary startup, continue to spawn secondary workers.
2017-08-23 09:23:21 +00:00
2018-01-26 09:44:47 +00:00
- a major addition to the worker process is fstack-handling: ff_init();ff_run(worker_process_cycle); worker_process_cycle(handle channel/host/fstack event).
2017-08-23 08:54:32 +00:00
2018-02-05 07:55:20 +00:00
## What's Different?
### New directives:
All the directives below are available only when ```NGX_HAVE_FSTACK``` is defined.
2018-01-26 13:44:05 +00:00
```
Syntax: kernel_network_stack on | off;
Default: kernel_network_stack off;
Context: http, server
2018-02-05 07:55:20 +00:00
2018-01-26 13:44:05 +00:00
Determines whether server should run on kernel network stack or fstack.
```
2018-02-05 07:55:20 +00:00
```
Syntax: proxy_kernel_network_stack on | off;
2024-10-15 06:48:49 +00:00
Default: proxy_kernel_network_stack off;
2018-02-05 07:55:20 +00:00
Context: http, stream, mail, server
Determines whether proxy should go through kernel network stack or fstack.
```
2017-08-31 09:39:11 +00:00
2018-02-05 07:55:20 +00:00
```
Syntax: schedule_timeout time;
2018-02-09 12:09:05 +00:00
Default: schedule_timeout 30ms;
2018-04-26 06:35:04 +00:00
Context: main
2018-02-05 07:55:20 +00:00
Sets a time interval for polling kernel_network_stack. The default value is 30 msec.
```
2017-08-23 08:54:32 +00:00
2018-02-05 07:55:20 +00:00
### Command-line `reload`
the `reload` is not graceful, service will still be unavailable during the process of reloading.
2017-08-23 08:54:32 +00:00
2018-02-05 07:55:20 +00:00
### Necessary modifies in nginx.conf:
2017-08-23 08:54:32 +00:00
```
user root; # root account is necessary.
fstack_conf f-stack.conf; # path of f-stack configuration file, default: $NGX_PREFIX/conf/f-stack.conf.
2017-08-31 09:41:27 +00:00
worker_processes 1; # should be equal to the lcore count of `dpdk.lcore_mask` in f-stack.conf.
2017-04-21 10:43:26 +00:00
2017-08-31 09:41:27 +00:00
events {
worker_connections 102400; # increase
use kqueue; # use kqueue
}
2017-04-21 10:43:26 +00:00
2017-08-31 09:41:27 +00:00
sendfile off; # sendfile off
2017-08-23 08:54:32 +00:00
```
2017-04-21 10:43:26 +00:00
2017-08-23 08:54:32 +00:00
## Nginx compiling
./configure --prefix=/usr/local/nginx_fstack --with-ff_module
make
make install
2017-04-21 10:43:26 +00:00