Orange
Orange是一个基于OpenResty的API Gateway,提供API及自定义规则的监控和管理,如访问统计、流量切分、API重定向、WEB防火墙等功能。它有以下特性:
配置项支持文件存储和MySQL存储(0.2.0版本开始将去除文件支持)
通过MySQL存储来简单支持集群部署
支持多种条件匹配和变量提取
支持通过自定义插件方式扩展功能
-
默认内置六个插件
全局状态统计
自定义监控
URL重写
URI重定向
简单防火墙
代理、ABTesting、分流
提供管理界面用于管理内置插件
以restful形式完全开放API
Github: https://github.com/sumory/orange
Screenshots
安装说明
安装OpenResty1.9.7.3+
安装lor,Orange要求的lor最低版本为0.1.0
-
Orange使用的uuid生成器,依赖libuuid.so, centos可通过以下命令安装,其他linux发行版请自行google
yum install libuuid-devel
-
安装Orange
git clone https://github.com/sumory/orange cd orange #查看并根据需要修改`orange.conf` { "plugins": [//默认的可用插件,若不需要删除即可 "stat", "monitor", "redirect", "rewrite", "waf", "divide" ], "store": "mysql", //存储方式:`mysql` "store_mysql": { //使用`mysql`存储时的配置,需要导入install/${对应版本}.sql到数据库中 "timeout": 5000, "connect_config": { "host": "127.0.0.1", "port": 3306, "database": "orange", "user": "root", "password": "", "max_packet_size": 1048576 }, "pool_config": { "max_idle_timeout": 10000, "pool_size": 3 }, "desc":"mysql configuration" } } #修改conf/nginx.conf里的一些配置,如 # `resolver`,用于DNS解析 # 各日志目录等 # 各lua_shared_dict的大小 # 端口为9999的`server`, 这个server用于Orange的管理,请确保对该端口的访问授权,如只支持内网访问 #修改好orange.conf和conf/nginx.conf后,启动即可 sh start.sh
特别注意
现实中由于用户的业务系统多种多样,对于复杂应用,Orange并不是一个开箱即用的组件,需要调整一些配置才能集成到现有系统中。
-
Orange提供的的配置文件和示例都是最简配置,用户使用时请根据具体项目或业务需要自行调整,这些调整可能包括但不限于:
使用的各个shared dict的大小, 如ngx.shared.status
nginx.conf配置文件中各个server、location的配置及其权限控制,比如orange dashboard的server应该只对内部有权限的机器开放访问
根据不同业务而设置的不同nginx配置,如timeout、keepalive、gzip、log、connections等等
其它
Orange0.2.0版本即将发布,API已经全部开放,用户可通过默认的Dashboard管理,也可通过Restful的API进行操作。第三方SPA版的Dashboard已在开发中,届时会伴随0.2.0一起发布。