优化服务退出流程,增加中间件文档

This commit is contained in:
孟帅
2023-05-15 18:37:40 +08:00
parent fdefb42253
commit c511a2e6b3
30 changed files with 335 additions and 97 deletions

View File

@@ -27,6 +27,7 @@ func Build(ctx context.Context, sk Skeleton, conf *model.BuildAddonConfig) (err
"@{.description}": sk.Description,
"@{.author}": sk.Author,
"@{.version}": sk.Version,
"@{.hgVersion}": consts.VersionApp, // HG 版本
}
)

View File

@@ -195,7 +195,9 @@ func (client *Client) connect() {
reconnect:
conn := client.dial()
if conn == nil {
client.Logger.Debugf(client.Ctx, "client dial failed")
if !client.stopFlag {
client.Logger.Debugf(client.Ctx, "client dial failed")
}
return
}
@@ -311,6 +313,11 @@ func (client *Client) Stop() {
client.Close()
}
// IsStop 是否已停止
func (client *Client) IsStop() bool {
return client.stopFlag
}
// Destroy 销毁当前连接
func (client *Client) Destroy() {
client.stopCron()

View File

@@ -294,6 +294,11 @@ func (server *Server) Close() {
server.wgLn.Wait()
}
// IsClose 服务是否关闭
func (server *Server) IsClose() bool {
return server.closeFlag
}
// Write 向指定客户端发送消息
func (server *Server) Write(conn *gtcp.Conn, data interface{}) (err error) {
if server.closeFlag {

View File

@@ -99,6 +99,8 @@ func Logout(r *ghttp.Request) (err error) {
claims, err := parseToken(ctx, header)
if err != nil {
g.Log().Debugf(ctx, "logout parseToken err:%+v", err)
err = errorLogin
return
}
@@ -138,10 +140,13 @@ func ParseLoginUser(r *ghttp.Request) (user *model.Identity, err error) {
claims, err := parseToken(ctx, header)
if err != nil {
g.Log().Debugf(ctx, "parseToken err:%+v", err)
err = errorLogin
return
}
var (
// 认证key
authKey = GetAuthKey(header)
// 登录token
tokenKey = GetTokenKey(claims.App, authKey)
@@ -285,7 +290,7 @@ func GetAuthorization(r *ghttp.Request) string {
// GetAuthKey 认证key
func GetAuthKey(token string) string {
return gmd5.MustEncryptString(token)
return gmd5.MustEncryptString("hotgo" + token)
}
// GetTokenKey 令牌缓存key