jjzjj

webSocket

全部标签

go - 有什么办法可以防止默认的 golang 程序完成

我有一个使用websocket连接和数据库的服务器。有些用户可以通过套接字连接,所以我需要在数据库中增加他们的“在线”;在他们断开连接的那一刻,我也减少了他们在数据库中的“在线”字段。但如果服务器出现故障,我会使用在线用户的局部变量replicamap[string]int。所以我需要推迟服务器关闭,直到它完成一个数据库请求,该请求根据我的变量副本减少所有用户“在线”,因为在这种情况下套接字连接不会发送默认的“关闭”事件。我找到了一个包github.com/xlab/closer来处理一些系统调用并且可以在程序完成之前做一些Action,但是我的数据库请求不能以这种方式工作(下面的代码

go - 使用 gob 在 Go 中编码 websockets

我正在使用Go中的websockets编写一个聊天应用程序。将有多个聊天室,想法是将连接到聊天室的所有websocket存储在Redis列表中。为了在Redis中存储和检索websockets,我必须对它们进行编码/解码,并且(根据this问题)我认为我可以为此使用gob。我正在使用github.com/garyburd/redigo/redis作为Redis和github.com/gorilla/websocket作为我的websocket库。我的函数看起来像:funcaddWebsocket(roomstring,ws*websocket.Conn){conn:=pool.Get(

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

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

Golang http : multiple response. WriteHeader 调用

这几天我在研究通过websoket发送消息,使用Beego框架。但是遇到错误信息http:multipleresponse.WriteHeadercalls问题出在哪里?任何提示都会很棒!func(this*WsController)Get(){fmt.Println("connected")handler(this.Ctx.ResponseWriter,this.Ctx.Request,this);conn,err:=upgrader.Upgrade(this.Ctx.ResponseWriter,this.Ctx.Request,nil)if_,ok:=err.(websocket

go - JSON-RPC方式获取websocket连接信息

我在Websocket上使用JSON-RPC。而且,在一个RPC方法中(例如,在下面的例子中,Multiply),我需要知道哪个连接调用了这个方法。下面的部分说“//此处需要Websocket连接信息”。我该怎么做?packagemainimport("code.google.com/p/go.net/websocket""net/http""net/rpc""net/rpc/jsonrpc")typeArgsstruct{AintBint}typeArithintfunc(t*Arith)Multiply(args*Args,reply*int)error{*reply=args.A

web - 每个客户端强制执行 1 个唯一的 websocket 连接?

我有一个与服务器建立websocket连接的网页。我必须确保站点的用户只能建立一个连接,因此打开一个新选项卡并导航到同一页面将关闭之前的连接。我想维护一个以sessionid为key的map;但是,随着越来越多的客户端连接,map的大小必须不断调整,我担心它会出现性能问题,并且由于它是并发访问的,因此您可能需要进行某种锁定。对于确保每个客户端唯一连接的性能高效方法有什么想法吗?很想听听建议,谢谢。 最佳答案 我不会担心问题中概述的解决方案的性能。如果您想关闭以前的连接,则无法维护服务器端映射。假设只有一个服务器并且您使用的是Gori

go - HTTP Chunked 流式传输到 WebSocket

我想监听多个传输编码响应的HTTP流,然后逐行从中获取消息,然后将消息推送到一个channel。然后我想从channel中读取并稍后通过websocket推送。funcsubscribe(wschan程序在reader.Scan()处阻塞。输出是Readingfrom1而不是别的。我查看了wireshark,消息正在通过。如何使用Go更好地设计这个问题? 最佳答案 主要block发送到无缓冲channelws。要解决此问题,请将ws更改为缓冲channel:ws:=make(chanstring,1)第二个问题是main()在到达E

image - Golang Websocket 检测文件消息并在超过 1 个 ws 帧字节时写入

我需要将每张新图片保存在一个文件中,该文件由多个框架通过websockets发送。这是我的文件的代码:packagemainimport("fmt""golang.org/x/net/websocket""log""net/http""os""time")var(dirPathstringtestbytelenFileint)funccheck(eerror){ife!=nil{panic(e)}}funcChatServer(ws*websocket.Conn){deferws.Close()vartest[]bytevarpayload[]bytefor{err:=websocke

带有 Web 代理的 Golang Gorilla Websocket

我正在使用Gorilla/Websocket开发POC,通过Web代理与Websocket检查网站“echo.websocket.org”进行通信。我正在使用免费的在线代理“hide.me/en/”进行测试。当我只是尝试与“echo.websocket.org”(服务器端)通信时,我的客户端WebsocketPOC会收到响应。但是当我尝试添加代理手势时,一切都出错了:(这是我的代码示例:packagemainimport("flag""log""net/url""os""os/signal""time""github.com/gorilla/websocket""net/http")v

json - 在 go 中通过同一个 websocket 多次读写

首先,上下文:我是新手,我参加过一门为期5周的类(class),但仅此而已。我是网络方面的新手,我已经使用websockets(ingo)玩了几天。我在一个小团队中工作,我的任务是使用Websockets开发一个IRC服务器(在进行中)。为了能够确保服务器正常工作,我编写了一个小型测试框架(也在进行中)。现在解决手头的问题:问题出在这段代码中。enc:=json.NewEncoder(ws)creator:=g.UserID{Name:_name,UUID:g.GenerateUID(_name+_subject)}ac:=g.DiscussionCreate{Subject:_sub