开启辅助访问 切换到宽版

精易论坛

 找回密码
 注册

QQ登录

只需一步,快速开始

用微信号发送消息登录论坛

新人指南 邀请好友注册 - 我关注人的新帖 教你赚取精币 - 每日签到


求职/招聘- 论坛接单- 开发者大厅

论坛版规 总版规 - 建议/投诉 - 应聘版主 - 精华帖总集 积分说明 - 禁言标准 - 有奖举报

查看: 1279|回复: 10
收起左侧

[完成] c/s架构多终端数据同步的问题

 关闭 [复制链接]
结帖率:100% (2/2)
发表于 2022-7-8 11:39:53 | 显示全部楼层 |阅读模式   四川省成都市
60精币
情景如下:
注:多终端使用,c/s架构;
当前模式: 1、当A终端操作某表格数据后,向服务器发送消息(UDP非TCP)
                 2、服务器收到消息后,向所有在线终端(B、C....等等)发送消息(UDP非TCP)通知更新
                 3、其它终端收到消息后更新被A终端修改的表格数据
注:修改表格数据只是举个例子,实际上有很多数据。
当前问题:多终端修改任何数据均会向服务器发送UDP更新信息,当信息量大时丢失消息的情况严重,可靠度下降,然而使用TCP话阻塞严重
问:有没有更好的思路,请指教(当前精币中有这么多,请谅解)

最佳答案

查看完整内容

你这问题在于,你自己认知的局限性。想要靠谱的多对一修改。必须使用mysql数据库。并且附带事务 锁,索引等一系列的。不要把这些东西局限在软件控件中。软件显示信息。全部通过读取数据库来进行。

结帖率:65% (36/55)

签到天数: 17 天

发表于 2022-7-8 11:39:54 | 显示全部楼层   河北省石家庄市
ataxi 发表于 2022-7-8 13:43
在复杂的系统中,并不是只面对某一张表或某一个简单的数据,有很多操作会涉及若干不同逻辑的数据,这此数 ...

你这问题在于,你自己认知的局限性。想要靠谱的多对一修改。必须使用mysql数据库。并且附带事务 锁,索引等一系列的。不要把这些东西局限在软件控件中。软件显示信息。全部通过读取数据库来进行。

评分

参与人数 1荣誉 +1 收起 理由
笨潴 + 1 热心帮助他人,荣誉+1,希望继续努力(*^__^*) 嘻嘻!

查看全部评分

回复

使用道具 举报

结帖率:65% (36/55)

签到天数: 17 天

发表于 2022-7-8 12:00:27 | 显示全部楼层   河北省石家庄市
应该所有终端都面向一个服务器。服务器操作mysql数据库。  所有终端的修改。都发给服务器 服务器修改数据库。这样相当于多对一。只有这种才是正确的方案。
回复

使用道具 举报

结帖率:100% (2/2)
 楼主| 发表于 2022-7-8 13:36:43 | 显示全部楼层   四川省成都市
糖心疼 发表于 2022-7-8 12:00
应该所有终端都面向一个服务器。服务器操作mysql数据库。  所有终端的修改。都发给服务器 服务器修改数据库 ...

问题最关键的不是谁来操作数据库,而是如何  “可靠 ”的通知所有终端,所有终端如何“可靠”接收消息
回复

使用道具 举报

结帖率:100% (2/2)
 楼主| 发表于 2022-7-8 13:43:18 | 显示全部楼层   四川省成都市
ataxi 发表于 2022-7-8 13:36
问题最关键的不是谁来操作数据库,而是如何  “可靠 ”的通知所有终端,所有终端如何“可靠”接收消息 ...

在复杂的系统中,并不是只面对某一张表或某一个简单的数据,有很多操作会涉及若干不同逻辑的数据,这此数据不可能在频繁的操作中都去重新读取数据库,必然会非常依赖变量或则某些表格,而这些变量或表格中的数据又可能因为其它终端数据的修改而失去当前数据本身的作用,所以,当这些数据所依赖的底层数据变动后,需要及时修正;而问题本身是用什么手段去  “可靠”通知所有受影响的其它终端
回复

使用道具 举报

结帖率:100% (7/7)

签到天数: 19 天

发表于 2022-7-8 14:25:16 | 显示全部楼层   广东省云浮市
内网的话,个人感觉udp广播就足够了,加上id记值顺序增加来进行判断是否丢包。
外网的话,在国内的环境,udp不好用。所以还是老老实实用tcp协议吧。
回复

使用道具 举报

结帖率:100% (2/2)
 楼主| 发表于 2022-7-8 15:29:43 | 显示全部楼层   四川省成都市
Bszk 发表于 2022-7-8 14:25
内网的话,个人感觉udp广播就足够了,加上id记值顺序增加来进行判断是否丢包。
外网的话,在国内的环境,ud ...

就没有其它办法了么?像VX中的多人编辑一个文档是用哪种方法实现的?
回复

使用道具 举报

结帖率:100% (2/2)
 楼主| 发表于 2022-7-8 15:32:14 | 显示全部楼层   四川省成都市
ataxi 发表于 2022-7-8 15:29
就没有其它办法了么?像VX中的多人编辑一个文档是用哪种方法实现的?

作压力测试时,也不是丢包,而是快速、高频时根本就收不到,例如我连续发1000个消息,最后可能只收到500个,
回复

使用道具 举报

结帖率:100% (7/7)

签到天数: 19 天

发表于 2022-7-8 15:36:14 | 显示全部楼层   广东省云浮市
ataxi 发表于 2022-7-8 15:29
就没有其它办法了么?像VX中的多人编辑一个文档是用哪种方法实现的?

你抓一下包就知道了,应该是tcp的。估计是依靠分布在全国的强大服务器,能做到很低的延迟。
回复

使用道具 举报

结帖率:65% (36/55)

签到天数: 17 天

发表于 2022-7-9 09:09:18 | 显示全部楼层   河北省石家庄市
ataxi 发表于 2022-7-8 15:29
就没有其它办法了么?像VX中的多人编辑一个文档是用哪种方法实现的?

VX中多人编辑也是通过mysql来实现的。 每个人显示的信息都是缓存。但是写入的时候是通过事务 和锁来进行写入的。不会造成冲突。
回复

使用道具 举报

您需要登录后才可以回帖 登录 | 注册

本版积分规则 致发广告者

发布主题 收藏帖子 返回列表

sitemap| 易语言源码| 易语言教程| 易语言论坛| 易语言模块| 手机版| 广告投放| 精易论坛
拒绝任何人以任何形式在本论坛发表与中华人民共和国法律相抵触的言论,本站内容均为会员发表,并不代表精易立场!
论坛帖子内容仅用于技术交流学习和研究的目的,严禁用于非法目的,否则造成一切后果自负!如帖子内容侵害到你的权益,请联系我们!
防范网络诈骗,远离网络犯罪 违法和不良信息举报电话0663-3422125,QQ: 793400750,邮箱:wp@125.la
Powered by Discuz! X3.4 揭阳市揭东区精易科技有限公司 ( 粤ICP备12094385号-1) 粤公网安备 44522102000125 增值电信业务经营许可证 粤B2-20192173

快速回复 返回顶部 返回列表