草庐IT

通信网络

全部标签

go - 无需输入网络拨号即可模拟网络连接

我目前正在研究vendorgobalancer代码。我需要删除tcp拨号调用并在没有调用的情况下模拟成功的连接。在下面的代码中,有这一行:ds,err:=net.Dial("tcp",backend.String());iferr!=nil{log.Printf("failedtodial%s:%s",backend,err)us.Close()return}它所做的是拨号到tcp服务器,然后返回连接ds中的响应,在此处定义:https://golang.org/pkg/net/#Dial我需要的是在不执行tcpdialer的情况下获取ds。我是尝试在没有任何实际tcp调用的情况下测试

linux - 给定网络掩码,计算可用主机的数量?

在Go中,我找到了这样一个算法,但是我不明白,谁能帮我解释一下,谢谢!funcnetworkSize(masknet.IPMask)int32{m:=net.IPv4Mask(0,0,0,0)fori:=0;i 最佳答案 将网络掩码中的每一位取反,将结果视为双字节序的32位整数的4个字节,并将结果加1。所以255.255.252.0=>00000000.00000000.00000011.11111111=>1023,加1就是1024。 关于linux-给定网络掩码,计算可用主机的数量?

PHP/Go 套接字通信

我正在尝试使用套接字在Go和PHP之间进行通信。我使用的代码是:开始:fmt.Println("Launchingserver...")ln,_:=net.Listen("tcp",":8080")conn,_:=ln.Accept()for{message,_:=bufio.NewReader(conn).ReadString('\n')fmt.Print("MessageReceived:",string(message))conn.Write([]byte("test"+"\n"))}PHP:$address=gethostbyaddr($ip);$socket=socket_c

http - TCP 是同一主机中 Go 程序之间通信的最佳方法吗?

假设我有两个独立的Go程序在我的本地主机上运行,​​就性能而言,TCP是否是在两个程序之间传输数据的最佳方法? 最佳答案 简短的回答是否定的。TCP/IP堆栈很慢,尤其是TCP部分。因此,就性能而言,您最好使用本地进程间通信方法,例如应用程序或Unix套接字之间的共享内存。如果您必须使用网络堆栈进行通信(例如,您计划在主机之间移动应用程序),那么UDP或原始套接字是性能方面的最佳选择。只有当你:必须使用网络并且您需要一个可靠的通信channel,那么TCP是一个不错的选择。因此,只需浏览您的要求并确定它是否是最适合您的方法。

docker - 如何让两个运行 flask 服务和 golang 服务的 docker 容器相互通信?

我有一个flask服务通过docker-compose在端口5000上运行。同样,我有一个不同的go服务通过另一个docker-compose在端口8000上运行。Golang服务需要调用在5000上运行的flaskAPI。我是在让go服务调用flask服务时遇到麻烦。我尝试添加docker-network但失败了。与单个docker-compose相比,通过不同的docker-compose运行这两种服务的优缺点是什么?(顺便说一句,我无法在单个docker-compose中成功运行它们)。dockerpsrunningboththecontainers.FlaskDocker组合v

go - 同一网络中的应用程序和服务器之间的通信

关闭。这个问题需要更多focused.它目前不接受答案。想改进这个问题吗?更新问题,使其只关注一个问题editingthispost.关闭3年前。Improvethisquestion我正在开发将在kubernetes上运行的CI/CD工具。该应用程序将负责创建一个k8s作业对象,该对象将被视为一个slave以运行管道。图像,slave将运行完全取决于用户,所以我无法控制它,除了它会在与CI/CD应用程序相同的本地网络中运行。我的问题是;在这种情况下,如何使CI/CD工具与从属之间进行通信?为了为此添加更多上下文,我想创建类似于Jenkins的东西。Jenkins与kubernetes

networking - Go 中的点对点网络

在Go中实现点对点网络时,最好从哪里开始?Go中是否有任何好的特性可以更轻松地实现对等网络? 最佳答案 channel使得在Go中处理异步网络事件比许多其他语言更容易。您应该先阅读NetworkprogramminginGo. 关于networking-Go中的点对点网络,我们在StackOverflow上找到一个类似的问题: https://stackoverflow.com/questions/21946290/

go - 在 CentOS 7 上将 Go 作为守护进程网络服务器运行

我正在尝试从PHP迁移到Go,并计划完全放弃nginx。但是我不知道如何在后台将gohttp网络服务器作为守护进程运行,我也不知道如何在我重新启动时自动启动网络服务器,或者如何终止进程。对于nginx,我所做的就是$systemctlstartnginx.service$systemctlrestartnginx.service$systemctlstopnginx.service$systemctlenablenginx.service$systemctldisablenginx.service这很方便,但似乎我不能用Gohttp服务器来做到这一点。我必须像任何其他Go程序一样编译和

http - Golang 网络应用程序本地化

我有一个用golang编写的网络应用程序,我计划以多种语言提供它,我查看了多个可用的l18n包,但有些事情我不清楚。哪些软件包最适合确定用户区域设置并相应地加载站点?比如浏览器偏好或位置? 最佳答案 您可以使用https://github.com/nicksnyder/go-i18n/然后在您的项目中,您必须创建一个名为i18n/的文件夹并使用如下函数:import("fmt""io/ioutil""github.com/nicksnyder/go-i18n/i18n")funcloadI18nFiles(){files,_:=io

测试网络/http?

我对如何构建goweb应用程序及其测试有点困惑。我读过HowtoWriteGoCode但还是不明白。例如,我有一个名为“beacon”的go项目,根目录下有一个beacon.go文件。添加一个简单的beacon_test.go文件(从http://golang.org/pkg/net/http/httptest/#example_Server逐字复制)会导致此错误:$gotest#github.com/jelder/beacon./beacon_test.go:11:mainredeclaredinthisblockpreviousdeclarationat./beacon.go:21