DICOM:docker实现DICOM服务虚拟化

背景:

docker,是一个开源的应用容器引擎,眼下大多应用在部署和运维领域,然而因为全然使用沙箱机制,相互之间能够看做独立的主机,且自身对资源的需求也十分有限。远远低于虚拟机。甚至非常多时候。能够直接把容器当做应用本身也没有不论什么问题。因此最近正在尝试将docker应用到传统DICOM服务领域。

本文作为该系列开篇,主要记录docker环境配置过程中遇到的奇葩问题,为兴许更复杂、更全面的应用做准备。

docker中安装jdk:

1. 下载docker镜像

#因为docker官方镜像网络不稳定,此处採用时速云的centos镜像来演示
docker pull index.tenxcloud.com/tenxcloud/centos

通过docker images 查看本地下载的镜像(此处使用-a參数罗列出镜像的所有历史,兴许博文会具体介绍docker镜像在本地的存储)。

2. 安装jdk到docker中

(1)首先启动docker镜像,创建容器

#使用-v參数,创建共享文件夹,方便jdk包传入docker容器内部
docker run -d -v /home/dockercluster/Downloads:/home/zssure --privileged=true IMAGE_ID

注:假设须要对/home/zssure文件夹进行拷贝、改动等操作,须要加入–privilleged=true来开启权限

(2)进入docker容器内部

docker exec -ti CONTAINER_ID /bin/bash

(3)安装jdk

进入docker内部。发现时速云的centos镜像是最精简版,缺少非常多经常使用命令。诸如tar、vim、clear等。遇到这样的问题须要使用yum install 安装

#查找命令所在的安装包
yum search COMMAND-NOT-FOUND
#直接安装查找后的包
yum install search-result-package

3. 提交镜像,并重新启动启动

又一次启动刚提交的镜像,直接检測java是否安装。发现之前安装的jdk失效。

须要使用

#刷新环境变量
source /etc/profile

才干使用jdk。

docker环境变量失效问题:

进到镜像里,查看/etc/profile,明明是有的。之前通过ssh进去也是能够启动的,这是为什么呢?

linux的启动过程里。/etc/profile是在用户登录的时候运行。在命令行run的时候可能是不会进行登录操作,所以没有对应的环境变量。

可是我们启动了ssh服务,从远程是通过登录进的系统,这时候就会有环境变量了。

解决方式:

(1)使用docker run中的-e參数。直接传入环境变量

(2)使用Dockfile中的ENV绑定环境变量

FROM centos:latest
ENV JAVA_HOME /usr/local/java/jdk1.8.0_65
ENV JRE_HOME $JAVA_HOME/jre
ENV CLASSPATH .:$JAVA_HOME/lib:$JRE_HOME/lib
ENV PATH $PATH:$JAVA_HOME/bin

方案摘自: How to source /etc/profile and save it in docker?

上述提到的两种方案。第一种非常适合眼下我们遇到的问题。通过本博文已经找到了解决安装jdk须要每次刷新环境变量的问题。兴许会进一步介绍docker的VOLUME数据卷、网络环境等细节,终于实现DICOM服务虚拟化部署。

作者:[email protected]

时间:2015-12-27

时间: 2024-10-12 14:51:56

DICOM:docker实现DICOM服务虚拟化的相关文章

DICOM:开源DICOM服务框架DCM4CHE 构建

背景: 前一篇博文DICOM:开源DICOM服务框架DCM4CHE 安装中介绍了一款开源DICOM服务框架DCM4CHE,对于开源项目学习的流程是先下载二进制可执行包安装,然后使用测试.在熟悉了大致的功能服务后,从官网下载源代码进行本地构建(Build),进而从根本上了解开源项目的底层框架设计,为后续修复.扩展做准备.本博文是继DCM4CHE安装后的续篇,讲解如何在本地构建DCM4CHE开源项目,文中尽量做到全面,但是由于刚开始接触J2EE领域,且多半都是自学,因此博文中还留有部分未解问题,如有

Docker学习总结(7)——云端基于Docker的微服务与持续交付实践

