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
重启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 smallchill@163.com
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>docker@163.com</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配合等等,后面再说吧。