2019-06-06 12:39:49 +08:00
## APISIX
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-06-06 14:40:04 +08:00
- **QQ group**: 552030619
2019-06-06 14:38:55 +08:00
## What's APISIX?
2019-05-06 10:14:39 +08:00
2019-06-06 14:38:55 +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-06-05 17:28:50 +08:00
2019-06-13 12:34:43 +08:00
APISIX is based on OpenResty and etcd. Compared with traditional API gateways, APISIX has dynamic routing and plug-in hot loading, which is especially suitable for API management under micro-service system.
2019-06-06 14:57:09 +08:00
[中文简介 ](README_CN.md )
2019-05-20 11:07:03 +08:00
2019-06-13 12:34:43 +08:00
## Why APISIX?
If you are building a website, mobile device or IoT (Internet of Things) application, you may need to use an API gateway to handle interface traffic.
APISIX is a cloud-based microservices API gateway that handles traditional north-south traffic and handles east-west traffic between services.
APISIX provides dynamic load balancing, authentication, rate limiting, and other plugins through plugin mechanisms, and supports plugins you develop yourself.
2019-06-15 10:50:00 +08:00
![](doc/images/apisix.jpg)
2019-06-13 12:37:06 +08:00
For more detailed information, see the [White Paper ](https://www.iresty.com/download/Choosing%20the%20Right%20Microservice%20API%20Gateway%20for%20the%20Enterprise%20User.pdf ).
2019-06-13 12:34:43 +08:00
2019-06-17 11:59:31 +08:00
## Plugins
Now we support the following plugins:
* [dynamic load balancing ](#Plugins ): load balance traffic across multiple upstream services, supports round-robin and consistent hash algorithms.
* [key-auth ](lua/apisix/plugins/key-auth.md ): user authentication based on Key Authentication.
* [limit-count ](lua/apisix/plugins/limit-count.md ): rate limiting based on a "fixed window" implementation.
* [limit-req ](lua/apisix/plugins/limit-req.md ): request rate limiting and adjustment based on the "leaky bucket" method.
* [limit-conn ](lua/apisix/plugins/limit-conn.md ): limite request concurrency (or concurrent connections).
* [prometheus ](lua/apisix/plugins/prometheus.md ): expose metrics related to APISIX and proxied upstream services in Prometheus exposition format, which can be scraped by a Prometheus Server.
2019-05-28 16:26:30 +08:00
## Install
2019-06-05 15:25:58 +08:00
APISIX Installed and tested in the following systems:
2019-06-05 08:56:16 +08:00
2019-06-06 21:49:29 +08:00
|OS | OpenResty|Status|
|------------|-----------|------|
|CentOS 7 | 1.15.8.1|√ |
|Ubuntu 18.04| 1.15.8.1|√ |
|Debian 9 | 1.15.8.1|√ |
2019-06-04 19:54:45 +08:00
You now have two ways to install APISIX: if you are using CentOS 7, it is recommended to use RPM, other systems please use Luarocks.
2019-06-04 17:58:01 +08:00
We will add support for Docker and more OS shortly.
2019-05-28 16:40:07 +08:00
2019-06-04 19:54:45 +08:00
### Install from RPM for CentOS 7
```shell
sudo yum install yum-utils
sudo yum-config-manager --add-repo https://openresty.org/package/centos/openresty.repo
sudo yum install -y openresty etcd
sudo service etcd start
2019-06-05 12:17:28 +08:00
sudo yum install -y https://github.com/iresty/apisix/releases/download/v0.4/apisix-0.4-0.el7.noarch.rpm
2019-06-04 19:54:45 +08:00
```
2019-06-05 06:59:04 +08:00
2019-06-04 19:54:45 +08:00
You can try APISIX with the [**Quickstart** ](#quickstart ) now.
### Install from Luarocks
#### Dependencies
2019-06-05 06:59:04 +08:00
2019-06-05 15:25:58 +08:00
APISIX is based on [OpenResty ](https://openresty.org/ ), the configures data storage and distribution via [etcd ](https://github.com/etcd-io/etcd ).
2019-06-05 06:59:04 +08:00
2019-06-05 15:25:58 +08:00
We recommend that you use [luarocks ](https://luarocks.org/ ) to install APISIX, and for different operating systems have different dependencies, see more: [Install Dependencies ](https://github.com/iresty/apisix/wiki/Install-Dependencies )
2019-05-28 16:26:30 +08:00
2019-06-05 15:25:58 +08:00
#### Install APISIX
2019-06-02 20:46:52 +08:00
```shell
2019-06-04 17:43:46 +08:00
sudo luarocks install apisix
2019-06-02 20:46:52 +08:00
```
2019-06-04 17:58:01 +08:00
If all goes well, you will see the message like this:
> apisix is now built and installed in /usr (license: Apache License 2.0)
Congratulations, you have already installed APISIX successfully.
2019-05-20 11:07:03 +08:00
2019-06-17 11:59:31 +08:00
#### Install APISIX Development Environment
If you are a developer, you can set up a local development environment with the following commands.
```shell
git clone git@github.com:iresty/apisix.git
cd apisix
make dev
```
If all goes well, you will see this message at the end:
> Stopping after installing dependencies for apisix
The following is the expected development environment directory structure:
```shell
$ tree -L 2 -d apisix
apisix
├── bin
├── conf
├── deps # dependent Lua and dynamic libraries
│ ├── lib64
│ └── share
├── doc
│ └── images
├── lua
│ └── apisix
├── t
│ ├── admin
│ ├── core
│ ├── lib
│ ├── node
│ └── plugin
└── utils
```
2019-05-28 16:26:30 +08:00
## Quickstart
2019-06-04 17:00:37 +08:00
1. start server:
2019-05-28 16:26:30 +08:00
```shell
2019-06-04 17:00:37 +08:00
sudo apisix start
2019-05-28 16:26:30 +08:00
```
2019-06-04 17:00:37 +08:00
2. try limit count plugin
2019-05-28 16:26:30 +08:00
2019-06-04 17:00:37 +08:00
For the convenience of testing, we set up a maximum of 2 visits in 60 seconds,
and return 503 if the threshold is exceeded:
2019-05-28 16:26:30 +08:00
```shell
2019-06-18 09:40:00 +08:00
curl http://127.0.0.1:9080/apisix/admin/routes/1 -X PUT -d '
2019-05-30 17:49:15 +08:00
{
2019-06-18 09:40:00 +08:00
"uri": "/index.html",
"plugins": {
"limit-count": {
"count": 2,
"time_window": 60,
"rejected_code": 503,
"key": "remote_addr"
}
},
"upstream": {
"type": "roundrobin",
"nodes": {
"39.97.63.215:80": 1
}
}
2019-05-30 17:49:15 +08:00
}'
2019-05-28 16:26:30 +08:00
```
```shell
2019-06-03 17:36:53 +08:00
$ curl -i http://127.0.0.1:9080/index.html
2019-06-03 17:39:24 +08:00
HTTP/1.1 200 OK
Content-Type: text/html
Content-Length: 13175
2019-05-30 17:49:15 +08:00
Connection: keep-alive
X-RateLimit-Limit: 2
2019-06-03 17:39:24 +08:00
X-RateLimit-Remaining: 1
Server: APISIX web server
Date: Mon, 03 Jun 2019 09:38:32 GMT
Last-Modified: Wed, 24 Apr 2019 00:14:17 GMT
ETag: "5cbfaa59-3377"
Accept-Ranges: bytes
2019-05-30 17:49:15 +08:00
...
2019-05-28 16:26:30 +08:00
```
2019-05-31 16:37:26 +08:00
## Benchmark
2019-06-06 14:38:55 +08:00
Using Google Cloud's 4 core server, APISIX's QPS reach to 60,000 with a latency of only 500 microseconds.
2019-06-06 14:40:04 +08:00
2019-06-06 14:38:55 +08:00
You can view the [benchmark documentation ](doc/benchmark.md ) for more detailed information.
2019-06-05 09:31:32 +08:00
2019-06-06 14:38:55 +08:00
## Documentation
English Development Documentation: TODO
2019-06-06 14:40:04 +08:00
2019-06-06 14:38:55 +08:00
[中文开发文档 ](doc/architecture-design-cn.md )
2019-05-28 16:26:30 +08:00
2019-06-06 14:38:55 +08:00
## Contributing
Contributions are welcomed and greatly appreciated.
2019-06-04 15:20:41 +08:00
2019-06-06 14:38:55 +08:00
## Acknowledgments
2019-06-04 15:20:41 +08:00
inspired by Kong