草庐IT

node_database

全部标签

node.js - UDP 和网络套接字的数据丢失

我有以下场景:本地PC通过蓝牙以50.000位/秒的速度接收数据样本。数据通过UDP发送到某个服务器。服务器依次通过网页/JavaScript和网络套接字将数据分发到处理数据的已连接浏览器。最终,来自浏览器的结果通过UDP传回本地PC。到目前为止,我正在试验严格的本地设置,即一切都在一台拥有四核CPU的机器上运行。我已经用node.js和golang编写了服务器代码。在这两种情况下,都存在严重的数据丢失,即即使只有一个Web套接字客户端连接,也并非服务器成功接收到通过UDP发送的每个样本。造成损失的瓶颈在哪里?一切都在本地机器上运行是事实吗?会不会是websocket带宽太小了?使用W

go - 使用与 node.js 或 Python 不同的结果的 Go 签名的 Hmac/sha1 消息

我正在尝试使用Go生成Hmac/SHA1签名,但我得到的结果与我使用Node.js或Python进行测试时的结果不同。这是我在Go中的代码:signature:=hmac.New(sha1.New,[]byte(signKey))signature.Write([]byte(buffer))returnhex.EncodeToString(signature.Sum(nil))这是我在Node.js中的代码:returncrypto.createHmac('sha1',signKey).update(buffer).digest('hex');python:returnhmac.new

node.js - 我可以用 Nodejs 而不是 go 编写 kubernetes Controller 吗?

正在研究它以制作很棒的api东西,但我还不知道Go。我看到有go的生成器,但我宁愿一开始使用更熟悉的语言。这是可能的还是我应该开始学习围棋? 最佳答案 Kubernetes的客户端库有多种语言版本。有关示例,请参见此处:https://kubernetes.io/docs/reference/using-api/client-libraries/ 关于node.js-我可以用Nodejs而不是go编写kubernetesController吗?,我们在StackOverflow上找到一个

database - 如何在 bolt 中获取桶中的键数

我正在使用bolt来存储数据,在存储桶中我将key存储为版本控制,并且我只想在存储桶中保留最大数量的版本。然后我想知道桶中的键是否太多。但是,我找不到比遍历所有键并计数更简单的方法。有谁知道如何获取桶中的键数?提前谢谢你。 最佳答案 我从未听说过或使用过bolt,但是thedocs建议Stats方法会做你想做的事。 关于database-如何在bolt中获取桶中的键数,我们在StackOverflow上找到一个类似的问题: https://stackoverf

database - 我可以使用 golang 为 sqlite3 数据库中的每个新用户增加数值吗?

我问是否可以使用golang和xorm在sqlite3数据库中增加每个新用户的ID号而不会导致异步问题?我将使用golang作为http服务器。所以可能很多用户在同一时间http请求和注册例如这是我的数据库sidintusernamestringpasswordstring现在的问题是,例如我之前有5个用户,最后一个用户sid是5,所以可以增加用户6的sid号码而不会出现问题吗?主要问题是这样的;在我的方法中,当服务器收到新的注册请求时。服务器检查来自sqlite3数据库的最后一个sid。例如,如果最后一个sid是5服务器增加这个数字+1所以我们的sid得到6但是当服务器繁忙时尝试将新

database - go database/sql - 奇怪的连接和事务行为

使用Go和使用database/sql的数据库驱动程序的实现,我似乎遇到的交易行为似乎是每次交易后都需要关闭连接。如果我不这样做,数据库将耗尽连接,并且我会收到以下错误:"BeginTransactionfailed.Error=Error1040:Toomanyconnections".Thishappensafter101commits.我尝试使用来自github的两个不同驱动程序-lib/pq和go-sql-driver/mysql,结果相同。这种行为对我来说很奇怪。这是预料之中的,还是我做错了什么?根据要求,代码如下:packagemainimport("database/sq

node.js - 如何从 Node 中正确终止 Go 进程

我想构建一个生成Go服务器的Grunt任务,然后在Go源文件更改时终止并重新生成它。我正在这样生成Go进程:goProcess=child_process.exec('gorunmain.go',...稍后我试图像这样终止进程:if(goProcess){goProcess.kill('SIGINT');}但是Go进程并没有消亡。如何正确终止Node中的Go进程?我这里有一个工作示例https://github.com/sporto/go-must-die 最佳答案 child_process.exec在shell中运行命令,似乎返

database - KyotoCabinet (TreeDB) 性能严重下降

我选择TreeDB作为KyotoCabinet后端,希望它能扩展到巨大的值(value)。不幸的是,有一个问题:#./kyotobenchGeneratedstringlength:10241000records,typet74.008887msthroughput:13511/sec2000records,typet145.390096msthroughput:13756/sec4000records,typet290.13486msthroughput:13786/sec8000records,typet584.46691msthroughput:13687/sec16000rec

node.js - 通过 POST 登录不会产生有效 session

我目前正在尝试将一个小型应用程序从nodejs转换为golang(因此有两个标签),但我在这样做时遇到了一些麻烦。本质上,这是一个非常简单的httpPOST登录,我似乎无法理解。背景是我的大学提供日历导出功能,我想提供这个日历作为可以添加到GoogleCal的提要。现在的问题是,我已经在node中完成了所有工作,但我真的很想也能在go中实现它。Node代码的重要部分是varquery=url.parse(req.url,true).query;vardata={u:query.user,//Usernamep:query.password,//Password};needle.post

database - 从数据库行在 Golang 中创建一个 map

基本上在执行查询后,我想获取结果行并生成一个[]map[string]interface{},但我不知道如何使用API执行此操作,因为Rows.Scan()函数需要特定数量的参数来匹配请求的列数(可能还有类型)才能正确获取数据。同样,我想概括此调用并进行任何查询并将其转换为[]map[string]interface{},其中映射包含映射到值的列名那一行。这可能效率很低,我计划稍后更改结构,使interface{}成为单个数据点的结构。我如何仅使用database/sql包或在必要时使用database/sql/driver包来执行此操作? 最佳答案