草庐IT

in-memory-data-grid

全部标签

postgresql - Golang、postgres事务: pq: unexpected transaction status in a failed transaction

Go:v1.3db:postgres使用lib/pq我有一个更新postgres数据库的应用程序。postgres数据库是使用pgbouncer设置的。因此,通过事件连接,我有运行插入和更新的代码。这是插入代码:func(sitemap*SiteMapData)InsertSiteMap(dbConnection*sql.DB)(int64,error){tx,err:=dbConnection.Begin()iferr!=nil{l4g.Error("InsertSiteMap:couldnotbeingtransaction:%v",err)return0,err}result,e

memory - 使用 Go 在主机之间共享变量

我有一个用golang编写的应用程序,它会将基本数据加载到全局变量中,这样可以使应用程序响应速度快,并导出一个http接口(interface)来在用户对数据库进行更改时更新变量。但是我部署了另一台服务器,并使用了代理。出现了一个问题,当用户向更新url发送http请求时,它会将流量加载到其中一台服务器。因此该服务器更新此var,但其他服务器不更新。比如utils.go:packageutilsvarBasicDatasmap[string]*MyModelfuncUpdateVar(){//dosomework}funcPreLoadVar(){//preloaddatatobasi

戈朗 : How can I populate a multi-struct map in a loop?

我有客户与API交互的日志文件。我想解析这些日志并将结果提供给结构映射,以便我可以将数据组织成有用的信息。例如,我想响应以下查询:“显示每个用户每天的请求总数”。我已经创建了一个看起来足够的结构来保存数据。但是,当我尝试运行程序时出现错误:无效操作:dates[fields[1]](type*Dates不支持索引)[processexitedwithnon-zerostatus]。http://play.golang.org/p/8u3jX26kttpackagemainimport("fmt""strings")typeStatsstruct{totalNumberOfRequest

sockets - 如何找到 IP :Port of incoming client in TCP Connection

收到来自conn,err:=listener.Accept()的连接后,我想在conn的另一端找到客户端的地址。我已经尝试使用conn.LocalAddr()和conn.RemoteAddr()(Documentation)来执行此操作。.LocalAddr()只是给出服务器进程的地址。.RemoteAddr()为客户端提供了正确的IP,但与我所知道的客户端绑定(bind)的端口号截然不同。如果它有什么不同,我用在同一台机器上运行的两个独立进程来做这件事。一个是客户端,一个是服务器。关于如何找到客户端的正确IP:Port的任何想法?我是要使用LocalAddr还是RemoteAddr?

json - golang : json. Unmarshal() 返回 "invalid memory address or nil pointer dereference"

我从websocket收到一条json消息,json字符串接收正常。然后我调用json.Unmarshal并引发运行时panic。我查看了其他示例,但这似乎是另一回事。这是代码:functranslateMessages(ssocket){message:=make([]byte,4096)for{fmt.Printf("Waitingforamessage...\n")ifn,err:=s.Read(message);err==nil{command:=map[string]interface{}{}fmt.Printf("Receivedmessage:%v(%dBytes)\n"

memory-leaks - 这会导致 Go 中的内存泄漏吗?

在下面的代码中,我有两个结构类型:ObjectDefinition和fieldDefinition都在同一个包中。fieldDefinition结构只能通过ObjectDefinition上的方法创建,以防止出现孤立字段(相关系统将是可扩展的CRM)。AddReferenceField方法应该创建一个新的fieldDefintion,在其上设置一些变量,将其添加到父结构的*fieldDefinitionslice中,然后然后还返回指向它的指针,以允许程序员轻松地进一步操作该字​​段,而无需从slice中查找和检索它。typeObjectDefinitionstruct{myIdid.I

android - 戈朗 : Android apps with gomobile crash when connect in UDP

我在gowithmobilepackage中编写Android应用程序,应用程序在到达以下代码后崩溃:ServerAddr,_:=net.ResolveUDPAddr("udp",SERVER_IP_AND_PORT)LocalAddr,_:=net.ResolveUDPAddr("udp",":0")Conn,err:=net.DialUDP("udp",LocalAddr,ServerAddr)buf:=[]byte("lalala")_,err:=Conn.Write(buf)//appscrashonthisline其中(实际ip用“x”表示):constSERVER_IP_A

data-structures - 在 Go 中存储和迭代命名嵌套数据结构的惯用方法?

我的问题分为两个:(1)为下面的taskList存储数据的最佳方式是什么,以及(2)迭代这种结构的最佳方式是什么?我想要命名task1因为它们是独特的任务并且不应该有ID冲突。我想要单独命名为subtask0,因为它们是具有不同要求的独特任务。下面是我意图的伪围棋表示:packagemainimport"fmt"fnmain(){consttaskList:={"task1":{"subtask0":"api.example.com/stuff/""subtask1":"api.example.com/stuff/""subtask2":"api.example.com/stuff/"

mysql - global var out out init.go in revel

(编辑以修复大写和添加上下文)在revel的init.go中,我有一个全局变量:DB。packageappimport("database/sql""fmt"_"github.com/go-sql-driver/mysql""github.com/revel/revel")varDB*sql.DBfuncInitDB(){connstring:=fmt.Sprintf("revel:revel@tcp(localhost:3336)/revel")varerrerrorDB,err=sql.Open("mysql",connstring)iferr!=nil{revel.INFO.Pr

pointers - panic : runtime error: invalid memory address or nil pointer dereference

我目前正在使用Go的Soundcloud包装器,我想打印用户的关注者,但这是我第一次遇到指针问题。构建错误后panic:runtimeerror:invalidmemoryaddressornilpointerdereference[signal0xbcode=0x1addr=0x10pc=0xc9c26]代码packagemainimport("fmt""github.com/njasm/gosoundcloud")funcmain(){//callbackurlisoptional-nilinexamples,_:=gosoundcloud.NewSoundcloudApi("Cl