1 準備工作:
1.1 搭建harbor
因為harbor是基于docker的,并且依賴于docker-compose,是以先要準備好dockers環境再安裝好compose工具
1.1.1 docker安裝,相關資料很多了,稍微記一下步驟
1.1.1.1 清除舊版本
$ yum update //可以先更新下yum
$ yum remove docker \
docker-client \
docker-client-latest \
docker-common \
docker-latest \
docker-latest-logrotate \
docker-logrotate \
docker-engine
1.1.1.2 設定倉庫(官方的比較慢,也可以不設定)
$ yum-config-manager \
--add-repo \
http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
1.1.1.3 安裝Docker Engine-Community(這裡預設最新的版本,也可以根據需要安裝指定版本)
$ yum install docker-ce docker-ce-cli containerd.io
1.1.1.4 檢視一下版本
1.1.2安裝Docker Compose(可以通過YML檔案配置并啟動服務)
1.1.2.1 這裡用的daocloud的提供的版本,github有點慢
$ curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
1.1.2.2 設定下權限
$ chmod +x /usr/local/bin/docker-compose
1.1.2.3 檢視下版本
啟動docker
$ systemctl start docker
1.1.3 harbor安裝
1.1.3.1 去官網下載下傳安裝包
這裡是用的1.9.4版本,位址
https://storage.googleapis.com/harbor-releases/release-1.9.0/harbor-offline-installer-v1.9.4.tgz
網速好的話可以直接wget
$ wget https://storage.googleapis.com/harbor-releases/release-1.9.0/harbor-offl ine-installer-v1.9.4.tgz
1.1.3.2 解壓縮
$ tar xvzf harbor-offline-installer-v1.9.4.tgz
1.1.3.3 修改配置檔案,這裡主要修改下hostname
$ cd harbor
$ vi harbor.yml
hostname: 你的ip
# http related config
http:
# port for http, default is 80. If https enabled, this port will redirect to https port
port: 80-這裡我用maven推送好像必須是80端口
1.1.3.4 初始化并啟動harbor
$ ./install.sh
1.1.3.4 檢視狀态
預設賬号amin 密碼Harbor12345進入添加一下項目資訊,使用者資訊
1.1.3.5 修改docker配置
docker1.3.2版本後推送的倉庫預設是https協定,是以需要修改下配置
$ vim /etc/docker/daemon.json
如果你是在另一台伺服器來推送鏡像到目前伺服器,需要開放docker的2375端口,防火牆自行處理一下
$ vi /lib/systemd/system/docker.service
在[Service]節點下方增加 ExecStart = ExecStart =/ usr / bin / dockerd - H tcp : // 0.0.0.0 : 2375 - H unix : // var / run / docker . sock
重新開機docker
$ systemctl daemon-reload && systemctl restart docker
重新開機 harbor
$ docker-compose stop // harbor 路徑下執行
$ docker-compose start
防火牆改一下
$ firewall-cmd --add-port=2375/tcp --permanent
$ service firewalld restart
1.1.3.6 測試一下子
$ docker pull nginx //拉一個nginx
$ docker login 192.168.0.111 //你的harbor伺服器ip
Username: admin
Password:
登陸成功後,對鏡像打标簽,推送至倉庫
$ docker tag [ImageId] harborIp/項目空間:[鏡像版本号] //打标簽
$ docker tag 8n8n8n8n8n 192.168.0.111/blade/nginx:v2 //例子 blade項目需要提前建好,配制好權限
$ docker push harborIp/項目空間:[鏡像版本号] // 推送至harbor
$ docker push 192.168.0.111/blade/nginx:v2 //例子
檢視一下
1.2 建立一個SpringBoot測試項目
1.2.1 https://start.spring.io/ 生成一個項目用例
1.2.2 導入idea,寫一個測試接口
1.2.3 運作一下
2 至此準備工作算是差不多了,剩下的就是配置一些檔案推送鏡像
2.1 項目根目錄建一個Dockerfile,内容參考如下
FROM adoptopenjdk/openjdk8-openj9:alpine-slim
EXPOSE 8080
MAINTAINER [email protected]
WORKDIR app
ADD ./target/demo-latest.jar /app/app.jar
ENTRYPOINT ["java","-Djava.security.egd=file:/dev/./urandom","-jar","/app/app.jar"]
FROM: 運作jar包需要java環境,這裡選的adoptopenjdk/openjdk8-openj9:alpine-slim 鏡像
EXPOSE 聲明對外端口
WORKDIR 指定工作目錄
ADD 類似于COPY
ENTRYPOINT 類似于CMD指令
2.2 修改pom 檔案,這裡用的是dockerfile-maven-plugin,完整配置檔案
<?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 https://maven.apache.org/xsd/maven-4.0.0.xsd">
<modelVersion>4.0.0</modelVersion>
<parent>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-parent</artifactId>
<version>2.3.3.RELEASE</version>
<relativePath/> <!-- lookup parent from repository -->
</parent>
<groupId>com.docker</groupId>
<artifactId>demo</artifactId>
<version>latest</version>
<name>demo</name>
<description>Demo project for Spring Boot</description>
<properties>
<java.version>1.8</java.version>
<docker.username>harbor賬号</docker.username>
<docker.password>harbor賬号密碼</docker.password>
<docker.registry.url>harbor ip</docker.registry.url>
<docker.namespace>blade</docker.namespace>
</properties>
<dependencies>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-web</artifactId>
</dependency>
<dependency>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-starter-test</artifactId>
<scope>test</scope>
<exclusions>
<exclusion>
<groupId>org.junit.vintage</groupId>
<artifactId>junit-vintage-engine</artifactId>
</exclusion>
</exclusions>
</dependency>
</dependencies>
<build>
<plugins>
<!--打包 jar-->
<plugin>
<groupId>org.springframework.boot</groupId>
<artifactId>spring-boot-maven-plugin</artifactId>
</plugin>
<!--利用dockerfile-maven-plugin 推送鏡像-->
<plugin>
<groupId>com.spotify</groupId>
<artifactId>dockerfile-maven-plugin</artifactId>
<configuration>
<username>${docker.username}</username>
<password>${docker.password}</password>
<repository>${docker.registry.url}/${docker.namespace}/${project.artifactId}</repository>
<tag>${project.version}</tag>
<useMavenSettingsForAuth>true</useMavenSettingsForAuth>
<buildArgs>
<JAR_FILE>target/${project.build.finalName}.jar</JAR_FILE>
</buildArgs>
<skip>false</skip>
</configuration>
</plugin>
</plugins>
</build>
</project>
2.3 因為用的是useMavenSettingsForAuth,是以還需要修改一下對應的maven配置檔案
位置 /apache-maven-3.6.3/conf/settings.xml
2.3.1 添加一個server
<servers>
<server>
<id>192.168.0.157</id>
<username>harbor賬号</username>
<password>harbor密碼</password>
<configuration>
<email>[email protected]</email>
</configuration>
</server>
</servers
2.3.2 添加一個pluginGroups
<pluginGroups>
<pluginGroup>com.spotify</pluginGroup>
</pluginGroups>
2.3.3 項目根目錄下執行--等待結果,第一次時間會比較長
$ mvn clean package dockerfile:build dockerfile:push
整個過程提示資訊還是很全的,如果有報錯,可以去針對性的去處理
2.3.4 看一下倉庫,已經有了
用鏡像跑一個
docker run -d -p 8080:8080 192.168.1.111/blade/demo
外網通路一下:
至此,整個流程算是跑完了,但是需要做的事情還是挺多的。拉取新的鏡像後,舊的鏡像怎麼處理,停掉的容器怎麼清理。如何和jenkins配合等等,後面再說吧。