欢迎您访问程序员文章站本站旨在为大家提供分享程序员计算机编程知识!
您现在的位置是: 首页  >  IT编程

docker-compose镜像发布springboot项目的流程分析

程序员文章站 2022-04-06 22:31:43
简介docker-compose项目是docker官方的开源项目,负责实现对docker容器集群的快速编排。compose允许用户通过一个单独的docker-compose.yml模板文件(yaml...

简介

docker-compose项目是docker官方的开源项目,负责实现对docker容器集群的快速编排。compose允许用户通过一个单独的docker-compose.yml模板文件(yaml 格式)来定义一组相关联的应用容器为一个项目(project)。docker-compose项目由python编写,调用docker服务提供的api来对容器进行管理。因此,只要所操作的平台支持docker api,就可以在其上利用compose来进行编排管理。

docker-compose将所管理的容器分为三层,分别是工程(project),服务(service)以及容器(container)。docker-compose运行目录下的所有文件(docker-compose.yml,extends文件或环境变量文件等)组成一个工程,若无特殊指定工程名即为当前目录名。一个工程当中可包含多个服务,每个服务中定义了容器运行的镜像,参数,依赖。一个服务当中可包括多个容器实例,docker-compose并没有解决负载均衡的问题,因此需要借助其它工具实现服务发现及负载均衡。

docker-compose的工程配置文件默认为docker-compose.yml,可通过环境变量compose_file或-f参数自定义配置文件,其定义了多个有依赖关系的服务及每个服务运行的容器。
使用一个dockerfile模板文件,可以让用户很方便的定义一个单独的应用容器。在工作中,经常会碰到需要多个容器相互配合来完成某项任务的情况。例如要实现一个web项目,除了web服务容器本身,往往还需要再加上后端的数据库服务容器,甚至还包括负载均衡容器等。

常用命令

docker-compose

介绍

compose的作用是“定义和运行多个docker容器的应用”。使用compose,你可以在一个配置文件(yaml格式)中配置你应用的服务,然后使用一个命令,即可创建并启动配置中引用的所有服务。
compose中两个重要概念:
• 服务 (service):一个应用的容器,实际上可以包括若干运行相同镜像的容器实例。
• 项目 (project):由一组关联的应用容器组成的一个完整业务单元,在 docker-compose.yml文件中定义。

docker compose的安装

compose的安装有多种方式,本文讲解通过shell安装的方式。其他安装方式如有兴趣,
可以查看docker的官方文档:https://docs.docker.com/compose/install/

docker compose安装步骤

通过github链接下载安装 非root用户记得加sudo

sudo curl -l "https://github.com/docker/compose/releases/download/1.25.5/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

给二进制下载文件可执行的权限

sudo chmod +x /usr/local/bin/docker-compose

验证是否安装

docker-compose --version

卸载
如果是二进制包方式安装的,删除二进制文件即可

rm /usr/local/bin/docker-compose

目录结构

compose
	docker-compose.yml
	eureka
		dockerfile
		eureka-server-2.0.2.release.jar
	user
		dockerfile
		user-2.0.2.release.jar
	power
		dockerfile
		power-2.0.2.release.jar

示例

compose的使用非常简单,只需要编写一个docker-compose.yml,然后使用docker-compose 命令操作即可。docker-compose.yml描述了容器的配置,而docker-compose 命令描述了对容器的操作。
1.我们使用一个微服务项目先来做一个简单的例子,首先创建一个compose的工作目录,然后创建一个jenkinstest文件夹,里面放可执行jar包和编写一个dockerfile文件,目录结构如下:
jenkins里面存放自己测试上传的jar包

docker-compose镜像发布springboot项目的流程分析

docker-compose.yml

version: '3.1'  #这里要指定docker-compose对应的docker版本
services:
  jenkinstest:             #指定服务名
    #image: jenkinstest  #指定镜像名称 小写不然会报错
    build: ./jenkinstest   #指定dockfile所在路径
    ports:
      - 8099:8099   #指定端口映射
    expose:
      - 8099  #对外暴露的服务端口

dockerfile文件

from adoptopenjdk/openjdk8:jdk8u-centos-nightly

#作者
maintainer lkz

# 镜像要暴露的端口,如要使用端口,在执行docker run命令时使用-p生效
expose 8099
 
copy jenkinstest.jar 11.jar 
# 在镜像运行为容器后执行的命令
entrypoint ["java","-jar","11.jar"]

启动微服务,可以加上参数-d后台启动

docker-compose up -d

docker-compose镜像发布springboot项目的流程分析

使用docker compose编排springcloud微服务

配置同上
修改docker-compose.yml文件

version: '3.3'
services:
  eureka:
    image: eureka:v1  #指定镜像名称
    build: ./eureka   #指定dockfile所在路径
    ports:
     - 8080:8080
  user:
    image: user:v1
    build: ./user #指定dockfile所在路径
    ports:
     - 8081:8081
  power:
    image: power:v1
    build: ./power #指定dockfile所在路径
    ports:
     - 8082:8082

到此这篇关于docker-compose镜像发布springboot项目的流程分析的文章就介绍到这了,更多相关docker-compose发布springboot项目内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!