修改文件信息路径如下:
/etc/docker/daemon.json
在配置文件中添加以下内容:
"hosts": ["tcp://0.0.0.0:2375", "unix:///var/run/docker.sock"]
注意:如果没有这个daemon.json,就自己在/etc/docker/目录下创建一个
touch daemon.json
tcp是开启远程访问,unix是本机访问,不开启本机访问,在服务器上使用时会有以下错误:
Cannot connect to the Docker daemon at unix:///var/run/docker.sock. Is the docker daemon running?
修改完成之后依次执行以下命令:
#重新加载配置文件
systemctl daemon-reload
# 重启服务
systemctl restart docker.service
# 查看端口是否开启 默认端口2375
netstat -anp|grep 2375
依次执行以下命令
添加指定需要开放的端口:
firewall-cmd --zone=public --add-port=2375/tcp --permanent
重载入添加的端口:
firewall-cmd --reload
查询指定端口是否开启成功:
firewall-cmd --query-port=2375/tcp
注意:以上配置全是在防火墙开启的情况下进行,如果未开启系统防火墙,则无需以上配置,比如我的服务器就 没有配置防火墙,运行时则显示以下信息:
最后我们看看我们的配置是否生效
curl http://127.0.0.1:2375/info
注意:我上面的192.168.1.2是我自己的服务器Ip,只需修改成你的docker所在服务器ip即可
点击Apply之后会在你的service中弹出
点击连接,我们就会发现我们docker配置的容器信息
安装插件:Docker-maven-plugin
<plugin>
<groupId>com.spotifygroupId>
<artifactId>docker-maven-pluginartifactId>
<version>1.0.0version>
<configuration>
<imageName>${project.artifactId}imageName>
<imageTags>
<imageTag>latestimageTag>
imageTags>
<baseImage>javabaseImage>
<maintainer>[email protected]maintainer>
<workdir>/ROOTworkdir>
<cmd>["java", "-version"]cmd>
<entryPoint>["java", "-jar", "${project.build.finalName}.jar"]entryPoint>
<dockerHost>http://192.168.1.2:2375dockerHost>
<resources>
<resource>
<targetPath>/ROOTtargetPath>
<directory>${project.build.directory}directory>
<include>${project.build.finalName}.jarinclude>
resource>
resources>
configuration>
plugin>
我所有的maven配置如下:
<project xmlns="http://maven.apache.org/POM/4.0.0" xmlns:xsi="http://www.w3.org/2001/XMLSchema-instance"
xsi:schemaLocation="http://maven.apache.org/POM/4.0.0 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0modelVersion>
<parent>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-parentartifactId>
<version>2.6.6version>
<relativePath/>
parent>
<groupId>com.examplegroupId>
<artifactId>dockerartifactId>
<version>0.0.1-SNAPSHOTversion>
<name>dockername>
<description>dockerdescription>
<properties>
<java.version>11java.version>
<maven.test.skip>truemaven.test.skip>
<maven.javadoc.skip>truemaven.javadoc.skip>
properties>
<dependencies>
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-webartifactId>
dependency>
<dependency>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-starter-testartifactId>
<scope>testscope>
dependency>
dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.bootgroupId>
<artifactId>spring-boot-maven-pluginartifactId>
plugin>
<plugin>
<groupId>com.spotifygroupId>
<artifactId>docker-maven-pluginartifactId>
<version>1.0.0version>
<configuration>
<imageName>${project.artifactId}imageName>
<imageTags>
<imageTag>latestimageTag>
imageTags>
<baseImage>javabaseImage>
<maintainer>[email protected]maintainer>
<workdir>/ROOTworkdir>
<cmd>["java", "-version"]cmd>
<entryPoint>["java", "-jar", "${project.build.finalName}.jar"]entryPoint>
<dockerHost>http://192.168.1.2:2375dockerHost>
<resources>
<resource>
<targetPath>/ROOTtargetPath>
<directory>${project.build.directory}directory>
<include>${project.build.finalName}.jarinclude>
resource>
resources>
configuration>
plugin>
plugins>
build>
project>
注意:在我们拉取插件成功之后,我们会发现目录结构变成如下所示 :
我们需要删除一个启动类,否则会导致打包失败,我将DockerApplication直接删除了
执行
mvn docker:build
这个就是我们打包好的镜像
在服务器上执行
docker images
在我们服务器内执行
docker run -d --name idea-docker-test -p 8089:8080 docker
注:我之所以暴露出8089端口,只要是因为8080冲突了,自己看自己的情况改就好
我们可以看到在 Idea里也可看到我们刚刚启动成功的镜像以及输出的日志了
至此idea部署SpringBoot至docker就结束啦