草庐IT

tcp-client-server

全部标签

go - golang 中 server.GracefulStop() 的行为

我有一个gRPC服务器,我已经实现了像这样正常关闭我的gRPC服务器funmain(){//Somecodeterm:=make(chanos.Signal)gofunc(){iferr:=grpcServer.Serve(lis);err!=nil{term这很好用。相反,如果我在主goroutine中编写grpcServer.Serve()逻辑并将关闭处理程序逻辑放入另一个goroutine,则server.GracefulStop()之后的语句通常不会执行.如果完全执行closeDbConnections(),一些DbConnections将关闭。server.GracefulS

go - kubebuilder的client.List方法如何使用?

我正在使用kubebuilder(版本1.0.8)为自定义资源开发自定义Controller。我有一个场景,我需要获取我的自定义资源的所有实例的列表,以便我可以与外部数据库同步。我见过的所有kubernetesController示例都使用client-go或直接通过http调用api服务器。然而,kubebuilder也给了我这个client.Client对象来获取和列出资源。所以我正在尝试使用它。在使用传入的Manager实例创建客户端实例后(即执行mgr.GetClient()),然后我尝试编写一些代码来获取我创建的所有环境资源的列表.funcsyncClusterWithDat

go - 如何为 golang tcp 服务器配置 GKE 负载均衡器?

部署golang服务器容器和gke负载均衡器后,我可以成功连接到负载均衡器的外部ip,但没有数据到达服务器容器。当我在本地运行服务器容器并将客户端指向本地主机时,它按预期工作。我将其更改为服务于http请求,并且它在相同的kuberneteslist上运行良好。但是,如果我尝试同时提供tcp和http(在不同的端口上),那么在gke上都不起作用,但在本地又可以正常工作。所以我怀疑这可能与我配置负载均衡器的方式或我在服务器中监听tcp连接的方式有关,这在gke上而非本地运行时会中断某些事情。K8s服务listapiVersion:v1kind:Servicemetadata:name:s

ssl - 如何在 Go 中建立到 memsql 的基于 ssl 的 tcp 连接

我正在尝试使用Go设置到memsql的基于ssl的tcp连接。应用程序/服务作为openshiftpod运行并用Go编写。我可以从该服务对memsql进行单向身份验证吗?我是否需要在memsql中启用任何端口来监听基于tls的ssl连接?除了将我的服务中的DSN更新为tls=true之外,还有什么方法可以自定义此配置。有人可以建议一种有效的方法来连接启用ssl的memsql吗?我已经关注了memsqldocumentation并将证书插入到memsqlmaster和聚合器中,并启用了权限检查,但我仍然能够进入memsql而无需在登录中提供rootCertificate。目前连接是通过以

sockets - 为什么当我在许多 goroutine 中发送一个 tcp shake packet(SYN) 时,我在每个 goroutine 中读取了很多响应包

我正在构建一个端口扫描器来检查远程机器上的某个TCP端口是否打开。为了提高性能,我只是构建一个TCPSYN数据包并将其发送到远程端口,而不是进行完整的3次握手。如果我成功接收到SYN-ACK数据包,那么该端口将被视为打开。这是我的部分代码:conn,_:=net.Dial("ip4:tcp",target)tcpSynPacket:=BuildTcpSynPacket()//hereIbuildatcpsynpacketconn.Write(tcpSynPacket.Marshal())deadlineTime:=time.NewTicker(time.Second*2)deferde

go - 当我更新节点或使用 client-go 部署时,我偶尔会遇到这样的错误 "the object has been modified"

当我更新节点或使用client-go部署时,我偶尔会收到这样的错误“对象已被修改;请将您的更改应用到最新版本并重试”。我的目标是添加一个污点/容忍度和一个一个节点/部署的标签。有人说应该用err=retry.RetryOnConflict(retry.DefaultBackoff,func()error{}),但是好像不行。funcAddFaultToleration(deploy*appsv1.Deployment,nsstring,clientkubernetes.Interface)(*appsv1.Deployment,error){updateDeploy,err:=clie

go - 如何修复 `kafka: client has run out of available brokers to talk to (Is your cluster reachable?)` 错误

我正在开发一个应用程序,该应用程序从sqs队列中读取一条消息,对该数据执行一些操作,然后获取结果并将其发布到kafka主题。为了在本地进行测试,我想在我的docker构建中设置一个kafka图像。我目前能够使用docker-compose在本地启动aws-cli、localstack和我的应用程序的容器。另外,我也可以毫无问题地启动kafka和zookeper。我无法让我的应用程序与kafka通信。我试过使用两个单独的撰写文件,也尝试过网络。最后,我引用了:https://rmoff.net/2018/08/02/kafka-listeners-explained/。这是我的docke

sql-server - 无法使用 'sa' 连接到远程 SQLServer

我正在尝试使用我正在编写的Go程序的连接字符串连接到SQLServer的远程实例。我有一个具有相同用户的远程数据库的本地版本。如果我使用这样的连接字符串连接到我的本地数据库,它工作得很好:DataSource=localhost;InitialCatalog=master;UserId=;Password=;现在,如果我使用相同的凭据,但我只是更改数据源,它也能正常工作:DataSource=;InitialCatalog=master;UserId=;Password=;现在,如果我尝试使用“sa”登录,它可以在本地运行,但不能远程运行。这很好用:DataSource=localho

mongodb - TCP连接管理

我在Go邮件列表中提出了这个问题,但我认为从SO那里得到更好的回应更为普遍。在使用Java/.Net平台时,我从来不需要像驱动程序那样手动管理数据库连接。现在,当尝试连接到具有非常基本的驱动程序支持的无sql数据库时,管理连接是我的责任。驱动程序允许连接、关闭、重新连接到tcp端口,但不确定我应该如何管理它(参见link)。我是否必须为每个数据库请求创建一个新连接?我可以使用其他第3方连接池库吗?谢谢。 最佳答案 我对MongoDB的了解还不够直接回答这个问题,但是你知道MongoDB是如何处理TCP请求的吗?例如,单个TCP连接的

【JavaEE初阶】第六节.网络原理TCP/IP协议

提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档文章目录前言一、TCP/IP协议五层协议栈;1.1应用层协议;二、传输层协议;2.1UDP协议;2.2TCP协议;      2.2.3序号2.3UDP和TCP协议传输的区别;2.4超时重传;2.5连接管理(面试中最高频的问题.网络知识中,最最高频的考题,没有之一!!!)2.5.1建立连接(“三次握手”)2.5.2断开连接(“四次挥手”)2.5.3三次握手;四次挥手总结;2.6滑动窗口2.7流量控制2.8拥塞控制2.9流量控制和拥塞控制的联系;2.10延时应答;2.11捎带应答2.22面向字节流2.23TCP连接出现异常时,如何处