apache/shenyu-nginx
Fork: 15 Star: 23 (更新于 1970-01-01 00:00:00)
license: Apache-2.0
Language: Lua .
Apache ShenYu Nginx.
最后发布版本: 1.0.0-1 ( 2022-11-03 22:28:02)
Apache ShenYu Nginx Module
This module provided SDK to watch available ShenYu instance list as upstream nodes by Service Register Center for OpenResty.
In the cluster mode, Apache ShenYu supports the deployment of multiple ShenYu instances, which may have new instances joining or leaving at any time. Hence, Apache ShenYu introduces Service Discovery modules to help client to detect the available instances. Currently, Apache ShenYu Bootstrap already supports Apache Zookeeper, Nacos, Etcd, and consul. Client or LoadBalancer can get the available ShenYu instances by those Service register center.
Here provides a completed examples.
=======
Here is a completed example working with ETCD.
Here is a completed example working with Nacos.
Here is a completed example working with Consul.
Here is a completed example working with Zookeeper.
Getting Started
- Prerequisite:
- Luarocks
- OpenResty
Build from source
The first, clone the source from GitHub.
git clone https://github.com/apache/shenyu-nginx
Then, build from source and install.
cd shenyu-nginx
luarocks make rockspec/shenyu-nginx-1.0.0-2.rockspec
Greeting ETCD
Modify the Nginx configure, create and initialize the ShenYu Register to connect to the target register center. The module will fetch the all of ShenYu instances which are registered to Etcd in the same cluster. It works like Etcd client to watch(based on long polling) ShenYu instance lists.
Here is an example for Etcd.
init_worker_by_lua_block {
local register = require("shenyu.register.etcd")
register.init({
balancer_type = "chash",
etcd_base_url = "http://127.0.0.1:2379",
})
}
-
balancer_type
specify the balancer. It has supportedchash
andround robin
. -
etcd_base_url
specify the Etcd server.(Currently, authentication is not supported.)
Add an upstream block
for ShenYu and enable to update upstream servers dynamically. This case will synchronize the ShenYu instance list with register center.
And then pick one up for handling the request.
upstream shenyu {
server 0.0.0.1; -- bad
balancer_by_lua_block {
require("shenyu.register.etcd").pick_and_set_peer()
}
}
Greeting Nacos
Modify the Nginx configure, create and initialize the ShenYu Register to connect to target register center. Here is an example for Nacos.
init_worker_by_lua_block {
local register = require("shenyu.register.nacos")
register.init({
shenyu_storage = ngx.shared.shenyu_storage,
balancer_type = "chash",
nacos_base_url = "http://127.0.0.1:8848",
username = "nacos",
password = "naocs",
})
}
-
balancer_type
specify the balancer. It has supportedchash
andround robin
. -
nacos_base_url
specify the Nacos server address. -
username
specify the username to log in Nacos. (it is only required when Nacos auth enable) -
password
specify the password to log in Nacos.
Modify the upstream
to enable to update upstream servers dynamically. This case will synchronize the ShenYu instance list with register center.
And then pick one up for handling the request.
upstream shenyu {
server 0.0.0.1; -- bad
balancer_by_lua_block {
require("shenyu.register.nacos").pick_and_set_peer()
}
}
Greeting Zookeeper
Modify the Nginx configure, create and initialize the ShenYu register to connect to target register center. Listen for changes to the node via the zookeeper watch event. Here is an example of the zookeeper configuration.
init_worker_by_lua_block {
local register = require("shenyu.register.zookeeper")
register.init({
servers = {"127.0.0.1:2181","127.0.0.1:2182"},
shenyu_storage = ngx.shared.shenyu_storage,
balancer_type = "roundrobin"
});
}
-
servers
zookeeper cluster address. -
balancer_type
specify the balancer. It has supportedchash
andround robin
.
Modify the upstream to enable to update upstream servers dynamically. This case will synchronize the ShenYu instance list with register center. And then pick one up for handling the request.
upstream shenyu {
server 0.0.0.1;
balancer_by_lua_block {
require("shenyu.register.zookeeper").pick_and_set_peer()
}
}
Greeting Consul
Modify the Nginx configure, create and initialize the ShenYu register to connect to target register center. Listen for changes to the node via the consul watch event. Here is an example of the consul configuration.
init_worker_by_lua_block {
local register = require "shenyu.register.consul";
register.init({
uri = "http://127.0.0.1:8500",
path = "/v1/catalog/service/demo",
shenyu_storage = ngx.shared.shenyu_storage,
balancer_type = "chash",
})
}
-
balancer_type
specify the balancer. It has supportedchash
andround robin
. -
uri
consul server address. -
path
path of service.
Modify the upstream to enable to update upstream servers dynamically. This case will synchronize the ShenYu instance list with register center. And then pick one up for handling the request.
upstream shenyu {
server 0.0.0.1;
balancer_by_lua_block {
require("shenyu.register.consul").pick_and_set_peer()
}
}
Finally
Finally, restart OpenResty.
openresty -s reload
Contributor and Support
License
最近版本更新:(数据更新于 1970-01-01 00:00:00)
2022-11-03 22:28:02 1.0.0-1
主题(topics):
nginx, shenyu
apache/shenyu-nginx同语言 Lua最近更新仓库
2025-01-16 22:10:34 kenzok8/small
2025-01-15 16:23:17 xiaorouji/openwrt-passwall
2025-01-15 06:44:56 LazyVim/LazyVim
2025-01-08 01:48:46 xiaorouji/openwrt-passwall2
2024-12-29 12:57:15 opq-osc/OPQ
2024-12-23 18:41:23 olimorris/codecompanion.nvim