1.  IDEA中配置Docker

Docker默认只接受本地客户端的请求,为了能够远程访问它,首先要开放Docker的监听端口,运行外部应用可以访问

修改 /lib/systemd/system/docker.service 文件

找到 ExecStart

在后面追加 -H tcp://0.0.0.0:2375

然后重启Docker

接下来就可以在idea中连接docker了

这样就不用登录到服务器上看了,直接在idea中查看即可,而且还有一个好处是,在idea中可以看到容器的日志

2.  Docker安装Redis

https://registry.hub.docker.com/_/redis

 docker pull redis
docker run --name my-redis -p 6380:6379 -d redis

这里由于宿主机上已经运行了一个redis并占用6379端口,所以在docker容器里面这个redis服务就映射到6380端口了

接下来,用redis-cli连接试一下

 docker exec -it my-redis /bin/bash
或者
/宿主机Redis安装目录/src/redis-cli -p 6380

用上面的方式直接启动redis的话,采用的是默认配置,默认配置下只允许本机连接,无法远程连接。通常情况下,我们会指定自己的配置文件

 docker run -v /usr/local/conf:/usr/local/etc/redis --name myredis3 -p 6381:6381 -d redis redis-server /usr/local/etc/redis/redis.conf

3.  使用 docker-maven-plugin 构建镜像

https://github.com/spotify/docker-maven-plugin

pom.xml中引入docker-maven-plugin插件

第一种方式:在pom文件中指定构建信息

 1 <build>
2 <plugins>
3 <plugin>
4 <groupId>org.springframework.boot</groupId>
5 <artifactId>spring-boot-maven-plugin</artifactId>
6 </plugin>
7
8 <plugin>
9 <groupId>com.spotify</groupId>
10 <artifactId>docker-maven-plugin</artifactId>
11 <version>1.2.2</version>
12 <configuration>
13 <imageName>example</imageName>
14 <dockerHost>http://192.168.28.31:2375</dockerHost>
15 <baseImage>java</baseImage>
16 <entryPoint>["java", "-jar", "/${project.build.finalName}.jar"]</entryPoint>
17 <resources>
18 <resource>
19 <targetPath>/</targetPath>
20 <directory>${project.build.directory}</directory>
21 <include>${project.build.finalName}.jar</include>
22 </resource>
23 </resources>
24 </configuration>
25 </plugin>
26 </plugins>
27 </build>

构建成功了,但是这个镜像太太太大了

咱们不用 java:8 ,换成 openjdk 试试

https://registry.hub.docker.com/_/openjdk

 1 <build>
2 <plugins>
3 <plugin>
4 <groupId>org.springframework.boot</groupId>
5 <artifactId>spring-boot-maven-plugin</artifactId>
6 </plugin>
7
8 <plugin>
9 <groupId>com.spotify</groupId>
10 <artifactId>docker-maven-plugin</artifactId>
11 <version>1.2.2</version>
12 <configuration>
13 <imageName>cjs/${project.artifactId}</imageName>
14 <dockerHost>http://192.168.28.31:2375</dockerHost>
15 <!--
16 <baseImage>java:8</baseImage>
17 <baseImage>openjdk:8</baseImage>
18 <baseImage>openjdk:8-jre</baseImage>
19 <baseImage>openjdk:8-alpine</baseImage>
20 -->
21 <baseImage>openjdk:8-jre-alpine</baseImage>
22 <entryPoint>["java", "-jar", "/${project.build.finalName}.jar"]</entryPoint>
23 <resources>
24 <resource>
25 <targetPath>/</targetPath>
26 <directory>${project.build.directory}</directory>
27 <include>${project.build.finalName}.jar</include>
28 </resource>
29 </resources>
30 </configuration>
31 </plugin>
32 </plugins>
33 </build>

 

从结果来看,openjdk:8-jre-alpine 是最小的,openjdk:8-alpine 其次

第二种方式:指定Dockerfile构建

首先,创建一个Dockerfile文件

 FROM openjdk:8-jdk-alpine
COPY hello-docker-0.0.1-SNAPSHOT.jar app.jar
ENTRYPOINT ["java","-jar","/app.jar"]

然后,指定Dockerfile文件所在的位置

 1 <build>
2 <plugins>
3 <plugin>
4 <groupId>org.springframework.boot</groupId>
5 <artifactId>spring-boot-maven-plugin</artifactId>
6 </plugin>
7
8 <plugin>
9 <groupId>com.spotify</groupId>
10 <artifactId>docker-maven-plugin</artifactId>
11 <version>1.2.2</version>
12 <configuration>
13 <imageName>cjs/${project.artifactId}</imageName>
14 <dockerHost>http://192.168.28.31:2375</dockerHost>
15 <dockerDirectory>src/main/docker</dockerDirectory>
16 <resources>
17 <resource>
18 <targetPath>/</targetPath>
19 <directory>${project.build.directory}</directory>
20 <include>${project.build.finalName}.jar</include>
21 </resource>
22 </resources>
23 <imageTags>
24 <imageTag>${project.version}</imageTag>
25 <imageTag>latest</imageTag>
26 </imageTags>
27 </configuration>
28 </plugin>
29 </plugins>
30 </build>

第三种方式:手动构建

 FROM openjdk:8-jdk-alpine
