草庐IT

socket_protect

全部标签

sockets - Golang HTTP POST 成功,但不调用 docker 操作

问题:虽然我可以在本地docker套接字上轻松地从curl发出GET和POST命令,但是当我尝试使用net.Dial在Golang中为dockerpull操作执行等效的POST操作时,我没有看到代表Docker采取的任何行动。请注意,与此同时,GET操作通过golang客户端使用docker套接字工作得很好。例如,当运行本文底部的代码时,我看到:2018/01/0514:16:33Pullinghttp://localhost/v1.24/images/create?fromImage=fedora&tag=latest......2018/01/0514:16:34Succeeded

sockets - golang grpc 套接字调整

我有一个golang客户端应用程序通过GRPC与服务器通信。我注意到,在应用程序运行时,客户端应用程序上累积的套接字数量一直在攀升,直到9000左右。此时我暂停了客户端。然而,在客户端和服务器之间不再有流量之后,即使在8小时后,套接字数量仍保持在该水平。我们是否可以针对套接字使用调整GRPC?比如超时后关闭套接字?使用流式传输是否是另一种限制打开的套接字数量的方法?感谢您的帮助。 最佳答案 我首先要确保您的客户端应用程序通过调用Close()方法清除未使用的连接(grpc.ClientConn)。此外,由于我不知道您的应用程序究竟做

sockets - 如何在客户端无错误地建立大量连接

我用golang写了一个程序,用linux随机选择的本地端口向不同的远程ip发出大约2000qps的请求,并在连接建立后立即关闭请求,但仍然遇到bind:addressalreadyinuse定期出错我做了什么:net.ipv4.ip_local_port_range为15000-65535net.ipv4.tcp_tw_recycle=1net.ipv4.tcp_tw_reuse=1net.ipv4.tcp_fin_timeout=30上面是sockstat:sockets:used1200TCP:inuse2302orphan1603tw40940alloc2325mem201我不

go - IIS 作为 golang socket.io 的反向代理

我使用IIShttpPlatformHandler在IIS后面运行socket.io的golang实现。当我禁用IISwebsocket模块让socket.io处理websocket连接时,我收到错误报告Sec-WebSocket-Accept响应header不存在。当我将应用程序作为独立进程运行时,header存在并且一切正常。我启用了iiswebsocket模块并且Sec-WebSocket-Accept现在存在但连接不稳定并且客户端因传输关闭原因而断开连接。有什么解决办法吗? 最佳答案 我不知道如何解决问题,但使用wss而不是

sockets - Golang - 为到不同服务器的多个连接扩展 websocket 客户端

我有一个websocket客户端。实际上,它比下面显示的基本代码复杂得多。我现在需要扩展此客户端代码以打开到多个服务器的连接。最终,从服务器接收到消息时需要执行的任务是相同的。处理这个问题的最佳方法是什么?正如我上面所说,接收消息时执行的实际代码比示例中显示的要复杂得多。packagemainimport("flag""log""net/url""os""os/signal""time""github.com/gorilla/websocket")varaddr=flag.String("addr","localhost:1234","httpserviceaddress")funcm

sockets - 无需使用 http.Serve 即可激活 Go TLS Socket 服务器服务

我有以下代码和systemd单元文件。我想要做的是激活监听器,而不必使用http.Serve来接受和接收传入连接。如果我将ln,err:=tls.Listen("tcp",listen,config)更改为ln,err:=activation.TLSListener(config)我看到我可以接收数据的唯一方法是使用http.Serve。我在使用ln,err:=activation.TLSListeners.(config)时得到的错误是ln.Acceptundefined(type[]net.ListenerhasnofieldormethodAccept)packagemainim

sockets - 为什么当我在许多 goroutine 中发送一个 tcp shake packet(SYN) 时,我在每个 goroutine 中读取了很多响应包

我正在构建一个端口扫描器来检查远程机器上的某个TCP端口是否打开。为了提高性能,我只是构建一个TCPSYN数据包并将其发送到远程端口,而不是进行完整的3次握手。如果我成功接收到SYN-ACK数据包,那么该端口将被视为打开。这是我的部分代码:conn,_:=net.Dial("ip4:tcp",target)tcpSynPacket:=BuildTcpSynPacket()//hereIbuildatcpsynpacketconn.Write(tcpSynPacket.Marshal())deadlineTime:=time.NewTicker(time.Second*2)deferde

sockets - 通过端口获取服务名称

我正在编写简单的网络扫描器,并坚持按端口号解析服务名称。最好的方法是什么?我认为它应该类似于python的socket.getservbyport()并创建了thislib,但不幸的是开发环境基于Windows,我也想要内置解决方案而不是解析器。packagemainimport("fmt""net""strings""sync""time")typePortScannerstruct{ipstring}funcScanPort(ipstring,portint,timeouttime.Duration){target:=fmt.Sprintf("%s:%d",ip,port)conn

sockets - 如何找到 IP :Port of incoming client in TCP Connection

收到来自conn,err:=listener.Accept()的连接后,我想在conn的另一端找到客户端的地址。我已经尝试使用conn.LocalAddr()和conn.RemoteAddr()(Documentation)来执行此操作。.LocalAddr()只是给出服务器进程的地址。.RemoteAddr()为客户端提供了正确的IP,但与我所知道的客户端绑定(bind)的端口号截然不同。如果它有什么不同,我用在同一台机器上运行的两个独立进程来做这件事。一个是客户端,一个是服务器。关于如何找到客户端的正确IP:Port的任何想法?我是要使用LocalAddr还是RemoteAddr?

sockets - 没有可用的缓冲区空间(tcp.cpp :69) when setting SNDBUF and RCVBUF ZeroMQ, golang,MacOSX

我在MacOSX上使用brew安装了zeromq:stable4.1.4,并编写了一个简单的PUB/SUB程序来测试zeromq。但是当我使用标志--bufsize>5运行示例程序时(使用大小>5MB的缓冲区)(去运行go_zmq_pubsub.go--bufsize=6);它抛出以下异常:没有可用的缓冲区空间(tcp.cpp:69)SIGABRT:中止PC=0x7fff9911c286m=0cgo执行时信号到达下面是我用来测试zeromq4.x的程序packagemainimport("fmt""flag""strconv""sync"log"github.com/Sirupsen/