GVKun编程网logo

k8s学习笔记(2)- Rancher2.x部署springboot应用及高可用、扩容(k8s部署springboot项目)

6

对于想了解k8s学习笔记的读者,本文将提供新的信息,我们将详细介绍2-Rancher2.x部署springboot应用及高可用、扩容,并且为您提供关于Docker镜像编排并部署SpringBoot应用

对于想了解k8s学习笔记的读者,本文将提供新的信息,我们将详细介绍2- Rancher2.x部署springboot应用及高可用、扩容,并且为您提供关于Docker 镜像编排并部署SpringBoot应用、Docker一键部署SpringBoot应用的方法,贼快贼好用!、Docker部署SpringBoot应用的实现步骤、idea整合docker快速部署springboot应用的详细过程的有价值信息。

本文目录一览:

k8s学习笔记(2)- Rancher2.x部署springboot应用及高可用、扩容(k8s部署springboot项目)

k8s学习笔记(2)- Rancher2.x部署springboot应用及高可用、扩容(k8s部署springboot项目)

前言:上一篇介绍基于k3s环境,使用kubectl部署springboot简单项目应用,本篇介绍基于rancher2.x部署应用程序

1、上篇已部署一个springboot应用,我们可以通过rancher查看工作负载状态

  • 说明:我们没有通过rancher添加主机管理部署K8s集群,所以我们这里直接用rancher在k3s上操作
  • 登录rancher,查看集群工作负载

    image

  • 点击负载名称,查看负载信息

    image

  • 可以看到springboot部署在了ubuntunode2节点上,ip地址192.168.231.132,所以我们可以通过http://192.168.231.132:30000/hello访问应用

    image

  • 重启k3s服务器,3个节点,只启动其中2个,且不启动昨天做的springbootapp所部署的那台server,ubuntunode2

    image

  • 输入命令,查看pod:springbootapp的状态
      sudo kubectl describe pod/springbootapp -n default
    
    说明: -n default 命名空间 default

    image

  • pod处于terminating状态,我们可以输入命令强制删除pod,重新部署
    格式:
      sudo kubectl delete pod 【podname】 --force --grace-period=0 -n 【命名空间】
    
    命令:
      sudo kubectl delete pod spingbootapp --force --grace-period=0 -n default
    

2、通过rancher2.x部署应用

  • 进入rancher工作负载界面

    image

  • 点击部署应用,填写参数信息,名称,镜像,命名空间,负载类型选择2个pod

    image

  • 点击启动

    image

  • 等待一段时间后,工作负载创建完成

    image

3、创建负载均衡ingress,提供对外访问springbootapp的pod

  • 进入负载均衡界面,点击-添加规则

    image

  • 填写相关参数,域名springbootapp.com,命名空间,选择对应的服务/工作负载

    image


    image

  • 保存后,启动一个负载均衡器

    image

4、通过域名:springbootapp.com,访问springbootapp应用的pod,由于没有DNS服务器,我们这里通过修改hosts文件,添加域名ip映射进行访问

  • 修改hosts文件,添加域名映射,ip地址可以是springbootapp部署的任一节点的ip地址

    image

  • 保存hosts文件,通过域名访问springbootapp服务

    image

5、模拟pod挂掉,重新部署应用

  • 强制删除一个节点,rancher会重新启动一个pod,保证2个副本工作

    image

  • 系统会很快帮我们重新构建一个pod

    image

  • 如果一台机器挂掉,pod处于Terminating状态,我们可以重新部署应用,rancher会中心创建2个pod提供服务

    image

  • 点击重新部署,会出现多个pod

    image

  • 这样不会使springbootapp服务中断,待新pod创建完成之后,会剔除老的pod

    image

6、服务扩容、缩容

  • 扩容
    在工作负载springbootapp中,点击增加pod节点

    image


    我们发现新增了一个pod节点提供服务

    image

  • 缩容
    在工作负载springbootapp中,点击减少pod节点

    image


    我们发现rancher帮我们减少了一个pod节点提供服务,释放了资源

    image

Docker 镜像编排并部署SpringBoot应用

Docker 镜像编排并部署SpringBoot应用

