coding概述:提供一站式开发协作工具,帮助研发团队快速落地敏捷开发与 DevOps 开发方式,实现研发效能升级
一、创建项目
省略 详细文档:https://g-mnbk6665.coding.net/quickstart
二、SSH连接
关于ssh相关命令
重启SSH服务
systemctl restart sshd
开机自动启动ssh命令
sudo systemctl enable sshd
关闭ssh开机自动启动命令
sudo systemctl disable ssh
单次开启ssh
sudo systemctl start ssh
单次关闭ssh
sudo systemctl stop ssh
设置好后重启系统
查看ssh是否启动,看到Active: active (running)即表示成功
sudo systemctl status sshd
 
ssh-keygen -t rsa
 

cd /root/.ssh
 
生成了三个文件:
authorized_keys:存放远程免密登录的公钥,主要通过这个文件记录多台机器的公钥id_rsa : 生成的私钥文件id_rsa.pub : 生成的公钥文件
进入id_rsa.pub文件,并将里面的内容全部拷贝到authorized_keys文件中保存
cat id_rsa.pub
vim authorized_keys
 
再查看私钥 id_rsa 内容并全部复制:配置coding即可
cat id_rsa
 

三、SpringBoot
持续集成
关联项目,结合自己项目进行关联
选择Spring+Docker模板

变量配置信息
构建方式有很多种 (分支,标签,版本号)
3.1 多环境配置
配置你的环境,可打包时选择相应环境
至此持续集成就完成了,但要考虑logs文件的保留问题,可通过脚本Copy到备份文件夹
3.2 Dockerfile
方式一
# 基础镜像
FROM  openjdk:8-jre
# author
MAINTAINER zxht
# 东八区
ENV TZ='Asia/Shanghai'
# 挂载目录
VOLUME /home/service
# 创建目录
RUN mkdir -p /home/service
# 指定路径
WORKDIR /home/service
# 复制jar文件到路径
COPY ./mes-web/target/mes.jar /home/service/mes.jar
# 启动系统服务
ENTRYPOINT ["java","-jar","mes.jar"]
方式二
FROM coding-public-docker.pkg.coding.net/public/docker/openjdk:8
COPY ./mes-web/target/mes.jar /root/workspace/mes.jar
CMD ["java", "-jar", "mes.jar"]
 
3.3 静态Jenkinsfile
pipeline {
  agent any
  stages {
    stage('检出') {
      steps {
        checkout([$class: 'GitSCM',
        branches: [[name: GIT_BUILD_REF]],
        userRemoteConfigs: [[
          url: GIT_REPO_URL,
          credentialsId: CREDENTIALS_ID
        ]]])
      }
    }
    stage('编译') {
      steps {
        sh 'mvn clean install -e -U -P ${PROFILES}'
      }
    }
    stage('构建镜像并推送到 CODING Docker 制品库') {
      steps {
        script {
          docker.withRegistry(
            "${CCI_CURRENT_WEB_PROTOCOL}://${CODING_DOCKER_REG_HOST}",
            "${CODING_ARTIFACTS_CREDENTIALS_ID}"
          ) {
            def dockerImage = docker.build("${CODING_DOCKER_IMAGE_NAME}:${DOCKER_IMAGE_VERSION}", "-f ${DOCKERFILE_PATH} ${DOCKER_BUILD_CONTEXT}")
            dockerImage.push()
          }
        }
      }
    }
    stage('部署到远端服务') {
      steps {
        script {
          def remoteConfig = [:]
          remoteConfig.name = "my-remote-server"
          remoteConfig.host = "${REMOTE_HOST}"
          remoteConfig.port = "${REMOTE_SSH_PORT}".toInteger()
          remoteConfig.allowAnyHosts = true
          withCredentials([
            sshUserPrivateKey(
              credentialsId: "${REMOTE_CRED}",
              keyFileVariable: "privateKeyFilePath"
            ),
            usernamePassword(
              credentialsId: "${CODING_ARTIFACTS_CREDENTIALS_ID}",
              usernameVariable: 'CODING_DOCKER_REG_USERNAME',
              passwordVariable: 'CODING_DOCKER_REG_PASSWORD'
            )
          ]) {
            // SSH 登录用户名
            remoteConfig.user = "${REMOTE_USER_NAME}"
            // SSH 私钥文件地址
            remoteConfig.identityFile = privateKeyFilePath
            // 请确保远端环境中有 Docker 环境
            sshCommand(
              remote: remoteConfig,
              command: "docker login -u ${CODING_DOCKER_REG_USERNAME} -p ${CODING_DOCKER_REG_PASSWORD} ${CODING_DOCKER_REG_HOST}",
              sudo: true,
            )
            sshCommand(
              remote: remoteConfig,
              command: "docker rm -f mes | true",
              sudo: true,
            )
            // DOCKER_IMAGE_VERSION 中涉及到 GIT_LOCAL_BRANCH / GIT_TAG / GIT_COMMIT 的环境变量的使用
            // 需要在本地完成拼接后,再传入到远端服务器中使用
            DOCKER_IMAGE_URL = sh(
              script: "echo ${CODING_DOCKER_REG_HOST}/${CODING_DOCKER_IMAGE_NAME}:${DOCKER_IMAGE_VERSION}",
              returnStdout: true
            )
            sshCommand(
              remote: remoteConfig,
              command: "docker run -d -p 8999:8999 --name mes ${DOCKER_IMAGE_URL}",
              sudo: true,
            )
            echo "部署成功,请到 http://${REMOTE_HOST}:8999/mes/doc.html#/home"
          }
        }
      }
    }
  }
  environment {
    CODING_DOCKER_REG_HOST = "${CCI_CURRENT_TEAM}-docker.pkg.${CCI_CURRENT_DOMAIN}"
    CODING_DOCKER_IMAGE_NAME = "${PROJECT_NAME.toLowerCase()}/${DOCKER_REPO_NAME}/${DOCKER_IMAGE_NAME}"
  }
}
 
