【Docker、Dockerfile】使用Dockerfile创建镜像并运行容器

创建SpringBoot项目

创建一个Springboot的Java项目,然后打包成可运行的Jar

编写Dockerfile文件

在项目文件夹下创建Dockerfile文件,内容如下

# 定义用于构建镜像的 JDK 版本参数,可以在构建过程中通过 --build-arg 选项传递给 docker build 命令
ARG JDK=openjdk:11-jre

# 使用指定的 JDK 版本作为基础镜像
FROM $JDK

# 指定 Dockerfile 的维护者信息
MAINTAINER lemon

# 在容器内创建 /home/service 目录
RUN mkdir -p /home/service

# 设置工作目录为 /home/service
WORKDIR /home/service

# 将容器内 /home/service/logs 目录作为卷
VOLUME /home/service/logs

# 将本地机器上的 JAR 文件复制到容器的 /home/service 目录下
COPY /target/docker-demo-1.0-SNAPSHOT.jar /home/service/docker-demo-1.0-SNAPSHOT.jar

# 设置环境变量 JVM_OPTS 和 SPRING_PROFILES_ACTIVEdo
ENV JVM_OPTS="-Xmx128m -Xms128m -XX:MetaspaceSize=128m -XX:MaxMetaspaceSize=128m" SPRING_PROFILES_ACTIVE="dev"

# 公开容器的端口 18888,以允许外部连接
EXPOSE 18888

# 配置容器的入口点命令
ENTRYPOINT java $JVM_OPTS -Dspring.profiles.active=${SPRING_PROFILES_ACTIVE} -Duser.timezone=GMT+08 -jar docker-demo-1.0-SNAPSHOT.jar

使用Docker命令构建镜像、运行容器

构建镜像

默认构建,使用jdk11

docker build -t docker-demo:v0.0.2 .

默认构建

修改构建参数,使用jdk8

docker build --build-arg JDK=openjdk:8-jre -t docker-demo:v0.0.0 .

修改构建参数

运行容器

运行容器(端口映射、挂载、环境变量)

docker run -it --name docker-demo -p 8888:18888 -v D:/docker/demo/logs:/home/service/logs -e SPRING_PROFILES_ACTIVE=test  docker-demo:v0.0.0

在这里插入图片描述

参考连接:Dockerfile命令介绍

  • 2
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
Docker Swarm是Docker的原生集群管理工具,可以用于在多个主机上运行和管理容器Dockerfile是一种用于定义Docker镜像构建过程的文本文件。 使用Docker Swarm时,可以使用Dockerfile创建镜像,但其实创建镜像的过程与在单个主机上创建镜像的过程非常相似。主要的区别是,在Swarm中创建镜像将会在整个集群中被使用,而非仅限于单个主机。 首先,在Swarm集群的主节点上创建一个Dockerfile,该文件包含了构建镜像的指令和配置。以一个简单的Node.js应用为例,可以定义如下的Dockerfile: ``` FROM node:14-alpine WORKDIR /app COPY package*.json ./ RUN npm install COPY . . EXPOSE 3000 CMD [ "npm", "start" ] ``` 然后,在主节点的终端中,使用`docker build`命令来构建镜像。例如,使用以下命令创建一个名为`my-app`的镜像: ``` docker build -t my-app . ``` 接下来,使用`docker push`命令将构建好的镜像推送到Docker镜像仓库。例如,可以推送到Docker Hub: ``` docker push username/my-app ``` 最后,在Swarm集群的其他节点上使用`docker service`命令来创建服务,并使用先前构建镜像作为服务的副本。例如,使用以下命令创建一个名为`my-app`的服务: ``` docker service create --name my-app --replicas 3 username/my-app ``` 这将在集群的多个节点上运行三个容器的副本,以提供高可用性和负载均衡的服务。 通过以上步骤,我们可以使用DockerfileDocker Swarm集群中创建镜像,并在集群中运行多个容器的副本来提供服务。这种方式使得应用程序可以更加灵活地在集群中运行,并可以根据需要进行扩展和管理。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值