Docker-compose是一个基于Docker的编排工具,所谓编排个人理解就是将不同的镜像通过配置,组成一个新的运行环境,官方定义是:Compose is a tool for defining and running multi-container Docker applications.

很简单的一句话,下面我们看下怎么部署一个JavaWeb项目.主要有几大步骤:

  • 安装Dcoker 和Docker-compose
  • 编译项目生成JAR包
  • 创建自定义的docker镜像
  • 创建docker-compose的配置文件
  • 启动服务

安装

安装docker 和 docker-compose 一样都非常的简单,这里不在多赘述,官网都有非常详细的教程. 至于docker_compose就是一个命令文件,将其所在的路径配置PATH环境变量中即可,不配置也行,这样的话就要打全路径了,比较麻烦.

  • Docker文档官网
  • Docker-componse 安装文档
  • Dockercomponse源码

启动Docker服务

我是用的是Manjaro的Linux发行版本,启动docker服务的命令systemctl start docker,

$ docker version
Client:
 Version:      18.05.0-ce
 API version:  1.37
 Go version:   go1.10.2
 Git commit:   f150324782
 Built:        Wed May 16 22:27:45 2018
 OS/Arch:      linux/amd64
 Experimental: false
 Orchestrator: swarm

Server:
 Engine:
  Version:      18.05.0-ce
  API version:  1.37 (minimum version 1.12)
  Go version:   go1.10.2
  Git commit:   f150324782
  Built:        Wed May 16 22:28:17 2018
  OS/Arch:      linux/amd64
  Experimental: false

查看Docker-compose

下载docker-compose完成之后,使用chmod +x docker-componse 来授权,否则会出现权限拒绝的报错信息

配置完成只有,在命令行中输入docker-compose version查看是否安装成功,输出类似以下信息,则代表成功


$ docker-compose version
docker-compose version 1.22.0-rc2, build 6817b533
docker-py version: 3.4.1
CPython version: 3.6.6
OpenSSL version: OpenSSL 1.1.0f  25 May 2017

创建Docker镜像

创建配置文件

此文件名位Dockerfile

FROM hub.c.163.com/library/java:8
VOLUME /tmp
ADD dmc_user.jar app.jar
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]
  • 依赖网易云的java:8镜像
  • 拷贝jar文件到镜像中
  • 执行命令运行

下面我们将使用Shell脚本的方式来利用这个Docker文件来进行创建镜像

编译生成镜像文件

由于这里使用SpringBoot创建的项目,个人使用Gradle构建项目,使用Maven或者其他方式构建的均可,这里写了一个Shell脚本,如下所示:


#!/usr/bin/env bash

#配置相关的路径地址
#配置项目名称
project_name="DMC_USER"
# 配置源码地址
project_dir="/home/yan/code/work/zhuxun/dmc_user"
#配置shell地址
shell_dir="/home/yan/code/shell/dmc/user"

echo "正在准备编译项目${project_name}....."
#切换到项目目录
cd ${project_dir}
echo "已经成功切换到${project_name}的工作目录......"
#使用gradle编译,跳过单元测试
./gradlew build -x test
if [ $? -eq 0 ]; then
    echo "正在拷贝JAR文件............"
#    编译成功,则将JAR文件拷贝当前Shell目录
    cp build/libs/dmc_user-0.0.1-SNAPSHOT.jar ${shell_dir}/dmc_user.jar
    cd ${shell_dir}
	echo "编译成功,正在编译为Docker镜像,请等待...."
#	使用docker build命令构建镜像文件,此时会读取Dockerfile文件
	docker build -t dmc_user:latest ${shell_dir}
	if [ $? -eq 0 ]; then
		echo "编译镜像成功,请使用docker images命令查看效果....."
	fi
fi

添加运行权限,运行之......

由于我这里使用的多个项目进行同事运行,因此需要在次编译另外一个项目,方法类似,这里不在赘述. 编译完成之后,我们在Dockerfile中查看一下镜像


$ docker images
REPOSITORY                    TAG                 IMAGE ID            CREATED             SIZE
dmc_user                      latest              a7ea7b79390f        3 hours ago         692MB
dmc_apim                      latest              56c7f37aee13        16 hours ago        704MB
hub.c.163.com/library/java    8                   a001fc27db5a        19 months ago       643MB

