English | 中文
Dubbo-Go-Pixiu(官网: https://dubbo.apache.org/zh/docs3-v2/dubbo-go-pixiu/) 是一款 Dubbo 生态下的高性能 API 网关和多语言解决方案 Sidecar
Pixiu 是一款开源的 Dubbo 生态的 API 网关和 接入 dubbo 集群的语言解决方案。作为 API 网关形态, Pixiu 能接收外界的网络请求,将其转换为 dubbo 等协议请求,转发给背后集群;作为 Sidecar,Pixiu 期望可以代替代理服务注册到 Dubbo 集群,让多语言服务接入 Dubbo 集群提供更快捷的解决方案
- go 1.17或者更高
- docker或者docker-desktop
你可以在 https://github.com/apache/dubbo-go-pixiu-samples 中找到所有有关 pixiu 功能的案例,可以按照如下的步骤进行操作。
git clone https://github.com/apache/dubbo-go-pixiu-samples.git
go get github.com/apache/[email protected]
cd dubbogo/simple
可以使用 start.sh 脚本快速启动案例项目,可以执行如下命令来获得更多信息
./start.sh [action] [project]
./start.sh help
下列步骤中,我们将启动简单代理[direct]案例项目
使用 start.sh 的 prepare 命令来准备配置文件和外部docker依赖
./start.sh prepare direct
如果想要手动准备文件,需要注意:
- 将 conf.yaml 中的 $PROJECT_DIR 修改为本地绝对路径
./start.sh startServer direct
./start.sh startPixiu direct
使用下列命令来手动启动 pixiu
go run cmd/pixiu/*.go gateway start -c /[absolute-path]/dubbo-go-pixiu/samples/dubbogo/simple/direct/pixiu/conf.yaml
如果希望启用wasm ,使用下列命令来手动启动 pixiu
go build -tags wasm -o pixiu cmd/pixiu/*.go
手动编译并启动pixiu:
go build cmd/pixiu/*.go
./pixiu gateway start -c /[absolute-path]/dubbo-go-pixiu/samples/dubbogo/simple/direct/pixiu/conf.yaml
可以使用 curl 或者执行单元测试来验证一下
curl http://localhost:8883/UserService/com.dubbogo.pixiu.UserService/GetUserByCode \
-H "x-dubbo-http1.1-dubbo-version:1.0.0" -H "x-dubbo-service-protocol:dubbo" \
-H "x-dubbo-service-version:1.0.0" -H "x-dubbo-service-group:test" \
-H "Content-Type:application/json" \
-d '[1]'
curl http://localhost:8883/UserService/com.dubbogo.pixiu.UserService/UpdateUserByName \
-H "x-dubbo-http1.1-dubbo-version:1.0.0" -H "x-dubbo-service-protocol:dubbo" \
-H "x-dubbo-service-version:1.0.0" -H "x-dubbo-service-group:test" \
-H "Content-Type:application/json" \
-d '["tc",{"id":"0002","code":1,"name":"tc","age":15}]'
curl http://localhost:8883/UserService/com.dubbogo.pixiu.UserService/GetUserByCode \
-H "x-dubbo-http1.1-dubbo-version:1.0.0" -H "x-dubbo-service-protocol:dubbo" \
-H "x-dubbo-service-version:1.0.0" -H "x-dubbo-service-group:test" \
-H "Content-Type:application/json" \
-d '[1]'
./start.sh startTest body
./start.sh clean direct
docker pull dubbogopixiu/dubbo-go-pixiu:latest
docker run --name pixiu-gateway -p 8888:8888 \
-v /yourpath/conf.yaml:/etc/pixiu/conf.yaml \
-v /yourpath/log.yml:/etc/pixiu/log.yml \
dubbogopixiu/dubbo-go-pixiu:latest
- 多协议支持:目前已支持 Http、Dubbo2、Triple、gRPC 协议代理和转换,其他协议持续集成中
- 安全认证:支持 HTTPS、JWT Token 校验等安全认证措施
- 注册中心集成:支持从 Dubbo 或 Spring Cloud 集群中获取服务元数据,支持 ZK、Nacos 注册中心
- 流量治理:集成 sentinel,支持多种协议限流
- 可观测性:集成 opentelemetry 和 jaeger,便于进行分布式链路追踪
- 自持 admin 和可视化界面:拥有 pixiu-admin 进行远程管理和可视化
Pixiu 控制面是 frok 自 istio v1.14.3 版本。提供包括服务发现、流量管理、安全等多种能力。
项目在快速迭代中,欢迎使用, 欢迎给出建议或者提交pr。
官方钉钉群(31203920):
We welcome the friends who can give us constructing suggestions instead of known-nothing.
Apache License, Version 2.0