Dockerfile
+ docker-compose
来构建docker容器travis-ci
+ github
来hook repo
的变更travis-ci
调用 Dockerfile
打包 docker image
并push到dockerhub
travis-ci
ssh 登陆到目标机器,copy docker-compose
并执行来完成部署因为项目是基于java
+gradle
来构建的,因此dockerfile
须要进行多阶段构建java
先build出fat-jar来:git
#以gradle 为基础构建build环境
FROM gradle:5.2.1-jdk8-alpine AS build-env
#copy源码
ADD --chown=gradle . /app
WORKDIR /app
#运行gradle task进行build
RUN gradle assemble --info
复制代码
将jar包copy到jre环境:github
FROM openjdk:8-jre
# 时区
RUN ln -sf /usr/share/zoneinfo/Asia/Shanghai /etc/localtime \
&& echo Asia/Shanghai > /etc/timezone \ && dpkg-reconfigure -f noninteractive tzdata # port EXPOSE 9000 #copy COPY --from=build-env /app/build/libs/xxx.jar /app/bin/xxx.jar #运行 CMD ["java", "-jar", "/app/bin/xxx.jar"] 复制代码
这里须要注意的是ADD
的时候要授予权限,不然gradle命令执行不了,多阶段构建须要声明--from
的上一个阶段,不然copy不到jar包。docker
version: '2'
services:
xxx-service:
image: xxx:latest
container_name: xxx
environment:
- JAVA_TOOL_OPTIONS=-Xms128m -Xmx256m
ports:
- "9000:8080"
复制代码
language: bash
services:
- docker
sudo: required
branches:
only:
- master
script:
- docker build . -t "xxx:latest"
- docker-compose -f docker-compose.yaml down
- docker-compose -f docker-compose.yaml up -d --force-recreate
- docker-compose -f docker-compose.yaml down
after_success:
- docker login --username=username -p="password" dockerhub
- docker push dockerhub:latest
- chmod 600 id_rsa
- scp -o "StrictHostKeyChecking no" -i id_rsa docker-compose.yml ubuntu@ip:/home/ubuntu/docker/
- ssh -o "StrictHostKeyChecking no" -i id_rsa ubuntu@ip "cd /home/ubuntu/docker/;sudo docker-compose -f docker-compose.yml pull;sudo docker-compose -f docker-compose.yml up -d;exit"
复制代码
分解一下:ubuntu
敏感信息这里能够经过Travis CI
的环境变量来设置,能够避免是公开仓库而泄露 ssh_key能够使用Travis CI
的加密key来避免泄露bash