Spring Boot 2.3.0用jib构建镜像
2020-06-01 本文已影响0人
EasyNetCN
Spring Boot 2.3.0发布了支持了build-image,但是由于墙的问题,本人一直没有尝试成功
jib(https://github.com/GoogleContainerTools/jib)是google发布的镜像构建工具,详细介绍和使用方法,可以看官方网站
注意事项
- 假如项目中存在多个包含main函数的类,需要指定运行主类
- 在mac中,假如出现安装了docker,但是提示为找到docker时,可以在mvn运行加上参数jib.dockerClient.executable=/usr/local/bin/docker
pom.xml中配置jib
<?xml version="1.0" encoding="UTF-8"?>
<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 http://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<groupId>cn.ydyun360</groupId>
<artifactId>ydyun360-app-service</artifactId>
<version>2.2.8.RELEASE</version>
<name>app service</name>
<properties>
<project.build.sourceEncoding>UTF-8</project.build.sourceEncoding>
<java.version>14</java.version>
<hikaricp.version>3.4.5</hikaricp.version>
<guava.version>29.0-jre</guava.version>
<logstash-logback-encoder.version>6.3</logstash-logback-encoder.version>
</properties>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.0.RELEASE</version>
</parent>
<repositories>
<repository>
<id>aliyun</id>
<url>http://maven.aliyun.com/nexus/content/groups/public/</url>
</repository>
</repositories>
<pluginRepositories>
<pluginRepository>
<id>aliyun</id>
<url>http://maven.aliyun.com/nexus/content/groups/public</url>
</pluginRepository>
</pluginRepositories>
<dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-dependencies</artifactId>
<version>Hoxton.SR5</version>
<type>pom</type>
<scope>import</scope>
</dependency>
</dependencies>
</dependencyManagement>
<dependencies>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-consul-all</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.cloud</groupId>
<artifactId>spring-cloud-starter-stream-kafka</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-webflux</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-jdbc</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-actuator</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-devtools</artifactId>
<optional>true</optional>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
</dependency>
<dependency>
<groupId>mysql</groupId>
<artifactId>mysql-connector-java</artifactId>
</dependency>
<dependency>
<groupId>org.apache.commons</groupId>
<artifactId>commons-lang3</artifactId>
</dependency>
<dependency>
<groupId>com.google.guava</groupId>
<artifactId>guava</artifactId>
<version>${guava.version}</version>
</dependency>
<dependency>
<groupId>net.logstash.logback</groupId>
<artifactId>logstash-logback-encoder</artifactId>
<version>${logstash-logback-encoder.version}</version>
</dependency>
</dependencies>
<build>
<plugins>
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
<configuration>
<executable>true</executable>
</configuration>
</plugin>
<plugin>
<groupId>com.google.cloud.tools</groupId>
<artifactId>jib-maven-plugin</artifactId>
<version>2.3.0</version>
<configuration>
<from>
<image>openjdk:14.0.1-slim</image>
</from>
<to>
<image>${project.artifactId}:${project.version}</image>
</to>
</configuration>
</plugin>
</plugins>
</build>
</project>
构建本地镜像
mvn compile jib:dockerBuild
启动运行容器,其中CONSUL_HOST,DB_HOST,DB_PORT,DB_USERNAME,DB_PASSWORD,KAFKA_BROKERS是在bootstrap.yml中自定义的变量(对应为consul.host,db.host,db.port,db.username,db.password,kafka.brokers),SPRING_CLOUD_CONSUL_DISCOVERY_IP_ADDRESS本身为Spring Cloud的配置
docker run --name app-service-local -p 8002:8002 -e CONSUL_HOST={consul地址} -e SPRING_CLOUD_CONSUL_DISCOVERY_IP_ADDRESS={用于服务发现的IP地址} -e DB_HOST={数据库地址} -e DB_PORT={数据库端口} -e DB_USERNAME={数据库用户名} -e DB_PASSWORD={数据库密码} -e KAFKA_BROKERS={kafka地址} --restart always -d app-service:2.2.8.RELEASE