使用gitlab構建基於docker的持續集成(三)


使用gitlab構建基於docker的持續集成(三)


 

 

構建發布思路:

1.構建單元測試鏡像,上傳鏡像倉庫。
2.拉取測試鏡像,執行單元測試。
3.構建發布鏡像,上傳鏡像倉庫。
4.使用docker-compose編排發布鏡像和數據庫鏡像,打包發布,我把項目也發布到了gitlab.luna.cn服務器

aspnetcore 下的dockerfile編寫

 

我的aspnetcore目錄結構

 

dockerfile的編寫,參考了dotnet官方的例子,是用分層配置,這樣只要寫一個dockerfile就可以了。

 

FROM microsoft/dotnet:2.0-sdk AS build
WORKDIR /app 
# copy csproj and restore as distinct layers
COPY *.sln . COPY User.Api/*.csproj ./User.Api/ COPY User.Api.UnitTest/*.csproj ./User.Api.UnitTest/ RUN dotnet restore 
# copy everything else and build app
COPY . . WORKDIR /app//User.Api RUN dotnet build 

FROM build AS testrunner
WORKDIR /app/User.Api.UnitTest ENTRYPOINT ["dotnet", "test", "--logger:trx"] 

FROM build AS publish
WORKDIR /app/User.Api RUN dotnet publish -c Release -o out 
FROM microsoft/aspnetcore:2.0 AS runtime
WORKDIR /app ENV ASPNETCORE_URLS http://+:80
EXPOSE 80
COPY --from=publish /app/User.Api/out ./
ENTRYPOINT ["dotnet", "User.Api.dll"] 

發布docker-compose

version: '3'

services: user.api: image: gitlab.luna.cn/lunaselene/findbook.first/master:release container_name: user.api ports: - '8080:80' links: - mysql-bate mysql-bate: image: 'mysql/mysql-server:5.7' restart: always container_name: mysql-bate volumes: - ./mysql/data:/var/lib/mysql - ./mysql/config/my.cnf:/etc/my.cnf - ./mysql/init:/docker-entrypoint-initdb.d/ ports: - '3306' 

gitlab-ci.yml的編寫

 

gitlab環境變量的設定

 

安裝構建思路,對應的yml文件如下

 

image: tico/docker
variables:
  CONTAINER_TEST_IMAGE: $CI_REGISTRY_IMAGE/$CI_COMMIT_REF_NAME:test
  CONTAINER_RELEASE_IMAGE: $CI_REGISTRY_IMAGE/$CI_COMMIT_REF_NAME:release
  DOCKER_DRIVER: overlay2

before_script:
  - docker login -u gitlab-ci-token -p $CI_JOB_TOKEN $CI_REGISTRY   #下面是登錄遠程服務器的設置sshkey操作
   # 其中私有變量$SSH_PRIVATE_KEY 是遠程服務器的ssh私匙
   # 我使用的部署gitlab的服務器所以url是gitlab.luna.cn
  - eval $(ssh-agent -s)   - ssh-add <(echo "$SSH_PRIVATE_KEY")   - mkdir -p ~/.ssh   - chmod 700 ~/.ssh   - ssh-keyscan gitlab.luna.cn > ~/.ssh/known_hosts   - chmod 644 ~/.ssh/known_hosts   - ssh -T root@gitlab.luna.cn stages:
  - build   - test   - release   - deploy 
build:
  stage: build
  script:
   - docker build --target testrunner --pull -t $CONTAINER_TEST_IMAGE .    - docker push $CONTAINER_TEST_IMAGE 
test:
  stage: test
  script:
    - docker pull $CONTAINER_TEST_IMAGE     - docker run $CONTAINER_TEST_IMAGE     - docker rm $(docker ps -q -l) 
release:
  stage: release
  script:
    - docker build --target runtime --pull -t $CONTAINER_RELEASE_IMAGE .     - docker push $CONTAINER_RELEASE_IMAGE   only:
    - master 
deploy:
  stage: deploy
  script:
    - scp -r mysql root@gitlab.luna.cn:/root/deploy     - scp docker-compose.yml root@gitlab.luna.cn:/root/deploy     - ssh root@gitlab.luna.cn "docker-compose --f /root/deploy/docker-compose.yml up -d --force-recreate "     - echo "Deploy to staging server"   only:
    - master 

一些參數的解釋

image

代表要使用的基礎docker鏡像,一切構建都是在這個鏡像下完成,也就是一個大環境,后面的命令必須要能在這個環境下能執行。
我指定這個是一個自帶docker環境的鏡像,它的信息可以到docker hub上查看。

variables

自定義變量,后面跟的是自定義的變量,$CI_REGISTRY_IMAGE等變量是gitlab-runner自帶的變量。

before_script

前置腳本,也就是每個stages運行之前都會執行的命令。

stages

定義CI每個步驟,這個步驟是一個執行完才執行下一個的,上一個失敗,全部失敗。

關於遠程發布ssh的補充

由於要全自動化發布,必須實現runner所在服務器和遠程發布主機的無密登錄。
ssh無密碼登錄,分為單向和雙向,這里用單向的就可以了。
因為使用的是docker in docker 的方式運行runner,所以秘鑰通過gitlab的環境變量進行傳遞。

1.遠程主機生成ssh秘鑰。

ssh-keygen -t rsa 

命令輸完一直回車到完成為止。
2.遠程主機中把公鑰設置到authorized_keys。

cd /root/.ssh
cat id_rsa.pub > authorized_keys

3.把私鑰設置成環境變量。
私鑰設置成環境變量
4.gitlab-ci.yml中給運行的容器設置runner私鑰。

  #下面是登錄遠程服務器的設置sshkey操作
   # 其中私有變量$SSH_PRIVATE_KEY 是遠程服務器的ssh私匙
   # 我使用的部署gitlab的服務器所以url是gitlab.luna.cn
  - eval $(ssh-agent -s)   - ssh-add <(echo "$SSH_PRIVATE_KEY")   - mkdir -p ~/.ssh   - chmod 700 ~/.ssh   - ssh-keyscan gitlab.luna.cn > ~/.ssh/known_hosts   - chmod 644 ~/.ssh/known_hosts   - ssh -T root@gitlab.luna.cn 

這樣遠程服務器的連接就設置完成了。

提交測試

 

build

 

 

 

test

 

 

 

release

 

 

 

deploy

 

 

 

全部通過

 

 

 

查看發布情況

 

 

 

本地訪問查看

 

 


免責聲明!

本站轉載的文章為個人學習借鑒使用,本站對版權不負任何法律責任。如果侵犯了您的隱私權益,請聯系本站郵箱yoyou2525@163.com刪除。



 
粵ICP備18138465號   © 2018-2025 CODEPRJ.COM