From ba96922f40f82d12e9a5f4cfa4d887e78f460125 Mon Sep 17 00:00:00 2001
From: zhangmeng <775834166@qq.com>
Date: 星期四, 26 十二月 2019 15:23:17 +0800
Subject: [PATCH] update

---
 util/util.go |   36 +++++++++++++++++++++++++++++++++---
 1 files changed, 33 insertions(+), 3 deletions(-)

diff --git a/util/util.go b/util/util.go
index b8fbcea..4c2b54f 100644
--- a/util/util.go
+++ b/util/util.go
@@ -1,14 +1,25 @@
 package util
 
 import (
-	"basic.com/valib/deliver.git"
 	"context"
 	"errors"
+
+	"basic.com/valib/deliver.git"
 
 	"basic.com/valib/logger.git"
 )
 
-const SHMMaxTryCount = 3
+const (
+	// 鍏变韩鍐呭瓨鍙戦��/鎺ユ敹澶辫触shmMaxTryCount娆¢噸鏂板垱寤洪�氶亾灏濊瘯
+	ShmMaxTryCount = 7
+	// 涓嶈鍏变韩鍐呭瓨/mangos鍙戦��/鎺ユ敹澶辫触鏈�澶ф鏁�,璁や负褰撳墠閫氶亾涓嶅啀浣跨敤, 鍏抽棴
+	// 鏈夐棶棰�,鎽勫儚鏈洪暱鏃堕棿鏂綉鍚庨噸杩�,浣嗘槸閫氶亾鍏抽棴
+	tooLongFailed = 300
+
+	File_Img_Id_Pre   = "img_"
+	File_Video_Id_Pre = "video_"
+	File_Audio_Id_Pre = "audio_"
+)
 
 type SocketContext struct {
 	Sock    deliver.Deliver
@@ -86,7 +97,6 @@
 
 // create server
 func NewSocketListen(mode int, url string, shm bool) (socket SocketContext, err error) {
-	logger.Info("url is: ", url)
 	ctx, cancel := context.WithCancel(context.Background())
 
 	socket.Context = ctx
@@ -128,3 +138,23 @@
 
 	return socket, nil
 }
+
+func MaybeRestartSocket(socket SocketContext, tryCnt *int) SocketContext {
+	if socket.UseSHM {
+		if *tryCnt > ShmMaxTryCount {
+			logger.Info("SDK SEND SHM TRY :", ShmMaxTryCount, " RESTART: ", socket.URL)
+
+			socket.Sock.Close()
+			newSocket, err := NewSocketListen(socket.Mode, socket.URL, socket.UseSHM)
+			if err != nil {
+				return socket
+			}
+
+			*tryCnt = 0
+
+			return newSocket
+		}
+	}
+
+	return socket
+}

--
Gitblit v1.8.0