DOCKER06_SpringBoot微服务项目打包成Docker镜像详解(二)

本文涉及的产品
服务治理 MSE Sentinel/OpenSergo,Agent数量 不受限
简介: DOCKER06_SpringBoot微服务项目打包成Docker镜像详解(二)

②. 编写Dockerfile文件


  • ①. 需要注意的是,这里的8080端口,如果在application.yaml中不写端口默认是8080


FROM openjdk:8u282-slim
# 如下操作可以让容器时间和虚拟机时间一致
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
LABEL maintainer="845195485@qq.com"
# COPY --from=buildapp /app/app.jar /app.jar
COPY demo-0.0.1-SNAPSHOT.jar /app.jar
EXPOSE 8080
# CMD ["--server.prot=8080"]
ENV JAVA_OPTS=""
ENV PARAMS=""
ENTRYPOINT [ "sh", "-c", "java -Djava.security.egd=file:/dev/./urandom $JAVA_OPTS -jar /app.jar $PARAMS" ]


③. 将jar包和Dockerfile文件上传服务器


  • ①. 在服务器上进行如下操作


[root@k8s-master dockerFileTest]# ls
demo  demo-0.0.1-SNAPSHOT.jar  Dockerfile
[root@k8s-master dockerFileTest]# docker build -t dockerfiledemo:1.0 -f Dockerfile .
Sending build context to Docker daemon   35.2MB
Step 1/8 : FROM openjdk:8u282-slim
 ---> 1a67dffb0ee8
Step 2/8 : RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
 ---> Using cache
 ---> 2e7e3104a115
Step 3/8 : LABEL maintainer="845195485@qq.com"
 ---> Using cache
 ---> a6a0060db56e
Step 4/8 : COPY demo-0.0.1-SNAPSHOT.jar /app.jar
 ---> fcd3b9f4dc33
Step 5/8 : EXPOSE 8080
 ---> Running in 1791b1aadb3d
Removing intermediate container 1791b1aadb3d
 ---> 1243444bc9ca
Step 6/8 : ENV JAVA_OPTS=""
 ---> Running in 7796f6f4e49d
Removing intermediate container 7796f6f4e49d
 ---> c9f0c47899a4
Step 7/8 : ENV PARAMS=""
 ---> Running in 6346bde227c7
Removing intermediate container 6346bde227c7
 ---> a4f64bd2afda
Step 8/8 : ENTRYPOINT [ "sh", "-c", "java -Djava.security.egd=file:/dev/./urandom $JAVA_OPTS -jar /app.jar $PARAMS" ]
 ---> Running in fdb39fafb931
Removing intermediate container fdb39fafb931
 ---> 2c651e7bb1f6
Successfully built 2c651e7bb1f6
Successfully tagged dockerfiledemo:1.0
[root@k8s-master dockerFileTest]# docker images
REPOSITORY                                                                 TAG                IMAGE ID       CREATED          SIZE
dockerfiledemo                                                             1.0                2c651e7bb1f6   7 seconds ago    306MB


微信图片_20220109211502.png


[root@k8s-master demo]# docker ps
CONTAINER ID   IMAGE                                                          COMMAND                  CREATED          STATUS          PORTS                                                        NAMES
32adb642988b   dockerfiledemo:1.0                                             "sh -c 'java -Djava.…"   26 seconds ago   Up 25 seconds   0.0.0.0:49170->8080/tcp 


