gitlab 下spring Cloud持續集成配置

前提

有gitlab 環境, 目標機器有java運行環境
複製代碼

1、安裝gitlab-runner

docker run -d --name gitlab-runner --restart always -v $PWD/config:/etc/gitlab-runner -v /var/run/docker.sock:/var/run/docker.sock gitlab/gitlab-runner:latest
複製代碼

2、添加執行器

docker exec -it gitlab-runner gitlab-ci-multi-runner register -n \
  --url http://192.168.1.4:8100/ \
  --registration-token -LC6aAyNAQ8MLk_9SYQS \
  --tag-list=cloudgateway \
  --description "spring Cloud gateway demo" \
  --docker-privileged=true \
  --docker-pull-policy="if-not-present" \
  --docker-image "docker:latest" \
  --docker-volumes /var/run/docker.sock:/var/run/docker.sock \
  --docker-volumes /root/m2:/root/.m2 \
  --executor docker 
複製代碼

注意其中java

registration-token
git

tag-list 默認執行器須要tag才運行,因此指定(settings/ci/cd對應的執行器能夠看到默認是須要的)spring

3、.gitlab-ci.yml 配置

  • gitlab 所在執行器添加密鑰docker

    docker exec –it gitlab-runner /bin/shbash

    ssh-keygen -t rsassh

    scp -P 68 ~/.ssh/id_rsa.pub root@192.168.1.4:/root/.ssh/authorized_keys (P端口指定要大寫)maven

  • 配置gitlab ci環境變量 gitlab

    此變量爲執行器ssh的私鑰 必須包含頭尾的"--- "內容

  • .gitlab-ci.yml 內容ui

variables:
  PACKAGE_JAR: "springCloud2.x-gateway-0.0.1-SNAPSHOT"

stages:
  - build
  - run
  
build:
  image: maven:3-jdk-8
  stage: build
  tags:
    - cloudgateway
  script: "mvn package -B -Dmaven.test.skip=true"
  artifacts:
    paths:
      - target/*.jar

deploy_qa:
  image: maven:3-jdk-8			#此鏡像包含ssh相應命令
  stage: run
  tags:			#對應的執行起默認須要個tag
    - cloudgateway
  before_script:  #全局的話每一個步驟都會執行
    - eval $(ssh-agent -s)
    # 清除一些系統中複製出現的換行符\r,並重定向到/dev/null防止泄露
    - echo "$SSH_PRIVATE_KEY" | tr -d '\r' | ssh-add - > /dev/null
    # 建立~/.ssh目錄,並配置權限(非root運行的runner)
    - mkdir -p ~/.ssh
    - chmod 700 ~/.ssh
    - ssh-keyscan 192.168.1.4 >> ~/.ssh/known_hosts
    - chmod 644 ~/.ssh/known_hosts
  script:
    - scp -o StrictHostKeyChecking=no -P 68 target/$PACKAGE_JAR.jar root@192.168.1.4:/home/work/
    - scp -o StrictHostKeyChecking=no -P 68 entry.sh root@192.168.1.4:/home/work/
    #-o StrictHostKeyChecking=no 禁止命令行詢問密碼 work 目錄給與執行權限chmod 777 work/*
    - ssh -o StrictHostKeyChecking=no -p 68 root@192.168.1.4 "cd /home/work/ ; ./entry.sh"  
複製代碼
相關文章
相關標籤/搜索