golang tcp socket在立即写入后不发送消息

时间:2013-07-29 04:15:47

标签: sockets tcp go

我的GO版本是1.1.1

服务器在连接关闭后收到消息,但是没有设置延迟。

有什么不对吗

addr, _ := net.ResolveTCPAddr("tcp", "localhost:5432")
conn, err := net.DialTCP("tcp", nil, addr)
defer conn.Close()
if err != nil {
    fmt.Println("connect fail")
    return
}
err = conn.SetNoDelay(true)
if err != nil {
    fmt.Println(err.Error())
}

for {
    var message string
    _, err := fmt.Scanln(&message)
    if err != nil && err.Error() != "unexpected newline" {
        fmt.Println("input finished", err)
        break
    }

    if message == "" {
        fmt.Println("no input, end")
        break
    }
    // message = fmt.Sprintf("%s\n",message) 
    //fmt.Fprintf(conn, message) // send immediately but following message won't send any more
    conn.Write([]byte(message)) // won't send until connection close
}

2 个答案:

答案 0 :(得分:6)

您的代码似乎没有任何重大错误,因此我猜测错误发生在服务器端。

如果在端口5432上创建本地TCP服务器,则可以对此进行测试。

尝试运行以下服务器代码,然后针对它测试客户端代码。它只是将所有收到的数据发送到stdout。

package main

import (
    "io"
    "log"
    "net"
    "os"
)

func main() {
    l, err := net.Listen("tcp", "localhost:5432")
    if err != nil {
        log.Fatal(err)
    }
    defer l.Close()
    for {
        conn, err := l.Accept()
        if err != nil {
            log.Fatal(err)
        }
        go func(c net.Conn) {
            defer c.Close()
            io.Copy(os.Stdout, c)
        }(conn)
    }
}

您应该在输入后立即看到发送给客户的每一行都打印出来(没有新行)。

答案 1 :(得分:1)

问题出在服务器端。

func handleConnection(conn net.Conn) {
// I didn't put it in for loop
message, err := bufio.NewReader(conn).ReadString('\n')
}