![b71173d67efc63a05c905a7a21cf5cb7.png](https://img-blog.csdnimg.cn/img_convert/b71173d67efc63a05c905a7a21cf5cb7.png)
>>>前提
项目部署对我来说一直都是件头疼的事情,更新一个项目需要停掉服务器上原有的项目,再重新上传新的项目到服务器上,有时可能还会在本地和服务的不同环境下还会启动报错,太浪费时间了
有一键部署项目到服务器的功能,你就可以愉快的去写代码改bug了
>>>服务器
首先你需要在服务器上搭建一个docker的环境,同时开启api端口监听
![867902f76dcdde6a15a946c78d080dfe.png](https://img-blog.csdnimg.cn/img_convert/867902f76dcdde6a15a946c78d080dfe.png)
>>>IDE
新建一个web项目,目录结构如下
![1926cc35b81821c84429be2bf2aaf9a2.png](https://img-blog.csdnimg.cn/img_convert/1926cc35b81821c84429be2bf2aaf9a2.png)
同时创建一个docker文件夹,在文件夹下创建一个Dockerfile文件(docker默认的Dockerfile文件)
FROM java:8
VOLUME /tmp
COPY websocket-0.0.1-SNAPSHOT.jar demo.jar
RUN bash -c "touch /demo.jar"
EXPOSE 7856
ENTRYPOINT ["java","-jar","demo.jar"]
这样写你需要在项目编译之后把jar包文件放到docker文件夹下,你也可以直接在外面直接创建一个dockerfile文件,然后把copy地址改成 /target/。。。
maven添加如下配置
<plugin>
<groupId>com.spotify</groupId>
<artifactId>docker-maven-plugin</artifactId>
<version>0.4.13</version>
<!--将插件绑定在某个phase执行-->
<executions>
<execution>
<id>build-image</id>
<!--将插件绑定在package这个phase上。也就是说,
用户只需执行mvn package ,就会自动执行mvn docker:build-->
<phase>package</phase>
<goals>
<goal>build</goal>
</goals>
</execution>
</executions>
<configuration>
<!--指定生成的镜像名,这里是我们的项目名-->
<imageName>${project.artifactId}</imageName>
<!--指定标签 这里指定的是镜像的版本,我们默认版本是latest-->
<imageTags>
<imageTag>latest</imageTag>
</imageTags>
<!-- 指定我们项目中Dockerfile文件的路径-->
<dockerDirectory>${project.basedir}/docker</dockerDirectory>
<!--指定远程docker 地址-->
<dockerHost>http://111.229.92.219:3375</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>
同时idea需要添加docker配置
![4f7ee33a2de3d63cc81f612d0a035003.png](https://img-blog.csdnimg.cn/img_convert/4f7ee33a2de3d63cc81f612d0a035003.png)
配置好之后直接maven编译,如果没有报错的话,就等着镜像push就好了
![76e06d17f24ca2d9b65360691918425f.png](https://img-blog.csdnimg.cn/img_convert/76e06d17f24ca2d9b65360691918425f.png)
![8d73637eef9f3cfa6cb3164013f5f700.png](https://img-blog.csdnimg.cn/img_convert/8d73637eef9f3cfa6cb3164013f5f700.png)
关注公众号获取更多知识
![876657e98b1f8cde3add9b60a5a9a79a.png](https://img-blog.csdnimg.cn/img_convert/876657e98b1f8cde3add9b60a5a9a79a.png)