草庐IT

通信模式

全部标签

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

regex - 匹配在 golang 中以逗号或空格一致分隔的重复模式

我正在尝试解析一个字符串文字中的多个标签。例如name=testName,key=testKey,columns=(c1,c2,c3),我可能会考虑在不久的将来在此字符串中添加更多具有不同语法的标签。所以研究正则表达式来实现它是很自然的。至于语法:有效:`name=testName,key=testKey``name=testName,key=testKey``name=testNamekey=testKey``name=testNamekey=testKey``name=testNamekey=testKeycolumns=(c1c2c3)``name=testNamekey=tes

go - 如何使用构建器模式构造动态实现接口(interface)的结构

我正在尝试使用builderpatterns(从Java借来的)允许结构实现接口(interface)。例如,理想情况下我会喜欢这种代码模式:packagemainimport"fmt"typeOnerinterface{One()int}typeTwoerinterface{Two()int}funcmain(){s:=NewObject().WithOne(1).Build()_,ok:=s.(Oner)fmt.Println(ok)//Printstrue_,ok=s.(Twoer)fmt.Println(ok)//Printsfalset:=NewObject().WithOn

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

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

并发模式帮助 - 扇入并返回结果?

我正在编写一个快速并发集成测试包。我已经编写了POC,现在我正在尝试为它想出一个新模式。我希望遵守以下规则:一个测试套件可能有很多测试一个测试套件必须有n个worker来运行TestPreppers一个测试套件必须有n个worker来运行TestValidators测试必须通过准备才能运行验证一个测试可能有很多child在运行子测试之前,测试必须通过验证结构如下:packageconctestfuncNew()*TestSuite{return&TestSuite{nil,1,1,make(chanTestPrepper),make(chanTestValidator)}}typeTe

java - 用于故障排除的指标模式分析

当我解决一些站点问题时,我需要检查许多指标,例如CPU、内存、应用程序指标等。通常,我想自动了解以下项目(无需人工一一检查所有指标):在此期间有多少指标出现峰值。如果指标X与指标Y具有相同的模式如果度量X具有一些周期性特征。对于第1项和第2项,我想我可以通过计算一些变化率来得到它。对于第3项,我目前还不知道。我的问题是:我们是否已经有一些可以在这里使用的库,语言(Go、Java、Python都可以)。您对需求3有什么建议吗?=====更多背景:我已经设置了Prometheus(监控系统),但我的问题是我想自动分析这些指标。例如:用户输入:这里有1000个时间序列数据,我在时间1到时间2

pointers - 为什么我的自定义错误类型会导致特定模式的错误?

这个问题在这里已经有了答案:MethodSets(PointervsValueReceiver)(3个答案)关闭4年前。我正在为go的接收器和指针而苦苦挣扎。我发现第4种模式会导致错误。为什么这种模式会导致错误,有什么区别?提前致谢。typeMyErrorstruct{}//OKpatternfunc(eMyError)Error()string{return"somethingbadhappened"}funcrun()error{returnMyError{}}//OKpatternfunc(eMyError)Error()string{return"somethingbadhap

go - GO 中的工厂模式(包装器)

作为学习练习,我着手编写一个简单的包装器来包装"go.uber.org/zap",并可能在每次我的日志记录功能运行时添加一些指标(statsD)呼吁让这变得有值(value)。.Info实现按预期工作。有趣的是,.Infow不起作用。我似乎无法让它为...interface{}类型工作,并且出现错误:2019-08-09T23:46:27.250-0400DPANICzap/sugar.go:179Ignoredkeywithoutavalue.{"ignored":[{},{}]}完全实现:packageiloggerimport("reflect""go.uber.org/zap"

go - 如何检查一个字符串在 GO 中是否有超过 n 个重复模式?

我想检查一个字符串是否包含超过阈值的重复模式。比如这两个字符串都超过了阈值2:"xyzxyzxyz"//contains"xyz"3timesinsuccession"abxyxyxyns"//contains"xy"3timesinsuccession有谁知道这是怎么可能的? 最佳答案 使用“重复”修饰符。re:=regexp.MustCompile(`(xy){3,}`)//match"xy"3ormoretimesfmt.Println(re.MatchString("abxyxyns"))//falsefmt.Println