(我是个封面)

docker简介

Docker 是一个开源的应用容器引擎,和传统的虚拟机技术相比,Docker 容器性能开销极低,因此也广受开发者喜爱。随着基于docker的开发者越来越多,docker的镜像也原来越丰富,未来各种企业级的完整解决方案都可以直接通过下载镜像拿来即用。因此docker变得越来越重要。

本文目的

本文通过一个项目实例来介绍如果通过docker对外接口来实现对docker容器的管理和监控。

应用场景:

对服务器资源池通过docker进行统一管理,按需分配资源和创建容器,达到资源最大化利用。同时保证各业务(容器)之间的隔离。并可支持项目的在线部署。

本项目模拟实现以上场景,代码不完全严禁,代码仅供学习。

实现功能:

1、通过界面创建docker的tomcat容器,并配置限额。

2、上传war包并部署到容器。

3、动态监控docker所有容器的资源使用情况。

代码基于docker-java开源组件,基于spring-boot完成功能开发。界面如下图:

基础环境

1、eclipse  2019-03;

2、docker for windows。本着学习和简单的目的,并未使用linux环境,但原理和基本命令相同。

相关技术和知识点:

maven,spring-boot;spring mvc;spring上传下载,jquery ajax和上传。

实现原理

docker对外提供了丰富接口(如:restfull APi),通过这些接口可对docker进行管理。docker-java开源组件基于这个接口做了封装,使得开发更加简单。当然市面上还有其他一些封装好的组件,大家可自行比较和学习。在这里对开源作者表示感谢。当然本人也会开源的参与者,相关文章:本人的ORM开源组件

实现过程之前期准备

1、升级windows

由于我们使用的是windows环境, 笔者自己电脑预装的是win10 家庭版,而docker for windows 需要运行在更高级别的操作系统上,才能使用虚拟化技术,因此需要升级到专业版。

如果需要升级的,升级过程也比较简单,简单介绍如下(已经是专业版的可以略过):

点击更改产品密匙,输入专业版的密匙之后,就等待慢慢升级了。密匙自己在网上找,反正是有的。

2、安装docker for windows

去官网下载后,一路下一步就可以了。安装完后,会自己启动,启动后工具栏就会出现docker的标志。

安装成功后,可以敲一些命令测试一下是否成功。如:查看docker基本信息。

3、修改docker镜像地址。

由于默认的镜像地址较慢,一个tomcat镜像都500多m,网络不好下载会很慢,可将镜像地址配置成网易的镜像地址,如下:

4、启动远程管理

勾选上最后一项,这里面的tcp//xxx就是远程连接地址。

启动后,在浏览器里面敲一下地址,看看是否能返回结果:

http://localhost:2375/info(此地址同在cmd里面输入docker indo)返回的是json格式的内容:

实现过程之代码开发

1、创建maven项目。

由于过程简单,省略此过程。整个项目的代码结构如下:

2、配置docker-java和spring boot的maven依赖,最终pom文件内容如下

通过看jar包,docker-java底层应该是用了netty依赖。

3、添加spring配置文件application.properties

配置jsp的位置和docker的管理地址。

4、主要类介绍:

1.spring boot启动主类。

当然也可以配置其他容器或者用maven的jetty插件来启动。

可参考另外一篇文章:Spring-boot原理(附带实现一个spring-boot-starter实例)附源码下载

注意这个类放的位置,最好放在根目录,这样根目录下的所有子目录都能被spring扫描到了。

2.DockerClientOperaterServer(与docker交互的类),具体如下:

包括如下方法:

initClient:初始化链接。

getDockerInfo:获取docker基本信息;

stat:实时统计信息;

refreshContainers:获取所有容器的基本信息,并放入缓存;

createAndStartrContainerAnddeployApp:根据界面传递的参数创建并启动容器,同时部署项目;

stopContainer:停止容器;

rmContainer:删除容器;

closeClient:关闭链接;

pushAppToCotainer:部署war包到tomcat;

由于代码片段太长,这里看几个主要的方法:

createContainer(创建容器):

这个方法里面通过docker-java创建容器,分配限额,配置端口映射等。

pushAppToCotainer:部署项目到tomcat

stat,监控方法:

监控这一块没有用docker-java的方法,其实它是支持的,但是由于返回结果需要各种处理,就用了投机取巧的方法。使用java调用cmd来执行(docker stats)获取监控结果。

docker-java来获取监控信息的代码如下:

3.DockerClientController(和界面交互的controller)。

主要方法介绍:

addContainer:添加容器以及上传war包

以上便是主要代码的讲解。

具体代码详情,请下载源码启动后按照过程查看。

实现后的主要界面:

由于是示例项目,代码没有用什么vue和bootstrap框架。自己写了点css和js。具体效果如下:

1、监控管理主页

2、添加容器;

~以上便是本次分享所有内容~

过程中又问可以留言,如果有时间可以一起讨论。谢谢!

源码下载

为防止地址失效,所有下载链接都在公众号维护,请关注公众号后,回复“R004” 获取完整源码。