四、持续集成 Vue
1.关联仓库后选择模板
2.本次使用的是ssh连接当然也可以选择账户+密码
3.创建制品仓Generic类型存储dist压缩包
变量和缓存
流程配置信息的几个说明点
1.这是创建的制品名称
2.指定Node版本
3.注意你的存放Nginx和文件路径一致否则依赖加载不到
// 服务器远程地址
def remotePath = "/www/wwwroot/kblogs"
 
pipeline {
  agent any
  stages {
    stage('检出') {
      steps {
        checkout([$class: 'GitSCM',
        branches: [[name: GIT_BUILD_REF]],
        userRemoteConfigs: [[
          url: GIT_REPO_URL,
          credentialsId: CREDENTIALS_ID
        ]]])
      }
    }
    stage('安装依赖') {
      steps {
        sh 'npx -p node@16.20.2 npm install'
      }
    }
    stage('执行构建') {
      steps {
        echo '开始构建'
        sh 'npx -p node@16.20.2 npm run build'
        echo '构建完成'
      }
    }
    stage('压缩制品Dist') {
      steps {
        echo '压缩中...'
        sh 'tar -zcf dist.tar.gz -C ./src/.vuepress/ dist'
        echo '压缩完成.'
        sh 'ls'
      }
    }
    stage('上传制品') {
      steps {
        echo '开始上传'
        codingArtifactsGeneric(files: 'dist.tar.gz', repoName: 'blogs', version: '${env.GIT_BUILD_REF}')
      }
    }
    stage('部署至服务器') {
      steps {
        script {
          def remote= [:]
          remote.name = "my-remote-server"
          remote.host = "${REMOTE_HOST}"
          remote.allowAnyHosts = true
          // 服务器远程地址
          def remotePath = "/www/wwwroot/kblogs"
          withCredentials([sshUserPrivateKey(
            credentialsId: "${REMOTE_CRED}",
            keyFileVariable: "privateKeyFilePath"
          )]) {
            remote.user = "${REMOTE_USER_NAME}"
            // SSH 私钥文件地址
            remote.identityFile = privateKeyFilePath
            stage("执行ssh脚本") {
              echo '开始执行脚本'
              sshCommand remote: remote, sudo: false, command: "rm -rf ${remotePath}/*"
              sshCommand remote: remote, command: "mkdir -p /www/wwwroot/kblogs/ && touch /www/wwwroot/kblogs/dist.tar.gz"
              sshPut remote: remote, from: './dist.tar.gz', into:remotePath + "/dist.tar.gz"                // SSH 上传文件到远端服务器
              sshCommand remote: remote, command: "tar -zxf ${remotePath}/dist.tar.gz -C ${remotePath}"     // 解压缩
              sshCommand remote: remote, sudo: false, command: "rm -f ${remotePath}/*.tar.gz"              // 删除压缩文件
              sshCommand remote: remote, sudo: false, command: "mv ${remotePath}/dist/* ${remotePath}"    //将dist文件夹所有内容移动到上一级
              sshCommand remote: remote, sudo: false, command: "rm -rf ${remotePath}/dist"    //将dist文件夹所有内容移动到上一级
              echo '脚本执行结束'
            }
          }
        }
      }
    }
  }
}
                


















