2019-10-31 09:27:28 +08:00
<!--
#
# Licensed to the Apache Software Foundation (ASF) under one or more
# contributor license agreements. See the NOTICE file distributed with
# this work for additional information regarding copyright ownership.
# The ASF licenses this file to You under the Apache License, Version 2.0
# (the "License"); you may not use this file except in compliance with
# the License. You may obtain a copy of the License at
#
# http://www.apache.org/licenses/LICENSE-2.0
#
# Unless required by applicable law or agreed to in writing, software
# distributed under the License is distributed on an "AS IS" BASIS,
# WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
# See the License for the specific language governing permissions and
# limitations under the License.
#
-->
2019-11-24 21:15:39 +08:00
[Chinese ](README_CN.md )
2019-06-06 12:39:49 +08:00
## APISIX
2019-10-30 10:45:09 +08:00
[![Build Status ](https://travis-ci.org/apache/incubator-apisix.svg?branch=master )](https://travis-ci.org/apache/incubator-apisix)
[![License ](https://img.shields.io/badge/License-Apache%202.0-blue.svg )](https://github.com/apache/incubator-apisix/blob/master/LICENSE)
2019-05-06 10:14:39 +08:00
2019-06-06 14:40:04 +08:00
- **QQ group**: 552030619
2019-11-02 08:44:15 +08:00
- Mail list: Mail to dev-subscribe@apisix.apache.org, follow the reply to subscribe the mail list.
2019-07-03 14:47:05 +08:00
- [![Twitter ](https://img.shields.io/twitter/follow/apisixfast.svg?style=social&label=Follow )](https://twitter.com/intent/follow?screen_name=apisixfast)
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-11-02 09:05:38 +08:00
APISIX is based on Nginx 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-13 12:34:43 +08:00
## Why APISIX?
2019-07-06 16:49:06 +08:00
2019-06-13 12:34:43 +08:00
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.
2019-12-06 14:48:50 +08:00
APISIX is a cloud-based microservices API gateway that handles traditional north-south traffic and handles east-west traffic between services, and can also be used as a k8s ingress controller.
2019-06-13 12:34:43 +08:00
2019-11-04 10:21:33 +08:00
APISIX provides dynamic load balancing, authentication, rate limiting, other plugins through plugin mechanisms, and supports plugins you develop yourself.
2019-06-13 12:34:43 +08:00
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-30 22:06:01 +08:00
![](doc/images/apisix.png)
## Features
2019-07-06 16:49:06 +08:00
2019-11-02 09:05:38 +08:00
- **Run Environment**: Both OpenResty and Tengine are supported.
2019-08-01 11:29:22 +08:00
- **Cloud-Native**: Platform agnostic, No vendor lock-in, APISIX can run from bare-metal to Kubernetes.
2019-10-15 18:36:39 +08:00
- **[Hot Updates And Hot Plugins](doc/plugins.md)**: Continuously updates its configurations and plugins without restarts!
2019-07-25 00:34:26 +08:00
- **Dynamic Load Balancing**: Round-robin load balancing with weight.
- **Hash-based Load Balancing**: Load balance with consistent hashing sessions.
2019-09-07 21:12:46 +08:00
- **[SSL](doc/https.md)**: Dynamically load an SSL certificate.
2019-09-16 13:03:26 +08:00
- **HTTP(S) Forward Proxy**
2019-08-04 14:10:17 +08:00
- **[Health Checks](doc/health-check.md)**: Enable health check on the upstream node, and will automatically filter unhealthy nodes during load balancing to ensure system stability.
2019-08-01 11:29:22 +08:00
- **Circuit-Breaker**: Intelligent tracking of unhealthy upstream services.
2019-09-26 15:06:17 +08:00
- **Authentications**: [key-auth ](doc/plugins/key-auth.md ), [JWT ](doc/plugins/jwt-auth.md )
2019-08-01 11:29:22 +08:00
- **[Limit-req](doc/plugins/limit-req.md)**
- **[Limit-count](doc/plugins/limit-count.md)**
- **[Limit-concurrency](doc/plugins/limit-conn.md)**
2019-10-09 15:10:16 +08:00
- **[Proxy Rewrite](doc/plugins/proxy-rewrite.md)**: Support for rewriting the `host` , `uri` , `schema` , `enable_websocket` , `headers` information upstream of the request.
2019-09-18 11:47:11 +08:00
- **OpenTracing: [support Apache Skywalking and Zipkin ](doc/plugins/zipkin.md )**
2019-09-12 13:27:18 +08:00
- **Monitoring And Metrics**: [Prometheus ](doc/plugins/prometheus.md )
2019-11-01 10:09:01 +08:00
- **[gRPC proxy](doc/grpc-proxy.md)**: Proxying gRPC traffic.
2019-08-22 10:46:57 +08:00
- **[gRPC transcoding](doc/plugins/grpc-transcoding.md)**: Supports protocol transcoding so that clients can access your gRPC API by using HTTP/JSON.
2019-08-26 13:10:15 +08:00
- **[Serverless](doc/plugins/serverless.md)**: Invoke functions in each phase in APISIX.
2019-08-01 12:51:28 +08:00
- **Custom plugins**: Allows hooking of common phases, such as `rewrite` , `access` , `header filer` , `body filter` and `log` , also allows to hook the `balancer` stage.
- **Dashboard**: Built-in dashboard to control APISIX.
2019-08-22 10:46:57 +08:00
- **Version Control**: Supports rollbacks of operations.
2019-08-01 11:29:22 +08:00
- **CLI**: start\stop\reload APISIX through the command line.
2019-06-30 22:06:01 +08:00
- **REST API**
2019-08-30 10:27:39 +08:00
- **Proxy Websocket**
2019-11-21 21:49:53 +08:00
- **[Response Rewrite](doc/plugins/response-rewrite.md)**: Set customized response status code, body and header to the client.
2019-09-05 00:03:46 +08:00
- **IPv6**: Use IPv6 to match route.
2019-08-23 10:19:23 +08:00
- **Clustering**: APISIX nodes are stateless, creates clustering of the configuration center, please refer to [etcd Clustering Guide ](https://github.com/etcd-io/etcd/blob/master/Documentation/v2/clustering.md ).
2019-08-30 10:27:39 +08:00
- **Scalability**: plug-in mechanism is easy to extend.
2019-08-04 14:10:17 +08:00
- **High performance**: The single-core QPS reaches 24k with an average delay of less than 0.6 milliseconds.
2019-07-15 13:14:07 +08:00
- **Anti-ReDoS(Regular expression Denial of Service)**
2019-09-12 13:27:18 +08:00
- **IP Whitelist/Blacklist**
2019-09-09 11:01:24 +08:00
- **IdP**: Support external authentication services, such as Auth0, okta, etc., users can use this to connect to Oauth2.0 and other authentication methods.
2019-09-09 17:42:20 +08:00
- **[Stand-alone mode](doc/stand-alone.md)**: Supports to load route rules from local yaml file, it is more friendly such as under the kubernetes(k8s).
2019-09-12 13:27:18 +08:00
- **Global Rule**: Allows to run any plugin for all request, eg: limit rate, IP filter etc.
2019-09-16 14:53:03 +08:00
- **[TCP/UDP Proxy](doc/stream-proxy.md)**: Dynamic TCP/UDP proxy.
2019-09-16 13:03:26 +08:00
- **[Dynamic MQTT Proxy](doc/plugins/mqtt-proxy.md)**: Supports to load balance MQTT by `client_id` , both support MQTT [3.1.* ](http://docs.oasis-open.org/mqtt/mqtt/v3.1.1/os/mqtt-v3.1.1-os.html ), [5.0 ](https://docs.oasis-open.org/mqtt/mqtt/v5.0/mqtt-v5.0.html ).
2019-08-19 13:59:47 +08:00
2019-10-23 15:14:55 +08:00
## Installation
2019-05-28 16:26:30 +08:00
2019-11-02 09:05:38 +08:00
APISIX Installed and tested in the following systems(OpenResty MUST >= 1.15.8.1, or Tengine >= 2.3.2):
2019-09-11 15:22:18 +08:00
2019-11-25 13:09:32 +08:00
CentOS 7, Ubuntu 16.04, Ubuntu 18.04, Debian 9, Debian 10, macOS, **ARM64** Ubuntu 18.04
2019-06-04 19:54:45 +08:00
2019-11-25 13:09:32 +08:00
Steps to install APISIX:
2019-11-27 21:55:56 +08:00
1. Installation runtime dependencies: OpenResty and etcd, refer to [documentation ](doc/install-dependencies.md )
2019-11-25 13:09:32 +08:00
2. There are several ways to install Apache APISIX:
2019-11-27 21:55:56 +08:00
- [Source Release ](doc/how-to-build.md#installation-via-source-release )
2019-11-25 13:09:32 +08:00
- [RPM package ](doc/how-to-build.md#installation-via-rpm-package-centos-7 ) for CentOS 7
- [Luarocks ](doc/how-to-build.md#installation-via-luarocks-macos-not-supported )
- [Docker ](https://github.com/apache/incubator-apisix-docker )
2019-07-05 19:01:20 +08:00
2019-05-28 16:26:30 +08:00
## Quickstart
2019-06-04 17:00:37 +08:00
1. start server:
2019-07-06 16:49:06 +08:00
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-07-18 16:09:30 +08:00
Limit count plugin is a good start to try APISIX,
you can follow the [documentation of limit count ](doc/plugins/limit-count.md ).
2019-05-28 16:26:30 +08:00
2019-10-23 15:14:55 +08:00
Then you can try more [plugins ](doc/README.md#plugins ).
2019-05-28 16:26:30 +08:00
2019-08-07 15:26:53 +08:00
## Dashboard
2019-11-26 21:24:45 +08:00
APISIX has built-in support for dashboards, as follows:
2019-11-27 21:55:56 +08:00
- Download the source code of [dashboard ](https://github.com/apache/incubator-apisix-dashboard ):
2019-11-26 21:24:45 +08:00
```
git clone https://github.com/apache/incubator-apisix-dashboard.git
```
2019-09-03 13:32:41 +08:00
2019-11-26 21:24:45 +08:00
- Install dependencies and compile
```
yarn install
yarn run build: prod
```
2019-08-07 15:26:53 +08:00
2019-11-26 21:24:45 +08:00
- Integration with APISIX
Copy the compiled files to the apisix / dashboard directory,
open `http://127.0.0.1:9080/apisix/dashboard/` with a browser and try it.
2019-08-07 15:26:53 +08:00
Do not need to fill the user name and password, log in directly.
2019-09-12 10:56:47 +08:00
Dashboard allow any remote IP by default, and you can modify `allow_admin` in `conf/config.yaml` by yourself, to list the list of IPs allowed to access.
2019-06-30 22:06:01 +08:00
2019-11-26 21:24:45 +08:00
We provide an online dashboard [demo version ](http://apisix.iresty.com ), make it easier for you to understand APISIX.
2019-05-31 16:37:26 +08:00
## Benchmark
2019-07-06 16:49:06 +08:00
2019-11-25 13:09:32 +08:00
Using AWS's 8 core server, APISIX's QPS reach to 140,000 with a latency of only 0.2 ms.
2019-06-06 14:40:04 +08:00
2019-11-25 13:09:32 +08:00
## Document
[Documents of Apache APISIX ](doc/README.md )
2019-07-18 07:48:41 +08:00
2019-10-30 16:22:03 +08:00
## Videos And Articles
2019-07-31 22:42:17 +08:00
2019-11-25 13:09:32 +08:00
- 2019.10.30 [Introduction to Apache APISIX Microservice Gateway Extreme Performance Architecture(Chinese) ](https://www.upyun.com/opentalk/440.html )
- 2019.8.31 [APISIX technology selection, testing and continuous integration(Chinese) ](https://www.upyun.com/opentalk/433.html )
- 2019.8.31 [APISIX high performance practice 2(Chinese) ](https://www.upyun.com/opentalk/437.html )
- 2019.7.6 [APISIX high performance practice(Chinese) ](https://www.upyun.com/opentalk/429.html )
2019-07-31 22:42:17 +08:00
2019-09-18 15:08:52 +08:00
## Who Uses APISIX?
2019-11-25 13:09:32 +08:00
A wide variety of companies and organizations use APISIX for research, production and commercial product, including:
2019-11-26 21:24:45 +08:00
1. dasouche 大搜车 https://www.dasouche.com/
1. ehomepay 理房通 https://www.ehomepay.com.cn/
1. haieruplus.com 海尔优家 http://haieruplus.com/
1. HelloTalk, Inc. https://www.hellotalk.com/
1. ke.com 贝壳找房 https://www.ke.com/
1. Meizu 魅族 https://www.meizu.com/
1. NASA JPL 美国国家航空航天局 喷气推进实验室 https://www.jpl.nasa.gov
1. Netease 网易 http://www.163.com
1. taikang.com 泰康云 http://taikang.com/
1. tangdou.com 糖豆网 http://www.tangdou.com/
1. Tencent Cloud 腾讯云 https://cloud.tencent.com/
1. Xin 优信二手车 https://www.xin.com/
1. zuzuche 租租车 https://www.zuzuche.com/
2019-09-18 15:08:52 +08:00
Users are encouraged to add themselves to the [Powered By ](doc/powered-by.md ) page.
2019-07-18 16:09:30 +08:00
## Landscape
2019-11-25 13:09:32 +08:00
< p align = "left" >
< img src = "https://landscape.cncf.io/images/left-logo.svg" width = "150" > < img src = "https://landscape.cncf.io/images/right-logo.svg" width = "200" >
< br / > < br / >
APISIX enriches the < a href = "https://landscape.cncf.io/category=api-gateway&format=card-mode&grouping=category" >
CNCF API Gateway Landscape.< / a >
< / p >
2019-08-07 13:12:40 +08:00
2019-06-06 14:38:55 +08:00
## Contributing
2019-07-06 16:49:06 +08:00
2019-09-09 11:01:24 +08:00
See [CONTRIBUTING ](Contributing.md ) for details on submitting patches and the contribution workflow.
2019-06-04 15:20:41 +08:00
2019-06-06 14:38:55 +08:00
## Acknowledgments
2019-07-06 16:49:06 +08:00
2019-07-04 21:17:33 +08:00
inspired by Kong and Orange.