草庐IT

Java检测丢失的连接

全部标签

sockets - Golang - 为到不同服务器的多个连接扩展 websocket 客户端

我有一个websocket客户端。实际上,它比下面显示的基本代码复杂得多。我现在需要扩展此客户端代码以打开到多个服务器的连接。最终,从服务器接收到消息时需要执行的任务是相同的。处理这个问题的最佳方法是什么?正如我上面所说,接收消息时执行的实际代码比示例中显示的要复杂得多。packagemainimport("flag""log""net/url""os""os/signal""time""github.com/gorilla/websocket")varaddr=flag.String("addr","localhost:1234","httpserviceaddress")funcm

go - 如何与本地主机上的 mysql 服务器建立连接?

我想与本地主机上的sqlserver建立新连接,以便能够从sqlserver获取数据。但是在连接时出现了一些问题。错误:-[mysql]2019/02/1115:30:00driver.go:81:net.ErrorfromDial()':dialtcpserverPort:3306:connect:connectiontimedout我使用的代码是funcConnectMsqlDb()(db*sql.DB,errerror){db,err=sql.Open("mysql",fmt.Sprintf("%s:%s@tcp(%s:"+SqlDbPort+")/"+SqlDatabase,S

go - 通过 SSH golang 连接到 mongoDB

我需要通过ssh连接到远程mongoDB服务器,我之前是用mysql做的,它看起来像:sshcon,err:=ssh.Dial("tcp",fmt.Sprintf("%s:%d",sshHost,sshPort),sshConfig)iferr==nil{defersshcon.Close()mysql.RegisterDial("mysql+tcp",(&ViaSSHDialer{sshcon}).Dial)mgo包里有类似mysql.RegisterDial的函数吗? 最佳答案 将隧道功能添加到您的代码中确实没有意义。一个简单的

ssl - RabbitMQ - Tls 连接 - Golang

我使用以下链接配置了RabbitMQ连接:https://github.com/streadway/amqp/blob/master/examples_test.go我根据此处的说明创建的证书:https://www.rabbitmq.com/ssl.html#enabling-tls-paths我使用安装在docker中的RabbitMQ3.7.0。调用amqp.DialTLS后,我在服务器端(在docker日志中)收到“证书错误”错误。我想问题是证书应该包含服务器名称,如果是这样,如果RabbitMQ安装在docker中,我应该在证书中设置哪个服务器名称?除此之外,还有什么想法吗?

firebase - 当路径中的数据不存在时如何使用 Go Firebase-Admin SDK 检测空结果

我正在使用以下代码从Firebase实时数据库中获取对象。typeItemstruct{titlestring`json:"title"`}varitemItemiferr:=db.NewRef("/items/itemid").Get(ctx,&item);err!=nil{log.Infof(ctx,"Anerroroccured%v",err.Error())}log.Infof(ctx,"Item%v",item)如果实时数据库中的给定路径不存在数据,SDK将不会返回错误,相反,我将在变量item中得到一个空结构。检测路径上的数据不存在的最干净/最可读的方法是什么?我已经搜索了

java - 在 Eureka Server 中,发现和注册服务/应用程序不是在 Spring 中开发的

如何在EurekaServer中发现和注册没有使用Spring(例如,在Java-JEE和Go上)构建的Web应用程序?在Spring-Boot应用程序中,很容易添加这些注释:@EnableDiscoveryClient@SpringBootApplication之前publicclassEurekaClientApp{publicstaticvoidmain(String[]args){SpringApplication.run(EurekaClientApp.class,args);}}在配置中,application.propertieseureka.client.registe

reactjs - 如何使用 Golang Gorilla/mux 托管并发 websocket 连接?

在此先感谢您的任何帮助或建议!我正在构建一个国际象棋应用程序,前端使用Reactjs,后端是使用Golillamux库用Golang编写的服务器。后端是一个供人类用户下棋的国际象棋引擎。React前端在顶级构造函数中创建与服务器的WebSocket连接。该应用程序适用于单个连接。但是,在打开第二个浏览器选项卡时,第一个浏览器选项卡的Websocket连接丢失。服务器报错,readerror:websocket:close1001(goingaway)然后,readerror:readtcp127.0.0.1:8081-\u003e127.0.0.1:64146:useofclosedn

go - 为什么这个 go 例程在关闭阻塞读取连接时随机无法退出?

为什么这个接收者在连接关闭时进入例程拒绝终止这按预期运行,但随后随机地,每调用20-10,000次,接收器将无法关闭,然后导致goroutine泄漏,导致100%cpu。注意:如果我记录所有错误,如果conn.SetReadDeadline被注释掉,我将在关闭的channel上看到读取。使用时,我将i/o超时视为错误。这运行了10k个周期,其中主进程启动了11对这样的发送/接收方,它们在主进程发送关闭信号之前处理了1000个作业。此设置在一夜之间运行了6小时以上而没有任何问题,达到10k个周期标记,但今天早上我无法让它运行超过20个周期而没有将接收器标记为未关闭和退出。funcsend

docker - 无法连接到 docker 容器中的数据库主机,从 api-service 到 db-service,以便在 golang 中使用 goose 进行迁移

goose是帮助我运行所有*sql文件并在数据库中运行查询的迁移工具。我想在我的api服务的docker容器中使用此工具自动执行迁移(创建表和其他内容)。问题是当docker运行命令“gooserun”时出现错误-gooserun:dialtcp:lookupdbon192.168.63.6:53:nosuchhost。docker-composeservices:db:build:./dbvolumes:-./db/pgdata:/pgdataimage:postgresports:-"5432"restart:alwaysenvironment:-POSTGRES_USER=use

json - 如何通过遍历 JSON 在 golang 中显示丢失的键?

我正在为我的应用构建一个翻译工具。我有2个不同的json文件(en.json、fr.json),其中包含我的键和值。en.json文件是引用文件,这意味着如果此文件中存在的键不存在,则需要将它们添加到fr.json文件中。有关更多详细信息,如果key存在于en.json而不是fr.json中,我们需要显示,但如果key仅存在于fr.json中,则不算在内,我们不会在屏幕上显示任何内容。如果key已经存在于两者中,我们就不需要在屏幕上显示任何内容。en.json文件是具有以下键的引用文件:{"i18n-outterJSON":{"i18n-value1":"value1","i18n-v