基于orthanc的影像云存储技术设想

大家好,我是帅气小伙。前段时间忙于实施医疗集团信息化的事情,太久没更文了,刚好今天更个文章梳理一下前段时间关于影像中心建设的一些感悟。很欢迎大家一同探讨。

为什么选择orthanc?

orthanc是一款能够提供RESTful API 的迷你影像服务器,orthanc提供了数据库存储dicom索引的插件(Postgresql,Mysql,SQLlite),它大大降低了技术开发的难度,开发者并不需要了解太多的dicom协议的知识,便能轻松应对dicom的图像的检索,dicom图像的存储,dicom图像的压缩,dicom图像的转发。因为他们面对的都是他们熟悉的东西,Http接口和关系型数据库;另外一方面,从软件实施的难度来看,orthanc提供了windows安装包,在应对医院前置机配置也是游刃有余(最糟糕的XP系统同样能兼容)

Dicom存储的难度

1.dicom图像的大小直接导致了存储成本的提高,虽然硬盘不贵
2.dicom如果使用分布式存储将提高检索难度。
3.dicom图像的管理如果采用分布式存储将会变得困难,假如要删除一次检查图像。
4.如果采用传统的HDFS这样的存储方式,开发接口将面对的是一堆未可知的问题,这并不是一堆简单的文件,需要从里面提取图像信息(根据检查号查询图像)。
5.dicom存储同样也存在网络带宽问题,影像中心到底需要多大的带宽?

问题分析

1.dicom文件的分布式存储是必然的,一组dicom图像可以把它看成是数据块(study),存储的时候不需要将它拆分,因为一旦拆分了,检索的时候很可能是大海捞针一般。
2.dicom图像的接收可以理解为点对点的传输,如果是相对于影像中心的概念,很可能是一点对多点的模式,因此对于接收节点的压力是很大的(在自动传输的情况下),并且接收节点同样也面临了磁盘使用率过高的情况,很容易造成磁盘坏道的情况。

云存储技术方案设想

1.影像中心层级结构

层级结构

1.采集层:部署在院内,负责影像的采集,图像来源可以来自设备和pacs系统
2.存储层:部署在云服务器上,负责影像图像的接收和存储
3.查询层:部署在云服务器上,负责开放对外接口(检索图像,查看图像...)

2.dicom图像分布式存储设计

分布式存储设计

采集层

自动转发:在接收到设备或pacs转发图像后,马上向影像中心转发。orthanc的技术实现是基于lua脚本。例如

function OnStoredInstance(instanceId, tags, metadata)
   -- Ignore the instances that result from a modification to avoid
   -- infinite loops
   if (metadata['ModifiedFrom'] == nil and
       metadata['AnonymizedFrom'] == nil) then

     -- The tags to be replaced
      local replace = {}
      replace['StationName'] = 'My Medical Device'
     -- 可以在此设置一些自定义的Tag,例如医院标识号等等

     -- The tags to be removed
      local remove = { 'MilitaryRank' }

     -- Modify the instance, send it, then delete the modified instance
      Delete(SendToModality(ModifyInstance(instanceId, replace, remove, true), 'sample'))

     -- Delete the original instance
      Delete(instanceId)
   end
end

手动转发:基于orthanc的RESTful API 可以实现手动转发
orthanc RESTful API

存储层

基于docker容器技术,快速实施部署和节点监控,目前的k8s技术已经相当成熟了,无论是节点的存储,节点的网络拓扑构建是相当的出色了。
orthanc dockerfile

环式节点转发存储

这个设想主要是考虑到,将接收节点的压力分发到各个节点,但是如果链太长,很容易图像在数据链路中丢失,这里可能会有更好的设计思路。

环式节点转发
orthanc采集上传流程.png

技术可行性


lua脚本关键回调

lua脚本可以通过命令行调用python脚本实现对于业务系统的对接。例如节点注册,节点销毁。

dicom图像连续性保证,在图像传输的情况下,假设有一个18张图像的检查,A节点已经存储了17张,但是磁盘使用超过了80%,按照我设计的链式转发规则,它应该存储到下一个节点。在转发之前,我们只需要知道当前节点是否存在与这张图像的检查号(studyid)相同的图像,再确认转发即可保证图像的连续性。这里预留了10%的磁盘空间就是为了应对这种情况。

dicom存储服务扩容,存储始终都会有溢出的一天,我们的运维要及时发现,快速解决,采用链式存储,最终由溢出节点回到原点并触发接收节点溢出告警,由于一开始转发节点不存储图像,有足够的缓存时间去扩容。采用链式存储的扩容其实很简单,再启动一个转发节点,配置它的转发节点即可,然后再把这个新启动的转发节点的ip更改即可。

查询层

经过了存储层和采集层的搭建,这里已经初步解决了dicom图像存储问题,下一步就是对dicom图像的检索了。其实这就是一个分布式数据源查询的问题。

简单的设想

开发影像接口从此回到了关系数据库接口开发。

orthanc数据库分析

影像查询服务功能

总结

这是一个设想,没有真正实施过,希望有这一方面使用的朋友,批评指正,我也希望这个方案能够真正的实施落地。

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

推荐阅读更多精彩内容

  • 关于Mongodb的全面总结 MongoDB的内部构造《MongoDB The Definitive Guide》...
    中v中阅读 31,915评论 2 89
  • feisky云计算、虚拟化与Linux技术笔记posts - 1014, comments - 298, trac...
    不排版阅读 3,837评论 0 5
  • 原文地址Dynamo 摘要 面对世界上最大的电商网站 Amazon.com,我们遇到的最大挑战之一就是海量规模下后...
    wangjie_yy阅读 2,178评论 0 3
  • 仅仅经历30多年明治维新的日本竟然相继战胜了老大帝国清朝和老牌帝国沙俄。是的,固然可以说,彼时清朝种种劣迹,此类议...
    古德曼Goodman阅读 1,331评论 2 12
  • #玩卡不卡·每日一抽#每一位都可以通过这张卡片觉察自己: 1、直觉他叫什么名字?红发少女 2、他几岁了?18 3、...
    李娟AINI阅读 177评论 0 0