如何使用Docker中构建Java jar包,并且实现开启自启

简介: 【4月更文挑战第3天】

Docker中构建Java JAR包

要在Docker容器中构建Java应用程序的JAR包,你可以遵循以下步骤:

  1. 创建一个Dockerfile:在你的项目根目录下创建一个名为 Dockerfile 的文件,用来定义Docker镜像的构建过程。
# 使用官方的 Java 11 镜像作为基础镜像
FROM openjdk:11

# 设置工作目录
WORKDIR /app

# 将本地的 JAR 文件复制到容器中的工作目录
COPY target/your-application.jar /app/your-application.jar

# 定义容器启动时执行的命令
CMD ["java", "-jar", "your-application.jar"]
  1. 构建Docker镜像:使用 docker build 命令来构建Docker镜像。确保在你的项目根目录下执行此命令。
docker build -t your-image-name .

其中,your-image-name 是你希望给你的Docker镜像起的名称。

  1. 运行Docker容器:使用 docker run 命令来运行你的Docker容器。
docker run -p 8080:8080 your-image-name

这里假设你的应用程序将在容器内部的8080端口运行,并且你希望将容器的8080端口映射到主机的8080端口。

这样就可以在Docker容器中成功构建和运行你的Java应用程序的JAR包了。确保在运行 docker build 命令之前已经构建了你的Java应用程序的JAR包,并将其放置在适当的位置。

后台运行并且可以开机自启

要在后台运行Docker容器,并且在开机时自动启动,你可以使用以下步骤:

  1. 在后台运行Docker容器:要在后台运行Docker容器,可以使用 -d 参数。
docker run -d -p 8080:8080 your-image-name

这将使容器在后台以守护进程模式运行。

  1. 为了在开机时自动启动容器,你可以使用Docker的restart选项。首先,为容器添加 --restart 选项:
docker run -d --restart always -p 8080:8080 your-image-name

这样,容器会在启动时自动启动,并且如果容器因任何原因停止,Docker也会自动重新启动它。

  1. 在Docker守护程序启动时自动启动容器:如果你想在Docker守护程序启动时自动启动容器,你可以使用系统级的工具(如 systemd)来管理Docker容器。以下是一个使用 systemd 的示例配置:

首先,创建一个名为 your-container-name.service 的文件,例如 my-java-app.service,内容如下:

[Unit]
Description=My Java App
Requires=docker.service
After=docker.service

[Service]
Restart=always
ExecStart=/usr/bin/docker run -d --name my-java-app -p 8080:8080 your-image-name
ExecStop=/usr/bin/docker stop -t 2 my-java-app
ExecStopPost=/usr/bin/docker rm -f my-java-app

[Install]
WantedBy=default.target

然后将该文件移动到 /etc/systemd/system/ 目录下,并执行以下命令启用该服务并启动它:

sudo systemctl daemon-reload
sudo systemctl enable my-java-app.service
sudo systemctl start my-java-app.service

这样,当你的系统启动时,Docker服务会自动启动,并且在Docker服务启动后,my-java-app 容器也会自动启动。

目录
相关文章
|
6天前
|
Java 测试技术 Maven
maven 打jar包:mvn clean package
maven 打jar包:mvn clean package
32 7
|
2天前
|
Oracle Java 关系型数据库
实时计算 Flink版操作报错合集之本地打成jar包,运行报错,idea运行不报错,是什么导致的
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
23 6
|
6天前
|
Java Maven
向 Maven 中央仓库上传一个修改过的基于jeecg的autoPOI的 jar包记录(一)
向 Maven 中央仓库上传一个修改过的基于jeecg的autoPOI的 jar包记录
19 0
|
1天前
|
Prometheus 监控 Cloud Native
构建高效稳定的Docker容器监控体系
【5月更文挑战第20天】 在微服务架构日益普及的今天,Docker作为其重要的实现技术之一,承载着大量应用的运行。然而,随之而来的是对于容器健康状态、资源使用情况以及性能指标的监控需求急剧增加。本文旨在探讨构建一个高效且稳定的Docker容器监控体系,不仅涵盖了监控工具的选择与配置,还详细阐述了监控数据的分析与处理流程。通过精心设计的监控策略和实时响应机制,我们能够确保系统的稳定性,并及时发现及处理潜在的问题。
|
2天前
|
Oracle Java 关系型数据库
实时计算 Flink版操作报错合集之本地打成jar包,运行报错,idea运行不报错,是什么导致的
在使用实时计算Flink版过程中,可能会遇到各种错误,了解这些错误的原因及解决方法对于高效排错至关重要。针对具体问题,查看Flink的日志是关键,它们通常会提供更详细的错误信息和堆栈跟踪,有助于定位问题。此外,Flink社区文档和官方论坛也是寻求帮助的好去处。以下是一些常见的操作报错及其可能的原因与解决策略。
12 0
|
4天前
|
Kubernetes 持续交付 Docker
构建高效微服务架构:Docker与Kubernetes的完美搭档
【5月更文挑战第17天】在当今云计算和微服务架构的大潮中,Docker容器化技术和Kubernetes容器编排系统成为了后端开发领域的热门技术栈。本文将探讨如何通过Docker和Kubernetes的结合使用来构建一个高效、可扩展且易于管理的微服务环境。我们将从基础概念出发,深入到实际操作层面,最后讨论这种组合对持续集成和持续部署(CI/CD)流程的影响,旨在为开发者和企业提供一种可靠的后端服务解决方案。
|
5天前
|
Java 数据库连接 Spring
K8S+Docker理论与实践深度集成java面试jvm原理
K8S+Docker理论与实践深度集成java面试jvm原理
|
6天前
|
存储 前端开发 JavaScript
基于 GitHub Workflow和 Docker 构建 NextJS
基于 GitHub Workflow和 Docker 构建 NextJS
9 0
|
6天前
|
Prometheus 监控 Cloud Native
构建高效稳定的Docker容器监控体系
【5月更文挑战第14天】 在现代微服务架构中,Docker容器作为应用部署的基本单元,其运行状态的监控对于保障系统稳定性和性能至关重要。本文将探讨如何构建一个高效且稳定的Docker容器监控体系,涵盖监控工具的选择、关键指标的采集、数据可视化以及告警机制的设计。通过对Prometheus和Grafana的整合使用,实现对容器资源利用率、网络IO以及应用健康状态的全方位监控,确保系统的高可用性和故障快速响应。
|
6天前
|
Java 编译器 Shell
Java 包(package)
5月更文挑战第8天