2、配置远程docker主机
1)首先登陆远程docker主机,修改配置文件 /usr/lib/systemd/system/docker.service
#vim /usr/lib/systemd/system/docker.service
打开文件,找到 ExecStart=/usr/bin/dockerd -H fd:// --containerd=/run/containerd/containerd.sock 这一行,在后面添加-H tcp://0.0.0.0:2375,表示打开2375端口,支持远程连接docker
2)修改文件后保存,重新加载配置文件并重启docker服务
#systemctl daemon-reload
#systemctl restart docker.service
3)Idea配置docker主机,File ——> Settings ——>Build,Execution,Depolyment ——> Docker,添加一个Docker主机,TCP socket中添加远程主机+端口,以tcp://开头,
tcp://192.168.0.6:2375,添加后会自动连接远程docker主机,下方看到connection successful表示连接成功,否则表示连接失败。
4)docker主机连接成功后,在docker插件面板中可以看到docker主机的容器和镜像,以及docker容器运行的日志等信息
3、创建Dockerfile文件
在服务根目录创建docker文件夹,路径如下
在docker目录创建一个Dockerfile文件,内容:
FROM java:8
VOLUME /tmp
ADD land-service-hi.jar app.jar
EXPOSE 8800
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
内容参数解释见docker
4、配置pom文件
在build的plugins插件标签中添加:
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<executions>
<execution>
<goals>
<!-- 打包成可执行jar包 -->
<goal>repackage</goal>
</goals>
</execution>
</executions>
</plugin>
<plugin>
<groupId>org.apache.maven.plugins</groupId>
<artifactId>maven-compiler-plugin</artifactId>
<configuration>
<encoding>utf-8</encoding>
<source>1.8</source>
<target>1.8</target>
</configuration>
</plugin>
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>1.0.0</version>
<!--将插件绑定在某个phase执行-->
<executions>
<execution>
<id>build-image</id>
<!--用户只需执行mvn package ,就会自动执行mvn docker:build-->
<phase>package</phase>
<goals>
<goal>build</goal>
</goals>
</execution>
</executions>
<configuration>
<!--指定docker文件目录-->
<dockerDirectory>${project.basedir}/docker</dockerDirectory>
<!--指定生成的镜像名-->
<imageName>land/${project.artifactId}</imageName>
<!--指定标签-->
<imageTags>
<imageTag>latest</imageTag>
</imageTags>
<!--指定远程 docker api地址-->
<dockerHost>http://192.168.0.6:2375</dockerHost>
<!-- 这里是复制 jar 包到 docker 容器指定目录配置 -->
<resources>
<resource>
<targetPath>/</targetPath>
<!--jar 包所在的路径 此处配置的 即对应 target 目录-->
<directory>${project.build.directory}</directory>
<!-- 需要包含的 jar包 ,这里对应的是 Dockerfile中添加的文件名 -->
<include>${project.build.finalName}.jar</include>
</resource>
</resources>
</configuration>
</plugin>
</plugins>
5、打包部署
通过上面一系列配置后,maven打包服务时将自动build 镜像到远程主机,通过docker插件的面板可以看到镜像已经推送到远程主机
#mvn clean package -DskipTests
二、docker部署多个服务
1、服务创建容器
给每个服务都进行上面的配置后,使用maven在父项目打包时,将自动上传所有服务的镜像到远程docker主机。这样,虽然上传了服务镜像到远程主机,但远程主机并没有创建和启动对应的容器。
方法:可以通过在docker面板手动创建容器,以后每次使用maven打包服务时,不仅会上传镜像同时还会自动重启远程主机的docker容器。
同样地,为每个服务手动创建一个容器,然后在项目根目录打包时,每个服务的镜像都会上传到远程docker主机并自动重启容器。
2、使用docker-compose
可以使用上面手动创建容器的方法,让远程docker主机启动容器。也可以待各个服务镜像上传到远程主机后,使用docker-compose完成服务编排,然后启动各个微服务。
1)在远程docker主机编辑docker-compose.yml文件
version: '2'
services:
land-eureka:
image: land/land-eureka:latest
container_name: land-eureka
ports:
- '8761:8761'
land-zuul:
image: land/land-zuul:latest
container_name: land-zuul
ports:
- '9000:9000'
land-netty:
image: land/land-netty:latest
container_name: land-netty
ports:
- '8000:8000'
land-service-hi:
image: land/land-service-hi:latest
container_name: land-service-hi
ports:
- '8800:8800'
land-service-consumer:
image: land/land-service-consumer:latest
container_name: land-service-consumer
ports:
- '8801:8801'
2)在docker-compose.yml文件目录下运行docker-compose命令,启动容器
#docker-compose up -d