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)
2019-05-28 16:26:30 +08:00
[![License ](https://img.shields.io/badge/License-Apache%202.0-blue.svg )](https://github.com/iresty/apisix/blob/master/LICENSE)
2019-05-06 10:14:39 +08:00
2019-05-28 16:26:30 +08:00
APISIX is a cloud-native microservices API gateway, delivering the ultimate performance, security, open source and scalable platform for all your APIs and microservices.
2019-05-06 10:14:39 +08:00
2019-05-28 16:26:30 +08:00
## Summary
- [**Install** ](#install )
- [**Quickstart** ](#quickstart )
- [**Distributions** ](#distributions )
2019-05-31 16:37:26 +08:00
- [**Benchmark** ](#benchmark )
2019-05-28 16:26:30 +08:00
- [**Development** ](#development )
2019-05-20 11:07:03 +08:00
2019-05-28 16:26:30 +08:00
## Install
2019-06-02 20:46:52 +08:00
### Dependencies
2019-05-28 16:40:07 +08:00
2019-05-28 16:26:30 +08:00
- 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
2019-05-28 16:26:30 +08:00
```shell
2019-05-30 17:49:15 +08:00
wget http://39.97.63.215/download/apisix-0.1-2.noarch.rpm
2019-05-28 16:26:30 +08:00
sudo rpm -ivh apisix-0.1-2.noarch.rpm
```
2019-05-20 11:07:03 +08:00
2019-05-28 16:26:30 +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
2019-05-28 16:26:30 +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 APISIX’ s 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.
2019-05-30 15:47:10 +08:00
* [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
2019-05-28 16:26:30 +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
2019-05-30 17:49:15 +08:00
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
}
}
}'
2019-05-28 16:26:30 +08:00
```
```shell
2019-05-30 17:49:15 +08:00
$ 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
...
2019-05-28 16:26:30 +08:00
```
## Distributions
- Docker: TODO
2019-06-02 20:46:52 +08:00
- LuaRocks: luarocks install apisix
2019-05-28 16:26:30 +08:00
- 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
```
2019-05-28 16:26:30 +08:00
## Development
### How to load the plugin?
![](doc/flow-load-plugin.png)
### Plugin
![](doc/flow-plugin-internal.png)