Память продолжает расти, когда клиент подключается к моему TCP-серверу - PullRequest
0 голосов
/ 17 октября 2018

Я новичок в Go и пытаюсь создать простой TCP-сервер.Я прикрепил свой код ниже.Когда клиент отключается, он будет добавлен в server.deadConns.

Если я использую простой клиент и продолжаю подключаться и отключаться от TCP-сервера (код ниже), использование памяти моего приложения Golang просто продолжает расти.Если я перестану подключать и заново подключать мой клиент и ждать, использование памяти будет постепенно снижаться.Это займет много времени, чтобы понизиться, но это будет.

Я заметил эту проблему, когда я запускал свой TCP-сервер в Azure, и использование памяти на виртуальной машине продолжало расти, пока машина не сломалась.Я проверил логи и увидел, что есть клиенты, которые постоянно подключаются и отключаются.Затем я попробовал это локально на своей машине и заметил, что происходит то же самое.

//NewTCPServer Creates the TCP Server
func NewTCPServer(port string, logger *logrus.Logger) *TCPServer {
    server := new(TCPServer)
    server.socketAPI = socketapi.NewSocketAPI(logger)
    newConns := make(chan net.Conn, 128)
    server.deadConns = make(chan net.Conn, 128)
    server.sessions = make(map[net.Conn]*types.ClientSession)
    fmt.Println(time.Now().Format("2006-01-02 15:04:05.000000") + ": Listening to: " + port)
    listener, err := net.Listen("tcp", ":"+port)
    if err != nil {
        panic(err)
    }
    go func() {
        for {
            conn, err := listener.Accept()
            if err != nil {
                panic(err)
            }
            fmt.Println(time.Now().Format("2006-01-02 15:04:05.000000") + ": Connected: " + conn.RemoteAddr().String())
            newConns <- conn
        }
    }()

    go func(server *TCPServer) {
        for {
            select {
            case conn := <-newConns:
                session := new(types.ClientSession)
                tcp := createTCPSocket(&conn, server)
                session.Socket = tcp
                server.sessions[conn] = session
            case deadConn := <-server.deadConns:
                sess, ok := server.sessions[deadConn]

                if ok {
                    fmt.Println(time.Now().Format("2006-01-02 15:04:05.000000") + ": Found session")
                    if server.socketAPI.StopSubscriptionOnClose(sess) {
                        delete(server.sessions, deadConn)
                    }
                }

                fmt.Println(time.Now().Format("2006-01-02 15:04:05.000000") + ": Delete session!")
                _ = deadConn.Close()
                sess.Socket = nil
                sess = nil
            }
        }
    }(server)
    return server
}

1 Ответ

0 голосов
/ 17 октября 2018

Я только что нашел ошибку.Я не закрыл канал в своем коде TCP-сервера.

Добро пожаловать на сайт PullRequest, где вы можете задавать вопросы и получать ответы от других членов сообщества.
...