Docker-02.Docker离我们有多远,场景(无基础学Docker系列文档)
mhr18 2024-09-14 05:40 32 浏览 0 评论
基础知识点
Docker作为一个开源的应用容器引擎,让开发者可以打包他们的应用及依赖环境到一个可移植的容器中,然后发布到任务运行有Docker引擎的机器上。它集版本控制、克隆继承、环境隔离等特性于一身,提出一整套软件构建、部署和维护的解决方案,可以非常方便地帮助开发人员,让大家可以随心所欲地使用软件而又不会深陷到环境配置中。
容器可以跨多个平台运行。Java曾提出“Write Once,Run Anywhere”,而Docker则提出了“Build once, Run Anywhere, Configure once,Run Anything”
Docker使软件部署的应用也呆以具备类似SVN的版本控制功能,对应用做一些修改,提交新版本,运行环境可以在多个版本间快速切换,自由选择使用哪个版本对外提供服务。
Docker用来管理软件部署的应用,Docker把应用打包成一个镜像,镜像带有版本控制功能,应用的每次修改迭代就对应镜像一个版本,制作好的镜像可以发布到镜像仓库,分享给别人;也可以直接从镜像仓库下载别人制作好的应用,不做修改即可运行起来。
举几个例子
1.小D刚进项目组不久,之前只用过MySQL数据库,这次要使用Oracle数据库开发,项目经理让小D在公司服务器(Linux)上安装Oracle数据库,作为开发库。
小D上网找资料,下Oracle安装包,一步一步操作,期间遇到N多问题:oracle依赖的软件包缺失;协议适配器问题;Failed to upgrade Oracle Cluster..等等,最终花了两天时间终于弄好了。
对于小D来说,这个过程耗时耗力,而对于立志于做码农的小D来说,这样的经历对他的职业发展来说,并没有多大的提升。对项目组来说,浪费了2人天的开发时间。
毫无疑问,使用Docker能极大的帮助我们解决这类问题,帮助有多大? 两行命令即可
下载镜像
从Docker Hub上下载Oracle镜像
docker pull wnameless/oracle-xe-11g:14.04.4
创建容器
根据下载好的Oracle镜像,建一个容器名为myOracle的容器
docker run -d --name myOracle -p 49160:22 -p 49161:1521 -e ORACLE_ALLOW_REMOTE=true wnameless/oracle-xe-11g:14.04.4
至此一个Oracle数据库安装完成,可以通过jdbc:oracle:thin:@192.168.251.241:49161:xe来访问了。
2.小D进项目组有段时间了,由于接触的是新的开发框架,新的中间件,从学习到现在非常熟练,积累了很多使用心得,希望能分享给大家,方便其他小伙伴,项目经理听到后很欣赏,决定通过知识库的方式来让组员分享。于是小D又接到了一个新的任务,搭建Confluence(知识库的一款软件)来积累项目开发经验。
小D又开始了上网找资料,下载安装包,一步一步操作,期间遇到了很多问题,虽然最终还是弄好了,但是花了很长时间。
仿佛历史重演…
如果使用Docker呢? 相信大家已经知道了,两行命令即可解决;
下载镜像
创建容器
3.小D所在的项目开发完成了,进入测试阶段。小E是一名QA测试工程师,他按小D给的文档来部署测试环境,测试聘大堆问题,通过和小D沟通,发现是开发和测试环境不一致引起的。
如果使用Docker呢?
小D将开发环境制作成镜像,并上传到公司的Docker Hub上
小E从Docker Hub上下载镜像
小E根据镜像创建容器
完成测试环境的搭建。注:实际的情况可能会更加复杂需要借助于CI工具如Jenkins来一起使用,这个在后续的文章中也会发出来。
4.小D不知不觉已经是一名“老人”了,到了给新员工培训的这天,第一天是要新员工在本地塔建好开发环境,Oracle、Tomcat、Nginx等。几十个人的培训规模,总是有一两个会出现一些奇怪问题,小D解决了半天也没有把新员工的开发环境弄好,颜面尽失,尴尬不已。
如果使用Docker呢?
下境相应的镜像
创建容器
5.小D这天要接手公司一个老系统,该系统在生产环境上正常运行,但由于几年没有人维护,开发和运维经历过更替,交接文档不全,现在谁都不知道该如何部署这个应用到新的机器上。小D只能一点点摸索,过程不言而渝。
如果使用Docker呢?
下境相应的镜像
创建容器
6.小D所在的项目组,需要使用微服务
待续...
相关推荐
- Java面试宝典之问答系列(java面试回答)
-
以下内容,由兆隆IT云学院就业部根据多年成功就业服务经验提供:1.写出从数据库表Custom中查询No、Name、Num1、Num2并将Name以姓名显示、计算出的和以总和显示的SQL。SELECT...
- ADG (Active Data Guard) 数据容灾架构下,如何配置 Druid 连接池?
-
如上图的数据容灾架构下,上层应用如果使用Druid连接池,应该如何配置,才能在数据库集群节点切换甚至主备数据中心站点切换的情况下,上层应用不需要变动(无需修改配置也无需重启);即数据库节点宕机/...
- SpringBoot多数据源dynamic-datasource快速入门
-
一、简介dynamic-datasourc是一个基于SpringBoot的快速集成多数据源的启动器,其主要特性如下:支持数据源分组,适用于多种场景纯粹多库读写分离一主多从混合模式。支持...
- SpringBoot项目快速开发框架JeecgBoot——项目简介及系统架构!
-
项目简介及系统架构JeecgBoot是一款基于SpringBoot的开发平台,它采用前后端分离架构,集成的框架有SpringBoot2.x、SpringCloud、AntDesignof...
- 常见文件系统格式有哪些(文件系统类型有哪几种)
-
PART.01常见文件系统格式有哪些常见的文件系统格式有很多,通常根据使用场景(Windows、Linux、macOS、移动设备、U盘、硬盘等)有所不同。以下是一些主流和常见的文件系统格式及其特点:一...
- Oracle MySQL Operator部署集群(oracle mysql group by)
-
以下是使用OracleMySQLOperator部署MySQL集群的完整流程及关键注意事项:一、部署前准备安装MySQLOperator通过Helm安装Operator到Ku...
- LibreOffice加入"转向Linux"运动
-
LibreOffice项目正准备削减部分Windows支持,并鼓励用户切换到Linux系统。自Oracle放弃OpenOffice后,支持和指导LibreOffice开发的文档基金会对未来有着明确的观...
- Oracle Linux 10发布:UEK 8.1、后量子加密、增强开发工具等
-
IT之家6月28日消息,科技媒体linuxiac昨日(6月27日)发布博文,报道称OracleLinux10正式发布,完全二进制兼容(binarycompatibility...
- 【mykit-data】 数据库同步工具(数据库同步工具 开源)
-
项目介绍支持插件化、可视化的数据异构中间件,支持的数据异构方式如下MySQL<——>MySQL(增量、全量)MySQL<——>Oracle(增量、全量)Oracle...
- oracle关于xml的解析(oracle读取xml节点的属性值)
-
有时需要在存储过程中处理xml,oracle提供了相应的函数来进行处理,xmltype以及相关的函数。废话少说,上代码:selectxmltype(SIConfirmOutput).extract...
- 如何利用DBSync实现数据库同步(通过dblink同步数据库)
-
DBSync是一款通用型的数据库同步软件,能侦测数据表之间的差异,能实时同步差异数据,从而使双方始终保持一致。支持各种数据库,支持异构同步、增量同步,且提供永久免费版。本文介绍其功能特点及大致用法,供...
- MYSQL存储引擎InnoDB(八十):InnoDB静态数据加密
-
InnoDB支持独立表空间、通用表空间、mysql系统表空间、重做日志和撤消日志的静态数据加密。从MySQL8.0.16开始,还支持为模式和通用表空间设置加密默认值,这允许DBA控制在这些模...
- JDK高版本特性总结与ZGC实践(jdk高版本兼容低版本吗)
-
美团信息安全技术团队核心服务升级JDK17后,性能与稳定性大幅提升,机器成本降低了10%。高版本JDK与ZGC技术令人惊艳,且JavaAISDK最低支持JDK17。本文总结了JDK17的主要...
- 4 种 MySQL 同步 ES 方案,yyds!(两个mysql数据库自动同步的方法)
-
本文会先讲述数据同步的4种方案,并给出常用数据迁移工具,干货满满!不BB,上文章目录:1.前言在实际项目开发中,我们经常将MySQL作为业务数据库,ES作为查询数据库,用来实现读写分离,...
- 计算机Java培训课程包含哪些内容?其实就这六大块
-
不知不觉秋天已至,如果你还处于就业迷茫期,不如来学习Java。对于非科班小白来说,Java培训会更适合你。提前了解下计算机Java培训课程内容,会有助于你后续学习。下面,我就从六个部分为大家详细介绍...
你 发表评论:
欢迎- 一周热门
- 最近发表
-
- Java面试宝典之问答系列(java面试回答)
- ADG (Active Data Guard) 数据容灾架构下,如何配置 Druid 连接池?
- SpringBoot多数据源dynamic-datasource快速入门
- SpringBoot项目快速开发框架JeecgBoot——项目简介及系统架构!
- 常见文件系统格式有哪些(文件系统类型有哪几种)
- Oracle MySQL Operator部署集群(oracle mysql group by)
- LibreOffice加入"转向Linux"运动
- Oracle Linux 10发布:UEK 8.1、后量子加密、增强开发工具等
- 【mykit-data】 数据库同步工具(数据库同步工具 开源)
- oracle关于xml的解析(oracle读取xml节点的属性值)
- 标签列表
-
- oracle位图索引 (74)
- oracle批量插入数据 (65)
- oracle事务隔离级别 (59)
- oracle 空为0 (51)
- oracle主从同步 (55)
- oracle 乐观锁 (51)
- redis 命令 (78)
- php redis (88)
- redis 存储 (66)
- redis 锁 (69)
- 启动 redis (66)
- redis 时间 (56)
- redis 删除 (67)
- redis内存 (57)
- redis并发 (52)
- redis 主从 (69)
- redis 订阅 (51)
- redis 登录 (54)
- redis 面试 (58)
- 阿里 redis (59)
- redis 搭建 (53)
- redis的缓存 (55)
- lua redis (58)
- redis 连接池 (61)
- redis 限流 (51)