创建配置文件

到这里,我们的镜像已经准备好了,下面我们使用docker-compose来编排镜像,组成新的服务.在shell的目录下创建 文件名称docker-compose.yml的配置文件,内容如下(删除注释)...


# 配置文件的版本
version: ''2''
# 创建的服务,这里我创建了3个服务,两个jar项目作为演示,一个mysql作为服务器
services:
  dmc_api:
#    容器的名称
    container_name: dmc_apim
#    容器的端口信息,这里的SpringBoot项目的端口是9092,可以在宿主机通过8082访问
    ports:
      - "8082:9092"
#      依赖的docker images镜像名称,当然也有版本这里是简写 dmc_api:latest
    image: dmc_apim
#    创建自服务的依赖项,此服务依赖属于mysql,在我们创建的三个服务中的最后一个
    depends_on:
      - dmc_dev_mysql

  dmc_user:
    container_name: dmc_user
    ports:
      - "8081:9091"
    image: dmc_user
    depends_on:
      - dmc_dev_mysql

  dmc_dev_mysql:
#  这个属性非常重要,在SpringBoot的服务中,可以通过这个名称访问,如果名称冲突,docker_compose会自动的添加后缀导致SpringBoot项目找不到数据库连接,
#  从而启动失败,因此需要配置容器的名称
    container_name: dmc_dev_mysql
#    挂载目录,其中 /docker-entrypoint-initdb.d/ 是比较重要的,他可以进行mysql的初始化,在我们的mysql服务的时候启动初始化脚本
#    因此需要在挂载的目录下创建init.sql脚本文件,用于初始化
    volumes:
      - ./data/:/var/lib/mysql/
      - ./mysql/init/:/docker-entrypoint-initdb.d/
#      配置映射端口,这里mysql的端口默认是3306,我们将其映射到宿主机的9936端口
    ports:
      - "9936:3306"
#      依赖的镜像
    image: hub.c.163.com/library/mysql
#    镜像运行需要的参数,可以根据自己的需要来配置,这个请参考镜像的说明文件
    environment:
      MYSQL_ALLOW_EMPTY_PASSWORD: yse


这里和创建docker Image类似,都是使用配置文件,我们来看下我们的配置文件,配置文件名称是固定的,因此要求名称要写对,否则会报一些错误:


$ docker-compose up
ERROR: 
        Can''t find a suitable configuration file in this directory or any
        parent. Are you in the right directory?

        Supported filenames: docker-compose.yml, docker-compose.yaml

可以看到,最后一句话中说明了配置的文件名称 Supported filenames: docker-compose.yml, docker-compose.yaml

## 启动Docker-compose

使用命令```docker-compose up```可以启动编排,要求运行此命令运行路径下必须有docker-compose的配置文件,否则会报上面的找不到文件,
添加 *-d *    就可以后台运行,查看docker-compose的帮助文件我们看下docker容器的状况:

