101 lines
3.3 KiB
YAML
101 lines
3.3 KiB
YAML
kind: pipeline
|
|
type: docker
|
|
name: tunnel-cloud-web
|
|
platform:
|
|
os: linux
|
|
arch: amd64
|
|
steps:
|
|
- name: build-package
|
|
image: registry.cn-chengdu.aliyuncs.com/claywang/node:16.20.0
|
|
volumes:
|
|
- name: cache
|
|
path: /drone/src/node_modules
|
|
- name: build
|
|
path: /app/build
|
|
commands:
|
|
- export CI=false
|
|
- npm -v
|
|
- mkdir -p ./node_modules
|
|
- export NODE_MODULES_PATH=`pwd`/node_modules
|
|
# - npm config set registry https://registry.npm.taobao.org
|
|
- set NODE_OPTIONS=--openssl-legacy-provider
|
|
# - npm install
|
|
- npm run build
|
|
- echo $NODE_MODULES_PATH
|
|
- cp -r dist /app/build/$DRONE_REPO_NAME
|
|
- ls
|
|
|
|
|
|
|
|
- name: build-docker # 制作docker镜像
|
|
image: registry.cn-chengdu.aliyuncs.com/claywang/docker # 使用官方docker镜像
|
|
volumes: # 将容器内目录挂载到宿主机
|
|
- name: build
|
|
path: /app/build
|
|
- name: docker
|
|
path: /var/run/docker.sock # 挂载宿主机的docker
|
|
- name: config
|
|
path: /config
|
|
environment: # 获取到密文的docker用户名和密码
|
|
DOCKER_USERNAME:
|
|
from_secret: docker_username
|
|
DOCKER_PASSWORD:
|
|
from_secret: docker_password
|
|
REGISTRY:
|
|
from_secret: registry
|
|
REGISTRY_NAMESPACE:
|
|
from_secret: registry_namespace
|
|
commands: # 定义在Docker容器中执行的shell命令
|
|
- cat Dockerfile
|
|
- sed -i 's/$REGISTRY/'"$REGISTRY"'/' deployment.yml
|
|
- sed -i 's/$REGISTRY_NAMESPACE/'"$REGISTRY_NAMESPACE"'/' deployment.yml
|
|
- sed -i 's/$DRONE_REPO_NAME/'"$DRONE_REPO_NAME"'/' deployment.yml
|
|
- sed -i 's/$DRONE_COMMIT/'"$DRONE_COMMIT"'/' deployment.yml
|
|
# docker登录,不能在脚本中登录,并且不能使用docker login -u -p
|
|
- echo $DOCKER_PASSWORD | docker login $REGISTRY --username $DOCKER_USERNAME --password-stdin
|
|
- chmod +x docker.sh
|
|
- cat docker.sh
|
|
- sh docker.sh
|
|
# 执行完脚本删除本次制作的docker镜像,避免多次后当前runner空间不足
|
|
- docker rmi -f $(docker images | grep $DRONE_REPO_NAME | awk '{print $3}')
|
|
|
|
- name: drone-rancher # rancher运行
|
|
image: registry.cn-chengdu.aliyuncs.com/claywang/kubectl #阿里云的kubectl镜像,里面包含kubectl命令行工具
|
|
volumes: # 将容器内目录挂载到宿主机
|
|
- name: build
|
|
path: /app/build # 将应用打包好的Jar和执行脚本挂载出来
|
|
- name: config
|
|
path: /app/config # 将kubectl 配置文件挂载出来
|
|
commands: # 定义在Docker容器中执行的shell命令
|
|
# 将deployment中定义的变量替换为drone中的内置变量
|
|
- cat deployment.yml
|
|
# 通过kubectl指令运行deployment.yml,并指定授权文件kubectl_conf.yml
|
|
- kubectl --insecure-skip-tls-verify=true apply -f deployment.yml -n pro --kubeconfig=/app/config/tunnel-cloud-new.yaml
|
|
|
|
volumes:
|
|
- name: build
|
|
host:
|
|
path: /home/build/tunnel-cloud-web
|
|
- name: cache
|
|
host:
|
|
path: /home/npm/tunnel-cloud-web
|
|
- name: config # k8s对接的配置文件
|
|
host:
|
|
path: /home/kubect
|
|
- name: maven-cache # maven的缓存文件
|
|
host:
|
|
path: /home/data/maven/cache
|
|
- name: docker # 宿主机中的docker
|
|
host:
|
|
path: /var/run/docker.sock
|
|
|
|
# 定义触发条件
|
|
trigger:
|
|
branch:
|
|
- dev
|
|
|
|
|
|
|
|
event:
|
|
- push
|