文档章节

使用docker发布spring cloud应用

逝去的回忆
 逝去的回忆
发布于 2017/02/17 17:44
字数 891
阅读 53
收藏 0

  本文涉及到的项目:

  cloud-simple-docker:一个简单的spring boot应用

  Docker是一种虚拟机技术,准确的说是在linux虚拟机技术LXC基础上又封装了一层,可以看成是基于LXC的容器技术。可以把容器看做是一个简易版的Linux环境(包括root用户权限、进程空间、用户空间和网络空间等)和运行在其中的应用程序。容器是用来装东西的,Docker可以装载应用本身及其运行环境进容器,这是一个很小的文件,然后把这个文件扔到任何兼容的服务器上就可以运行,也是基于这一点,Docker可以同时让应用的部署、测试和分发都变得前所未有的高效和轻松!

   下面例子参考“Spring Boot with Docker”官方例子。

  1)建立一个简单的应用,只有一个类,包含main方法,代码如下:

  @SpringBootApplication
  @RestController
  public class Application {

  @RequestMapping("/")

  public String home() {

        return "Hello Docker World";

  }

  public static void main(String[] args) {

        SpringApplication.run(Application.class, args);         

  }

  }

  2)建立Dockerfile

  # 基于那个镜像

  FROM daocloud.io/java:8

  # 将本地文件夹挂载到当前容器(tomcat使用)

  VOLUME /tmp

  # 拷贝文件到容器

  ADD cloud-simple-docker-1.0.0.jar /app.jar

  # 打开服务端口

  EXPOSE 8080

  # 配置容器启动后执行的命令

  ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

  这里特别要注意,这里的FROM采用国内的docker镜像,如果连国外的docker镜像下载,基本是不太可能下载下来的,原因大家都知道。

  有了Dockerfile,就可以部署docker了。

  3)部署docker示例

  部署分为2步,分别是创建镜像、运行。

  • 创建镜像

  将编译后的jar文件考到服务器某个目录,这里是tmp目录。然后将Dockerfile也考到该目录,最后进入到该目录下运行命令:

  docker build  -t  local/cloud-docker-hello .

  别掉了后面的“.”符号,这个符号表示目录,这个命令执行成功,你会看到以下界面:

   

  运行成功后,就创建了一个镜像,可以使用docker images来查看该镜像。

  • 运行镜像

  有了镜像就可以运行了,使用下面命令运行:

  docker run -p 8080:8080 –t  local/cloud-simple-docker

  其中8080:8080表示本机端口映射到Docker实例端口。如果本机端口没有打开,还需要打开该端口,打开端口在centos 7中使用firewall-cmd命令:

  firewall-cmd --zone=public --add-port=8080/tcp --permanent

  firewall-cmd –reload

  成功后可以使用docker ps –a查看镜像运行情况:

  local/cloud-docker-hello | latest | 3ef51d55eb27 | 22 minutes ago | 667.2 MB

  可以看到这个包括了java运行环境的web应用镜像是667MB。

  该步骤运行结果如下:

   

  最后使用curl命令或者直接在浏览器打开,可以直接测试该应用。使用curl命令如下:

  curl http://localhost:8080

  返回:Hello Docker World

  docker应用,水比较深,这里只是举一个hello world级别的例子。Spring Boot with Docker例子还提供了一个maven插件docker-maven-plugin,这个插件可以直接将项目编译为docker镜像。另外这个插件还可以让你结合jenkins完成项目的持续集成和自动部署。具体来说就是jenkins自动通过git或svn拉到工程代码,然后使用maven进行编译,再调用项目中的Dockerfile生成镜像。如此以来不管是什么应用,只需要部署docker就可以了,那些配置,那些乱七八糟的环境搭建都不需要了。

本文转载自:http://www.cnblogs.com/skyblog/p/5163691.html

共有 人打赏支持
逝去的回忆
粉丝 12
博文 136
码字总数 219842
作品 0
深圳
高级程序员
Spring Cloud Edgware新特性之一:解决Eureka中Jersey 1.x版本过旧的问题-不使用Jersey

Spring Cloud是当前炙手可热的微服务开发框架。它的功能强大,组件丰富,设计优雅。目前Spring Cloud还在不断发展之中。 Spring Cloud即将发布 版本。该版本解决了不少Bug,新增了不少新特性...

周立_ITMuch
2017/10/24
0
0
如何使用Spring Cloud实现高并发微服务设计

本文根据dbaplus社群第161期线上分享整理而成。 大家好,今天我们主要是分享一下我写作的《Spring Cloud与Docker高并发微服务架构设计实施》这本书的一些心得,也可以说是我近几年从事微服务...

陈韶健
09/07
0
0
使用 Docker 部署 Spring Boot之项目的构建

Docker通常用于如下场景: web应用的自动化打包和发布; 自动化测试和持续集成、发布; 在服务型环境中部署和调整数据库或其他的后台应用; 从头编译或者扩展现有的OpenShift或Cloud Foundry...

qq_28089993
04/21
0
0
使用阿里云容器服务部署高可用eureka

之前在网上搜了很久,基本上都是自己维护的swarm集群,并不是使用的阿里云的容器服务功能,所以基本都不能使用,下面是我最终可用的配置,但是无法使用阿里云的蓝绿发布来发布eureka,不过这...

endom
06/29
0
0
这些优秀的 Spring Cloud 开源软件,你知道几个?

Spring Cloud是一系列框架的有序集合。它利用Spring Boot的开发便利性巧妙地简化了分布式系统基础设施的开发,如服务发现注册、配置中心、消息总线、负载均衡、断路器、数据监控等,都可以用...

技术小能手
08/30
0
0

没有更多内容

加载失败,请刷新页面

加载更多

Apache Spark 2.3 重要特性介绍

本文翻译自:https://databricks.com/blog/2018/02/28/introducing-apache-spark-2-3.html 为了继续实现 Spark 更快,更轻松,更智能的目标,Spark 2.3 在许多模块都做了重要的更新,比如 St...

hblt-j
17分钟前
1
0
Git基本操作

Git基本操作 git add . git commit git commit -m "updata" git log查看日志 git checkout xxx 切换分支到xxx 常用命令 版本库管理 创建版本库 # 初始化版本库mkdir learngit && cd learng...

lslaiwy
20分钟前
1
0
ubuntu 彻底删除 mysql 然后重装 mysql

ubuntu 彻底删除 mysql 然后重装 mysql 删除 mysql sudo apt-get autoremove --purge mysql-server-5.0 sudo apt-get remove mysql-server sudo apt-get autoremove mysql-server sudo apt-......

关上越
23分钟前
1
0
Fabric.js高级点的教程3--添加遮罩和裁剪的方法

写这篇文章的时候我就要说一下了,这个遮罩和裁剪耗费了我真的是九牛二虎之力 裁剪的插件很多,无论你用原生JS,JQuery, Vue还是React.总能找到一款裁剪插件。今天我要说的是自己写一个截图功...

xmqywx
26分钟前
1
0
springboot 初始化不设置数据源 由接口动态设置数据源(传入ip 端口 数据库名称 账号 密码)

程序无需重启可以加个过滤器支持未设置数据库无法调用将配置存到property文件,也可存到缓存设置时需要一个工具类判断传入的数据库是否可连接等import org.apache.commo...

林伟琨
32分钟前
2
0

没有更多内容

加载失败,请刷新页面

加载更多

返回顶部
顶部