使用docker发布spring cloud应用

本文涉及到的项目:

  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就可以了,那些配置,那些乱七八糟的环境搭建都不需要了。

原文地址:https://www.cnblogs.com/xuyatao/p/8446407.html

时间: 2024-11-04 20:20:46

使用docker发布spring cloud应用的相关文章

在阿里云容器服务上开发基于Docker的Spring Cloud微服务应用

本文为阿里云容器服务Spring Cloud应用开发系列文章的第一篇. 一.在阿里云容器服务上开发Spring Cloud微服务应用(本文) 二.部署Spring Cloud应用示例 三.服务发现 四.服务间通信与集成 五.服务智能路由 六.集中配置管理 七.高可用和容错 八.监控和日志 九.服务的部署和发布策略 微服务概述 单体应用通常指在一个程序中满足多个业务或技术领域的需求,不同的需求领域内化为模块.假定我们要开发一个Web应用,通常的MVC模式可以满足要求.针对不同领域有不少代码生成工具

发布spring cloud + vue项目

服务器部署结构 1.服务器访问直接访问NGINX 2.静态资源访问, nginx读取本地文件夹 3.API接口路由, nginx把以api开头的访问都路由到业务逻辑服务器. nginx配置 server { listen 80; server_name localhost; #charset koi8-r; #access_log logs/host.access.log main; # 静态资源位置 (这里的dist文件夹,即vue打包的默认文件名) location / { root c:/

SpringCloud教程 | 第十一篇: docker部署spring cloud项目

版权声明:本文为博主原创文章,欢迎转载,转载请注明作者.原文超链接 ,博主地址:http://blog.csdn.net/forezp. http://blog.csdn.net/forezp/article/details/70198649 目录(?)[+] 转载请标明出处: http://blog.csdn.net/forezp/article/details/70198649 本文出自方志朋的博客 一.docker简介 Docker是一个开源的引擎,可以轻松的为任何应用创建一个轻量级的.可

利用Docker部署Spring Cloud项目

1.按照创建server的方式创建一个项目,可以参照https://www.cnblogs.com/SakerLiu/p/9743577.html 2.在pom.xml文件中添加插件,代码如下所示 <build> <plugins> <plugin> <groupId>org.springframework.boot</groupId> <artifactId>spring-boot-maven-plugin</artifact

结合Docker运行Spring Cloud微服务的多种方式

如何通过以下方式在Docker中运行Spring-Cloud MicroService拓扑: Docker端口映射到外部主机网络Docker LinksDocker Bridge网络 从Docker机器的外部访问Docker容器中微服务 Eureka和MicroServices可通过docker机器的静态IP地址访问.客户端只需获取eureka注册表并通过docker-machine的IP调用特定的MicroService,并将容器的端口映射到客户端的网络端口. 如果设置eureka.insta

使用docker部署spring cloud项目详细步骤

准备工作JDK1.8.Docker1.12.1.CentOS7.0 1.CentOS7.0下JDK1.8的安装 (1)到Oracle官网下载好 jdk-8u181-linux-x64.tar.gz 备用 (2)卸载系统自带的java java -version # 如果有结果出来,则说明自带了javarpm -qa|grep java # 查询出已经安装的javayum -y remove [上面查出来的东西,多个用空格分隔](3)安装jdk cd /usr #进入到要安装jdk的目录mkdir

使用 Spring Cloud 和 Docker 构建微服务

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

《Spring Cloud与Docker微服务架构实战》配套代码

不才写了本使用Spring Cloud玩转微服务架构的书,书名是<Spring Cloud与Docker微服务架构实战> - 周立,已于2017-01-12交稿.不少朋友想先看看源码,现将代码放出. 本次放出的代码: 共计70+个DEMO 覆盖Eureka.Ribbon.Feign.Hystrix.Zuul.Spring Cloud Config.Spring Cloud Bus.Spring Cloud Sleuth.Docker.Docker Compose等. 1-11章代码地址: ht