用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插件,一键直接部署,后续可以继续再写~~

 

   

 

 

 

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

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

【正版授权,激活自己账号】: Jetbrains全家桶Ide使用,1年售后保障,每天仅需1毛

【官方授权 正版激活】: 官方授权 正版激活 支持Jetbrains家族下所有IDE 使用个人JB账号...

(0)


相关推荐

  • C++ docker_docker部署mysql

    C++ docker_docker部署mysql版权声明:本文为博主原创文章,未经博主允许不得转载。Docker介绍Docker是一个开源的容器引擎,它有助于更快地交付产品。Docker可将应用程序和基础设施层隔离,并且将基础设施当作程序一样进行管理。使用Docker,可以更快地打包,测试以及部署应用程序,并可以缩短从编程到部署运行代码的周期docker部署c/c++程序关于docker的使用网上有很多的教程但是很少有介绍如…

    2022年10月19日
  • docker部署web项目_docker web程序本地化

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

  • docker(2)CentOS 7安装docker环境[通俗易懂]

    docker(2)CentOS 7安装docker环境[通俗易懂]前言前面一篇学了mac安装docker,这篇来学习在linux上安装docker环境准备Docker支持以下的CentOS版本,目前,CentOS仅发行版本中的内核支持Docker。Doc

  • 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宿主机

  • docker更换默认存储目录、默认存储目录磁盘剩余空间不足,采用软连、换目录、加容量解决

    docker更换默认存储目录、默认存储目录磁盘剩余空间不足,采用软连、换目录、加容量解决

  • kafka集群搭建-docker版本[通俗易懂]

    kafka集群搭建-docker版本[通俗易懂]提示:文章写完后,目录可以自动生成,如何生成可参考右边的帮助文档kafka集群搭建文章目录kafka集群搭建前言一、kafka是什么?二、集群1.集群2.负载均衡3.扩容4.ZookeeperLeader选举kafka架构集群搭建下载安装zookeeper前言kafka是个高吞吐的消息中间件,为啥快啊?1顺序读写20拷贝3批量提交和批量ACK4分片和副本消息队列高可用就得用集群。提示:以下是本篇文章正文内容,下面案例可供参考一、kafka是什么?kafka理论参

发表回复

您的电子邮箱地址不会被公开。

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