Jenkins builds Docker images and pushes them to Harbor warehouse

Jenkins builds Docker images and pushes them to Harbor warehouse

The spring boot project uses Jenkins to build a Docker image, push it to the harbor repository, start the container, and then pull the image to the local running container.

Dockerfile

Location: in the root directory, at the same level as src

FROM java:8
 # Author: MAINTAINER zhaoyc
VOLUME /tmp
#ARG JAR_FILE
#Add the jar package to the container and rename it to app.jar
ADD target/*.jar app.jar
RUN bash -c 'touch /app.jar'
ENV TZ=Asia/Shanghai
#RUN ln -snf /usr/share/zoneinfo/$TZ /etc/localtime && echo $TZ > /etc/timezone
EXPOSE 81
#CMD ["-jar", "/app.jar"] "nohup" "&"
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app.jar"]

pom.xml

To specify the Maven version number as 1.4.2, other versions have not been tested, otherwise the main-class cannot be found

<plugins>
 <!-- mavn jar package startup plug-in -->
	<plugin>
		<groupId>org.springframework.boot</groupId>
		<artifactId>spring-boot-maven-plugin</artifactId>
		<version>1.4.2.RELEASE</version>
	</plugin>
</plugins>

Jenkins Configuration

System settings configuration docker – need to install Docker plugin

insert image description here

Create a new Maven project configuration parameter build

insert image description here

Project git repository configuration

insert image description here

mvn build buile configuration

insert image description here

Build the Docker image and push it to the repository configuration

insert image description here

Execute the script after pushing to the repository

#!/bin/bash
#IMAGE=${module_filename}
#TAG=${Tag}
IMAGE=$1
TAG=$2
PULL_IMAGE=192.168.1.100:81/project/${IMAGE}:${TAG}
# Calculate subtraction and output with 0 in front of the decimal point, such as 0.3-0.1=0.2
CURRENT_IAMGE=`echo "$TAG - 0.1" | bc | awk '{printf "%.1f", $0}'`

echo '================Start logging into Harbor warehouse================'
docker login http://192.168.1.100:81 -u admin -p Harbor12345

if [ $? -eq 0 ]; then
    echo '================Login successful================='
else
    echo '================Login failed================='
    return 1
fi

echo '================Start pulling image================'
docker pull ${PULL_IMAGE}
echo '================End of pulling image================'

# Update container operation echo '================Stop running the image================'
docker stop ${IMAGE}_${CURRENT_IAMGE}
echo "wait 10 seconds"
sleep 10

echo '================Start starting mirror================'
#if [ ${IMAGE} == "java-demo" ]; then
# docker run -d --name ${IMAGE}_${TAG} -p 9001:9001 ${PULL_IMAGE}
#elif [ ${IMAGE} == "spring-cloud-eureka-client-demo" ]; then
# docker run -d --name ${IMAGE}_${TAG} -p 9012:9012 ${PULL_IMAGE}
#fi
docker run -d --name ${IMAGE}_${TAG} -p 9001:9001 ${PULL_IMAGE}
if [ $? -eq 0 ]; then
    echo '================Mirroring started successfully================'
else
    echo '================Mirror startup failed================'
    return 1
fi

This is the end of this article about how Jenkins builds Docker images and pushes them to the Harbor repository. For more information about how Jenkins builds Docker images, please search for previous articles on 123WORDPRESS.COM or continue to browse the following related articles. I hope you will support 123WORDPRESS.COM in the future!

You may also be interested in:
  • How to use Docker buildx to build multi-platform images and push them to private repositories
  • Use Docker to build a Git image using the clone repository
  • How to use domestic image warehouse for Docker
  • docker-maven-plugin packages the image and uploads it to a private warehouse
  • How to use Docker image repository
  • Alibaba Cloud deployment steps for Docker private image repository
  • Docker container practice image warehouse

<<:  Prometheus monitors MySQL using grafana display

>>:  HTML form application includes the use of check boxes and radio buttons

Recommend

Vue routing lazy loading details

Table of contents 1. What is lazy loading of rout...

52 SQL statements to teach you performance optimization

1. To optimize the query, try to avoid full table...

How to delete table data in MySQL

There are two ways to delete data in MySQL, one i...

How to optimize images to improve website performance

Table of contents Overview What is Image Compress...

26 Commonly Forgotten CSS Tips

This is a collection of commonly used but easily ...

Today I will share some rare but useful JS techniques

1. Back button Use history.back() to create a bro...

react-beautiful-dnd implements component drag and drop function

Table of contents 1. Installation 2.APi 3. react-...

Example of implementing dynamic verification code on a page using JavaScript

introduction: Nowadays, many dynamic verification...

Detailed explanation of HTML area tag

The <area> tag defines an area in an image ...

MySQL 5.7.18 release installation guide (including bin file version)

The installation process is basically the same as...

In-depth understanding of Vue transition and animation

1. When inserting, updating, or removing DOM elem...

Summary of block-level elements, inline elements, and variable elements

Block element p - paragraph pre - format text tabl...

Vue.js performance optimization N tips (worth collecting)

Table of contents Functionalcomponents Childcompo...

iframe parameters with instructions and examples

<iframe src=”test.jsp” width=”100″ height=”50″...