用docker部署jar包_war包和jar包部署区别

用docker部署jar包_war包和jar包部署区别对于springboot项目运行,直接是java-jar的方式运行,如果想要放到docker中运行,有三种方式:方式一:1.上传jar到服务器的指定目录2.在该目录下创建Dockerfile文件viDockerfile3.然后将下面的内容复制到Dockerfile文件中FROMjava:8MAINTAINERbin…

大家好,又见面了,我是你们的朋友全栈君。如果您正在找激活码,请点击查看最新教程,关注关注公众号 “全栈程序员社区” 获取激活教程,可能之前旧版本教程已经失效.最新Idea2022.1教程亲测有效,一键激活。

Jetbrains全系列IDE稳定放心使用

对于springboot项目运行,直接是 java -jar 的方式运行,如果想要放到docker中运行,有三种方式:

方式一:

    1. 上传jar到服务器的指定目录

    2. 在该目录下创建Dockerfile 文件

      vi Dockerfile

    3. 然后将下面的内容复制到Dockerfile文件中

FROM java:8
MAINTAINER bingo
ADD demo-0.0.1-SNAPSHOT.jar demo.jar
EXPOSE 8080
ENTRYPOINT ["java","-jar","demo.jar"]

# from java:8   拉取一个jdk为1.8的docker image

# maintainer  作者是bingo

# demo-0.0.1-SNAPSHOT.jar 就是你上传的jar包,替换为jar包的名称

# demo.jar  是你将该jar包重新命名为什么名称,在容器中运行

#  expose  该容器暴露的端口是多少,就是jar在容器中以多少端口运行

# entrypoint 容器启动之后执行的命令,java -jar demo.jar  即启动jar

 

   4. 创建好Dockerfile文件之后,执行命令 构建镜像:

      docker build -t my/demo .

  注意最后的 .  表示 Dockerfile 文件在当前目录下

   my/demo  构建之后镜像名称

 

   5. 镜像构建成功之后,就可以运行容器了:

       docker run -d –name demo -p 8080:8080 my/demo

    docker run -d --restart=always --name demo -p 8080:8080  my/demo   这个表示docker容器在停止或服务器开机之后会自动重新启动 --restart=always

  6. 然后docker ps 看看你的容器有没有在运行即可 

  7. docker logs –tail  300 -f  demo  查看启动日志 

   

另: 如果docker run 的时候没有加 –restart=always ,然后已经运行的docker容器怎么设置自动重启? 执行下面命令:

   docker update –-restart=always demo 

 demo : 你的容器名称

 

方式二:

     这种方式就是运行一个jdk的容器,然后挂载其中的目录到宿主机,然后运行之后,就可以将需要运行的jar放在宿主机的挂载目录下,然后每次重新运行docker容器即可。不用每次发布需要重新构建docker容器,只需要替换宿主机中的jar包即可

    1. 在服务器中拉取jdk1.8的镜像

         docker pull jdk8

     2. 创建目录

      cd /server/

     mkdir deploy/jar

     3. 构建容器

docker run -d \
--restart=always \
-v /server/deploy/jar:/jar -v /server/logs/demo:/mnt/logs/demo \
-p 7778:7778 \
--name demo \
jdk8 /usr/bin/java -jar \
-Duser.timezone=GMT+08 \
/jar/demo-1.0.jar

   # -Duser.timezone 是设置时区

   # jdk8 /usr/bin/java -jar 是执行 java jar的命令

   # /jar/demo-1.0.jar 是需要运行的jar包的位置在容器中的什么位置,/jar 下面

 

上面就是两种部署jar包的方式,并且还可以更方便的部署~~,就是使用maven插件,一键直接部署,后续可以继续再写~~

 

   

 

 

 

版权声明:本文内容由互联网用户自发贡献,该文观点仅代表作者本人。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如发现本站有涉嫌侵权/违法违规的内容, 请联系我们举报,一经查实,本站将立刻删除。

发布者:全栈程序员-站长,转载请注明出处:https://javaforall.net/180432.html原文链接:https://javaforall.net

(0)
全栈程序员-站长的头像全栈程序员-站长


相关推荐

  • Xshell安装docker「建议收藏」

    Xshell安装docker「建议收藏」docker基本组成镜像(image):docker镜像好比一个模板,可以通过这个模板创建容器服务,例如:tomcat镜像===>run===>tomcat01容器(提供服务器)通过这个镜像可以创建多个容器(最终服务或项目在容器中运行)容器(container):docker利用容器技术,独立运行一个或一组应用,通过镜像来创建。启动、停止、删除基本命令目前就可以把这个容器理解为就是一个简易的linux系统仓库(repository):存放镜像的地方,类似maven中央仓库仓库

    2022年9月9日
    0
  • Docker启动mysql服务「建议收藏」

    Docker启动mysql服务「建议收藏」1:确保自己的服务器已经安装好了docker输入dockerinfo或者dockerversion2:然后我们去dockerhub去下载自己的想要的mysql镜像找到offic的版本,点击进入3:经命令放入linux中执行。[root@iZ2zehajf73atd9gbz1qdbZredisconf]#dockerpullmysql:5.64:然后检测自己是否下载成功:dockerimages5:dockerrun–name…

    2022年10月6日
    0
  • docker结构框架图

    docker结构框架图

    2021年5月29日
    108
  • docker 修改容器时间_jenkins docker持续集成

    docker 修改容器时间_jenkins docker持续集成前言用docker搭建的Jenkins环境时间显示和我们本地时间相差8个小时,需修改容器内部的系统时间查看时间查看系统时间date-R进入docker容器内部,查看容器时间dockere

    2022年7月30日
    4
  • docker安装redis集群_docker eureka集群

    docker安装redis集群_docker eureka集群NeoKylin-Server离线部署跨主机redis集群NeoKylin-Server离线部署跨主机redis集群一、说明二、部署过程:1.切换root账号或所有语句加sudo;2.关闭6个节点防火墙(或打开端口);3.6个节点导入rpm包后安装基础环境:4.设置所有节点;5.启动docker并导入images;6.时间同步;7.etcd集群配置;8.部署flannel网络;9.n1-n3部署pxc;10.m1-m3部署Haproxy+Keepalived容器;11.m1-m3宿主机

    2022年8月10日
    4
  • docker部署web项目_docker构建高可用web应用

    docker部署web项目_docker构建高可用web应用前言前面我们运行的容器并没有一些什么特别的用处。接下来让我们尝试使用docker构建一个web应用程序。我们将在docker容器中运行一个PythonFlask应用来运行一个web

    2022年7月30日
    3

发表回复

您的邮箱地址不会被公开。 必填项已用 * 标注

关注全栈程序员社区公众号