草庐IT

端口转发

全部标签

go - 如何配置 krakend.json 转发参数化 url?

基本上我只是想转发这个请求:http://somehost:4321/api/v1/{uid}/profile进入这个:http://123.45.67.89:4321/api/{uid}/profile我在krakend.json中完成了这个:{"version":2,"timeout":"3000ms","cache_ttl":"300s","name":"myapi","output_encoding":"json","port":4321,"endpoints":[{"endpoint":"/api/v1/{uid}/profile","method":"GET","heade

go - 如何查看UDP IP和端口是否打开

如何查看UDP端口和IP是否开放?我已经检查了net.DialUDP()方法,但显示错误,"cannotassignrequestedaddress"ln,err:=net.DialUDP()我想要的结果是“地址已被使用” 最佳答案 要检查一个udpip和端口是否打开,尝试在这个端口上监听,即在这个端口上设置一个服务器。您可能会收到一个错误消息,提示地址已被使用。sAddr,err:=net.ResolveUDPAddr("udp","ipaddress:port")iferr!=nil{log.Fatalln(err)}sConn

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

routing - 分布式负载转发

我正在尝试设计一个将部署在AWS不同区域的分布式应用程序。这个想法是,用户离部署区域越近,延迟就越低。我的问题是,当预期接收者位于区域B时,是否有任何论文、设计模式或算法可以可靠地将从区域A发出的请求转发到区域B。这意味着区域A中的用户只会触发请求,但实际交易是从区域B中的用户到部署在那里的应用程序。因此负载将被路由,其余的处理将在接收者端发生。希望我说得有道理,但如果它有助于思考,我想到的一个例子是录音。它不会将流媒体从区域A定向到B,而是先复制到区域B,然后从那里流式传输给用户。 最佳答案 如果您要使用geo-dns(我认为AW

mysql - 如何使用 github.com/go-sql-driver/mysql 指定服务器的端口号?

我正在为MySQL使用以下包http://godoc.org/github.com/go-sql-driver/mysql#MySQLDriver.Open我的代码是:import("bufio""database/sql"_"github.com/go-sql-driver/mysql")db,err:=sql.Open("mysql","me_id:username@tcp(db1.abc.com)/dataname?timeout=2s")但我收到错误消息error:dialtcp:missingportinaddressdb1.abc.com无论如何我可以指定没有任何端口号的服

Linux 不接受到端口 25 的连接

我在一个简单的smtp服务器上工作,但一直坚持在端口25上接受TCP连接。我尝试运行到服务器并从本地主机使用telnet,它工作正常。在另一台计算机上,它说正在尝试(ip)...当从GMail发送电子邮件到我的smtp服务器时,它没有看到任何连接Golang中的相关代码funcmain(){listener,err:=net.Listen("tcp",":25")checkError(err)for{conn,err:=listener.Accept()checkError(err)gohandleConnection(conn)}}它是一个运行在DigitalOcean上的Ubunt

go - 在端口 80 和 apache 中运行 beego

我试图在谷歌计算引擎实例中运行我的beego。我让它在端口8080上运行。但是当我尝试将它更改为端口80时,它会出现ListenAndServePermissiondenied错误。我该怎么做才能让它在端口80上运行。我是否可以使用Apache2为beego项目提供服务,以便我可以在不执行beerun的情况下运行该项目? 最佳答案 1024以下的端口具有特权,因此您需要root访问权限才能运行监听其中任何端口的进程。对于您的第二个问题:您可以使用apache或任何其他反向代理来托管您的应用程序。这基本上意味着您运行两个独立的进程(一

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","

sockets - 如何调试以下 Go 代码,它试图与 IP 地址和端口建立 TCP 连接?

我从Bittorrent跟踪器获取特定torrent文件的IP地址和端口号。它代表bittorrent网络上的对等点。我正在尝试使用此代码连接到对等方。连接总是超时(getsockopt:操作超时)。我想我在这里遗漏了一些非常基本的东西,因为我在python中尝试了相同的代码,结果完全相同,操作超时。它发生在每个对等IP地址上。我下载了这个BT客户端-https://github.com/jtakkala/tulva它能够使用这种类型的代码(第245行,peer.go)从我的系统连接到对等点。我还能够使用类似的代码连接到在本地主机上运行的tcp服务器。在JimB的评论和KennyGra

http - 使用 Beego 将服务器 API 转发到另一个端口

我有两个网络应用程序在同一个虚拟机中运行。一个是监听443端口的Beego,一个是8000端口的Centrifugo消息服务器。如果用户由于他的ISP不允许连接端口8000,我是否可以转发https://my.domain/chat_api(在443端口被Beego拦截)到https://my.domain:8000/chat_api(由Centrifugo在端口8000提供服务),以便我的聊天客户端连接端口443就像连接端口8000一样?如果是,在Beego的架构下如何实现? 最佳答案 你不需要在Beego中实现它。只需设置一个反