| | |
| | | var sec = flag.Int("sec", 10, "the second for query data. ") |
| | | |
| | | var Level = flag.String("level","ErrorLevel","log level") |
| | | //var ipMap map[string]net.Conn |
| | | |
| | | func main() { |
| | | flag.Parse() |
| | | |
| | |
| | | |
| | | connArr:=make([]net.Conn,0) |
| | | |
| | | //ipMap = make(map[string]net.Conn,0) |
| | | for { |
| | | conn, err := listener.Accept()// |
| | | |
| | | //clientIpPort := conn.RemoteAddr().String() |
| | | //index := strings.Index(clientIpPort, ":") |
| | | //ipStr := clientIpPort[:index-1] |
| | | //if oldConn,ok := ipMap[ipStr];ok { |
| | | // oldConn.Close() |
| | | //} |
| | | //ipMap[ipStr] = conn |
| | | |
| | | connArr = append(connArr,conn) |
| | | if err != nil { |
| | |
| | | ech <- err |
| | | |
| | | }(conn, ech) |
| | | //go func(conArray []net.Conn) { |
| | | // for { |
| | | // if len(conArray)>50 { |
| | | // for _,connEach :=range conArray{ |
| | | // connEach.Close() |
| | | // } |
| | | // return |
| | | // } |
| | | // time.Sleep(200*time.Second) |
| | | // } |
| | | //}(connArr) |
| | | |
| | | tick := time.NewTicker(10 * time.Second) |
| | | |
| | | for { |
| | |
| | | conn.Close() |
| | | return |
| | | } |
| | | |
| | | } |
| | | |
| | | log.Log.Infoln("Client at " + remoteAddr + " disconnected.") |