K8STARS
K8STARS is a convenient solution to run TARS services in kubernetes.
Characteristics
- Maintain the native development capability of TARS
- Automatic registration and configuration deletion of name service for TARS
- Support smooth migration of original TARS services to K8S and other container platforms
- Non intrusive design, no coupling relationship with operating environment
How it works
-
Three interfaces are added in the tarsregistry, which are used for automatic registration, heartbeat reporting and node offline. For details, please refer to interface definition。
-
A ‘tarscli’ command-line tool is provided to allocate ports, generate configuration, report heartbeat and node offline.
Deployment examples
- Deployment tars basic service
curl https://raw.githubusercontent.com/TarsCloud/K8STARS/master/baseserver/install_all.sh | sh -
Deployment service example -Deploy sample simpleserver
cd examples/simple && kubectl apply -f simpleserver.yamlExample description:
- The image is created by the
examples/simple/dockerfilefile, and the basic image is created bycmd/tarscli/dockerfile - start.sh:
tarscli genconfin is used to generate the tars service startup configuration - server_ meta.yaml The file is used to configure the metadata of the service. For field information, please refer to
app/genconf/config.gostructureServerConf. Endpoint defaults totcp -h ${local_ip} -p ${random_port}, supports automatic filling of IP and random ports. -ased on Golang HelloWorld program TestApp.HelloGo See examples/README.md
- The image is created by the
- Verify the deployment
Login
db_tars, then executeselect * from t_server_conf\GThe node information of simpleserver has been registered automatically.
Tars deployment directory structure
tarscli based on environment variable TARS_PATH(default/tars) to manage services. The directory functions are as follows:
${TARS_PATH}/bin:Startup scripts and binaries${TARS_PATH}/conf:Configuration file${TARS_PATH}/log: Log file${TARS_PATH}/data:Runtime, Cache file
About tarscli
tarscli provides a set of command tools to facilitate container deployment of TARS services. Parameters can be specified through environment variables. For details, see tarscli help.
Here are the sub commands supported by tarscli
genconfis used to generate the startup configuration file of the TARS service. The supported environment variables are:TARS_APPLICATIONthe application name specified. By default, the_ server_ meta.yamlRead fromTARS_SERVERis the service name specified by the_ server_ meta.yamlRead fromTARS_BUILD_SERVERthe service name at compile time. It will be used when the compiled service name is different from the running service nameTARS_LOCATORcan specify the address of registry. The default istars.tarsregistry.QueryObj@tcp -h tars-registry.tars-system.svc.cluster.local -p 17890(address of service)TARS_SET_IDcan specify service setTARS_MERGE_Confcan specify the configuration template file and merge the configuration into the service startup configuration file
supervisorexecutes thegenconfcommand by default, and then starts and monitors the service. The supported environment variables are:TARS_START_PATHThe startup script of the service$TARS_PATH/bin/start.shTARS_STOP_PATHThe stop script, by default, kill all service processes under path$TARS_PATHTARS_REPORT_INTERVALreports the interval heartbeat to registryTARS_DISABLE_FLOWwhether to enable traffic when registering with registry. If it is not empty, it means it is off. It is enabled by defaultTARS_CHECK_INTERVALcheck the service status interval. If the status changes, it will be synchronized to the registry in real timeTARS_BEFORE_CHECK_SCRIPTthe shell command that runs before each checkTARS_CHECK_SCRIPT_TIMEOUTthe timeout to run the shell command before each checkTARS_PRESTOP_WAITTIMEturn off traffic - the waiting time before stopping the service. It is used for lossless changes. The default value is 80 seconds
hzcheckis used to synchronize the service status and the pod status of k8s. You need to set thereadiness Probeof pod totarscli hzcheckcommandprestopis used to delete the configuration corresponding to the registry before the service exitsTARS_PRESTOP_WAITTIMEturn off traffic - the waiting time before stopping the service. It is used for lossless changes. The default value is 80 seconds
notifyis used to send management commands. The common commands are: tars.setloglevel/tars.pprof, etc
Basic services
TARS related basic services provide rich service governance functions. Please refer to baseserver for deployment.