```shell
$ docker ps -a
CONTAINER ID        IMAGE                         COMMAND                  CREATED             STATUS                   PORTS                    NAMES
6c2b3823bd93        dmc_apim                      "java -Djava.securit…"   2 hours ago         Up 2 hours               0.0.0.0:8082->9092/tcp   dmc_apim
f1473486bbec        dmc_user                      "java -Djava.securit…"   2 hours ago         Up 2 hours               0.0.0.0:8081->9091/tcp   dmc_user
3c632926a642        hub.c.163.com/library/mysql   "docker-entrypoint.s…"   2 hours ago         Up 2 hours               0.0.0.0:9936->3306/tcp   dmc_dev_mysql

可以看到两个SpringBoot项目和一个MySql项目在docker中运行完成.....

附录 docker-compose命令

命令名称 说明
docker-compose build Build or rebuild services
docker-compose bundle Generate a Docker bundle from the Compose file
docker-compose config Validate and view the Compose file
docker-compose create Create services
docker-compose down Stop and remove containers, networks, images, and volumes
docker-compose events Receive real time events from containers
docker-compose exec Execute a command in a running container
docker-compose help Get help on a command
docker-compose images List images
docker-compose kill Kill containers
docker-compose logs View output from containers
docker-compose pause Pause services
docker-compose port Print the public port for a port binding
docker-compose ps List containers
docker-compose pull Pull service images
docker-compose push Push service images
docker-compose restart Restart services
docker-compose rm Remove stopped containers
docker-compose run Run a one-off command
docker-compose scale Set number of containers for a service
docker-compose start Start services
docker-compose stop Stop services
docker-compose top Display the running processes
docker-compose unpause Unpause services
docker-compose up Create and start containers
docker-compose version Show the Docker-Compose version information

更多内容请查看 Docker-componse官网教程

Docker一键部署SpringBoot应用的方法,贼快贼好用!

Docker一键部署SpringBoot应用的方法,贼快贼好用!

在《Gradle真能干掉Maven?今天体验了一把,贼爽!》一文中我们讲到了使用Gradle来构建SpringBoot应用,这两天又发现个Gradle插件,支持一键打包、推送Docker镜像。今天我们来讲讲这个插件,希望对大家有所帮助!

SpringBoot实战电商项目mall(40k+star)地址:https://github.com/macrozheng/mall

Gradle Docker Plugin 简介

一款可以通过远程API管理Docker镜像和容器的插件,专为Java应用打造,原生支持SpringBoot。

使用该插件具有如下特性:

  • 与构建工具Gradle及其DSL无缝集成。
  • 在幕后处理Docker客户端和守护程序之间的复杂通信逻辑。
  • 简化了复杂工作流程的定义。
  • 最大程度地减少构建脚本的编写逻辑。

该插件由以下三个插件组成:

  • com.bmuschko.docker-remote-api:提供自定义任务,可以通过远程API与Docker进行交互。
  • com.bmuschko.docker-java-application:为Java应用创建并推送Docker镜像。
  • com.bmuschko.docker-spring-boot-application:为SpringBoot应用创建并推送Docker镜像。

操作镜像

还是以我的脚手架项目mall-tiny为例,让我们来看看使用该插件打包推送Docker镜像是不是够快够简单!

构建镜像

  • 要使用该插件,我们需要在build.gradle中进行如下配置,这里选择使用远程API插件和SpringBoot插件;
plugins {
    id 'com.bmuschko.docker-remote-api' version '6.7.0'
    id 'com.bmuschko.docker-spring-boot-application' version '6.7.0'
}
  • 然后在ext节点下面定义一个常量,这里定义好了镜像仓库地址,方便我们之后引用;
ext{
    registryUrl='192.168.5.78:5000'
}
  • 接下来就是非常重要的插件配置了,配置好Docker远程API的访问路径,还有SpringBoot应用镜像相关配置;
docker {
    url = 'tcp://192.168.5.78:2375'
    springBootApplication {
        baseImage = 'java:8'
        maintainer = 'macrozheng'
        ports = [8080]
        images = ["${registryUrl}/mall-tiny/${rootProject.name}:${version}"]
        jvmArgs = ['-Dspring.profiles.active=prod']
    }
}
  • 接下来我们来解读下这些配置到底有什么作用;
属性类型作用
urlStringDocker远程API访问路径
baseImageStringSpringBoot应用使用的基础镜像
maintainerString项目维护者
portsList镜像暴露的端口
imagesSet打包推送的镜像名称
jvmArgsListJava应用运行时的JVM参数
  • 接下来我们直接在IDEA中使用dockerBuildImage命令,即可将应用镜像打包到远程服务器上去;

  • 让我们看下控制台输出的日志,其实就是给我们默认创建了一个Dockerfile(连Dockerfile都省的写了),然后用它来打包Docker镜像;
> Task :dockerBuildImage
Building image using context 'I:\developer\gitee\mall-tiny-gradle\build\docker'.
Using images '192.168.5.78:5000/mall-tiny/mall-tiny:1.0.0-SNAPSHOT'.
Step 1/8 : FROM java:8
 ---> d23bdf5b1b1b
Step 2/8 : LABEL maintainer=macrozheng
 ---> Running in 9a63f56a03ae
Removing intermediate container 9a63f56a03ae
 ---> ed45af8fff90
Step 3/8 : workdir /app
 ---> Running in 8bd4b513eb23
Removing intermediate container 8bd4b513eb23
 ---> d27759d1d7df
Step 4/8 : copY libs libs/
 ---> 84c3a983972a
Step 5/8 : copY resources resources/
 ---> c8a27f3475fc
Step 6/8 : copY classes classes/
 ---> 3a76a8efc02b
Step 7/8 : ENTRYPOINT ["java", "-Dspring.profiles.active=prod", "-cp", "/app/resources:/app/classes:/app/libs/*", "com.macro.mall.tiny.MallTinyApplication"]
 ---> Running in e56ae56fd6eb
Removing intermediate container e56ae56fd6eb
 ---> 22d73f95e756
Step 8/8 : EXPOSE 8080
 ---> Running in b21d898456cb
Removing intermediate container b21d898456cb
 ---> 73684cf8c643
Successfully built 73684cf8c643
Successfully tagged 192.168.5.78:5000/mall-tiny/mall-tiny:1.0.0-SNAPSHOT
Created image with ID '73684cf8c643'.

BUILD SUCCESSFUL in 34s
5 actionable tasks: 5 executed
10:56:15: Task execution finished 'dockerBuildImage'.
  • 在项目的build\docker文件夹下可以发现这个Dockerfile,具体内容如下:
FROM java:8
LABEL maintainer=macrozheng
workdir /app
copY libs libs/
copY resources resources/
copY classes classes/
ENTRYPOINT ["java", "-Dspring.profiles.active=prod", "-cp", "/app/resources:/app/classes:/app/libs/*", "com.macro.mall.tiny.MallTinyApplication"]
EXPOSE 8080
  • 打包完镜像之后,直接使用如下命令即可运行项目,注意安装好MysqL和Redis。
docker run -p 8080:8080 --name mall-tiny \
--link MysqL:db \
--link redis:redis \
-v /etc/localtime:/etc/localtime \
-v /mydata/app/mall-tiny/logs:/var/logs \
-d 192.168.5.78:mall-tiny/mall-tiny:1.0.0-SNAPSHOT

推送镜像

  • 接下来我们试试推送镜像功能,不过首先需要安装一个镜像仓库,安装可视化镜像仓库可以参考《还在手动部署SpringBoot应用?试试这个自动化插件!》;

  • 推送镜像也是非常简单的,直接在IDEA中使用dockerPushImage命令即可;

  • 推送完成后,在我们的可视化镜像仓库中就可以看到该镜像了。

对比Maven

我们通过把项目clean以后再打包成Docker镜像,对比下使用Gradle和Maven的速度。

  • 使用Gradle进行clean并构建Docker镜像,耗时30s

  • 使用Maven进行clean并构建Docker镜像,耗时58s,果然Gradle还是能比Maven快一倍的!

总结

今天我们体验了一把Gradle和Docker结合使用,发现真是够快够简单。对比Maven速度快了一倍,内置了Dockerfile,大大降低了配置难度。

参考资料

官方文档:https://bmuschko.github.io/gradle-docker-plugin/

项目源码地址

https://github.com/macrozheng/mall-tiny/tree/gradle

本文 GitHub https://github.com/macrozheng/mall-learning 已经收录,欢迎大家Star!

Docker部署SpringBoot应用的实现步骤

Docker部署SpringBoot应用的实现步骤

前言

部署项目时可能会需要依赖于node.js、Redis、RabbitMQ、MySQL等,这些服务部署时所需要的函数库、依赖项各不相同,甚至会有冲突。给部署带来了极大的困难。而Docker确巧妙的解决了这些问题,Docker为了解决依赖的兼容问题的,采用了两个手段:

  1. 将应用的Libs(函数库)、Deps(依赖)、配置与应用一起打包
  2. 将每个应用放到一个隔离容器去运行,避免互相干扰

在这里插入图片描述

本文将讲解如何使用Docker来部署我们平时用SpringBoot开发的项目:

在这里插入图片描述

Dockerfile

什么是 Dockerfile?

Dockerfile 是一个用来构建镜像的文本文件,文本内容包含了一条条构建镜像所需的指令和说明。

在这里插入图片描述

Dockerfile语法

构建自定义的镜像时,并不需要一个个文件去拷贝,打包。

我们只需要告诉Docker,我们的镜像的组成,需要哪些BaseImage、需要拷贝什么文件、需要安装什么依赖、启动脚本是什么,将来Docker会帮助我们构建镜像。

而描述上述信息的文件就是Dockerfile文件。

Dockerfile就是一个文本文件,其中包含一个个的指令(Instruction),用指令来说明要执行什么操作来构建镜像。每一个指令都会形成一层Layer。

在这里插入图片描述

打包SpringBoot项目

准备项目:

项目端口

server.port=8080

在templates文件夹下新建index.html

<!DOCTYPE html>
<html lang="en" xmlns:th="http://www.thymeleaf.org">
<head>
    <meta charset="UTF-8">
    <title>Docker部署SpringBoot应用</title>
</head>
<body>
<h1>Docker部署SpringBoot应用</h1>
<img src="/static/img/2.jpg" alt="" width="100%">
</body>
</html>

定义主页Controller,跳转到index

@Controller
public class indexController {

    @RequestMapping("/")
    public String index(){
        return "index";
    }
}

在本地预览效果:

在这里插入图片描述

在本地将SpringBoot应用打包成jar

准备maven-compiler-plugin插件

<build>
	<!--编译打包后的文件包名-->
	<finalName>app</finalName>
	<plugins>
		<plugin>
			<!--GAV坐标(G组织id,A项目id,V版本号)-->
			<groupId>org.apache.maven.plugins</groupId>
			<artifactId>maven-compiler-plugin</artifactId>
			<version>3.8.1</version>
			<!--配置:
		    一般而言,target与source是保持一致的,但是,有时候为了让程序能在其
		    他版本的jdk中运行(对于低版本目标jdk,源代码中不能使用低版本jdk中不
		    支持的语法),会存在target不同于source的情况-->
			<configuration>
				<!--源代码使用的JDK版本-->
				<source>1.8</source>
				<!-- 需要生成的目标class文件的编译版本 -->
				<target>1.8</target>
				<!-- 字符集编码,防止中文乱码 -->
				<encoding>UTF-8</encoding>
			</configuration>
		</plugin>
	</plugins>
</build>

maven是个项目管理工具,如果不告诉它代码要使用什么样的jdk版本编译,它就会用编译插maven-compiler-plugin默认的jdk版本来处理,这样就容易出现版本不匹配的问题,以至于可能导致编译不通过的问题。例如代码中要是使用上了Java8的新特性,比如函数式编程,但是maven在编译的时候使用的是Java7,那这一段代码是完全不可能编译成.class文件的。为了避免出现这种情况,在构建maven项目的时候,我习惯性第一步就是配置maven-compiler-plugin插件,指定项目源码的jdk 版本,编译后的 jdk 版本,以及编码方式。

然后执行clean,最后执行package进行项目打包

在这里插入图片描述

出现BUILD SUCCESS说明打包成功了

在这里插入图片描述

打包成功后会出现target文件夹,目录下就会有刚刚打包的jar包

在这里插入图片描述

准备jar包和Dockerfile

复制jar到桌面或自定义位置,在本地创建编写Dockerfile文件(注:名字必须为Dockerfile,去掉后缀名)

在这里插入图片描述

编写Dockerfile

Dockerfile指令

FROM java:8-alpine
COPY ./app.jar /tmp/app.jar
ENTRYPOINT java -jar /tmp/app.jar

Dockerfile说明

FROM java:8-alpine:

基于java8构建镜像,默认构建java镜像需要安装配置环境变量,而java:8-alpine这个镜像已经帮我们把前面的步骤都做完了

COPY ./app.jar /tmp/app.jar

复制jar包

ENTRYPOINT java -jar /tmp/app.jar

入口命令

使用工具将jar和Dockerfile上传到服务器

上传位置看个人,我存放的位置:/tmp/docker

cd tmp
mkdir docker

选择上传文件

在这里插入图片描述

上传到/tmp/docker目录下

在这里插入图片描述

构建镜像

进入上传文件的目录:cd /tmp/docker,输入ls查看文件

在这里插入图片描述

输入命令构建镜像

docker build -t test:1.0 .

格式:docker build -t 镜像名称:版本号 Dockerfile所在目录路径

命令说明:

build:docker的二级命令

  • 构建镜像

-t

  • -名称: 一般的镜像名称格式:名称:版本号(test:1.0)

.

  • Dockerfile所在目录,因为我们已经进入了Dockerfile所在的目录,.代表当前目录

可以看到构建镜像的时候会以我们编写Dockerfile的三条命令分为3个步骤执行

在这里插入图片描述

查看镜像

查看Docker中的镜像命令:

docker images

可以看到我们自定义镜像test

在这里插入图片描述

创建并运行容器

运行Docker镜像命令:

docker run --name springboot -p 8080:8080 -d test:1.0

命令说明:

docker run: docker二级命令

  • 创建并运行容器

--name

  • 定义容器名称,后面跟上容器名称(springboot)

-p端口映射

  • 左边端口为Linux的端口 ,右边为容器的端口号
  • 将linux端口映射在容器端口号上,这样访问linux端口等于访问容器端口号

-d

  • 后台运行容器 ,否则退出之后容器就会停止运行

test:1.0–>镜像名称

  • 选择自定义镜像test 的1.0版本来创建容器

创建并运行容器成功!

在这里插入图片描述

查看正在运行的镜像

正在运行的镜像命令

docker ps

在这里插入图片描述

浏览器访问服务器的8080端口

在这里插入图片描述

手机访问:

在这里插入图片描述

查看日志

查看容器日志命令

docker logs -f springboot

说明:

查看容器日志但是不是实时更新,想要查看新的日志还需要重复运行

docker logs + 容器名称

实时更新日志

docker logs -f + 容器名称

在这里插入图片描述

Docker部署SpringBoot应用教程结束!

到此这篇关于Docker部署SpringBoot应用的文章就介绍到这了,更多相关Docker部署SpringBoot应用内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

您可能感兴趣的文章:
  • SpringBoot 整合 Docker的详细过程
  • idea整合docker快速部署springboot应用的详细过程
  • Docker快速部署SpringBoot项目介绍

idea整合docker快速部署springboot应用的详细过程

idea整合docker快速部署springboot应用的详细过程

一、前言

容器化一词相信大家已经不陌生了,听到它我们可能会想到docker、k8s、jenkins、rancher等等。那么今天我来说一下idea如何使用docker快速部署springboot应用。

二、环境及工具

  • windows10(开发)
  • centos 7.6 (部署)
  • idea
  • docker
  • xshell

三、安装docker以及配置远程连接

安装docker步骤网上有很多,在这里还是再说一下:

先更新一波

sudo yum update

安装最新的docker

yum install docker -y

安装完如图所示

启动docker

systemctl start docker

使用docker images可以查看镜像状态,如下图所示代表启动成功(目前里面没有镜像)

在这里插入图片描述

如果是如下图所示,则代表启动失败

在这里插入图片描述

开启docker远程连接
编辑docker.service文件

vim /lib/systemd/system/docker.service

打开后,内容如下所示:

在这里插入图片描述

在绿色光标那一行添加如下:

# centos7及以上
ExecStart=/usr/bin/dockerd -H tcp://0.0.0.0:2375 -H unix://var/run/docker.sock
# centos7以下
ExecStart=/usr/bin/dockerd -H fd:// -H tcp://0.0.0.0:2375

这里我使用其他端口,如12377,改完后,内容如下图所示:

在这里插入图片描述

保存完毕后对配置文件进行重载,并重启docker:

systemctl daemon-reload 
systemctl restart docker

为了检查12377端口是否被监听,执行lsof -i:12377

在这里插入图片描述

如果使用的是云服务器则需要开启12377防火墙规则,如果使用默认的2375端口,只是虚拟机或者内网使用倒也无所谓,如果暴露在公网,估计第二天就会发现你的cpu爆满,挂载了大量马、矿程序,有时间的同学可以进一步配置安全配置,这里可以自行搜索。

四、idea连接远程docker

安装插件docker

在这里插入图片描述

配置连接
安装完毕后,找到setting中如下图位置

在这里插入图片描述

在TCP socket配置你的docker地址,格式如下:
tcp://ip:12377,填写完后,稍等一小会儿,下边会进行连接测试,连接成功后会如上图显示连接成功。 五、springboot项目配置docker pom配置
博主当前项目打包方式是jar包,pom中properties配置如下

<properties>
    <!--properties节点中设置docker镜像的前缀“springboot”-->
    <docker.image.prefix>springboot</docker.image.prefix>
</properties>

build中配置如下:

 <build>
        <finalName>docker-demo</finalName>
        <plugins>
            <plugin>
                <groupId>org.springframework.boot</groupId>
                <artifactId>spring-boot-maven-plugin</artifactId>
                <version>${spring-boot.version}</version>
            </plugin>
            <plugin>
                <!-- docker-maven插件-->
                <groupId>com.spotify</groupId>
                <artifactId>docker-maven-plugin</artifactId>
                <version>1.0.0</version>
                <configuration>
                    <dockerHost>http://ip:12377</dockerHost>
                    <imageName>${docker.image.prefix}/${project.artifactId}</imageName>
                    <dockerDirectory>src/main/docker</dockerDirectory>
                    <resources>
                        <resource>
                            <targetPath>/</targetPath>
                            <directory>${project.build.directory}</directory>
                            <include>${project.build.finalName}.jar</include>
                        </resource>
                    </resources>
                </configuration>
            </plugin>
        </plugins>
    </build>

resources是为了找到打好的jar,dockerDirectory是为了找到项目中配置的Dockerfile,imageName则是镜像名称

创建Dockerfile(注意Dockerfile不是驼峰命名)
结构如下图所示

在这里插入图片描述

Dockerfile文件内容:

FROM williamyeh/java8 # 源可以使用 docker search java8搜索得到的第一个源
VOLUME /tmp
ADD docker-demo.jar /app/docker-demo.jar
#COPY target/demo-0.0.1-SNAPSHOT.jar app.jar
ENTRYPOINT ["java", "-jar", "/app/docker-demo.jar"]

FROM :指定基础镜像,必须为第一个命令
VOLUME : 用于指定持久化目录
ADD : 将本地文件添加到容器中,tar类型文件会自动解压(网络压缩资源不会被解压),可以访问网络资源,类似wget
ENTRYPOINT : 配置容器,使其可执行化

其余指令可以自行搜索

  • 到此为止,需要的配置已经完成,接下来开始运行
  • 找到idea右侧的maven窗口,执行clean

在这里插入图片描述

clean完毕后再执行package进行打包

在这里插入图片描述

然后执行如图所示的docker:build

在这里插入图片描述

在这个过程中会在target目录下创建docker文件夹,并把Dockerfile文件和生成的jar包拷贝下来,然后根据Dockerfile中的配置拉取基础镜像,传送jar到服务器指定位置,再进行镜像制作。BUILD SUCCESS后点击idea底部的Services

在这里插入图片描述

窗口如下

在这里插入图片描述

双击Docker进行连接,连接成功后我们能够看到镜像和容器运行状况:

在这里插入图片描述

然后就可以右击springboot/**:latest镜像创建容器

在这里插入图片描述

弹出create选项,进行创建配置

在这里插入图片描述

在里面配置容器名称以及运行选项,最后点击run运行容器。在Services窗口中我们能够看到容器的运行日志:

在这里插入图片描述

到此为止,idea整合docker快速部署springboot应用便完成了,后边有空博主会总结下jenkins+k8s+docker的使用。

到此这篇关于idea整合docker快速部署springboot应用的文章就介绍到这了,更多相关idea docker部署springboot内容请搜索以前的文章或继续浏览下面的相关文章希望大家以后多多支持!

您可能感兴趣的文章:
  • Docker部署SpringBoot应用的实现步骤
  • SpringBoot 整合 Docker的详细过程
  • Docker快速部署SpringBoot项目介绍

关于k8s学习笔记2- Rancher2.x部署springboot应用及高可用、扩容的问题我们已经讲解完毕,感谢您的阅读,如果还想了解更多关于Docker 镜像编排并部署SpringBoot应用、Docker一键部署SpringBoot应用的方法,贼快贼好用!、Docker部署SpringBoot应用的实现步骤、idea整合docker快速部署springboot应用的详细过程等相关内容,可以在本站寻找。

本文标签: