草庐IT

sock_listen

全部标签

http - Go net listener 关闭及常规处理

我正在开始例行程序并在网络监听器(HTTP)上进行监听。我想关闭监听器,关闭例程并开始一个新例程,然后重新启动监听器。当我关闭监听器时,一切都乱套了。(listener是全局的)listener,_=net.Listen(CONN_TYPE,CONN_HOST+":"+CONN_PORT)goPassThrough()在哪里funcPassThrough(){verbose:=flag.Bool("v",false,"shouldeveryproxyrequestbeloggedtostdout")flag.Parse()proxy:=goproxy.NewProxyHttpServe

ssl - 为什么 grpc 服务器示例使用 net.Listen 而不是 tls.Listen

关闭。这个问题是opinion-based.它目前不接受答案。想要改进这个问题?更新问题,以便editingthispost可以用事实和引用来回答它.关闭5年前。Improvethisquestion我正在设置一个将使用TLS进行客户端授权/身份验证的golanggrpc服务器。我见过的所有服务器设置示例都使用net.Listen()而不是tls.Listen()。这是为什么?import("crypto/tls""github.com/pkg/errors""google.golang.org/grpc""google.golang.org/grpc/credentials""net

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.

go - 为什么 Simple dialer(socks) 总是返回 EOF?

在任何地址中获取此错误。ma​​in.gopackagemainimport("fmt""os")funcdialSocks(socksstring)(Dialproxy.Dialer,errerror){Dial,err=proxy.SOCKS5("tcp",socks,nil,proxy.Direct)return}funccheckError(errerror){iferr!=nil{fmt.Fprintf(os.Stderr,"Fatalerror:%s",err.Error())os.Exit(1)}}funcmain(){dialSocksProxy,err:=dialSo

http - 是否可以在 Go 中将代理/ socks 与 http2 客户端一起使用?

我发现,http2包中传输的实现不支持http2客户端的代理/socks。有没有简单的方法让它发挥作用? 最佳答案 是的,我似乎想起了不久前关于http2客户端无法使用HTTP/SOCKS5代理的事情。无论如何,时间已经过去,下面的工作正常(如果那是你所追求的)。请注意,如果在传输中使用自定义DialTLS,仍然不支持代理连接。packagemainimport("log""net/http""net/url")funcmain(){varaddressString="https://www.facebook.com/"varpro

go - 捕获传递给 http.Server.Serve 的 net.Listener

我想通过执行正常关闭和我将在我的HTTP服务中共享的其他一些小工具来扩展http.Server功能。目前我的代码或多或少说:typeMyServerstruct{server*http.Server//...}func(s*MyServer)ListenAndServe(){//Createlistenerandpasstos.server.Serve()}这很有效很好,但是需要手动公开http.Server的所有必要方法和变量。包装大多数方法不会是一个大问题,但我无法找到一种明智的方法来公开对http.Server.ListenAndServeTLS的访问,而无需实际从thesour

go - golang中master进程和子进程如何共享listen fd和accept new connection?

我已经被这个问题困扰好几天了:我在主进程中监听一个带有fd的端口。然后我fork一个继承fd的新子进程。我不想杀死主进程,我怎样才能在主进程或子进程中接受连接????我已经尝试了一些:如果主进程还活着,只有它可以接受连接;它被杀死了,child去做。我的golang版本是1.6.2。谢谢,期待您的回复!!!! 最佳答案 杀死你的主人——让你的child处理新的连接(child将成为主人)。http://grisha.org/blog/2014/06/03/graceful-restart-in-golang/作为旁注...我这样做了

go - 通过 go-socked.io 接收字节数组时出错

我正在尝试从浏览器发送一个Int8Array到go-socked.io,这是我客户的代码:functioninit(){conn=io('http://localhost:8080/');varc=newInt8Array([127]);conn.emit('m',c)}这是我的服务器代码funcmain(){server,err:=socketio.NewServer(nil)iferr!=nil{log.Fatal(err)}server.On("connection",on_connection)http.Handle("/socket.io/",server)http.Hand

c - O_NONBLOCK SOCK_STREAM 限制为 8192

我正在从C程序写入SOCK_STREAM正在从go程序监听的Unix域套接字,使用net.Listen("unix",sockname).当我将套接字设置为O_NONBLOCK使用fcntl(),我看到C程序在第一次写入时只写入了8192字节。失败后,我监控并回写剩余数据,但我服务器上读取的数据在这种情况下是无效的。当我不使用O_NONBLOCK时,然后整个8762字节被写在一个单一的写入中,一切都按预期工作。C客户端套接字连接if((fd=socket(AF_UNIX,SOCK_STREAM,0))==-1){return;}intflags=fcntl(fd,F_GETFL,0);

go - 有没有办法在 Go 中进行基于 socks 的动态端口转发,就像 SSH 中的 -d 开关一样?

我曾经使用批处理脚本创建可用作socks5代理的SSH隧道。今天,我想我会在Go中实现它,既是为了学习这门语言,也是为了让我无需在连接断开时不断运行批处理脚本文件。现在,我的做法是使用plink.使用plink执行此操作的命令是:plink-N-C-D8888-pwpasswordusername@example.com这是我的Go代码:packagemainimport("os""os/exec""log")funcrunPlink(){command:=exec.Command("plink.exe","-N","-C","-D","8888","-pw","password","