- fix: use luajit by default when run apisix #3335
- feat: use luasocket instead of curl in etcd.lua #2965
- π feat: support to communicate with etcd by TLS without verification in command line #3415
- π feat: chaos test on route could still works when etcd is down #3404
- π feat: ewma use p2c to improve performance #3300
- π feat: support specifying https in upstream to talk with https backend #3430
- π feat: allow customizing lua_package_path & lua_package_cpath #3417
- π feat: allow to pass SNI in HTTPS proxy #3420
- π feat: support gRPCS #3411
- π feat: allow getting upstream health check status via control API #3345
- π feat: support dubbo #3224
- π feat: load balance by least connections #3304
- π feat: kafka-logger implemented reuse kafka producer #3429
- π feat(authz-keycloak): dynamic scope and resource mapping. #3308
- π feat: proxy-rewrite host support host with port #3428
- π feat(fault-injection): support conditional fault injection using nginx variables #3363
- fix(standalone): require consumer's id to be the same as username #3394
- fix: support upstream_id & consumer with grpc #3387
- fix: set conf info when global rule is hit without matched rule #3332
- fix: avoid caching outdated discovery upstream nodes #3295
- fix: create the health checker in
access
phase #3240 - fix: make set_more_retries() work when upstream_type is chash #2676
For more changes, please refer to Milestone
- disable node-status plugin by default #2968
- k8s_deployment_info is no longer allowed in upstream #3098
- don't treat route segment with ':' as parameter by default #3154
- π allow create consumers with multiple auth plugins #2898
- π increase the delay before resync etcd #2977
- π support enable/disable route #2943
- π route according to the graphql attributes #2964
- π share etcd auth token #2932
- π add control API #3048
- π feat(limt-count): use 'remote_addr' as default key #2927
- π feat(fault-injection): support Nginx variable in abort.body #2986
- π
feat: implement new plugin
server-info
#2926 - π feat: add batch process metrics #3070
- π feat: Implement traffic splitting plugin #2935
- π feat: the proxy-rewrite plugin support pass nginx variable within header #3144
- π feat: Make headers to add to request in openid-connect plugin configurable #2903
- π feat: support var in upstream_uri on proxy-rewrite plugin #3139
- basic-auth plugin should run in rewrite phases. #2905
- fixed the non effective config update in http/udp-logger #2901
- always necessary to save the data of the limit concurrency, and release the statistical status in the log phase #2465
- avoid duplicate auto-generated id #3003
- fix: ctx being contaminated due to a new feature of openresty 1.19. For openresty 1.19 users, it is recommended to upgrade the APISIX version as soon as possible. #3105
- fix: correct the validation of route.vars #3124
For more changes, please refer to Milestone
- π support ENV variable in configuration. #2743
- π support TLS connection with etcd. #2548
- generate create/update_time automatically. #2740
- add a deprecate log for enable_websocket in upstream.#2691
- add a deprecate log for consumer id.#2829
- Added
X-APISIX-Upstream-Status
header to distinguish 5xx errors from upstream or APISIX itself. #2817 - support Nginx configuration snippet. #2803
- π Upgrade protocol to support Apache Skywalking 8.0#2389. So this version only supports skywalking 8.0 protocol. This plugin is disabled by default, you need to modify config.yaml to enable, which is not backward compatible.
- π add aliyun sls logging plugin.#2169
- proxy-cache: the cache_zone field in the schema should be optional.#2776
- fix: validate plugin configuration in the DP #2856
- π fix(etcd): handle etcd compaction.#2687
- fix: move
conf/cert
tot/certs
and disable ssl by default, which is not backward compatible. #2112 - fix: check decrypt key to prevent lua thread aborted #2815
-In the 2.3 release, the consumer will only support user names and discard the id. The consumer needs to manually clean up the id field in etcd, otherwise the schema verification will report an error during use -In the 2.3 release, opening websocket on upstream will no longer be supported -In version 3.0, the data plane and control plane will be separated into two independent ports, that is, the current port 9080 will only process data plane requests, and no longer process admin API requests
For more changes, please refer to Milestone
This is release candidate.
- π Migrate from etcd v2 to v3 protocol, which is not backward compatible. Apache APISIX only supports etcd 3.4 and above versions. #2036
- add labels for upstream object.#2279
- add managed fields in json schema for resources, such as create_time and update_time.#2444
- use interceptors to protect plugin's route#2416
- support multiple ports for http and https listen.#2409
- implement
core.sleep
.#2397
- π add AK/SK(HMAC) auth plugin.#2192
- π add referer-restriction plugin.#2352
limit-count
support to useredis
cluster.#2406- feat(proxy-cache): store the temporary file under cache directory. #2317
- feat(http-logger): support for specified the log formats via admin API #2309
- π
high priority
When the data plane receives an instruction to delete a resource(router or upstream etc.), it does not properly clean up the cache, resulting in the existing resources cannot be found. This problem only occurs in the case of long and frequent deletion operations.#2168 - fix routing priority does not take effect.#2447
- set random seed for each worker process at
init_worker
phase, onlyinit
phase is not enough.#2357 - remove unsupported algorithm in jwt plugin.#2356
- return correct response code when
http_to_https
enabled in redirect plugin.#2311
For more changes, please refer to Milestone
- Fixed Admin API default access token vulnerability
- Admin API: support authentication with SSL certificates. 1747
- Admin API: support both standard
PATCH
and sub pathPATCH
. 1930 - HealthCheck: supports custom host port. 1914
- Upstream: supports turning off the default retry mechanism. 1919
- URI: supports delete the '/' at the end of the
URI
. 1766
- π Request Validator 1709
- change: nginx worker_shutdown_timeout is changed from 3s to recommended value 240s. 1883
- change: the
healthcheck
timeout time type changed frominteger
tonumber
. 1892 - change: the
request-validation
plugin input parameter supportsSchema
validation. 1920 - change: add comments for Makefile
install
command. 1912 - change: update comment for config.yaml
etcd.timeout
configuration. 1929 - change: add more prometheus metrics. 1888
- change: add more configuration options for
cors
plugin. 1963
- fixed: failed to get
host
in health check configuration. 1871 - fixed: should not save the runtime data of plugin into
etcd
. 1910 - fixed: run
apisix start
several times will start multi nginx processes. 1913 - fixed: read the request body from the temporary file if it was cached. 1863
- fixed: batch processor name and error return type. 1927
- fixed: failed to read redis.ttl in
limit-count
plugin. 1928 - fixed: passive health check seems never provide a healthy report. 1918
- fixed: avoid to modify the original plugin conf. 1958
- fixed: the test case of
invalid-upstream
is unstable and sometimes fails to run. 1925
- doc: added APISIX Lua Coding Style Guide. 1874
- doc: fixed link syntax in README.md. 1894
- doc: fixed image links in zh-cn benchmark. 1896
- doc: fixed typos in
FAQ
γadmin-api
γarchitecture-design
γdiscovery
γprometheus
γproxy-rewrite
γredirect
γhttp-logger
documents. 1916 - doc: added improvements for OSx unit tests and request validation plugin. 1926
- doc: fixed typos in
architecture-design
document. 1938 - doc: added the default import path of
Nginx
for unit testing inLinux
andmacOS
systems in thehow-to-build
document. 1936 - doc: add
request-validation
plugin chinese document. 1932 - doc: fixed file path of
gRPC transcoding
inREADME
. 1945 - doc: fixed
uri-blocker
plugin path error inREADME
. 1950 - doc: fixed
grpc-transcode
plugin path error inREADME
. 1946 - doc: removed unnecessary configurations for
k8s
document. 1891
- Fix: multiple SSL certificates are configured, but only one certificate working fine. 1818
- π Apache Skywalking plugin 1241
- π Keycloak Identity Server Plugin 1701
- π Echo Plugin 1632
- π Consume Restriction Plugin 1437
- Batch Request : Copy all headers to every request 1697
- SSL private key encryption 1678
- Improvement of docs for multiple plugins
The 1.3 version is mainly for security update.
- reject invalid header#1462 and uri safe encode#1461
- only allow 127.0.0.1 access admin API and dashboard by default. #1458
The 1.2 version brings many new features, including core and plugins.
- π support etcd cluster. #1283
- using the local DNS resolver by default, which is friendly for k8s. #1387
- support to run
header_filter
,body_filter
andlog
phases for global rules. #1364 - changed the
lua/apisix
dir toapisix
(not backward compatible). #1351 - add dashboard as submodule. #1360
- allow adding custom shared dict. #1367
- π add Apache Kafka plugin. #1312
- π add CORS plugin. #1327
- π add TCP logger plugin. #1221
- π add UDP logger plugin. 1070
- π add proxy mirror plugin. #1288
- π add proxy cache plugin. #1153
- drop websocket enable control in proxy-rewrite plugin(not backward compatible). 1332
- Adding support to public key based introspection for OAuth plugin. #1266
- response-rewrite plugin support binary data to client by base64. #1381
- plugin
grpc-transcode
supports grpc deadline. #1149 - support password auth for limit-count-redis. #1150
- Zipkin plugin add service name and report local server IP. #1386
- add
change_pwd
anduser_info
for Wolf-Rbac plugin. #1204
- π support key-based authentication for Admin API(not backward compatible). #1169
- hide SSL private key in admin API. #1240
- missing
clear
table before to reuse table (will cause memory leak). #1134 - print warning error message if the yaml route file is invalid. #1141
- the balancer IP may be nil, use an empty string instead. #1166
- plugin node-status and heartbeat don't have schema. #1249
- the plugin basic-auth needs required field. #1251
- check the count of upstream valid node. #1292
This release is mainly to strengthen the stability of the code and add more documentation.
- always specify perl include path when running test cases. #1097
- Feature: Add support for PROXY Protocol. #1113
- enhancement: add verify command to verify apisix configuration(nginx.conf). #1112
- feature: increase the default size of the core file. #1105
- feature: make the number of file is as configurable as the connections. #1098
- core: improve the core.log module. #1093
- Modify bin/apisix to support the SO_REUSEPORT. #1085
- doc: add link to download grafana meta data. #1119
- doc: Update README.md. #1118
- doc: doc: add wolf-rbac plugin. #1116
- doc: update the download link of rpm. #1108
- doc: add more english article. #1092
- Adding contribution guidelines for the documentation. #1086
- doc: getting-started.md check. #1084
- Added additional information and refactoring sentences. #1078
- Update admin-api-cn.md. #1067
- Update architecture-design-cn.md. #1065
- ci: remove patch which is no longer necessary and removed in the upst. #1090
- fix path error when install with luarocks. #1068
- travis: run a apisix instance which intalled by luarocks. #1063
- feature: Add wolf rbac plugin. #1095
- Adding UDP logger plugin. #1070
- enhancement: using internal request instead of external request in node-status plugin. #1109
This release is mainly to strengthen the stability of the code and add more documentation.
- π Support routing priority. You can match different upstream services based on conditions such as header, args, priority, etc. under the same URI. #998
- When no route is matched, an error message is returned. To distinguish it from other 404 requests. #1013
- The address of the dashboard
/apisix/admin
supports CORS. #982 - The jsonschema validator returns a clearer error message. #1011
- Upgrade the
ngx_var
module to version 0.5. #1005 - Upgrade the
lua-resty-etcd
module to version 0.8. #980 - In development mode, the number of workers is automatically adjusted to 1. #926
- Remove the nginx.conf file from the code repository. It is automatically generated every time and cannot be modified manually. #974
- Added documentation on how to customize development plugins. #909
- fixed example's bugs in the serverless plugin documentation. #1006
- Added documentation for using the Oauth plugin. #987
- Added dashboard compiled documentation. #985
- Added documentation on how to perform a/b testing. #957
- Added documentation on how to enable the MQTT plugin. #916
- Add test cases for key-auth plugin under normal circumstances. #964
- Added tests for gRPC transcode pb options. #920
This release brings many new features, such as support for running APISIX with Tengine, an advanced debugging mode that is more developer friendly, and a new URI redirection plugin.
- π Supported to run APISIX with tengine. #683
- π Enabled HTTP2 and supported to set ssl_protocols. #663
- π Advanced Debug Mode, Target module function's input arguments or returned value would be printed once this option is enabled. #614
- Support to install APISIX without dashboard. #686
- Removed router R3 #725
- Redirect URI: Redirect URI plugin. #732
- Proxy Rewrite: Supported remove
header
feature. #658 - Limit Count: Supported global limit count with
Redis Server
.#624
- lua-resty-radixtree
- Support for
host + uri
as an index.
- Support for
- lua-resty-jsonschema
- This extension is a JSON data validator that replaces the existing
lua-rapidjson
extension.
- This extension is a JSON data validator that replaces the existing
- key-auth plugin cannot run accurately in the case of multiple consumers. #826
- Exported schema for plugin serverless. #787
- Discard args of uri when using proxy-write plugin #642
- Zipkin plugin not set tracing data to request header. #715
- Skipped check cjson for luajit environment in apisix CLI. #652
- Skipped to init etcd if use local file as config center. #737
- Support more built-in parameters when set chash balancer. #775
- Replace the
lua-rapidjson
module withlua-resty-jsonschema
global,lua-resty-jsonschema
is faster and easier to compile.
Released on 2019/09/30
This release brings many new features, such as stream proxy, support MQTT protocol proxy, and support for ARM platform, and proxy rewrite plugin.
- π support stand-alone mode: using yaml to update configurations of APISIX, more friendly to kubernetes. #464
- π support stream proxy. #513
- π support consumer bind plugins. #544
- support domain name in upstream, not only IP. #522
- ignored upstream node when it's weight is 0. #536
- π
MQTT Proxy: support to load balance MQTT by
client_id
, both support MQTT 3.1 and 5.0. #513 - proxy-rewrite: rewrite uri, schema, host for upstream. #594
- π APISIX can run normally under Ubuntu 18.04 of ARM64 architecture, so you can use APISIX as IoT gateway with MQTT plugin.
- lua-resty-ipmatcher
- support IPv6
- IP white/black list, route.
- lua-resty-radixtree
- allow to specify multiple host, remote_addr and uri.
- allow to define user-function to filter request.
- use
lua-resty-ipmatcher
instead oflua-resty-iputils
,lua-resty-ipmatcher
matches fast and support IPv6.
- healthcheck: the checker name is wrong if APISIX works under multiple processes. #568
- removed
lua-tinyyaml
from source code base, and install through Luarocks.
Released on 2019/09/06
This release brings many new features, such as IP black and white list, gPRC protocol transcoding, IPv6, IdP (identity provider) services, serverless, Change the default route to radix tree (not downward compatible), and more.
- π gRPC transcoding: supports protocol transcoding so that clients can access your gRPC API by using HTTP/JSON. #395
- π radix tree router: The radix tree is used as the default router implementation. It supports the uri, host, cookie, request header, request parameters, Nginx built-in variables, etc. as the routing conditions, and supports common operators such as equal, greater than, less than, etc., more powerful and flexible.IMPORTANT: This change is not downward compatible. All users who use historical versions need to manually modify their routing to work properly. #414
- Dynamic upstream supports more parameters, you can specify the upstream uri and host, and whether to enable websocket. #451
- Support for get values from cookies directly from
ctx.var
. #449 - Routing support IPv6. #331
- π serverless: With serverless support, users can dynamically run any Lua function on a gateway node. Users can also use this feature as a lightweight plugin.#86
- π support IdP: Support external authentication services, such as Auth0, okta, etc., users can use this to connect to Oauth2.0 and other authentication methods. #447
- rate limit: Support for more restricted keys, such as
X-Forwarded-For
andX-Real-IP
, and allows users to use Nginx variables, request headers, and request parameters as keys. #228 - IP black and white list Support IP black and white list for security. #398
- Add the
version
directive to get the version number of APISIX. #420
- The
PATCH
API is supported and can be modified individually for a configuration without submitting the entire configuration. #365
- π Add the online version of the dashboardοΌusers can experience APISIX without install. #374
Released on 2019/08/05
This release brings many new features such as health check and circuit breaker, debug mode, opentracing and JWT auth. And add built-in dashboard.
- π Health Check and Circuit Breaker: Enable health check on the upstream node, and will automatically filter unhealthy nodes during load balancing to ensure system stability. #249
- Anti-ReDoS(Regular expression Denial of Service). #252
- supported debug mode. #319
- allowed to use different router. #364
- supported to match route by host + uri. #325
- allowed plugins to handler balance phase. #299
- added desc for upstream and service in schema. #289
- π OpenTracing: support Zipkin and Apache SkyWalking. #304
- JWT auth. #303
- support multiple ips of
allow
. #340 - supported real_ip configure in nginx.conf and added functions to get ip and remote ip. #236
- π add built-in dashboard. #327