apisix/README.md

230 lines
5.7 KiB
Markdown
Raw Normal View History

2019-06-03 16:24:38 +08:00
[![Build Status](https://travis-ci.org/iresty/apisix.svg?branch=master)](https://travis-ci.org/iresty/apisix)
[![License](https://img.shields.io/badge/License-Apache%202.0-blue.svg)](https://github.com/iresty/apisix/blob/master/LICENSE)
APISIX is a cloud-native microservices API gateway, delivering the ultimate performance, security, open source and scalable platform for all your APIs and microservices.
## Summary
- [**Install**](#install)
- [**Quickstart**](#quickstart)
- [**Distributions**](#distributions)
2019-05-31 16:37:26 +08:00
- [**Benchmark**](#benchmark)
- [**Development**](#development)
2019-05-20 11:07:03 +08:00
## Install
2019-06-02 20:46:52 +08:00
### Dependencies
- OpenResty
```shell
sudo yum install yum-utils
sudo yum-config-manager --add-repo https://openresty.org/package/centos/openresty.repo
sudo yum install openresty
```
- etcd
```shell
sudo yum install etcd
```
2019-06-02 20:46:52 +08:00
### Install from RPM
```shell
wget http://39.97.63.215/download/apisix-0.1-2.noarch.rpm
sudo rpm -ivh apisix-0.1-2.noarch.rpm
```
2019-05-20 11:07:03 +08:00
If no error has occurred, APISIX is already installed in this directory: `/usr/share/lua/5.1/apisix`.
2019-05-20 11:07:03 +08:00
Now, you can try APISIX, go to [**Quickstart**](#quickstart).
2019-05-20 11:07:03 +08:00
2019-06-02 20:46:52 +08:00
### Install from Source
Now OpenResty and etcd are installed, we can use Luarocks to install APISIXs Lua sources:
2019-05-20 11:07:03 +08:00
2019-06-02 20:46:52 +08:00
#### Install by Luarocks
```shell
luarocks install apisix
```
If you want to know more details, the Luarocks will clone and compile the following dependencies:
2019-05-20 11:07:03 +08:00
* [lua-resty-r3] Setups the [resty-r3#install](https://github.com/iresty/lua-resty-r3#install) library.
* [lua-resty-etcd] Setups the [resty-etcd#install](https://github.com/iresty/lua-resty-etcd#install) library.
* [lua-resty-balancer] Setups the [resty-balancer#install](https://github.com/iresty/lua-resty-balancer#installation) library.
* [lua-var-nginx-module] Setups the [lua-var-nginx-module#install](https://github.com/iresty/lua-var-nginx-module#install) library, this C module is optional, it will use `ngx.var.*` if the C module is not found.
2019-05-20 11:07:03 +08:00
## Quickstart
1. start etcd:
```shell
systemctl start etcd
```
2. init etcd:
```shell
curl http://127.0.0.1:2379/v2/keys/apisix/routes -X PUT -d dir=true
curl http://127.0.0.1:2379/v2/keys/apisix/upstreams -X PUT -d dir=true
curl http://127.0.0.1:2379/v2/keys/apisix/services -X PUT -d dir=true
```
3. start APISIX:
```shell
sudo openresty -p /usr/share/lua/5.1/apisix -c /usr/share/lua/5.1/apisix/conf/nginx.conf
```
4. try limit count plugin
For the convenience of testing, we set up a maximum of 2 visits in 60 seconds, and return 503 if the threshold is exceeded:
```shell
curl http://127.0.0.1:2379/v2/keys/apisix/routes/1 -X PUT -d value='
{
"methods": ["GET"],
"uri": "/hello",
"id": 1,
"plugin_config": {
"limit-count": {
"count": 2,
"time_window": 60,
"rejected_code": 503,
"key": "remote_addr"
}
},
"upstream": {
"type": "roundrobin",
"nodes": {
"220.181.57.215:80": 1,
"220.181.57.216:80": 1
}
}
}'
```
```shell
$ curl -i -H 'Host: baidu.com' http://127.0.0.1:9080/hello
HTTP/1.1 302 Found
Content-Type: text/html; charset=iso-8859-1
Content-Length: 222
Connection: keep-alive
X-RateLimit-Limit: 2
X-RateLimit-Remaining: 0
...
```
## Distributions
- Docker: TODO
2019-06-02 20:46:52 +08:00
- LuaRocks: luarocks install apisix
- CentOS: [RPM for CentOS 7](http://39.97.63.215/download/apisix-0.1-2.noarch.rpm)
- RedHat: TODO
- Ubuntu: TODO
- Homebrew:TODO
- Nightly Builds: TODO
2019-05-31 16:37:26 +08:00
## Benchmark
### Benchmark Environments
n1-highcpu-8 (8 vCPUs, 7.2 GB memory) on Google Cloud
But we **only** used 4 cores to run APISIX, and left 4 cores for system and [wrk](https://github.com/wg/wrk),
which is the HTTP benchmarking tool.
### Benchmark Test for reverse proxy
Only used APISIX as the reverse proxy server, with no logging, limit rate, or other plugins enabled,
and the response size was 1KB.
2019-05-31 16:52:02 +08:00
#### QPS
2019-05-31 16:37:26 +08:00
The x-axis means the size of CPU core, and the y-axis is QPS.
![](doc/benchmark-1.jpg)
2019-05-31 16:52:02 +08:00
#### Latency
Note the y-axis latency in **microsecond(μs)** not millisecond.
2019-05-31 16:37:26 +08:00
![](doc/latency-1.jpg)
2019-05-31 16:52:02 +08:00
#### Flame Graph
2019-05-31 16:37:26 +08:00
The result of Flame Graph:
![](doc/flamegraph-1.jpg)
And if you want to run the benchmark test in your machine, you should run another Nginx to listen 80 port.
```shell
curl http://127.0.0.1:2379/v2/keys/apisix/routes/1 -X PUT -d value='
{
"methods": ["GET"],
"uri": "/hello",
"id": 1,
"plugin_config": {},
"upstream": {
"type": "roundrobin",
"nodes": {
"127.0.0.1:80": 1,
"127.0.0.2:80": 1
}
}
}'
```
then run wrk:
```shell
wrk -d 60 --latency http://127.0.0.1:9080/hello
```
### Benchmark Test for reverse proxy, enabled 2 plugins
Only used APISIX as the reverse proxy server, enabled the limit rate and prometheus plugins,
and the response size was 1KB.
2019-05-31 16:52:02 +08:00
#### QPS
2019-05-31 16:37:26 +08:00
The x-axis means the size of CPU core, and the y-axis is QPS.
![](doc/benchmark-2.jpg)
2019-05-31 16:52:02 +08:00
#### Latency
Note the y-axis latency in **microsecond(μs)** not millisecond.
2019-05-31 16:37:26 +08:00
![](doc/latency-2.jpg)
2019-05-31 16:52:02 +08:00
#### Flame Graph
2019-05-31 16:37:26 +08:00
The result of Flame Graph:
![](doc/flamegraph-2.jpg)
And if you want to run the benchmark test in your machine, you should run another Nginx to listen 80 port.
```shell
curl http://127.0.0.1:2379/v2/keys/apisix/routes/1 -X PUT -d value='
{
"methods": ["GET"],
"uri": "/hello",
"id": 1,
"plugin_config": {
"limit-count": {
"count": 999999999,
"time_window": 60,
"rejected_code": 503,
"key": "remote_addr"
},
"prometheus":{}
},
"upstream": {
"type": "roundrobin",
"nodes": {
"127.0.0.1:80": 1,
"127.0.0.2:80": 1
}
}
}'
```
then run wrk:
```shell
wrk -d 60 --latency http://127.0.0.1:9080/hello
```
## Development
### How to load the plugin?
![](doc/flow-load-plugin.png)
### Plugin
![](doc/flow-plugin-internal.png)