草庐IT

start_tcp_server

全部标签

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?

使用 http.server 转到上下文

为了测试我正在编写的服务器,我希望能够在测试框架中启动和停止它。为此,我希望我可以整合thecontextpackage在http.Server结构中。我希望能够在调用Done函数并且ctx.Done()channel返回某些内容时停止服务器。我想做的就是修改thehttp.Server.Serve()method,在for循环的每次迭代中接受context.Context并检查它是否完成,如下所示:func(srv*server)Serve(ctxcontext.Context,lnet.Listener)error{deferl.Close()vartempDelaytime.Du

c - C/Go 中的 LDAP : Error code 53 "Server is unwilling to perfom" when trying to set unicodePwd

所以我正在用Go编写一个程序,由于CGo,我使用C绑定(bind),并且我正在使用ldap来执行搜索、添加和修改操作。我可以设法做到所有这些,但现在我试图在unicodePwdmod_type中设置密码,但我似乎无法解决错误53:服务器不愿意执行。我知道很多东西会导致这个错误,所以:我与ldaps连接。为了测试目的,我硬编码了一个由10个字符组成的密码,开头和结尾都带有双引号,并以UTF-16LE、Base64格式获得了该密码。密码有小写字母、大写字母和标点符号。这是我的一些代码示例,我现在只是在测试一些东西,所以编码真的很糟糕:设置选项:C.ldap_set_option(l,LDA

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/

go - TCP `net.Conn.Read` 在使用 `encoding/gob` 解码器后挂起

我可以用encoding/goben/decoder包裹TCPnet.Conn的末端,并通过它成功地en/decode一个值,但是如果我遵循在卡在Read上的原始连接上使用Read进行Decode:packagemainimport("encoding/gob""net""log""sync")funcmain(){varwgsync.WaitGroupaddr:=&net.TCPAddr{IP:net.ParseIP("127.0.0.1"),Port:9000}ready:=make(chanstruct{})wg.Add(1)gofunc(){deferwg.Done()ln,e

go - 接受与接受 TCP

有人能解释一下为什么Go的net包有func(l*TCPListener)Accept()(Conn,error)和func(l*TCPListener)AcceptTCP()(*TCPConn,error)而TCPConn是吗?typeTCPConnstruct{conn}以上来自tcpsock_posix.go。拥有一个返回*TCPConn的函数比Conn有什么优势? 最佳答案 答案很简单,net.Conn类型是一个接口(interface),net.TCPListener类型是一个实现net.Conn接口(interface)

go - 如何正确停止Go sdk自带的web-server?

关闭GoSDK附带的Web服务器的正确方法是什么?这是一个示例网络服务:packagemainimport("fmt""net/http")funchandler(whttp.ResponseWriter,r*http.Request){fmt.Fprintf(w,"Hithere,Ilove%s!",r.URL.Path[1:])}funcmain(){http.HandleFunc("/",handler)http.ListenAndServe(":8080",nil)}这是从这里提取的:https://golang.org/doc/articles/wiki/#tmp_3但是,我

c++ - 建立P2P TCP/UDP连接(NAT穿越)

有没有办法在没有中间服务器的情况下通过TCP或UDP建立真正的P2P通信?我知道如果两台计算机只有公共(public)IP地址,这是非常可行的,但如果它们位于任何类型的NAT路由器后面或在专用网络上,它就会开始变得棘手。.事实上,我越看越觉得平淡不可能。我发现了STUN、TURN和ICE协议(protocol)以及打洞,但据我所知,它们都需要某种服务器来至少建立连接。我很惊讶看似如此简单的事情似乎很难做到,我错过了什么吗?理想情况下,我正在寻找使用Golang的解决方案,任何帮助或C++中的示例也会很有用,谢谢。 最佳答案 这不是严

go - Go Server无需重启的无缝补丁部署

我很好奇是否有任何解决方案可以部署go服务器而无需将其关闭并重新启动。我知道ASP.Net和PHP等流行的解决方案可以为用户session无缝执行此操作。无状态session会处理这个问题吗? 最佳答案 即使是最简单的应用程序服务器也可以通过引入请求路由器(例如nginx)来实现这种无缝部署。或haproxy.这两个路由器都允许您将请求转发到不同的服务(称为反向代理),并在不断开连接的情况下重新加载它们的配置。举个例子:将您的路由器配置为监听0.0.0.0.80并将这些请求转发到127.0.0.1:5001。在127.0.0.1:5

sql-server - 使用 ODBC 驱动程序调用 Microsoft SQL Server 上的存储过程

我有一个存储过程,名称为“vijaystoredprocedure”,如果它是mssql中的一些查询,那么我将在Go中查询,如l_query_str=fmt.Sprintf(`select*fromUserswhereFname='%s'`,l_firstanme)row,err:=DBC.Query(l_query_str)iferr!=nil{log.Fatal("Preparefailed:",err.Error())}_,rows,r_err:=DBScan_fn(row)ifr_err!=nil{fmt.Println("nodatafounderr")return}现在因为