本文根据[2016 全球运维大会?深圳站]现场演讲嘉宾分享内容整理而成 讲师简介 易立 毕业于北京大学,获得学士学位和硕士学位:目前负责阿里云容器技术相关的产品的研发工作. 加入阿里之前,曾在IBM中国开发中心工作14年,担任资深技术专员,负责IBM企业平台云产品线PureApplication System的研发工作:还负责和参与了一系列IBM在Web 2.0,SOA中间件的研发和创新,也曾为全球客户提供SOA技术咨询和项目实施. 日程 大家好,我演讲的主题是<云端基于Docker的微服务与持

【译文】用Spring Cloud和Docker搭建微服务平台

by Kenny Bastani Sunday, July 12, 2015 转自:http://www.kennybastani.com/2015/07/spring-cloud-docker-microservices.html This blog series will introduce you to some of the foundational concepts of building a microservice-based platform using Spring Cloud

云端基于Docker的微服务与持续交付实践

云端基于Docker的微服务与持续交付实践笔记,是基于易立老师在阿里巴巴首届在线技术峰会上<云端基于Docker的微服务与持续交付实践>总结而出的. 本次主要讲了什么? Docker Swarm Docker Swarm mode 微服务支持(Docker集群架构体系) Docker的发展趋势和前沿成果 在Docker技术方面还是很佩服大牛的,所以赶紧写下笔记,追随大神的脚步. 阿里云资深专家易立,技术就不说了,他比其他直播间硬生生多讲了半个多点,于情于理还是万分感谢本次分享的(可惜devOp

使Docker提供对外服务的网络配置(桥接与端口)

前沿: docker 启动容器后,如何对外服务?   希望大家看了这篇文章后有些帮助. docker的有关网络问题没怎么搞清楚,请教了下邓磊同学,感谢 ! Docker生成的容器,一般会给你生成一个ip地址,这个ip地址是和docker0的地址是一个ip段的. 通过ip a命令 ,咱们可以看到docker0的ip和子网的范围 . 大家会发现除了docker0 还有一个vethc 数字的网卡,这个也算是虚拟网卡绑在桥接上的. 我们创建一个容器,并且暴露22端口. 这个22端口的意思是对外暴露了22

使用 Spring Cloud 和 Docker 构建微服务

该项目主要是对微服务,以及Spring Cloud系统学习的一些总结,使用gitbook写成了书. 探讨的话题主要有: 什么是微服务注册中心Eureka服务提供者服务消费者客户端负载均衡Ribbon简化的Http客户端Feign熔断器Hystrix Hystrix监控界面Hystrix DashboardHystrix集群监控工具Turbine配置中心 API Gateway使用Docker构建微服务 目前基于Spring Cloud构建微服务的必要组件已经讲解完成. 下一步是讲解Docker的

使用Spring Cloud和Docker构建微服务

什么是Spring Cloud?Spring Cloud 是Pivotal提 供的用于简化分布式系统构建的工具集.Spring Cloud引入了云平台连接器(Cloud Connector)和服务连接器(Service Connector)的概念.云平台连接器是一个接口,需要由云平台提供者进行实现,以便库中的其他模块可以与该云平台协同工作.(更多介绍,可以阅读 InfoQ的这篇文章:http://www.infoq.com/cn/news/2014/06/spring-cloud-platfor

从 0 开始的微服务架构:(五)代码给你,看如何用Docker支撑微服务

很好的一篇文章,全面.系统. 虽然已经红了很久,但是"微服务架构"正变得越来越重要,也将继续火下去.各个公司与技术人员都在分享微服务架构的相关知识与实践经验,但我们发现,目前网上的这些相关文章中,要么上来就是很有借鉴意义的干货,要么就是以高端的专业术语来讲述何为微服务架构.就是没有一个做到成熟地将技术传播出来,同时完美地照顾"初入微服务领域人员",从 0 开始,采用通俗易懂的语言去讲解微服务架构的系列.所以,我们邀请青柳云的苏槐与 InfoQ 一起共建微服务架构专题

Docker(八)用docker compose部署服务

用docker compose部署服务 docker compose可以方便我们快捷高效地管理容器的启动.停止.重启等操作,它类似linux下的shell脚本,基于yaml语法,在该文件里我们可以描述应用的架构,比如用什么镜像.数据卷.网络模式.监听端口等信息.我们可以在一个compose文件中定义一个多容器的应用,然后通过该compose来启动这个应用. 下载安装docker-compose # curl -L https://github.com/docker/compose/release