本文由葡萄城技术团队原创并首发

转载请注明出处:葡萄城官网,葡萄城为开发者提供专业的开发工具、解决方案和服务,赋能开发者。

Excel是我们办公中常用的工具 ,它几乎能为我们处理大部分数据,友好的交互界面、丰富的公式函数和易于上手的图表为我们在数据统计方面提供了不小的帮助,但经过一段时期运行,就会出现下面的情况:

这样多分枝的混乱状况就会难以保证文档的安全性及权威性。

于是聪明的小伙伴想到了一个解决方案,共享出一份Excel文档,根据人员的职级不同,设置仅可只读和编辑的权限,同时根据为不同人制定不同规则,例如:张某每天十点编辑,王某每天十一点编辑的方式来解决冲突的问题。这种方式很聪明,从流程上解决了多副本的问题,但不能同时编辑的问题依然没有被解决,如果一个部门的人足够多,这样分时的策略可能需要花一天时间才能完成一份Excel的编辑。

所以多人协作在线文档的需求也变得越发变得强烈,因为在日常工作中,与团队的其他人进行文档协作是一种再常见不过的工作方式。由于工作分工、工作进展的不同,团队内部的信息往往需要及时同步,然而伴随着团队经营规模的不断扩大,在线协同、多人协作,以及软件项目管理等问题将会接踵而至,成为制约企业高效发展的瓶颈。

而这些问题,通常表现为:

  1. 跨部门、地区沟通协作的不便
  2. 过度依赖文件、文件夹共享的形式,不能确保文档的安全性
  3. 没法纪录和体现职工对文本文档的意见和评价
  4. 文档记录发生变更时,无法及时通知到相关部门和员工
  5. 文档无法在线协同编辑,缺失必要的流程管控
  6. 多人共同编辑一个文档,无法留存修改记录和历史版本

针对上述问题,现在在市面上,已经有了很多这类多人协作的工具,例如:国外的Google Docs、Office365,及国内的腾讯文档、石墨文档、有道云协作等。

因为这篇文章我们的目的是想向大家从企业IT管理者的角度出发深入研究协同办公系统的形式、基础和难点等实现原理,所以成品软件我们在这不做过多赘述。那我们正式开始吧。

多人协作的形式:历史与发展

多人协作的历史十分悠久,起源于静态的多人协作模式,即每个人先完成自己的工作,然后再进行汇总。

多人协作的初期:静态协作

  • 递增式协作

    • 邮件:你来我往
    • 论坛:跟帖回复
  • 独占式协作
    • 文档传递
    • 微软VSS
  • 合并式协作
    • SVN
    • Git
    • diff,patch,merge指令

常见的静态多人协作方式

多人协作的发展期:从静态到动态

  • 静态协作的比喻

    • 拼接画
    • 积木
  • 静态协作的特点
    • 多版本
    • 块操作
    • 有协作动作
  • 静态协作的缺点
    • 版本碎片化
    • 缺乏时效性
    • 协作动作成本高

静态多人协作的成本,会随着加入人数和项目的复杂度呈几何级数的增长。因此,对于企业来说,急需一种无协作动作、唯一版本、版本可控的无协作成本模式,即动态多人协作模式。

多人协作的蓬勃期:动态

  • 动态协作的比喻

    • 一起画黑板
  • 动态协作的特点
    • 唯一版本
    • 原子操作
    • 无协作动作
  • 动态协作的优点
    • 版本可控
    • 实时
    • 无协作成本
  • 典型产品
    • Office Online
    • 石墨
    • OnlyOffice

多人协作的基础:原理与架构

任何信息,无论其是什么展现形式,如果要做到多人实时编辑与展现,只需要实现以下三步而已:

  1. 操作化
  2. 可传输
  3. 可还原

举例说明多人协作的实现方式

操作化

操作化,指任何信息都可以转换为一组操作的集合。很容易理解,但它仍有不少值得思考的点:

  • 分割与组合

    • 如何保证:信息的所有变化都可以分解为操作的集合?反之,操作如何覆盖出信息的所有变化?
    • 分割的颗粒度如何决定?
      • 粗一点?
      • 细一点?
      • 如何兼顾解释性与扩展性?
  • 绝对操作与相对操作
    • 绝对操作

      • 针孔打印机的完美世界
      • 打印机时代的编辑噩梦
    • 相对操作
      • 4K电视不是梦
      • 为什么数字电视稳定性不如模拟电视
    • 绝对操作与相对操作比喻:时间与空间的互换

可传输

可传输,就是指操作有办法通过网络传输给其他终端。实现动态多人协作,需要考虑以下几点:

  • 传输内容

    • 原始文本

      • 清晰
      • 冗余
    • 压缩技术
      • 逻辑压缩
      • 协议压缩
      • 手动压缩
  • 网络协议
    • Socket

      • TCP
      • UDP
    • HTTP
    • WebSocket
  • QoS(Quality of Service,服务质量)
    • 快速失败

    • 自动回滚

    • 自动重连

    • 自动恢复

