草庐IT

Java数据库驱动设计

全部标签

go - 如何分别从服务器上运行的两个并发进程接收数据?

我正在尝试构建一个基本的客户端/服务器架构,其中两者之间有一些数据交换,并且双方都有一些处理。所以我的服务器有两个线程正在向客户端发送一些数据。我想知道如何将这些数据分别接收到两个不同的变量中。我了解到,尽管我仍然不确定,这与竞争条件、互斥锁等概念有关。我对它们有一个基本的了解,但从未实际使用过它们。我想知道关于这个问题是否有一些预先设计的解决方案。服务器端:funchandleConn(connnet.Conn){gofunc(){io.WriteString(conn,"Text1")}()gofunc(){io.WriteString(conn,"Text2")}()}客户端:f

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

database - 如何解决 go 编程语言中的数据库结构问题?

我正在尝试创建postgresql数据库结构以在Golang中自动化系统。此代码有效;packagemainimport("database/sql""fmt"_"github.com/lib/pq")funccheckError(errerror){iferr!=nil{panic(err)}}const(host="localhost"port=5432user="postgres"password="123"dbname="DatabaseName")funcmain(){psqlInfo:=fmt.Sprintf("host=%sport=%duser=%s"+"passwor

go - 如何使用 golang libp2p 流向多个主机发送数据?

我的问题是指golang中的libp2p库:https://github.com/libp2p/go-libp2p此视频介绍了背景:https://www.youtube.com/watch?v=hP0hSZ7E7_Y网络中的对等点通过缓冲流rw进行通信。对于每个新的连接对等点,都会创建一个新流,使用地址将他连接到现有对等点。这意味着有多个流,但并非所有对等点都直接相互连接。使用这些流,对等点可以通过从中读取和写入数据rw:=bufio.NewReadWriter(bufio.NewReader(stream),bufio.NewWriter(stream))通过写入消息`rw.Wri

Dockerizing 一个面向包的设计去模块应用程序

我正在按照描述的面向包的设计方式尝试go模块here这样多个可执行服务就可以“dockerized”,但我正在努力在一个repo中正确连接。我无法使用这种方法成功构建docker镜像。大多数在线示例都适用于单模块方法,其中main.go和dockerfile位于根文件夹中。我的目录结构是这样的项目1-应用程序接口(interface)-build-服务1-docker文件-服务2-docker文件-命令-服务1-main.go-服务2-main.go-部署-文档-内部的-第三者-go.mod-go.sum-生成文件-vendor#AccepttheGoversionfortheimag

mongodb - 用MongoDB官方Golang驱动可以查到一条记录,但是记录是空的

我正在尝试学习Go,我写了一些代码来处理MongoDB测试数据库,插入一些通用的“项目”。这是代码:https://pastebin.com/ptNwKbk2我可以毫无问题地插入和更新记录,但是当我尝试FindOne或查找记录时,出现的是一些空壳,它找到了记录,但记录仅显示其ID。首先找到[第89行]:err=collection.FindOne(context.TODO(),filter).Decode(&resultItem)结果:Foundasingledocument:{ID:ObjectID("5cb488c30eeb652e64ecdaeb")itemID:priority

unit-testing - 表驱动测试中的竞争检测

我有一个表驱动测试和表循环外的initvar(worker)。我使用gotest-raсe运行测试并添加了t.Parallel()并且没有检测到竞争条件。我可以假设我的测试没有竞争条件吗://Thismockcouldbeinaseparatefile.typemockWorkerstruct{}//implmentourWorkeriterfacefunc(mdmockWorker)Work()error{returnnil}typemockDoerstruct{ErrorerrorWorkerworker}//implmentourDoeriterfacefunc(mdmockDo

mysql - 通过 API 创建数据未使用 beego 保存

版本:beeversion______|___\||_//______|___\/_\/_\||_//|__/|__/\____/\___|\___|v1.10.0├──Beego:1.11.1├──GoVersion:go1.12.1创建一个beego项目:beenewquickstart使用beego的bee工具生成post脚手架:beegeneratescaffoldpost-fields="title:string,body:text"-driver=mysql-conn="root:root@tcp(127.0.0.1:3306)/quickstart"路由器/router.

go - 在 golang 项目中查询 sqlx 后数据库连接仍在使用中

我在一个使用sqlx和postgres的golang项目中工作。当应用程序启动时,我打开一个与数据库的连接并像这样使用它:varconnRO*sqlx.DBvarconnRW*sqlx.DB.../GetInstance-willreturntheconnectionopenedtothedatabasefuncGetInstance(readonlybool)*sqlx.DB{ifreadonly{returnconnRO}returnconnRW}问题是在某些代码块中连接仍在使用中,这里有一个例子:instanceRW:=database.GetInstance(false)ins

mongodb - map[string]interface{} 自切换到新的 go mongo 驱动程序后未被正确解析

我正在切换到新的mongogo驱动程序(mongo-go-driver),远离mgo尽管解码方法没有改变(变成map[string]interface{}),但我们的一个函数不再工作我相信正在发生的事情是返回的数据没有作为map[string]接口(interface)正确处理{}摄取的数据是一个mongo聚合查询:result=map[query_key:procedure_on_citiesquery_type:runprocedurequery_value:map[aggregate:[map[£match:map[Source:Cities]]map[£sort:map[Ord