TARS企业版本提供了命令行控制终端 tarsctl
, 来完成对框架的管理, 包括:
Usage:
bin/tarsctl help --tars=tars.conf
查看帮助 ok
bin/tarsctl adapter list --target=[App.HelloServer or App.HelloServer_192.168.0.1]
获取adapter列表
bin/tarsctl adapter servants --target=[App.HelloServer]
获取服务下的所有servant名称列表
bin/tarsctl adapter nodes --node_names=[xxx,xxx]
获取指定nodeName列表下的adapter
bin/tarsctl adapter obj --target=[App.HelloServer_192.168.0.1] --obj=[HelloObj]
根据obj获取指定的adapter
bin/tarsctl adapter delete --target=[App.HelloServer.HelloObj]
根据Obj名称删除指定的adapter
bin/tarsctl adapter update --id=[id] --node-name=[xxxx] --servant=[App.HelloServer.HelloObj] --thread-num=[xxx] --endpoint=[xxx] --max-connections=[xxx] --allow-ip=[xxx] --queuecap=[xxx] --queuetimeout=[xxx] --protocol=[tars/not_tars]
编辑servant:
id: 目标servantId
node-name: 节点名称[192.168.1.1]
thread-num: 线程数[5]
endpoint: 节点[tcp -h 192.168.0.169 -t 60000 -p 12000]
max-connections: 最大连接数[2000]
servant: OBJ名称, 例如: App.HelloServer.HelloObj
allow-ip: 允许IP
queuecap: 队列长度[10000]
queuetimeout:队列超时(ms)[6000]
protocol:协议[tars]
bin/tarsctl adapter listObjFir --servants=[APP.HelloServer.Obj1, tars.tarsAdminRegistry.AdminRegObj]
获取adapter列表
bin/tarsctl admin help
查看帮助
bin/tarsctl admin create-user --uid=[xxx] --password=[xxx]
创建用户
bin/tarsctl admin list-user
获取用户列表
bin/tarsctl admin get-user --uid=[xxx]
查看某个用户信息
bin/tarsctl admin modify-pass --uid=[xxx] --password=[xxx]
修改用户密码
bin/tarsctl admin delete-users --uids=[xxx,xxx]
删除用户列表
bin/tarsctl admin create-token --uid=[xxx] --expireTime=[xxx]
创建指定用户的token
bin/tarsctl admin list-token --uid=[xxx]
获取某个用户的所有token, 如果没有指定uid, 获取所有系统中的token
bin/tarsctl admin delete-token --token=[xxxxx]
删除指定token
bin/tarsctl admin get-token --token=[xxx]
根据token获取token info
获取有token
bin/tarsctl admin valid-token --token=[xxxx] --valid=[1/0]
设置token有效性
bin/tarsctl admin create-auth --flag=[application or application.server_name] --role=[admin/operator/developer] --uid=[_test]
为用户创建权限
bin/tarsctl admin auth-list --uid=[_test]
获取指定用户的权限列表, 如果不指定uid, 获取所有auth
bin/tarsctl admin delete-auth --uid=[test] --roles=[admin,operator,developer] --flag=[application or application.server_name]
删除指定的用户权限
bin/tarsctl application list
列出所有application
bin/tarsctl application create --name=[App]
创建一个application
bin/tarsctl application delete --name=[App]
删除一个application
bin/tarsctl application servers --name=[App]
列出应用下所有的服务的名称
bin/tarsctl auth help
查看帮助
bin/tarsctl auth list
获取用户自己的权限列表
bin/tarsctl auth serverList
获取服务的权限列表
bin/tarsctl business list
列出所有业务
bin/tarsctl business create --name=[Business] --show-name=[系统应用]
创建一个业务
bin/tarsctl business update --newName=[Business] --oldName=[OldBusiness] --show-name=[系统应用]
修改业务的显示名称
bin/tarsctl business view --name=[Business]
查看业务中的所有的app
bin/tarsctl business addApp --name=[Business] --app=[App]
在业务中添加app
bin/tarsctl business delApp --name=[Business] --app=[App]
在业务中删除app
bin/tarsctl business delete --name=[Business]
删除一个业务
bin/tarsctl config list --target=[App or App.HelloServer]
应用级别配置或者服务配置, target: App or App.HelloServer
bin/tarsctl config create --target=[App] --name=[config name] --file=[config file] --reason=test --update
创建某个应用配置, --update: 存在则修改配置
bin/tarsctl config create --target=[App.HelloServer] --name=[config name] --file=[config file] --reason=test --update
创建某个服务配置, --update: 存在则修改配置
bin/tarsctl config create --target=[App.HelloServer_192.168.1.1] --name=[config name] --file=[config file] --reason=test --update
创建某个节点配置, --update: 存在则修改配置
bin/tarsctl config view --target=[App] --name=[config name]
查看某个应用配置
bin/tarsctl config view --target=[App.HelloServer] --name=[config name]
查看某个服务配置
bin/tarsctl config view --target=[App.HelloServer_192.168.1.1] --name=[config name]
查看某个服务的节点配置
bin/tarsctl config view --target=[App.HelloServer_192.168.1.1] --name=[config name] --with-merge
查看某个服务的节点配置, 并合并节点配置, --with-merge: 是否合并业务配置
bin/tarsctl config delete --target=[App] --name=[config name]
删除某个应用配置
bin/tarsctl config delete --target=[App.HelloServer] --name=[config name]
删除某个服务配置, 会一并删除所有节点配置
bin/tarsctl config delete --target=[App.HelloServer_192.168.1.1] --name=[config name]
删除某个服务节点配置
bin/tarsctl config update --target=[App] --name=[config name] --file=[config file] --reason=test --create
更新某个配置: --create: 不存在则创建
bin/tarsctl config update --target=[App.HelloServer] --name=[config name] --file=[config file] --reason=test --create
更新某个配置: --create: 不存在则创建
bin/tarsctl config update --target=[App.HelloServer_192.168.1.1] --name=[config name] --file=[config file] --reason=test --create
更新某个节点配置 --create: 不存在则创建
bin/tarsctl config history --target=[App] --name=[config name]
查看某个应用配置所有历史变更记录
bin/tarsctl config history --target=[App.HelloServer] --name=[config name]
查看某个服务配置所有历史变更记录
bin/tarsctl config history --target=[App.HelloServer_192.168.1.1] --name=[config name]
查看某个服务的节点配置所有历史变更记录
bin/tarsctl config viewHistory --id=[historyId]
查看指定的历史配置内容
bin/tarsctl config restore --target=[App] --name=[config name] --id=[historyId] --reason=test
恢复某个应用配置指定的历史配置
bin/tarsctl config restore --target=[App.HelloServer] --name=[config name] --id=[historyId] --reason=test
恢复某个服务配置指定的历史配置
bin/tarsctl config restore --target=[App.HelloServer_192.168.1.1] --name=[config name] --id=[historyId] --reason=test
恢复某个节点配置指定的历史配置
bin/tarsctl framework check
检查框架所有服务
bin/tarsctl framework ping --obj=[obj]
ping所有obj服务
bin/tarsctl framework iplist --obj=[obj] --node-name=[xxx]
获取某个obj对应的活跃和非活跃的ip list, 如果不指定node-name则从主控获取, 如果指定node-name则从对应的tarsnode获取
bin/tarsctl framework install --install-path=[/usr/local/app] --file=tars.tgz --locator="tcp -h xxx1 -p yyy1:tcp -h xxx2 -p yyy2:tcp -h xxx3 -p yyy3" --registry="tcp -h xxx1 -p yyy1" --localip=[] --node-name=[]
安装framework相关组件
--install-path: 框架安装目录, 默认为: /usr/local/app
--file: 安装包文件
--locator: 主控三节点地址
--registry: 当前节点tarsregistry的QueryObj的绑定地址, 通常处于locator之一
--localip: 可选, 当前节点ip地址, 如果不指定则为registry中指定的ip地址
--node-name: 当前节点的名称, 如果不指定则为localip
bin/tarsctl framework start --install-path=[/usr/local/app] --server-name=[]
启动当前节点上tars框架服务
bin/tarsctl framework stop --install-path=[/usr/local/app] --server-name=[]
停止当前节点上tars框架服务
bin/tarsctl framework restart --install-path=[/usr/local/app] --server-name=[]
重启当前节点上tars框架服务
bin/tarsctl framework list --install-path=[/usr/local/app] --server-name=[]
列出当前目录上安装的tars服务的状态
bin/tarsctl idc list
查看所有的分组信息
bin/tarsctl idc create --update --name=[xxx] --name_cn=[xxx] --order=[denny_allow|allow_denny] --allow_ip_rule=[xxx.xxx.xxx.*,yyy.yyy.yyy.*] --denny_ip_rule=[xxx.xxx.xxx.*,yyy.yyy.yyy.*]
创建一个分组信息
--name: 分组名称, 请使用英文, 作为分组的关键字, 每个分组唯一标识, 例如: sz1
--name_cn: 分组名称, 中文提示, 例如: 深圳机房1
--update: 如果存在则修改分组信息
--order: 使用ip分组时的顺序, denny_allow: 先使用denny_ip_rule, 再使用allow_ip_rule判断, allow_denny: 先使用allow_ip_rule, 再使用denny_ip_rule判断
--allow_ip_rule: 进入分组的ip列表, 可以第四组为*, 比如: 192.168.3.*, 多个ip端用,分割
--denny_ip_rule: 不允许进入该分组的ip列表, 可以第四组为*, 比如: 192.168.5.*, 多个ip端用,分割
bin/tarsctl idc update --name=[xxx] --name_cn=[xxx] --order=[denny_allow|allow_denny] --allow_ip_rule=[xxx.xxx.xxx.*,yyy.yyy.yyy.*] --denny_ip_rule=[xxx.xxx.xxx.*,yyy.yyy.yyy.*]
修改指定name的分组信息
idc delete --name=[xxx]
删除某个分组
idc station-list
查看站点列表, 多个idc分组可以合并设置为一个站点, 并且站点有优先级, 从主控获取ip list时, 如果同组的idc分组查不到ip list, 则会按照站点优先级匹配其他分组, 查询ip list
idc station --name=[xxx] --group=[xxx,xxx,xxx] --order=[order]
设置站点信息, 当有多个站点, 每个站点有多个分组, 如果服务只部署在其中某些分组中, 当客户端访问服务时, 主控会按照站点优先级顺序, 返回合适的ip list
--name: 站点名称, 例如: sz-idc
--group: idc分组列表, 例如: sz1,sz2,sz3
--order: 优先级顺序, 数字越小, 优先级越高
bin/tarsctl image create --update --registry=[docker.io] --target=[tarscloud/tars.cppbase:latest] --remark=[text]
添加容器仓库中基础镜像, --registry: 仓库地址, --target: 基础镜像地址, --remark: 备注
bin/tarsctl image update --id=[id] --target=[tarscloud/tars.cppbase:latest] --remark=[text]
修改容器仓库中基础镜像的信息, --registry: 仓库地址, --target: 更新的基础镜像地址, --remark: 备注
bin/tarsctl image delete --registry=[docker.io] --target=[tarscloud/tars.cppbase:latest]
删除容器仓库中的镜像
bin/tarsctl image list --registry=[docker.io]
列出所有仓库中所有的基础镜像
bin/tarsctl tarsctl install web --install-path=[/usr/local/app] --file=web.tgz --locator="tcp -h xxx1 -p yyy1:tcp -h xxx2 -p yyy2:tcp -h xxx3 -p yyy3"
安装web组件
bin/tarsctl load timediff --node-name=[xxx] --start=[%Y%m%d%H%M%S] --end=[%Y%m%d%H%M%S]
获取某个node和tarscollect leader节点的时间差异, 如果不指定start, end, 则获取最新的数据
bin/tarsctl load timediffs
获取所有node最新的时间差异
bin/tarsctl load device --node-name=[]
获取某个node, 硬盘设备分区名称
bin/tarsctl load disk --node-name-[] --device=[] --start=[%Y%m%d%H%M%S] --end=[%Y%m%d%H%M%S]
获取某个node, 某个分区硬盘大小变化数据
bin/tarsctl load cpu --node-name=[] --start=[%Y%m%d%H%M%S] --end=[%Y%m%d%H%M%S]
获取某个node, cpu负载变化数据 --start=[%Y%m%d%H%M%S] --end=[%Y%m%d%H%M%S]
bin/tarsctl load mem --node-name=[] --start=[%Y%m%d%H%M%S] --end=[%Y%m%d%H%M%S]
获取某个node, 内存负载变化数据
bin/tarsctl login help
login帮助
bin/tarsctl login --uid=[uid] --password=[xxx]
使用用户uid登录
bin/tarsctl logout help
logout帮助
bin/tarsctl logout
退出当前用户登录
bin/tarsctl node list --name=[xxx] --idc=[xxx] --curPage=[1] --pageSize=[20]
分页所有node, 当不指定pageSize或curPage, 则列出所有node, --name: 模糊搜索节点, 不指定则不检索, --idc: 模糊搜索指定idc的节点, 不指定则不检索
bin/tarsctl node server --name=192.168.1.1
列出node上的所有服务
bin/tarsctl node stub --name=192.168.1.1 --stub=[]
修改某台节点的stub名称
bin/tarsctl node ping --name=192.168.1.1
ping node
bin/tarsctl notify help
查看帮助
bin/tarsctl notify query --target=[Test or Test.HelloServer or Test.HelloServer_192.168.0.1] --from=[202401021035] --limit=[100]
查询异常上报数据, target: 目标服务, from: 从这个数据往前的异常上报数据, limit: 查询条数
bin/tarsctl patch list --target=[App.HelloServer]
查看服务的发布包
bin/tarsctl patch download --id=[xxx]
下载服务的发布包
bin/tarsctl patch download --target=[App.HelloServer]
下载服务缺省发布包
bin/tarsctl patch delete --id=[xxx]
删除服务的发布包
bin/tarsctl patch default --id=[xxx]
将当前id包设置为服务的缺省发布包
bin/tarsctl prop help
查看帮助
bin/tarsctl prop query --date=[20240102] --from=[0000] --to=[1035] --module-name=[] --node-name=[] --property-name=[] --policy=[Sum,Avg,Count,Max,Min] --group-by-time=[ON/OFF]
查询调用数据, date: 日期, 如果不填则默认今天, from: 起始分钟, 例如:1035(10点35分), to: 结束分钟, group-by-time: 是否按时间做group
bin/tarsctl repo create --update --registry=[docker.io] --user=[xxx] --password=[xxx]
添加容器仓库地址, --update: 存在则更新
bin/tarsctl repo update --id=[id] --registry=[docker.io] --user=[xxx] --password=[xxx]
修改指定id的容器仓库信息
bin/tarsctl repo login --registry=[docker.io]
检查仓库是否可以登录
bin/tarsctl repo delete --registry=[docker.io]
删除容器仓库地址
bin/tarsctl repo list
列出所有容器仓库
bin/tarsctl server list --target=[App.HelloServer] --detail
根据名字列出所有的服务, name : App or App.HelloServer, --detail: 输出所有详细信息
bin/tarsctl server list --obj=[App.HelloServer.Obj] --detail
根据Obj列出所有的服务, --detail: 输出所有详细信息
bin/tarsctl server list --abnormal=[App.HelloServer] --detail
根据名字列出所有异常服务, abnormal : App or App.HelloServer,--detail: 输出所有详细信息
bin/tarsctl server bak
列出所有主备模式的服务
bin/tarsctl server node --target=[App.HelloServer]
列出所有node, name: App or App.HelloServer
bin/tarsctl server create --update --target=[App.HelloServer] --set=[set_name.set_area.set_group] --template-name=[tars.default] --profile=[] --server-type=[tars_cpp,tars_java,tars_nodejs,tars_go] --node-names=[xxx,xxx,xxx] --open-master-slave --config=file1.conf,file1path:file2.conf:file2path --obj=[Obj1,Obj2] --bind-Obj1=[endpoint,endpoint,endpoint] --bind-Obj2=[endpoint,endpoint,endpoint] --Obj1=[threads,maxconns,queuecap,queuetimeout,protocol(tars/not_tars),allow] --Obj2=[...]
创建服务: target: 指定服务名称
update: 如果存则更新
set: set分组信息, 缺省空
template-name: 使用的模板名称
profile: 私有模板文件
server-type: 服务类型
node-names: 部署在哪些节点上, 多个节点以,分割
open-master-slave: 启用主备模式, 如果不指定则是缺省模式
config: 服务的配置文件, 格式为: 文件名:路径,文件名:路径
obj: 服务的Obj名字(不需要App.HelloServer)
bind-Obj1: Obj1以实际obj中指定的名字为准(比如: HelloObj), endpoint和node-name中个数保持一致, Obj1在对应的节点上的绑定地址, 例如: tcp -h xxx -p yyy
Obj1: 指定对应Obj的参数, 如果不填写则使用缺省值[5,10240,10000,20000,tars,]
bin/tarsctl server send --target=[App.HelloServer_192.168.1.1] --command=[text]
给服务发送命令, target: App.HelloServer or App.HelloServer_192.168.1.1
bin/tarsctl server delete --target=[App.HelloServer_192.168.1.1]
删除服务, target: App.HelloServer or App.HelloServer_192.168.1.1
bin/tarsctl server stop --target=[App.HelloServer_192.168.1.1]
停止服务, target: App.HelloServer or App.HelloServer_192.168.1.1
bin/tarsctl server start --target=[App.HelloServer_192.168.1.1]
启动服务, target: App.HelloServer or App.HelloServer_192.168.1.1
bin/tarsctl server restart --target=[App.HelloServer_192.168.1.1]
重启服务, target: App.HelloServer or App.HelloServer_192.168.1.1
bin/tarsctl server patch --target=[App.HelloServer_192.168.1.1] --file=[tgz] --default-version --update=[text]
上传文件并发布服务
target: 指定的服务, App.HelloServer or App.HelloServer_192.168.1.1
file: 发布文件包
default-version: 指定为缺省版本
update: 发布描述
bin/tarsctl server expand --target=[App.HelloServer] --src-node-name=[192.168.1.0] --dst-node-names=[192.168.1.1,192.168.1.2] --set=[xx.xx.xx] --copy-node-config --bind-Obj1=[endpoint,endpoint,endpoint] --bind-Obj2=[endpoint,endpoint,endpoint]
扩容服务到指定节点, 并发布重启
target: 扩容指定服务
src-node-name: 扩容源节点
dst-node-names: 扩容目的节点, node_name数组
set: 如果指定, 则启用set, 格式为: set_name.set_area.set_group
copy-node-config: 如果有节点配置, 则复制节点配置
bind-Obj1: Obj1以实际obj中指定的名字为准(比如: HelloObj), endpoint和node-name中个数保持一致, Obj1在对应的节点上的绑定地址, 例如: tcp -h xxx -p yyy
bin/tarsctl server repatch --target=[App.HelloServer_192.168.1.1] --id=[patch_id]
再发布服务, 使用已经存在的patch记录发布服务
bin/tarsctl server set --target=[App.HelloServer]
查看服务的所有set信息
bin/tarsctl server obj --target=[App.HelloServer]
查看服务的obj信息
bin/tarsctl server log-list --target=[App.HelloServer_192.168.1.1]
查看某个服务的日志列表
bin/tarsctl server log --target=[App.HelloServer_192.168.1.1] --file=[App.HelloServer.log] --search=[xxx]
查看某个服务的日志, 根据search实时搜索最后几行, file如果为空, 则默认获取缺省的日志文件
bin/tarsctl server tree --search=[tars] --type=1 --reload=1
web左侧导航菜单树状数据结构
search: 搜索关键字
type: 1: 应用服务 2: DCache应用服务
reload: 刷新缓存
bin/tarsctl stat help
查看帮助
bin/tarsctl stat query --date=[20240102] --from=[0000] --to=[1035] --master-name=[] --slave-name=[] --master-ip=[] --slave-ip=[] --interface-name=[] --group-by=[master-name,slave-name,master-ip,slave-ip,interface-name] --group-by-time=[ON/OFF]
查询调用数据, date: 日期, 如果不填则默认今天, from: 起始分钟, 例如:1035(10点35分), to: 结束分钟, group-by-time: 是否按时间做group
station list
查看站点列表, 多个station分组可以合并设置为一个站点, 并且站点有优先级, 从主控获取ip list时, 如果同组的station分组查不到ip list, 则会按照站点优先级匹配其他分组, 查询ip list
station create --update --station=[xxx] --name=[xxxx] --group=[xxx,xxx,xxx] --order=[order]
设置站点信息, 当有多个站点, 每个站点有多个分组, 如果服务只部署在其中某些分组中, 当客户端访问服务时, 主控会按照站点优先级顺序, 返回合适的ip list
--station: 站点名称, 关键字, 例如: sz-station
--name: 站点描述
--group: station分组列表, 例如: sz1,sz2,sz3
--order: 优先级顺序, 数字越小, 优先级越高
station update --station=[xxx] --group=[xxx,xxx,xxx] --order=[order]
修改站点信息
station delete --station=[xxx]
删除站点信息
bin/tarsctl stub list
列出所有的stub节点
bin/tarsctl stub update --node-name=[node] --inner-address="tcp -h xxx -p yyy" --outer-address="tcp -h xxx -p yyy"
更新stub的信息实例
bin/tarsctl template list
列出所有模板
bin/tarsctl template view --name=[tars.default] --with-parent
查看指定的模板, --with-parent: 是否合并父模板
bin/tarsctl template create --name=[tars.xxx] --parent=[tars.default] --file=[filepath]
添加模板
bin/tarsctl template update --name=[tars.default] --file=[filepath]
更新模板
bin/tarsctl template delete --name=[tars.default]
删除一个模板
bin/tarsctl help
查看帮助
bin/tarsctl token create --expireTime=[xxsecond/minute/hour/day/month/year]
创建token, 例如: token create --expireTime=4hour
bin/tarsctl token list --valid=[1/0]
获取uid下所有token, --valid如果没有指定, 则列出所有token
bin/tarsctl token delete --token=[xxx]
删除token
bin/tarsctl token get --token=[xxx]
根据token获取token info
bin/tarsctl token valid --token=[xxx] --valid=[1/0]
设置token有效性
bin/tarsctl user modify-pass --password=[xxx]
修改用户自己的密码