草庐IT

socket_last_error

全部标签

sockets - 使用 os.OpenFile() 而不是 net.Listen()

我深入研究了os.OpenFile和net.Listen的调用堆栈,看看我是否可以使用os创建一个UNIX域套接字。打开文件。以下是我的尝试。但是,在跟踪两个调用堆栈(os.OpenFile和net.Listen)之后,我仍然感到困惑。显然,下面的代码没有从文件中读取数据,而是将数据存储到文件系统。如何使用os.OpenFile实现UNIX域套接字?如果os.ModeSocket不与os.OpenFile一起使用以创建UNIX套接字,它的用途是什么?packagemainimport("fmt""log""os")funcmain(){sock,err:=os.OpenFile("f.

macos - OS X 10.9 中的 Golang : CGO_ENABLED=0 GOOS=linux GOARCH=arm ERROR

cd/usr/local/go/srcCGO_ENABLED=0GOOS=linuxGOARCH=arm./make.bash#BuildingCbootstraptool.cmd/dist#BuildingcompilersandGobootstraptoolforhost,darwin/amd64.lib9libbiolibmachmisc/pprofcmd/addr2linecmd/covcmd/nmcmd/objdumpcmd/packcmd/profcmd/cccmd/gccmd/6lcmd/5l/usr/local/go/src/cmd/5l/../ld/lib.c:661

mongodb - 当我运行 docker compose 时,我的 golang(摄取)容器无法显示 "Error establishing Mongo session"

我运行了一个docker-composeup,我在我的golang容器上收到一条错误消息,提示“ErrorestablishingMongosession”,然后容器退出。我不确定问题是否始于我的golang容器或mongo。此时我已经尝试了很多事情。这是我的golang容器的docker日志文件。golang的docker日志Torunindebugmode,runwith'-dtrue'optiontime="2019-08-20T20:12:12Z"level=infomsg="LogginginINFOmode"time="2019-08-20T20:12:12Z"level=

sockets - 通过 TCP 处理多个客户端

好的,我刚开始学习golang,到目前为止我很喜欢它。但是我没有发现他们的文档适合入门者,这是我的问题。我想编写接受连接并向客户端写入内容的小服务器程序。到目前为止没有问题。然而,一旦它获得真正的功能,我就需要能够处理多个客户端,我认为这也是goroutines的一个很好的练习。listener,error:=net.Listen("tcp",remote)con,error:=listener.Accept()gohandleClient(&con);funchandleClient(con*net.Conn){我已经删除了大部分代码。问题是,无论我尝试什么,我都无法通过con。co

memory - Golang, fatal error : out of memory on 1 TB RAM machine

我的代码包含一个巨大的uint8slice,其中包含近5.9亿个元素。我将此数组保留在代码中以使其尽可能快地运行。代码的最终大小为1.3GB。当我尝试编译它时,它引发了fatalerror:内存不足。与以下#command-line-argumentsfatalerror:outofmemoryruntimestack:runtime.throw(0x8fb3f2,0xd)/usr/local/go/src/runtime/panic.go:566+0x95runtime.(*mcache).refill(0x7f5c2afa3ba8,0x1440000000a,0x7f57dc46d

sockets - 从正在收听的相同端口调用地址

我正在开发一个P2P应用程序,并希望节点同时充当客户端和服务器。比如我建立了一个监听节点,在goroutine中运行如下代码:ln,_:=net.Listen("tcp",":8080")for{conn,err:=ln.Accept().....}然后,在另一个goroutine中,逻辑确定它必须联系另一个节点以让它知道它的存在,比如在本地主机地址“:8081”上,它也有一个类似的监听循环正在运行。如果我只使用net.Dial("tcp",":8081"),它将选择一个随机端口号进行连接,并且节点位于8081将尝试联系该端口而不是8080上的正确端口。有没有办法从8080发起net.

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

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

go - fatal error : concurrent map read and map write

fatalerror:concurrentmapreadandmapwritegoroutine5065809[running]:runtime.throw(0x6b4281,0x21)/usr/local/go/src/runtime/panic.go:566+0x95fp=0xc420c05670sp=0xc420c05650runtime.mapaccess1_faststr(0x65ea20,0xc420015020,0xc42178ea8e,0x16,0x0)/usr/local/go/src/runtime/hashmap_fast.go:201+0x4f3fp=0xc42

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中缓冲请求并稍后处理

go - 如何解决 `unknown escape sequence (and 2 more errors)`的错误

我正在尝试使用golang代码验证图像url,但正则表达式有错误我在这个问题中显示了我的正则表达式:-varvalidation=regexp.MustCompile("(http(s?):)|([/|.|\w|\s])*\.(?:jpg|gif|png)")错误:-unknownescapesequence(and2moreerrors)playlink 最佳答案 \.是无效的转义序列。我建议您在定义正则表达式时使用反引号。例如regexp.MustCompile(`^https?://.*\.(jpg|gif|png)$`)//