IDEA集成Docker构建SpringBoot镜像上传服务器

简介: IDEA集成Docker构建SpringBoot镜像上传服务器

IDEA集成Docker打包SpringBoot项目


参考学习


视频:IDEA整合Docker,快捷部署SpringBoot应用


文档:IDEA集成Docker的快捷部署


1、首先开启docker的2375端口监听


主要目的是为了之后IDEA进行连接服务器的2375端口


修改配置文件:


# 编辑打开其中的docker.service文件
vim /usr/lib/systemd/system/docker.service
# 将其中的execstart进行替换
ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock


然后重新加载docker.server文件并重启docker服务:


# 重新加载服务配置docker.server
systemctl daemon-reload
# 重新启动docker
systemctl restart docker


来测试一下当前2375端口是否在监听:


# 若是出现json文件内容说明已经在监听了
curl http://127.0.0.1:2375/version
# 查看下2375端口是否被监听
netstat -nlpt
# 服务器防火墙开启2375端口
firewall-cmd --add-port=2375/tcp --permanent
firewall-cmd --reload
firewall-cmd --zone=public --list-ports


2、IDEA配置docker


打开IDEA的Settings配置,输入好下方内容即可自动进行连接:


tcp://192.168.1.109:2375



点击ok之后


在下方services窗口我们就可以看到对应的docker了,双击即可进行连接:



3、集成Maven插件


打开Pom.xml,进行配置docker-maven插件,分别包含你的镜像前缀、连接的远程服务器地址,之后即可进行构建打包直接上传你的服务器:


<properties>
    <!--docker镜像的前缀:标签名-->
    <docker.image.prefix>docker</docker.image.prefix>
</properties>
<plugin>
  <groupId>com.spotify</groupId>
  <artifactId>docker-maven-plugin</artifactId>
  <version>1.0.0</version>
  <configuration>
    <!--远程Docker的地址-->
    <dockerHost>http://服务器地址:2375</dockerHost>
    <!--镜像名称,前缀/项目名-->
    <imageName>${docker.image.prefix}/${project.artifactId}</imageName>
    <!-- 我们自己配置编写的docker目录,也就是dockerfile:指定位置在src/main/docker中    -->
    <dockerDirectory>src/main/docker</dockerDirectory>
    <!-- 我们要打包镜像需要带上的资源:默认会去找我们项目目录下对应打包好的jar包   -->
    <resources>
      <resource>
        <targetPath>/</targetPath>
        <directory>${project.build.directory}</directory>
        <include>${project.build.finalName}.jar</include>
      </resource>
    </resources>
  </configuration>
</plugin>



4、Maven添加SpringBoot项目启动类配置


接着添加你的项目主启动类,若是不配置就会出现:no main manifest attribute, in /app/app.jar 报错


<plugin>
    <groupId>org.springframework.boot</groupId>
    <artifactId>spring-boot-maven-plugin</artifactId>
    <executions>
        <execution>
            <phase>package</phase>
            <goals>
                <goal>repackage</goal>
            </goals>
        </execution>
    </executions>
    <configuration>
        <includeSystemScope>true</includeSystemScope>
        <!--指定主类-->
        <mainClass>com.**.**.xxxApplication</mainClass>
    </configuration>
</plugin>



主启动器如下完整路径:



5、项目打包,编写Dockerfile


执行Maven install首先来对我们项目进行打包,这里我们就能够提前看到打包后的jar包名,方便之后来配置编写DockerFile:



在过程3中我们默认Dockerfile的文件目录下src/main/docker,那我们就在main下新建docker目录,然后编写Dockerfile文件如下:



FROM java:8
MAINTAINER changlu 939974883@qq.com
VOLUME /tmp
ADD zf-web-1.0.0.jar /app.jar
RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
EXPOSE 8999
ENTRYPOINT ["java", "-jar", "app.jar"]


下面是对应DockerFile的详细说明:主要就是ADD命令后前面jar包名你要对应上自己的


# 指定的基础镜像
FROM java:8
# 镜像维护者姓名或邮箱地址
MAINTAINER Sunny 306509906@qq.com
# 指定容器挂载点到宿主机自动生成的目录,用于作为缓存目录
VOLUME /tmp
# 拷贝宿主机jar包到容器中,这里是将application-server.jar拷贝成app.jar【***修改这里的application-server.jar即可***】
ADD zf-web-1.0.0.jar /app.jar
RUN cp /usr/share/zoneinfo/Asia/Shanghai /etc/localtime && echo 'Asia/Shanghai' >/etc/timezone
# 暴露出端口(提示)
EXPOSE 28011
# 运行容器时执行的shell命令
ENTRYPOINT ["java", "-jar", "app.jar"]


6、构建镜像并上传服务器


在对应引入插件的下,找到docker,执行docker:build命令:



接着就会根据我们的DockerFile构建镜像并上传到我们的服务器,出现build success就表示构建成功!



