【问题标题】:golang tcp socket does not send message after write immediatelygolang tcp套接字在立即写入后不发送消息
【发布时间】:2013-07-28 18:22:43
【问题描述】:

我的 GO 版本是 1.1.1

连接关闭后服务器收到消息,但设置了NoDelay。

有什么问题

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
}

【问题讨论】:

  • 仅供参考,您不需要这样做conn.SetNoDelay(true),因为默认情况下是这样。 (golang.org/pkg/net/#TCPConn.SetNoDelay)。此外,Write 返回写入的字节数和错误。试试_, err = conn.Write([]byte(message)) 看看是否能解决问题。
  • 我刚刚测试了您的代码(进行了一些更改,没什么大不了的,请参阅play.golang.org/p/CaVynZMXWJ),它似乎按预期工作。你确定问题不在服务器端?
  • 是的,我只是添加 conn.SetNoDelay(true) 以确保
  • @Intermernet 哦,你是对的,这是我的错,我会在我的回答中解释它

标签: sockets tcp go


【解决方案1】:

您的代码似乎没有任何严重错误,所以我猜测错误出在服务器端。

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

尝试运行以下服务器代码,然后针对它测试您的客户端代码。它只是将所有接收到的数据回显到标准输出。

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)
    }
}

您应该会在您按下回车后立即看到发送给客户端的每一行都打印出来(不带换行符)。

【讨论】:

    【解决方案2】:

    问题出在服务器端。

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

    【讨论】:

    • 容易犯错误:-)
    猜你喜欢
    • 2015-02-07
    • 2019-03-31
    • 1970-01-01
    • 2011-07-16
    • 2020-12-28
    • 2014-11-20
    • 2012-03-25
    • 2012-07-14
    • 2015-01-09
    相关资源
    最近更新 更多