springboot 项目 docker化部署
最近公司项目需要docker化,项目所使用的框架是springboot,linux环境。第一次接触docker化方面的技术。做的时候,所接触的新知识比较多,留下此文,以便以后用到的时候快速入手。
修改maven pom.xml 文件
<properties>
<project.build.sourceEncoding>UTF-</project.build.sourceEncoding>
<java.version>1.7</java.version>
<project.codeName>projectName</project.codeName>
<project.repository>docker.xw.com.cn</project.repository>
<project.moduleName>microdocc</project.moduleName>
</properties>
引入docker-maven-plugin插件
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>0.4.</version>
<configuration>
<serverId>xw-docker-registry</serverId>
<imageName>${project.repository}/${project.codeName}/${project.moduleName}</imageName><!-- 镜像名称 -->
<forceTags>true</forceTags>
<imageTags>
<imageTag>${project.version}</imageTag>
<imageTag>latest</imageTag>
</imageTags>
<dockerDirectory>src/main/docker</dockerDirectory><!-- Dockerfile文件地址 -->
<resources>
<resource>
<targetPath>/</targetPath>
<directory>${project.build.directory}</directory><!--项目构建输出目录/ -->
<include>${project.build.finalName}.jar</include><!--打包出来的jar名称-->
</resource>
</resources>
</configuration>
</plugin>
编写Dockerfile文件
FROM jdk1..0_25 # Set the timezone.
RUN echo "Asia/Shanghai" > /etc/timezone
RUN dpkg-reconfigure -f noninteractive tzdata # Make logs dir
RUN mkdir -p /opt/file/logs # Add the jar and run
ADD ifle.jar /opt/file/ifle.jar
WORKDIR /opt/file
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","file.jar"]
Dockerfile 文件释意
使用 # 来注释
FROM 指令告诉 Docker 使用哪个镜像作为基础
RUN 开头的指令会在创建中运行, 比如安装一个软件包, 在这里使用 apt-get 来安装了一些软件
RUN
格式为 RUN <command> 或 RUN
["executable", "param1", "param2"] 。
前者将在 shell 终端中运行命令, 即 /bin/sh -c ;后者则使用 exec 执行。 指定使用其它终端可以通过
第二种方式实现, 例如 RUN ["/bin/bash",
"-c", "echo hello"] 。
每条 RUN 指令将在当前镜像基础上执行指定命令, 并提交为新的镜像。 当命令较长时可以使用 \ 来换
行。
ADD
格式为 ADD <src> <dest> 。
该命令将复制指定的 <src> 到容器中的 <dest> 。 其中 <src> 可以是Dockerfile所在目录的一个相对路
径;也可以是一个 URL;还可以是一个 tar 文件( 自动解压为目录)
WORKDIR
WORKDIR 为后续的 RUN 、 CMD 、 ENTRYPOINT 指令配置工作目录。
ENTRYPOINT
两种格式:
ENTRYPOINT ["executable", "param1",
"param2"]
ENTRYPOINT command param1 param2 ( shell中执行) 。
配置容器启动后执行的命令, 并且不可被 docker run 提供的参数覆盖。
每个 Dockerfile 中只能有一个 ENTRYPOINT , 当指定多个时, 只有最后一个起效
执行maven命令生成镜像
mvn clean package docker:build -Ptest
-DskipTests=true -DpushImageTag
docker images 命令查看生产的镜像
启动docker 镜像生成 容器
执行如下命令:
docker run --name projectName-1.0.5 -p
9006:8080 -d -v /app/conf/projectName/application.properties:/opt/test-Project/application.properties -v /app/logs/projectName3:/tmp/logs/projectName
docker.xw.com.cn/projectName/microdocc /bin/bash
解析docker run 命令
使用镜像nginx:latest以交互模式启动一个容器,在容器内执行/bin/bash命令, 可以执行:runoob@runoob:~$ docker run -it nginx:latest /bin/bash
==========================================================================================
使用 hostPort:containerPort
格式本地的 5001 端口映射到容器的 5000
端口, 可以执行:$ sudo docker run -d -p 5001:5000 training/webapp python app.py
==========================================================================================
使用 -v 标记也可以指定挂载一个本地主机的目录到容器中去。
==========================================================================================
$ sudo docker run -d -P --name web -v /src/webapp:/opt/webapp
training/webapp python app
上面的命令加载主机的 /src/webapp 目录到容器的 /opt/webapp 目录。 这个功能在进行测试的时候十
分方便, 比如用户可以放置一些程序到本地目录中, 来查看容器是否正常工作。
==========================================================================================
在使用 -d 参数时, 容器启动后会进入后台。
==========================================================================================
标红的参数为,镜像的 仓库全名。 --name 后的参数为 ,运行容器的名称,新起的名字。
参考:【Docker从入门到实践】
springboot 项目 docker化部署的更多相关文章
- SpringBoot项目docker化
前言 有很多种方案构建Docker镜像,包括Dockerfile构建.maven插件构建,这里我使用了最简单的Dockerfile构建的. 一.安装Docker 我的虚拟机系统是CentOS7,需要是 ...
- 使用Gitlab-CI 实现NetCore项目Docker化并部署到阿里云K8S
使用Gitlab-CI 实现NetCore项目Docker化并部署到阿里云K8S 先行条件: 1.了解NetCore项目基础命令,如dotnet publish 等几个常用命令. 2.了解Dock ...
- 从头认识一下docker-附带asp.net core程序的docker化部署
从头认识一下docker-附带asp.net core程序的docker化部署 简介 在计算机技术日新月异的今天, Docker 在国内发展的如火如荼,特别是在一线互联网公司, Docker 的使用是 ...
- SpringBoot项目设置热部署
记录一个SpringBoot 设置热部署(修改项目之后,项目自动重启)实例 POM.XML 文件 <!-- 配置springBoot项目的热部署启动 --> <dependency& ...
- Eclipse中创建新的SpringBoot项目(打包并且部署到tomcat)
Spring-boot因为其对jar包的高度集成以及简化服务配置,快速部署等的优点,逐渐成为Java开发人员的热衷的框架.下面演示一下怎么在Eclipse中新建Spring-boot项目以及打包部署. ...
- SpringBoot使用Docker快速部署项目
1.简介 建议阅读本文最好对Dokcer有一些了解 首先我们先了解一下Docker是什么 Docker 属于 Linux 容器的一种封装,提供简单易用的容器使用接口.它是目前最流行的 Linux 容器 ...
- springboot项目容器化
创建一个简单的springboot项目,依赖中加入: 编写一个Restfull接口: 编写启动类: 启动项目,浏览器访问该接口,得到想要的结果.下面,就将这个项目进行Docker容器化(applica ...
- FastDfs集群docker化部署
初识分布式文件系统FastDFS- 1.分布式与集群的区别 区别:集群是个物理形态,分布式是个工作方式.只要是一堆机器,就可以叫集群,他们是不是一起协作着干活,这个谁也不知道:一个程序或系统,只要运行 ...
- 基于vue+springboot+docker网站搭建【七】制作后端spring-boot的docker镜像部署
制作spring-boot的docker镜像并部署 一.下载后端项目:https://github.com/macrozheng/mall 二.修改mall-admin项目的配置文件 修改applic ...
随机推荐
- Redis的持久化——RDB
前面说到redis的三大特性:缓存.分布式内存数据库.持久化,所以今天将为大家介绍redis的两种数据持久化技术RDB和AOF, 先介绍RDB吧. 一.RDB是什么? 1.RDB全称redis dat ...
- spring中quartz的使用。【转http://www.cnblogs.com/kay/archive/2007/11/02/947372.html】
注:从spring3到spring4改变 org.springframework.scheduling.quartz.CronTriggerBean org.springframework.sched ...
- linux文件夹作用
linux下的文件结构,看看每个文件夹都是干吗用的/bin 二进制可执行命令 /dev 设备特殊文件 /etc 系统管理和配置文件 /etc/rc.d 启动的配置文件和脚本 /home 用户主目录的基 ...
- JCaptcha+Memcache的验证码集群实现
一.问题背景 为了防止垃圾信息发布机器人的自动提交攻击,采用CAPTCHA验证码来保护该模块,提高攻击者的成本. 二.验证码简介 全自动区分计算机和人类的图灵测试(Completely Automat ...
- shell的case脚本的简单入门
shell的case脚本的简单入门 示例1: #/bin/bash a=$ case "$a" in ") echo 'hell 2';; ") echo 'h ...
- .net core webapi jwt 更为清爽的认证 ,续期很简单
我的方式非主流,控制却可以更加灵活,喜欢的朋友,不妨花一点时间学习一下 jwt认证分为两部分,第一部分是加密解密,第二部分是灵活的应用于中间件,我的处理方式是将获取token放到api的一个具体的co ...
- Croc Champ 2013 - Round 2 C. Cube Problem
问满足a^3 + b^3 + c^3 + n = (a+b+c)^3 的 (a,b,c)的个数 可化简为 n = 3*(a + b) (a + c) (b + c) 于是 n / 3 = (a + b ...
- JS标签获取另一个页面传过来的href值
a href=b.html?id=楼主>B页面</a>b.html中的获取函数:function getParam(){C1=window.location.href.split(& ...
- java实现简单的算法
排序大的分类可以分为两种:内排序和外排序.在排序过程中,全部记录存放在内存,则称为内排序,如果排序过程中需要使用外存,则称为外排序.下面讲的排序都是属于内排序. 内排序有可以分为以下几类: (1).插 ...
- BUPT复试专题—网络传输(2014网研)
题目描述 网络的高效互联与智能传输是提升海量用户服务请求映射效率的重要措施.在这个任务中,你需耍在最小的传输时间内,将数据源传输到指定的网络节点中.我们给定的网络一共包含N个节点,其中节点1为数据源. ...