草庐IT

tcp - 端口号

全部标签

asynchronous - 如何有效地解码 gobs 并等待更多通过 tcp 连接到达

我想为游戏应用程序建立TCP连接。时间效率很重要。我想有效地接收许多对象。由于负载的原因,提高CPU效率也很重要。到目前为止,我可以确保每次使用go的net库调用连接时都会调用handleConnection。但是,一旦创建了连接,我就必须进行轮询(一遍又一遍地检查以查看连接上是否已准备好新数据)。这似乎效率低下。如果新数据不必要地占用CPU,我不想运行该检查以查看新数据是否已准备就绪。我一直在寻找诸如以下两个选项之类的东西,但没有找到我要找的东西。(1)执行以某种方式阻塞(不占用CPU)的读取操作,然后在连接流上准备好新内容时解除阻塞。我找不到那个。(2)采用异步方法,当新数据到达连

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

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

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

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

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

HUAWEI(MAC-地址绑定端口)

【理解尚浅,有错请指出】交换机的mac地址和端口绑定有什么用?1、没有经过认证的计算机接入立即就被阻断(防止陌生的计算机接入)。一旦MAC地址与端口绑定,内部计算机从绑定端口任意插入到另一个端口,该计算机将被阻断,但是计算机接回原来的绑定端口时,可继续使用。避免了人为随意调换交换机端口2、为了彻底解决IP地址盗用的现象,单位对MAC地址与交换机的端口进行了绑定,绑定之后,IP地址盗用的现象消失了MAC地址是计算机的唯一物理标识,可以通过在交换机对应的端口上进行绑定,非绑定的MAC将无法接入到网络中。查看MAC地址的方法有几种:(1)在计算机中执行ipconfig命令即可查看本机的MAC地址;(

go - 如何将数据从默认端口路由到另一个[4001]

关闭。这个问题需要debuggingdetails.它目前不接受答案。编辑问题以包含desiredbehavior,aspecificproblemorerror,andtheshortestcodenecessarytoreproducetheproblem.这将有助于其他人回答问题。关闭4年前。Improvethisquestion目前我的go服务器正在端口4001上运行,用于https请求。要访问Web应用程序,我需要在浏览器中键入域名:4001。我只想键入域名a以连接到端口40001上的Web服务器。

Go:使用 TCP 连接写入 header

我从这里用以下代码结构实现了一个TCP服务器:http://golang.org/pkg/net/#example_Listener我正在尝试从浏览器pingTCP服务器。TCP服务器能够写入我的浏览器。但是,它无法写入客户端header,因为它未使用HTTP协议(protocol)。如何保持TCP协议(protocol)和连接,但仍然能够写入浏览器的header? 最佳答案 HowdoIkeeptheTCPprotocolandconnectionsbutstillbeabletowritetothebrowser'sheader

go - 在 Golang 中,为什么 conn.Write tcp 响应为空?

我有一个读取文件的tcp服务器,该文件将文件内容发送到客户端。“status.txt”文件仅包含一个bool值。当我curl时,这显示true(带有前导空格)。dat,err:=ioutil.ReadFile("./status.txt")conn.Write([]byte(""+string(dat)))而此代码导致curl:(52)Emptyreplyfromserver。conn.Write([]byte(string(dat)))知道为什么会这样吗?我不想填充我的响应字符串。 最佳答案 如果您不使用HTTP协议(protoc