可还原

可还原,就是指接收到来自网络的操作消息后,可以在本地完全一致地再次执行该操作。可还原包括了:

  1. 绝对操作的还原
    • 控制体积
    • 合理的提示
  2. 相对操作的还原
    • 严格的顺序性
    • 从源头保障顺序性
    • 顺序性的补救
  3. 本地操作的还原
    • 过滤收到的操作集合
    • 从源头细化操作颗粒
    • 本地保存本地执行
  4. 无入侵的还原
    • 定义入侵
    • 排除入侵
    • 千人千面

多人协作的难点:乱序与冲突

乱序

乱序的表现形式如下图,小明在客户端执行了一系列操作,传递到服务器时发生乱序,导致小花看到了截然不同的信息:

为了解决乱序问题,可以尝试以下方法:

1. 用性能换取顺序正确——基于协议

2. 用性能换取顺序正确——基于回执

两种方法的优缺点
  1. 基于协议
  • 优点

    • 可靠,历经考验
    • 简单,无需开发
  • 缺点
    • 资源开销高
    • 必须整套使用
  • 优点
    • 自主可控,按需开发
    • 资源开销可控
  • 缺点
    • 需要自己投入开发
    • 应用层逻辑控制使得网络复杂度向外蔓延
    • 复杂度带来维护成本
  1. 基于回执
基于乱序处理方法的总结

网络不是绝对可靠的,为了实现相对可靠,需要付出一定的代价,企业需要考虑的是:如何衡量所付出的代价与产出成正比。

冲突

比乱序更高级的一种表现形式,存在多向、多维度等问题。

如何避免错误的蔓延?

原则:任何一次不一致,都会导致后续的操作基于错误的信息进行,从而不断扩大错误,造成无法收拾的结果。因此,不一致是不能被容忍的。

解决办法:

  1. 严格一致性:独占
  2. 最终一致性:检查与修复
  3. 非技术手段:设计与提示
严格的一致性

独占就是同一时间同一范围只能由一人操作。

  1. 范围
    1. 整个表格,类似VSS
    2. 工作表
    3. 单元格范围
  2. 排他性
    1. 独占冲突时,必有一方被弹开
    2. 直到占有者解开,不然无法占用
    3. 占用前无法操作
    4. 原理和锁基本一致
  3. 优点
    1. 可以确保严格一致性,不会产生多版本的错误累积
    2. 比起修复恢复这类弥补手段,一开始就不出错的成本最低
    3. 逻辑清楚简单,开发维护成本低
  4. 缺点
    1. 静态协作的味道
    2. 独占动作严重影响体验
    3. 大幅降低协作效率
  5. 需对表格实现的 功能
    1. 锁定工作表
    2. 锁定单元格
最终一致性

基于唯一正确顺序,察觉客户端的错误,撤销错误操作后重新执行正确的操作。

  1. 唯一正确
    1. 服务器到达顺序
    2. 协作边界分流
    3. P2P+选举算法
  2. 察觉错误
    1. 服务器回执id
    2. 服务器回执操作,MS
  3. 撤销错误
    1. 撤销到错误发生前的一步操作的结果
    2. 保存副本实现撤销功能
    3. 利用操作版本快照
  4. 重新执行
    1. 操作队列需保存
    2. 区分好无感知执行与显式执行

针对多人协作难点的总结

如何实现Excel相关功能是需要开发人员需要花时间去研究的,另外为了满足需求,适配多设备和平台的兼容性也非常重要。

另外,多人协作表格的本质还具有如下本质和特点:

  • Server – Clients 中心系统,类似数值敏感的小型网游
  • 任何这类系统都是在体验和正确性中寻求平衡
  • 表格的数值敏感性高于网游,数据操作和存储的挑战更大
  • 表格的计算复杂度更高,尤其涉及复杂公式嵌套与全量统计筛选
  • Web存在天花板,所以复杂的页游并不多见,端游较多

最后,假如您想了解更多如何实现多人协作平台相关的内容,欢迎参加2019年12月18日(周三) 14点由上海佳软CTO带来的一场线上直播:https://live.vhall.com/483759540,相信届时我们都会受益良多的。

