`
liujiekasini0312
  • 浏览: 147487 次
  • 性别: Icon_minigender_1
  • 来自: 北京
社区版块
存档分类
最新评论

spring cloud微服务框架第五天

 
阅读更多

  第五天,使用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 微服务简单框架

    这个“spring cloud 微服务简单框架”包含了一个基础的微服务架构,包括服务提供者、服务消费者和服务中间转发等组件的源码。 1. **服务提供者**:在 Spring Cloud 中,服务提供者是拥有业务逻辑的应用程序,它们...

    Springcloud微服务框架.docx

    【SpringCloud微服务框架】 SpringCloud 是一套完整的微服务解决方案,它提供了服务发现、负载均衡、熔断机制、路由网关等一系列工具,帮助开发者构建分布式系统。本文将深入探讨SpringCloud中的服务调用原理、负载...

    SpringCloud第3季2024.7z

    SpringCloud是微服务架构中的一个核心框架,它提供了一套完整的解决方案,用于构建分布式系统,如服务发现、负载均衡、断路器、API网关、数据流处理等。本资源"SpringCloud第3季2024.7z"很可能包含的是关于Spring...

    从天气项目看Spring Cloud微服务治理

    ### 从天气项目看Spring Cloud微服务治理 #### Spring Cloud简介 Spring Cloud 是一套基于 Spring Boot 实现的微服务云应用开发框架,它利用 Spring Boot 的开发便利性巧妙地简化了分布式系统基础设施的开发,如...

    Java之 Spring Cloud 微服务搭建网关(第三个阶段)【一】.zip

    在本教程中,我们将深入探讨如何使用Spring Cloud构建微服务网关,这是Spring Cloud生态中的一个关键组件。Spring Cloud提供了一套工具集,用于简化分布式系统(如配置管理、服务发现、断路器、智能路由、微代理、...

    《深入理解Spring Cloud与微服务构建》word版本

    Spring Cloud作为目前最流行的微服务框架之一,它提供了大量的工具和服务,帮助开发者快速搭建分布式系统。该书可能涵盖了以下几个核心知识点: 1. **Spring Cloud简介**:Spring Cloud是基于Spring Boot的云应用...

    SpringCloud微服务接口查询Demo

    在"SpringCloud微服务接口查询Demo"中,我们主要探讨的是如何利用SpringCloud来实现微服务之间的接口查询和交互,以便更好地理解和监控服务的运行状态。 1. **服务注册与发现**: SpringCloud的核心组件之一是...

    《springcloud微服务实战》知识点评估试题.docx

    根据给定文件的信息,我们可以总结出以下几个与Spring Cloud微服务框架相关的知识点: ### 1. 服务熔断 **服务熔断**是一种重要的微服务架构中的保护机制,它主要用于防止因某一服务出现故障而导致整个系统崩溃的...

    Spring Cloud微服务事务处理Demo

    在这个"Spring Cloud微服务事务处理Demo"中,我们将探讨如何在微服务环境中解决事务一致性问题。 首先,我们来看核心组件——Spring Boot。Spring Boot是基于Spring Framework的快速开发框架,它简化了Spring应用...

    基于layui+springcloud的企业级微服务框架

    仿百度能力开放平台的spring cloud 微服务框架 ,历经多家公司生产考验 1.用户权限 基于spring security jwt 的无session后台管理框架 2.注册中心 基于eureka的服务注册中心 提供动态上线下线功能 3 配置中心 集成...

    《深入理解Spring Cloud与微服务构建》学习笔记(八)

    在《深入理解Spring Cloud与微服务构建》的学习笔记中,第八部分主要聚焦于如何使用Eureka来实现服务注册和发现。以下是一些核心知识点: 1. **Eureka Server**: 这是Eureka的核心组件,作为一个服务注册中心,它...

    spring cloud 体系版本选型,涉及spring cloud alibaba spring boot spring cloud

    Spring Cloud作为一个广泛使用的微服务框架,其版本迭代迅速,每个版本都有其特定的功能特性和生命周期。以下将详细阐述如何进行Spring Cloud、Spring Boot以及Spring Cloud Alibaba的版本选型。 首先,让我们来看...

    基于SpringCloud微服务技术开发的“淘东”电商项目--taodong-shop.zip

    "基于SpringCloud微服务技术开发的“淘东”电商项目--taodong-shop"是一个全面展示微服务架构在电商领域应用的实际案例。SpringCloud作为Java生态中的微服务框架,为大型分布式应用程序提供了全面的服务发现、配置...

    SpringBoot+SpringCloud+nacos+gateway+mybatis搭建微服务

    在构建分布式系统时,Spring Boot、Spring Cloud、Nacos、Gateway和MyBatis这五大组件是常见的技术选型。下面将详细阐述它们的功能、如何整合以及在微服务架构中的作用。 1. Spring Boot:作为核心启动框架,Spring...

    springcloud视频学习

    3. 创建并部署第一个SpringCloud微服务:演示如何使用Spring Cloud Netflix Eureka创建服务注册中心,以及如何让其他微服务实例注册到这个中心。 4. 使用Spring Cloud Config实现配置管理:讲解如何通过Config ...

    7天学会spring cloud教程.pdf.zip

    第五天:Spring Cloud Stream与消息驱动 1. Spring Cloud Stream:理解消息驱动的设计模式,学习如何使用Spring Cloud Stream处理异步消息。 2. RabbitMQ与Kafka:对比两种常见消息中间件,了解它们在Spring Cloud ...

    深入理解Spring Cloud与微服务构建 方志朋 高清pdf

    Spring Cloud 是一套基于 Spring Boot 实现的微服务云应用开发框架。它提供了构建分布式系统中服务治理、配置管理、消息总线、负载均衡、断路器、数据监控等工具。Spring Cloud 的目标是让开发者能够快速地搭建出...

    springboot springcloud 构建 微服务

    在IT行业中,微服务架构已经成为了现代应用开发的主流趋势,Spring Boot和Spring Cloud作为Java生态中的两大神器,为构建微服务提供了强大的支持。本文将深入探讨如何利用Spring Boot和Spring Cloud来构建微服务。 ...

    尚硅谷SpringCloud第二季笔记

    SpringCloud是基于Spring Boot实现的微服务框架,它提供了构建分布式系统所需的诸多服务发现、配置管理、断路器、智能路由、微代理、控制总线等工具,旨在简化微服务架构的开发和运维工作。 在云原生(Cloud Native...

    springCloud-master_单点登录_springCloud单点登录_SpringCloud系统_springclou

    SpringCloud是基于Spring Boot的微服务治理框架,它提供了包括服务发现、负载均衡、断路器、配置中心、熔断机制等一系列微服务解决方案。在"springCloud-master_单点登录_springCloud单点登录_SpringCloud系统_...

Global site tag (gtag.js) - Google Analytics