Namingserver 注册中心(beta)
Namingserver 是 Seata 原生的注册中心.
预备工作
从链接下载seata的二进制压缩包
编译器运行namingserver
如果您需要本地调试或开发namingserver,请导入Seata源码,并找到namingserver
模块,在resources/application.yml
下设置namingserver启动的端口号,启动namingserver
运行namingserver
解压后进入seata-namingserver目录,打开目录下的conf/application.yml中配置namingserver启动的端口号, mac或linux运行
bin\seata-namingserver.sh
windows环境运行
bin\seata-namingserver.bat
快速上手
Seata 使用 namingserver 作为注册中心的操作步骤非常简单,分为在client端的配置以及在server端的配置
Namingserver 配置说明
server:
port: 8081 ## namingserver的端口
spring:
application:
name: seata-namingserver
logging:
config: classpath:logback-spring.xml
file:
path: ${log.home:${user.home}/logs/seata}
console: ## 2.4开始控制台从Seata-server迁移至Namingserver,故此配置为控制台相关配置
user:
username: seata ## 控制台界面,和open-api鉴权所需账号,强烈建议修改不要采用默认值
password: seata ## 控制台界面,和open-api鉴权所需密码,强烈建议修改不要采用默认值
heartbeat:
threshold: 90000 ## 当Seata-server节点非优雅下线时,摘除时间
period: 60000 ## 每60秒检查节点心跳是否正常,如果超过threshold的配置,将进行摘除
seata:
security:
secretKey: SeataSecretKey0c382ef121d778043159209298fd40bf3850a017 ## 签发token秘钥,强烈建议修改,不要采用默认值
tokenValidityInMilliseconds: 1800000 ## token过期时间
csrf-ignore-urls: /naming/v1/**,/api/v1/naming/** ## 无需csrf防护接口,采用默认值即可,因为此默认值是提供给client的open-api,不通过控制台。
ignore:
urls: /,/**/*.css,/**/*.js,/**/*.html,/**/*.map,/**/*.svg,/**/*.png,/**/*.jpeg,/**/*.ico,/api/v1/auth/login,/version.json,/naming/v1/health,/error ## 无需鉴权的相关接口
Client端配置注册中心
在 application.yml 中加入对应的注册中心。
seata:
registry:
type: seata
seata:
server-addr: 127.0.0.1:8081 ##第一步配置的namingserver的ip+端口,若有多个namingserver节点则用逗号分割
namespace: public ##命名空间
heartbeat-period: 5000 ##心跳时间
username: seata
password: seata
Server端配置注册中心
在 conf/application.yaml
加入以下配置,
其余配置参考 configuration options:
seata:
registry:
type: seata
seata:
server-addr: 127.0.0.1:8081 ##第一步配置的namingserver的ip+端口,若 有多个namingserver节点则用逗号分割
cluster: default ##集群名称
namespace: public ##命名空间
heartbeat-period: 5000 ##心跳时间
username: seata
password: seata
获取token
如果你使用idea自带的httpclient,可参考以下方式获取token
POST http://localhost:8081/api/v1/auth/login
Content-Type: application/json
{
"username": "username",
"password": "password"
}
如果你使用curl,可参考以下方式获取token
curl -X POST http://localhost:8081/api/v1/auth/login \
-H "Content-Type: application/json" \
-d '{"username": "username", "password": "password"}'
将会得到如下响应,请复制其中的data放入后续的authorization
请求头中
{
"code": "200",
"message": "success",
"data": "Bearer xxxxxxxxxx",
"success": true
}