草庐IT

tcp_keepalive_time

全部标签

sockets - 如何发现客户端正在从 go 中的 tcp 缓冲区读取

我开始在一个项目中使用golang相当长的时间。在我的项目中,我必须实现一个响应tcp客户端的tcp服务器。服务器必须向客户端发送大量消息。问题是,当服务器向客户端连接写入消息时,它必须等到客户端从缓冲区读取该消息,然后再发送另一条消息(服务器必须等到客户端调用reader.ReadString('\n')方法)。在我的服务器代码中我写了:for{data:=但服务器将所有消息发送给客户端,而无需等待客户端中的ReadString。如何让服务器等到客户端读取一条消息,然后再发送另一条消息? 最佳答案 我认为要么赋值不明确,要么你误解

date - time.AddDate() 不适用于仅解析时间,并将日期设置为今天?

https://play.golang.org/p/O1FWb9O97ldfuncmain(){//constlongForm="Jan2,2006at3:04pm(MST)"t1,_:=time.Parse("03:04:05","12:03:30")fmt.Printf("currentdatetime%v\n",t1)now:=time.Now().UTC()t1.AddDate(now.Year(),int(now.Month()),now.Day())fmt.Printf("currentdatetime%v",t1)}输出当前日期时间0000-01-0112:03:30+0

sockets - 如何处理 go 中的粘性 tcp 数据包?

我有一个tcp服务器和一个客户端,服务器执行以下操作funcproviderCallback(connnet.Conn){reader:=bufio.NewReader(conn)varerrerrorfor{lenbyte,_:=reader.Peek(4)reader.Discard(4)slen:=int(binary.BigEndian.Uint32(lenbyte))data,err=reader.Peek(slen)process(data)reader.Discard(slen)}}客户端发送数据包的速度似乎快于进程可以处理的速度,因此我想在bufio中缓冲请求并稍后处理

Golang : Recursive function for reconnecting a TCP client. .. 坏主意?

我有这个有效的TCP客户端代码。当它在TCP连接上写入或读取失败时,它会使用递归函数tcpReconnect()创建一个新连接。这安全吗?它会填满RAM吗?它可能会在几天(周末或节假日)后尝试重新连接。此代码是监视工业机器状态的驱动程序的一部分。也许这个问题有更好的解决方案。我找不到。PS:我不喜欢投票packagemainimport("fmt""net""time")varpollTime=1000//msvarhost="127.0.0.1"varport="11000"funcmain(){finished:=make(chanbool)goDriver()

postgresql - docker + golang lib/pq "dial tcp 127.0.0.1:5432: connect: connection refused"

sql.Open()不会出错:ifdb,err=sql.Open("postgres",url);err!=nil{returnnil,fmt.Errorf("Postgresconnecterror:(%v)",err)}但是db.Ping()会报错:iferr=db.Ping();err!=nil{returnnil,fmt.Errorf("Postgrespingerror:(%v)",err)}这仅仅是因为lib/pq连接字符串无法从具有单独连接参数的docker容器内进行连接。例如:url:=fmt.Sprintf("user=%vpassword=%vhost=%vport

戈朗 : why does the word "hello" loop 5 times while the word "world" loops only 4?

这个问题在这里已经有了答案:Nooutputfromgoroutine(3个答案)关闭7年前。packagemainimport("fmt""time")funcsay(sstring){fori:=0;i运行代码,输出为:helloworldhelloworldhelloworldhelloworldhello在前4个循环中,每100毫秒,将打印一个“hello”,然后打印一个“world”。并且在最后一个循环中只会打印一个“hello”。有没有人可以解释一下代码的执行顺序是什么?

performance - Go 中异步 TCP 服务器的正确结构是什么?

我有一个客户端发送大约50万个请求(消息)/分钟。每条消息大约为200字节到2KB。每条消息都将保存在数据库中(例如Couchbase)。根据核心、端口、连接和goroutines来构建GoTCP服务器以处理此负载的正确方法是什么? 最佳答案 正如JimB所提到的,TCP服务器应该不难建立并开始针对您的需求进行基准测试。一个简单的布局是等待传入的TCP连接,然后执行一个go例程来处理它。在那个goroutine中,你可以放置任何你想要的阻塞代码,在本例中是写入数据库。这是一个简单示例的链接:Simpleexample一旦你开始工作,

json - 将纪元时间戳解码为 time.Time

使用此结构运行Decode()会产生“时间戳”列错误:typeMetricsstruct{Idint`orm:"column(id);auto"`Namestring`orm:"column(name);size(255);null"json:"metric_name"`json:"lon"`Timestamptime.Time`orm:"column(timestamp);type(datetime)"json:"timestamp;omitempty"`}错误:parsingtime"1352289160"as""2006-01-02T15:04:05Z07:00"":cannot

date - Golang time.Parse 定义新格式类型

这个问题在这里已经有了答案:Go:time.Format:howtounderstandmeaningof'2006-01-02'layout?(3个答案)关闭5年前。我正在尝试解析格式为“2017/02/2817:07:54”的日期。我正在使用time.Parse方法。Playground示例:https://play.golang.org/p/B_hnws1AGv这是失败的。它产生一个时间对象:0001-01-0100:00:00+0000UTC(这显然不是我要解析的日期)。如何解析这种格式的日期?我的最终目标是将“2017/02/2817:07:54”转换为“Feb28”请注意,

go - 如何使用自定义时区自动填充类型为 `time.Time` 的结构字段?

我正在使用GORM从Postgresql数据库中检索数据。在postgresql数据库中,我将时间存储为默认的UTC。当我通过gorm/golang加载它们时,我想自动将它们转换为“欧洲/伦敦”位置。目前,所有时间都作为我的本地时区(CEST)返回。我正在努力寻找一种方法来手动覆盖它?相关代码如下:typeBookingstruct{gorm.ModelServiceServiceServiceIDuint`json:serviceId`Starttime.TimeFinishtime.Time}funcgetBookings()http.HandlerFunc{returnfunc(