草庐IT

Git代理

全部标签

go - 如何访问代理的 grpc 服务中的请求 header 。 golang 中的 grpc 网关

我有一个由grpc-gateway代理的grpc服务器。当我对网关端点进行HTTP调用时,会调用相应的grpc服务方法。现在,grpc服务实现接收到一个包含header的上下文。我不知道如何访问header。当我调试我的grpc服务并设置断点时,这是我的服务接收到的Context对象的结构。现在,如何获取任何HTTP请求header的值? 最佳答案 HTTPheader存储在元数据中。md,ok:=metadata.FromIncomingContext(ctx)应该可以获取传入的元数据。

git - 使用 Docker 在生产中部署 Go 服务

我正在使用Docker开发Go服务,并认为在编译时要在生产中部署代码,我只需要dockercompose和在我的注册表上发布的Docker镜像。因为我来自PHP世界,所以我习惯于克隆我的整个项目来部署它。有什么方法可以仅使用docker-compose文件部署我的项目?我在thispost上看到了我只能gitclone一个文件,但感觉这不是一个好方法,用Docker部署Go微服务的最佳实践是什么? 最佳答案 您的问题中有两个不同的问题,我不确定您要寻找哪个问题的答案。Q1:为我的Go项目创建Dockerfile的好方法是什么A1:看

git - Go:无法在符号链接(symbolic link)中打包

我有一个一次性的项目。在这个项目中,例如我有一个lib_project是到另一个目录的符号链接(symboliclink),例如:github_projectpull源代码到本地后,我更新了另一个git子模块(github_project是一个子模块)。然后我去这里编译项目。之后,我转到我的主项目并尝试运行命令go。我遇到异常:packagegithub.com/main_project/test.go:cannotfindpackage"github.com/main_project/lib_project/some_random_file.go"inanyof:/usr/local

git - git 在什么时候完成它的执行操作?

我在Go中有一个实用程序,它通过os/exec运行提交检查,然后对来自提交的文件执行一些操作。我怀疑此时此命令返回其返回码:_,err:=exec.Command("git","-C",sourceDir,"checkout",hash).Output()文件夹中的整个文件树都是最新的,我可以对文件做任何我想做的事,无需等待某些操作在后台完成。如果它是一个非常大的存储库,其中一个提交与另一个提交有很大不同,并且从一个提交切换到另一个提交时同步删除/添加/修改的文件需要时间怎么办?我可以在gitcheckout返回0后立即运行我的操作吗? 最佳答案

go - 向代理发送 TCP 数据包

我熟悉HTTP_PROXY并定义了一个DefaultTransport来代理HTTP请求。但是我找不到任何关于如何为TCP做同样的事情。这可能吗?还是必须依靠代理本身来转发数据包? 最佳答案 这是可能的,但不能使用HTTP代理。你想要一个SOCKS代理。查看https://godoc.org/golang.org/x/net/proxy提供SOCKS5拨号器的软件包。packagemainimport("fmt""os""golang.org/x/net/proxy")var(proxy_addr="my.socks.proxy.l

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

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

git - 去 dep 去生成

如何添加自动生成的Go依赖项?我有一个protobuf存储库,其根目录中有一个go文件,其中包含以下内容://go:generate./scripts/generate_go_sources.shpackageprotobuf上述脚本遍历“message/”子文件夹中的所有.proto文件,并生成go-sources。之后,存储库包含许多子包,如ptyes/package1/file.goptyes/package2/file.go我不想将这些文件checkin版本控制。我如何将此存储库与godep一起使用?我正在尝试切换到godep以进行依赖管理,但我无法说服它下载此存储库并执行“g

go - 由于 CLOSE_WAIT 和 TIME_WAIT 套接字上升导致代理服务器不稳定

我有一个用golang编写的socks5代理服务器。守护进程正在监听从15000到25000的10000个端口,所以这是一个代理列表。最近我们开始对一些客户进行测试,最终我们在其中5000个端口上获得了大约500rps。这不是我想的那么多,但我立即指出了一堆问题。服务器是Ubuntu18,8核,32G内存,1Gb网络。我一直观察到几乎800%的CPU,并且CLOSE_WAIT和TIME_WAIT套接字状态的数量不断增加。我仔细调查了大约一个星期的代码,但没有指出任何问题,所有连接都在关闭。pprof说这都是关于系统调用的,更准确地说是套接字读取。这里的ReadAtLeast是读取soc

http - 在重定向和代理上转到 http.Request header

https://groups.google.com/forum/#!topic/golang-nuts/OwGvopYXpwE正如在此线程中所见,当http.Client向重定向发送请求时,header会重置。有一个解决方法,如:client.CheckRedirect=func(req*http.Request,via[]*http.Request)error{iflen(via)>=10{returnfmt.Errorf("toomanyredirects")}iflen(via)==0{returnnil}forattr,val:=rangevia[0].Header{if_,o

http - golang程序判断用户是否使用代理

我希望我的golanghttp客户端仅在用户提供代理值时才使用代理。//MakeHTTPGET/POSTrequestproxyUrl,err:=url.Parse(proxy)tr:=&http.Transport{DisableKeepAlives:true,Proxy:http.ProxyURL(proxyUrl),}即使代理变量为空,上面的代码总是尝试通过代理进行连接。 最佳答案 感谢您的建议。现在我可以让它工作了。下面是修改后的代码。tr:=&http.Transport{}tr.DisableKeepAlives=tru