第五天,使用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命令如下:
curlhttp://localhost:8080
返回:Hello Docker World
docker应用,水比较深,这里只是举一个hello world级别的例子。Spring Boot with Docker例子还提供了一个maven插件docker-maven-plugin,这个插件可以直接将项目编译为docker镜像。另外这个插件还可以让你结合jenkins完成项目的持续集成和自动部署。具体来说就是jenkins自动通过git或svn拉到工程代码,然后使用maven进行编译,再调用项目中的Dockerfile生成镜像。如此以来不管是什么应用,只需要部署docker就可以了,那些配置,那些乱七八糟的环境搭建都不需要了。
分享到:
相关推荐
这个“spring cloud 微服务简单框架”包含了一个基础的微服务架构,包括服务提供者、服务消费者和服务中间转发等组件的源码。 1. **服务提供者**:在 Spring Cloud 中,服务提供者是拥有业务逻辑的应用程序,它们...
【SpringCloud微服务框架】 SpringCloud 是一套完整的微服务解决方案,它提供了服务发现、负载均衡、熔断机制、路由网关等一系列工具,帮助开发者构建分布式系统。本文将深入探讨SpringCloud中的服务调用原理、负载...
SpringCloud是微服务架构中的一个核心框架,它提供了一套完整的解决方案,用于构建分布式系统,如服务发现、负载均衡、断路器、API网关、数据流处理等。本资源"SpringCloud第3季2024.7z"很可能包含的是关于Spring...
### 从天气项目看Spring Cloud微服务治理 #### Spring Cloud简介 Spring Cloud 是一套基于 Spring Boot 实现的微服务云应用开发框架,它利用 Spring Boot 的开发便利性巧妙地简化了分布式系统基础设施的开发,如...
在本教程中,我们将深入探讨如何使用Spring Cloud构建微服务网关,这是Spring Cloud生态中的一个关键组件。Spring Cloud提供了一套工具集,用于简化分布式系统(如配置管理、服务发现、断路器、智能路由、微代理、...
Spring Cloud作为目前最流行的微服务框架之一,它提供了大量的工具和服务,帮助开发者快速搭建分布式系统。该书可能涵盖了以下几个核心知识点: 1. **Spring Cloud简介**:Spring Cloud是基于Spring Boot的云应用...
在"SpringCloud微服务接口查询Demo"中,我们主要探讨的是如何利用SpringCloud来实现微服务之间的接口查询和交互,以便更好地理解和监控服务的运行状态。 1. **服务注册与发现**: SpringCloud的核心组件之一是...
根据给定文件的信息,我们可以总结出以下几个与Spring Cloud微服务框架相关的知识点: ### 1. 服务熔断 **服务熔断**是一种重要的微服务架构中的保护机制,它主要用于防止因某一服务出现故障而导致整个系统崩溃的...
在这个"Spring Cloud微服务事务处理Demo"中,我们将探讨如何在微服务环境中解决事务一致性问题。 首先,我们来看核心组件——Spring Boot。Spring Boot是基于Spring Framework的快速开发框架,它简化了Spring应用...
仿百度能力开放平台的spring cloud 微服务框架 ,历经多家公司生产考验 1.用户权限 基于spring security jwt 的无session后台管理框架 2.注册中心 基于eureka的服务注册中心 提供动态上线下线功能 3 配置中心 集成...
在《深入理解Spring Cloud与微服务构建》的学习笔记中,第八部分主要聚焦于如何使用Eureka来实现服务注册和发现。以下是一些核心知识点: 1. **Eureka Server**: 这是Eureka的核心组件,作为一个服务注册中心,它...
Spring Cloud作为一个广泛使用的微服务框架,其版本迭代迅速,每个版本都有其特定的功能特性和生命周期。以下将详细阐述如何进行Spring Cloud、Spring Boot以及Spring Cloud Alibaba的版本选型。 首先,让我们来看...
"基于SpringCloud微服务技术开发的“淘东”电商项目--taodong-shop"是一个全面展示微服务架构在电商领域应用的实际案例。SpringCloud作为Java生态中的微服务框架,为大型分布式应用程序提供了全面的服务发现、配置...
在构建分布式系统时,Spring Boot、Spring Cloud、Nacos、Gateway和MyBatis这五大组件是常见的技术选型。下面将详细阐述它们的功能、如何整合以及在微服务架构中的作用。 1. Spring Boot:作为核心启动框架,Spring...
3. 创建并部署第一个SpringCloud微服务:演示如何使用Spring Cloud Netflix Eureka创建服务注册中心,以及如何让其他微服务实例注册到这个中心。 4. 使用Spring Cloud Config实现配置管理:讲解如何通过Config ...
第五天:Spring Cloud Stream与消息驱动 1. Spring Cloud Stream:理解消息驱动的设计模式,学习如何使用Spring Cloud Stream处理异步消息。 2. RabbitMQ与Kafka:对比两种常见消息中间件,了解它们在Spring Cloud ...
Spring Cloud 是一套基于 Spring Boot 实现的微服务云应用开发框架。它提供了构建分布式系统中服务治理、配置管理、消息总线、负载均衡、断路器、数据监控等工具。Spring Cloud 的目标是让开发者能够快速地搭建出...
在IT行业中,微服务架构已经成为了现代应用开发的主流趋势,Spring Boot和Spring Cloud作为Java生态中的两大神器,为构建微服务提供了强大的支持。本文将深入探讨如何利用Spring Boot和Spring Cloud来构建微服务。 ...
SpringCloud是基于Spring Boot实现的微服务框架,它提供了构建分布式系统所需的诸多服务发现、配置管理、断路器、智能路由、微代理、控制总线等工具,旨在简化微服务架构的开发和运维工作。 在云原生(Cloud Native...
SpringCloud是基于Spring Boot的微服务治理框架,它提供了包括服务发现、负载均衡、断路器、配置中心、熔断机制等一系列微服务解决方案。在"springCloud-master_单点登录_springCloud单点登录_SpringCloud系统_...