ARG JAR_FILE=target/*.jar
COPY ${JAR_FILE} app.jar
ENTRYPOINT ["java","-jar","/app.jar"]

命令行执行

 docker build -t cjs/hello-docker .

运行的时候可以指定环境变量参数

 docker run -e "SPRING_PROFILES_ACTIVE=prod" -p 8084:8083 -d cjs/hello-docker:0.0.2-SNAPSHOT

4.  备忘录

https://github.com/spotify/docker-maven-plugin

https://registry.hub.docker.com/_/openjdk

https://registry.hub.docker.com/_/redis

https://spring.io/guides/gs/spring-boot-docker/

https://spring.io/guides/topicals/spring-boot-docker

Spring Boot Docker的更多相关文章

  1. Spring Boot Docker 实战

    Spring Boot Docker 开发环境 开发工具: Intellij IDEA 2018.2.6 springboot: 2.0.6.RELEASE jdk: 1.8.0_192 maven: ...

  2. spring boot docker 初尝试

    Docker服务中进程间通信通过/var/run/docker.sock实现,默认服务不提供监听端口,因此使用docker remote api 需要手动绑定端口. 在centos7.2下,可以进行这 ...

  3. Spring Boot + Docker + K8S 简单示例

    前言 最近看了看k8s,感觉用这个管理docker确实比自己写一坨脚本进步太多了,简直不是一个次原的东西. 看着k8s的官方文档随手写了个小Demo,一个基于k8s的spring boot服务. 代码 ...

  4. idea spring boot docker 多项目 maven 编译

    1,重复的model [INFO] Scanning for projects... [ERROR] [ERROR] Some problems were encountered while proc ...

  5. Spring Boot + docker +mongo

    启动mongo镜像 docker run --name mongo-container -d -P mongo 连接到容器内 docker exec -it eb sh 输入:mongo 输入:sho ...

  6. java Spring boot Docker打包

    https://blog.csdn.net/Stephanie_1/article/details/88831993

  7. 【原创】Docker容器及Spring Boot微服务应用

    Docker容器及Spring Boot微服务应用 1 什么是Docker 1.1 Docker的出现 问题一:项目实施环境复杂问题 传统项目实施过程中经常会出现“程序在我这跑得好好的,在你那怎么就不 ...

  8. Java微服务之Spring Boot on Docker

    本文学习前提:Java, Spring Boot, Docker, Spring Cloud 一.准备工作 1.1 安装Docker环境 这一部分请参考我的另一篇文章<ASP.NET Core ...

  9. Spring Boot 2 (四):使用 Docker 部署 Spring Boot

    Spring Boot 2 (四):使用 Docker 部署 Spring Boot Docker 技术发展为微服务落地提供了更加便利的环境,使用 Docker 部署 Spring Boot 其实非常 ...

随机推荐

  1. Promise解析(待完成)

    Promise是一种异步操作的解决方案,将写法复杂的传统的回调函数和监听事件的异步操作,用同步代码的形式表达出来.避免了多级异步操作的回调函数嵌套. 1.主要用于异步计算 2.可以将异步操作队列化,按 ...

  2. 17.继承 and18.接口和多态 内部类 匿名内部类,Lambda表达式

    1. 继承 1.1 继承的实现(掌握) 继承的概念 继承是面向对象三大特征之一,可以使得子类具有父类的属性和方法,还可以在子类中重新定义,以及追加属性和方法 实现继承的格式 继承通过extends实现 ...

  3. (原创)高DPI适配经验系列:(三)字体与字号、缩放锚点

    一.前言 程序最基本的元素,就是文本,也就是字体.如果程序未进行高DPI的适配,最直观的感受便是字体的模糊.所以本篇便来说一下高DPI适配中的字体问题. 高DPI的适配,简单来说便是便是根据不同的DP ...

  4. [Java]数据分析--数据可视化

    时间序列 需求:将一组字符顺序添加到时间序列中 实现:定义时间序列类TimeSeries,包含静态类Entry表示序列类中的各项,以及add,get,iterator,entry方法 TimeSeri ...

  5. 2.9. 管道和重定向ls /proc && echo suss! || echo failed. 能够提示命名是否执行成功or失败; 与上述相同效果的是: if ls /proc; then echo suss; else echo fail; fi

    2.9. 管道和重定向 批处理命令连接执行,使用 | 串联: 使用分号 ; 前面成功,则执行后面一条,否则,不执行:&& 前面失败,则后一条执行: || ls /proc && ...

  6. 【Python成长之路】装逼的一行代码:快速共享文件

    [Python成长之路]装逼的一行代码:快速共享文件 2019-10-26 15:30:05 华为云 阅读数 335 文章标签: Python编程编程语言程序员Python开发 更多 分类专栏: 技术 ...

  7. docker部署harbor私有镜像库(3)

    一.harbor介绍 在实际生产运维中,往往需要把镜像发布到几十.上百台或更多的节点上.这时单台Docker主机上镜像已无法满足,项目越来越多,镜像就越来越多,都放到一台Docker主机上是不行的,我 ...

  8. Java 运行 Jar 包中java -cp 与 java jar 的区别

    java -cp java -cp 和 -classpath 一样,是指定类运行所依赖其他类的路径,通常是类库和jar包,需要全路径到jar包,多个jar包之间连接符:window上分号"; ...

  9. ubuntu中软件的升级管理-(转自Josh_)

    给Ubuntu软件升级命令 sudo apt-get update  --更新软件源 sudo apt-get upgrade -更新已经安装的软件 以非root用户更新系统 sudo: sudo是l ...

  10. linux 解压总结

    tar解压 gz解压 bz2等各种解压文件使用方法 .tar 解包:tar xvf FileName.tar 打包:tar cvf FileName.tar DirName (注:tar是打包,不是压 ...