由于我IDEA已经连接上了服务器的Docker,这里就可以直接查看我们上传的Springboot镜像:



7、进入容器执行运行命令


参考:mall在Linux环境下的部署(基于Docker容器)


使用xshell连接服务器:执行下列命令


# --link表示链接容器,让他们能够进行互相访问
# -p指定映射端口、-link表示链接指定的容器,对于各个容器可以使用对应后缀名来访问,如mysql访问其地址直接用db即可
# -d后台运行,之后就是镜像名
docker run -p 8999:8999 --name studo-admin \
--link mysql:db \
--link redis:redis \
--link nginx:nginx \
-v /etc/localtime:/etc/localtime \
-d studio/zf-web:latest


相关文章
|
6月前
|
存储 测试技术 数据安全/隐私保护
【Docker项目实战】使用Docker部署dufs文件服务器
【Docker项目实战】使用Docker部署dufs文件服务器
874 17
【Docker项目实战】使用Docker部署dufs文件服务器
|
5月前
|
Ubuntu 网络安全 PHP
如何使用vscode的Docker插件管理ubuntu 拉取服务器的镜像以及创建容器
本测试镜像旨在记录使用vscode的Docker插件拉取病创建Dockerfile,以及拉取镜像。
|
6月前
|
弹性计算 关系型数据库 Nacos
低配阿里云 ECS 如何 docker 环境部署 NACOS : 单机版模式
NACOS 单机版 Docker 安装指南。使用指定端口和 custom.env 配置文件启动 Nacos 服务,适用于 2.X 版本,包含 gRPC 支持及 MySQL 数据源配置。 -e MODE=standalone \
543 5
|
7月前
|
Ubuntu 安全 数据安全/隐私保护
在Docker容器中部署GitLab服务器的步骤(面向Ubuntu 16.04)
现在,你已经成功地在Docker上部署了GitLab。这就是我们在星际中的壮举,轻松如同土豆一样简单!星际旅行结束,靠岸,打开舱门,迎接全新的代码时代。Prepare to code, astronaut!
503 12
|
10月前
|
NoSQL Redis Docker
Docker——阿里云服务器利用docker搭建redis集群
本文详细记录了使用Docker搭建Redis集群的过程,包括检查Docker和Docker Compose的安装、创建Redis配置文件、编写`docker-compose.yml`文件、启动Redis节点、创建Redis集群的具体步骤,以及最终的验证方法。文章还提供了在多服务器环境下搭建Redis集群的注意事项,帮助读者全面了解 Redis 集群的部署流程。
1294 68
|
9月前
|
关系型数据库 MySQL Linux
在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾
以上就是在Linux环境下备份Docker中的MySQL数据并传输到其他服务器以实现数据级别的容灾的步骤。这个过程就像是一场接力赛,数据从MySQL数据库中接力棒一样传递到备份文件,再从备份文件传递到其他服务器,最后再传递回MySQL数据库。这样,即使在灾难发生时,我们也可以快速恢复数据,保证业务的正常运行。
427 28
|
弹性计算 Ubuntu Linux
阿里云服务器一键安装Docker社区版教程,基于系统运维管理OOS
阿里云服务器一键安装Docker社区版教程,基于系统运维管理OOS自动化部署。支持Ubuntu 22.04/20.04、CentOS 7.7-7.9及Alibaba Cloud Linux 3.2104 LTS。前提条件:ECS实例需运行中且有公网。步骤:选择Docker扩展并安装,验证成功通过命令`docker -v`查看版本号。
959 79
|
10月前
|
Docker Python 容器
Docker——阿里云服务器使用Docker部署python项目全程小记
本文记录了我在阿里云服务器上使用Docker部署python项目(flask为例)的全过程,在这里记录和分享一下,希望可以给大家提供一些参考。
1272 1
|
10月前
|
弹性计算 运维 Ubuntu
在阿里云ECS云服务器上安装、配置及高效使用Docker与Docker Compose
本文介绍了在阿里云ECS上使用Ubuntu系统安装和配置Docker及Docker Compose的详细步骤。通过这些工具,可以快速部署、弹性扩展和高效管理容器化应用,满足开发和运维需求。内容涵盖Docker的安装、镜像源配置、创建Web程序镜像以及使用Docker Compose部署WordPress等实际操作,并分享了使用体验,展示了阿里云实例的高性能和稳定性。
1797 4
|
10月前
|
Linux 虚拟化 Docker
Linux服务器部署docker windows
在当今软件开发中,Docker成为流行的虚拟化技术,支持在Linux服务器上运行Windows容器。流程包括:1) 安装Docker;2) 配置支持Windows容器;3) 获取Windows镜像;4) 运行Windows容器;5) 验证容器状态。通过这些步骤,你可以在Linux环境中顺利部署和管理Windows应用,提高开发和运维效率。
1570 1

热门文章

最新文章