②. 通过浏览器访问(http://139.198.169.136:49170/helloTang)


微信图片_20220109211529.png

相关实践学习
容器服务Serverless版ACK Serverless 快速入门:在线魔方应用部署和监控
通过本实验,您将了解到容器服务Serverless版ACK Serverless 的基本产品能力,即可以实现快速部署一个在线魔方应用,并借助阿里云容器服务成熟的产品生态,实现在线应用的企业级监控,提升应用稳定性。
云原生实践公开课
课程大纲 开篇:如何学习并实践云原生技术 基础篇: 5 步上手 Kubernetes 进阶篇:生产环境下的 K8s 实践 相关的阿里云产品:容器服务 ACK 容器服务 Kubernetes 版(简称 ACK)提供高性能可伸缩的容器应用管理能力,支持企业级容器化应用的全生命周期管理。整合阿里云虚拟化、存储、网络和安全能力,打造云端最佳容器化应用运行环境。 了解产品详情: https://www.aliyun.com/product/kubernetes
相关文章
|
3天前
|
关系型数据库 Java 数据库
docker部署postgresql数据库和整合springboot连接数据源
docker部署postgresql数据库和整合springboot连接数据源
13 0
|
3天前
|
Java
springboot项目出现Exception in thread “main“ java.lang.NoClassDefFoundError: javax/servlet/Filter
springboot项目出现Exception in thread “main“ java.lang.NoClassDefFoundError: javax/servlet/Filter
11 0
|
4天前
|
Java Spring
Spring boot项目如何发送邮件
Spring boot项目如何发送邮件
14 2
|
10天前
|
存储 Java 应用服务中间件
Springboot项目打war包部署到外置tomcat容器【详解版】
该文介绍了将Spring Boot应用改为war包并在外部Tomcat中部署的步骤:1) 修改pom.xml打包方式为war;2) 排除内置Tomcat依赖;3) 创建`ServletInitializer`类继承`SpringBootServletInitializer`;4) build部分需指定`finalName`;5) 使用`mvn clean package`打包,将war包放入外部Tomcat的webapps目录,通过startup脚本启动Tomcat并访问应用。注意,应用访问路径和静态资源引用需包含war包名。
|
11天前
|
Java
SpringBoot 项目启动初始化一个Map对象到内存
SpringBoot 项目启动初始化一个Map对象到内存
|
12天前
|
Java Docker 微服务
|
3天前
|
API 持续交付 开发者
构建高效微服务架构:后端开发的新视角
【5月更文挑战第8天】 随着现代软件开发的演变,微服务架构已经成为了企业追求敏捷、可扩展和灵活部署的重要解决方案。本文将深入探讨如何构建一个高效的微服务架构,包括关键的设计原则、技术栈选择以及持续集成与部署的最佳实践。我们还将讨论微服务带来的挑战,如数据一致性、服务发现和网络延迟,并提出相应的解决策略。通过本文,后端开发者将获得构建和维护微服务系统所需的深度知识,并了解如何在不断变化的技术环境中保持系统的健壮性和可维护性。
35 8
|
1天前
|
监控 持续交付 Docker
使用Docker进行微服务架构的最佳实践
【5月更文挑战第10天】本文探讨了使用Docker实施微服务架构的最佳实践。首先,理解微服务架构是拆分小型独立服务的模式,借助Docker实现快速部署、高可移植性和环境一致性。Docker的优势在于服务扩展、容器编排、自动化构建与部署。最佳实践包括:定义清晰服务边界,使用Dockerfile和Docker Compose自动化构建,利用Docker Swarm或Kubernetes编排,实施服务发现和负载均衡,监控与日志记录,以及持续集成和持续部署。Docker虽重要,但需与其他技术结合以确保系统整体稳定性。
|
1天前
|
缓存 负载均衡 API
微服务架构下的API网关性能优化实践
【5月更文挑战第10天】在微服务架构中,API网关作为前端和后端服务之间的关键枢纽,其性能直接影响到整个系统的响应速度和稳定性。本文将探讨在高并发场景下,如何通过缓存策略、负载均衡、异步处理等技术手段对API网关进行性能优化,以确保用户体验和服务的可靠性。
|
1天前
|
存储 监控 API
构建高效微服务架构:后端开发的现代实践
【5月更文挑战第9天】 在本文中,我们将深入探讨如何在后端开发中构建一个高效的微服务架构。通过分析不同的设计模式和最佳实践,我们将展示如何提升系统的可扩展性、弹性和维护性。我们还将讨论微服务架构在处理复杂业务逻辑和高并发场景下的优势。最后,我们将分享一些实用的工具和技术,以帮助开发者实现这一目标。