想实现多人协作的“在线Excel”?真没那么简单的更多相关文章

  1. 支持多人协作的在线免费作图工具:ProcessOn

    之前朋友给我推荐一款作图工具ProcessOn,出于好奇我就研究了一下它,今天我就给大家简单介绍一下这款免费的在线作图工具:ProcessOn 首先使用ProcessOn我们需要有一个帐号,这样每次操 ...

  2. 苹果开发者账号如何多人协作进行开发和真机调试XCode

    首先,先说明一下,我们最容易误解或者理解错误的是:p12证书. 其实p12证书,最直接的使用就是,我们在一台电脑上生成好了cer证书之后,如果使用了开发者账号(无论公司或者个人的)进行ipa进行打包和 ...

  3. 腾讯在线文档发布:实现QQ、微信多平台多人协作编辑

    18日,腾讯宣布推出专注多人协作的在线文档产品—腾讯文档,据介绍,腾讯文档是一款支持随时随地创建.编辑的多人协作式在线文档工具,拥有一键翻译.实时股票函数和浏览权限安全可控等功能,以及打通QQ.微信等 ...

  4. GitHub多人协作简明教程

    本文面向已经了解/熟悉git基本命令但是并不熟悉如何使用GitHub进行多人协作开发项目的同学. 为了简单起见,这里假设只有两个开发人员,HuanianLi 和 DaxiangLi.他们在GitHub ...

  5. Git多人协作工作流程

    前言 之前一直把Git当做个人版本控制的工具使用,现在由于工作需要,需要多人协作维护文档,所以去简单了解了下Git多人协作的工作流程,发现还真的很多讲解的,而且大神也已经讲解得很清楚了,这里就做一个简 ...

  6. Git学习笔记(7)——多人协作

    本文主要记录了,多人协作时,产生冲突时的解决情况. 多人环境创建 首先我们需要模拟一个多人环境.前面的Git的学习都是在Ubuntu上面,现在我们也搭建一个win环境吧.安装win环境下的Git,很简 ...

  7. Git学习之路(5)- 同步到远程仓库及多人协作问题

    ▓▓▓▓▓▓ 大致介绍 我们写好文件后添加到版本库,但是这样还没有做完,我们还需要将它同步到GitHub的远程仓库上,这里就以我们刚开始的drag项目为例,我们在Git学习之路(2)-安装GIt和创建 ...

  8. Git版本控制之多人协作

         上篇文章我们主要简单的介绍了有关git的一些基本常识和一些简单的命令.但那终究是皮毛,我们使用git最主要的目的还是管理我们的项目,多人协作.本篇文章主要涉及以下两个大模块: 分支的概念及原 ...

  9. 三、Snapman多人协作电子表格之——软件的基本功能

    Snapman多人协作电子表格是一个即时工作系统. 一.SnapmanServer服务端 SnapmanServer服务端在安装Snapman软件一起自带,是一个小巧的控制台程序SnapmanServ ...

随机推荐

  1. [LLL邀请赛]参观路线(图论+dfs)

    emmmm....学校的oj被查水表了,扒不到原题面,所以.... 但是我还是扒到了题面... 题目大意:给定一个完全图,删掉其中一些边,然后求其字典序最小的遍历顺序 有点像去年day2T1啊.... ...

  2. Python实现发送邮件代码

    代码如下: # -*- coding: utf-8 -*- #!/usr/bin/env python # @Time : 2017/12/22 17:50 # @Desc : # @File : m ...

  3. python的变量内存管理

    一.变量的引用机制 当你在python中定义一个值,如x = 500时,python会在内存中开辟一个小地方用于存储数值. x = 500 #定义一个变量 print(id(x)) #打印该变量的内存 ...

  4. VLAN的 基本用法与配置

    需求:在一家小型企业中,所有员工都使用一台交换机,老板为了避免员工私下通信,将他们分配了不同网段,但偶尔还是会发现,有些员工会自行修改网段和别人通信.如果你是这家企业的网络工程师,你该如何处理? 1. ...

  5. 花一天时间试玩vsphere6.7(EXSI)服务器版的vmware

    花一天时间试玩vsphere6.7(EXSI)服务器版的vmware 要注册账号(2019年11月14注册): 登陆网址:https://my.vmware.com/cn/group/vmware/h ...

  6. 为企业应用开发提速,写给企业IT部门的低代码开发基础知识

    简介:应用程序开发长期以来一直是IT部门和业务部门面临的问题. IT部门总是被新的应用程序需求弄得不堪重负.他们不可能完成业务部门想要完成的每一个项目. 同时,业务部门的用户厌倦了等待,并开始完全绕过 ...

  7. 如何打造一款m3u8视频爬虫

    0.前言 m3u8是一种很常见的网页视频播放器的视频源,比如说中国大学MOOC中课程就是使用了该种视频格式. 随便打开一门课程,就可以发现在网络请求中存在一个m3u8的文件,在preview中预览,它 ...

  8. Bran的内核开发教程(bkerndev)-08 中断服务程序(ISR)

    中断服务程序(ISR)   中断服务程序(ISR)用于保存当前处理器的状态, 并在调用内核的C级中断处理程序之前正确设置内核模式所需的段寄存器.而工作只需要15到20行汇编代码来处理, 包括调用C中的 ...

  9. Spring基于构造函数和设值函数的依赖注入

    基于构造函数的依赖注入 我们知道,bean标签中指定的类会进行初始化,这个初始化过程中自然会调用构造函数,那我们也可以利用这个构造函数完成依赖注入. 先创建一个类: public class Text ...

  10. Django使用mysql数据的流程

    创建一个mysql数据库 1.打开终端(cmd): 输入: mysql -uroot -p 密码:*** 输入: create database 数据库名字; 2.在settings中进行配置 DAT ...