基于spring-boot和docker-java实现对docker容器的动态管理和监控[附完整源码下载]的更多相关文章

  1. Java导出Excel(附完整源码)

    导出excel是咱Java开发的必备技能啦,之前项目有这个功能,现在将其独立出来,分享一下.所用技术就是SpringBoot,然后是MVC架构模式.废话不多说,直接上代码了,源码点末尾链接就可以下载. ...

  2. 你也可以用java的swing可以做出这么炫的mp3播放器_源码下载

    I had published the blog : 你用java的swing可以做出这么炫的mp3播放器吗? and to display some screenshots about this M ...

  3. Java打飞机小游戏(附完整源码)

    写在前面 技术源于分享,所以今天抽空把自己之前用java做过的小游戏整理贴出来给大家参考学习.java确实不适合写桌面应用,这里只是通过这个游戏让大家理解oop面向对象编程的过程,纯属娱乐.代码写的很 ...

  4. 适合新手:从零开发一个IM服务端(基于Netty,有完整源码)

    本文由“yuanrw”分享,博客:juejin.im/user/5cefab8451882510eb758606,收录时内容有改动和修订. 0.引言 站长提示:本文适合IM新手阅读,但最好有一定的网络 ...

  5. 基于Spring Boot、Spring Cloud、Docker的微服务系统架构实践

    由于最近公司业务需要,需要搭建基于Spring Cloud的微服务系统.遍访各大搜索引擎,发现国内资料少之又少,也难怪,国内Dubbo正统治着天下.但是,一个技术总有它的瓶颈,Dubbo也有它捉襟见肘 ...

  6. 【docker】centOS7上部署的mysql和spring boot服务,要求,mysql的时间、java程序服务的时间和宿主机的时间完全保持一致【修改mysql时区,临时和永久】【修改spring boot配置文件时区】【修改docker启动spring boot实例程序时区】

    要求:centOS7上部署的mysql和spring boot服务,要求,mysql的时间.java程序服务的时间和宿主机的时间完全保持一致: ============================ ...

  7. 基于Spring Boot和Spring Cloud实现微服务架构学习

    转载自:http://blog.csdn.net/enweitech/article/details/52582918 看了几周Spring相关框架的书籍和官方demo,是时候开始总结下这中间的学习感 ...

  8. 基于Spring Boot和Spring Cloud实现微服务架构学习--转

    原文地址:http://blog.csdn.net/enweitech/article/details/52582918 看了几周spring相关框架的书籍和官方demo,是时候开始总结下这中间的学习 ...

  9. 基于Spring Boot+Cloud构建微云架构

    前言 首先,最想说的是,当你要学习一套最新的技术时,官网的英文文档是学习的最佳渠道.因为网上流传的多数资料是官网翻译而来,很多描述的重点也都偏向于作者自身碰到的问题,这样就很容易让你理解和操作出现偏差 ...

随机推荐

  1. linux命令学习笔记(32):gzip命令

    减少文件大小有两个明显的好处,一是可以减少存储空间,二是通过网络传输文件时,可以减少传输的时间. gzip是在Linux系统中经常使用的一个对文件进行压缩和解压缩的命令,既方便又好用.gzip不仅可以 ...

  2. 如何在Mac下显示Finder中的所有文件

    在Unix下工作,你可能需要处理一些“特殊“文件或文件夹,例如/usr,/bin, etcf,或一些"dot files"(如.bash_profile).但是Linux/Unix ...

  3. ACM学习历程——HDU5202 Rikka with string(dfs,回文字符串)

    Problem Description As we know, Rikka is poor at math. Yuta is worrying about this situation, so he ...

  4. 使用Tornado作为Django App的服务器

    闲来无事,折腾折腾. 老是听说tonado是个异步web框架和服务器,作为框架倒是了解到了,但是服务器一直不太懂.所以决定了解一下,既然可以做服务器,那就把自己的django app部署到这上边去. ...

  5. WPF DatePicker 的textbox的焦点

    要得到DatePicker的textchange属性, 必须通过TextBoxBase.TextChanged 事件来处理. 想要判断是否当前DatePicker的textbox获取到焦点, 可以通过 ...

  6. JIRA 破解文件研究(Win 7环境)

    最近再次回来研究 Win 7 下的 JIRA,按网上的很多方法去尝试,竟然无法正常安装! 经过几次的弯路尝试,终究还是成功了. 嗯,有必要总结一下: 发觉网上的很多破解方法都太老!不管是什么原因,在6 ...

  7. 用c++STL实现进程管理

    项目要求: 设计一个允许n个进程并发运行的进程管理模拟系统.该系统包括有简单的进程控制,其进程调度采用时间片轮转算法.每个进程用一个PCB表示,其内容根据具体情况设置.各进程之间有一定的同步关系(可选 ...

  8. day1 java基础

    常见的dos命令 盘符: 进入指定的盘符下. dir : 列出当前目录下的文件以及文件夹 md : 创建目录 rd : 删除目录    注意:rd不能删除非空的文件夹,而且只能用于删除文件夹. cd ...

  9. HDU - 4804 Campus Design(状压+轮廓线dp)

    Campus Design Nanjing University of Science and Technology is celebrating its 60th anniversary. In o ...

  10. GridView_RowDataBound 常用方法

    1.这个就不用说,鼠标经过行颜色变化 protected void GridView1_RowDataBound(object sender, GridViewRowEventArgs e)    { ...