iOS平台群控系统框架

做在线算法服务平台的的时候搞了这么一套东西,刚开始的时候完全没有意识到它能有这方面的用途。等到项目基本结束的时候,突然发现这个daemon当真具备了群控平台的基础:打开/关闭应用、与本地app/服务器实时通信,最重要的是它具备了硬件设备的热加入功能。

框架分工

整个框架中大致有三种角色:用户、集群控制器兼服务器、终端集群,其中集群控制器处于最核心的位置,它担负着用户与终端设备间信息交换的责任。

集群控制系统
  • 用户的主要职责就是通过集群控制器对外提供的接口,向控制器传送服务需求与原始输入,然后等待集群控制器把最后的输出返回给自己。
  • 终端集群的职责也比较简单,接收控制器中转过来的用户输入,执行相应的任务并将最终生成的结果传送给控制器,由控制器转达用户。
  • 集群控制器的核心任务是管理整个集群,通过它能够非常方便的添加移除终端设备,能够对终端设备进行操纵式控制,比如打开/关闭/安装/卸载指定应用、模拟点击、关机重启、截录屏等等。除了管理集群功能、在用户与终端间中转数据进而达成分布式计算任务是这套系统的最终目标。

实现细节

建立连接

为了实现终端设备的热加入功能以及控制器与终端间的实时通信,通信协议毫无疑问地选择了TCP长连接的方式。如此控制器定然要对外提供一套TCP服务,终端通过TCP连接到服务器并报告自己的终端身份以及所具体的服务能力。控制器将这些信息加入到自己的任务管理列表中。用户提交任务后,控制器便可以到任务管理列表中查找有任务处理能力的终端,根据一定的规则选择终端并调度其执行任务。

终端设备热加入集群

集群的管理与控制

只有具备了与终端的实时通信能力,集群控制器对集群各终端的管理与控制才成为可能。iOS平台的特殊性注定了终端设备上的TCP连接程序不可能基于上层应用中,其长时间运行、开机自动运行等行为特征也是上层应用所不具备的。显然iOS平台上的另外一种程序类型-daemon服务是惟一的选择。

daemon后台服务

该daemon服务的职责与终端的职责基本重合,惟一的不同是执行的任务类型。daemon服务所执行的服务一般都是系统级别的任务,比如开关机、截屏、安装打开关闭应用、模拟点击等,但对于一些涉及到应用内部行为的任务无能为力,比如调用应用内部的某个算法接口。

Socket Client是负责与控制器通信的TCP长连接,它会接收服务器发来的各种数据并处理,同时也会主动向服务发送心跳包以保持稳定的连接状态,同样也会转发由Socket Server接收到的数据包。而这个Socket Server正是为了上面所说的特殊任务面存在的。

应用控制

为了控制应用做出其工作范围之外的动作,必须在应用的代码里值入插件代码,这种插件有个学名叫Tweak,这里不在做具体介绍。如果在插件代码里同样集成TCP连接的代码,就能将应用与daemon服务连接起来。如此daemon作为服务器就可以控制前台应用作Tweak中设定好的额外动作了。

另一组服务器客户端模型

总信息流

像下图一次典型的信息处理流程,通过客户发起,经过层层转发,到最终找到处理程序处理,返回数据同样经过层层转发回客户。如此效率可能成为该系统的一个瓶颈,所幸的是客户同样可以选择一次提交大区量的数据,而该系统的分布式特点正好可以发挥其作用了,因此效率方面完全不是问题,当然前提条件是该集群系统拥有大量的终端设备,钱的问题都不是问题(实际上还是问题,尤其是iOS平台)。

典型的信息流

总结

该集群系统是我在在线算法服务平台的基础上提取出来的,该服务平台已经基本搭建完毕,并拟向外界开放,欢迎有兴趣的朋友前来咨询与交流。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,657评论 6 492
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,662评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,143评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,732评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,837评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,036评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,126评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,868评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,315评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,641评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,773评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,470评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,126评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,859评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,095评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,584评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,676评论 2 351

推荐阅读更多精彩内容