腾讯系持续集成(CI)方案

术语概念

构建计划( Job ):作为持续集成流程的基本单元,每个Job都代表一个步骤,可配置代码源、构建流程、触发规则、环境变量、通知提醒等信息。

快速上手

图形化配置:具体参考官方文档,易用性高
Jenkinfile灵活配置:提前写好Jenkinsfile放到项目最外层(与.git同级),在Coding选择[配置来源] -> [使用代码库的{你编写的Jenkinfile名称}]

官方文档
持续集成文档
流水线语法

流水线入门

下面指令按照层级进行介绍,每个子级必须包括在父级的大括号里面

  1. pipeline:声明一条流水线,必须编写并包裹在最外层
    1. agent:代理,指定执行流水线的容器
      1. docker: 在Docker内执行流水线
        1. image <镜像名称>:指定Docker镜像
        2. args <参数>:指定运行Docker时的参数
      2. dockerfile:先构建Docker镜像再在容器中执行流水线
        1. filename <文件名>:指定dockerfile的文件名,如果不指定则默认’dockerfile’
        2. dir <文件夹>:指定构建镜像的路径(影响dockerfile获取文件)
    2. stages:阶段集合(据作者测试没有实际作用,但必须声明否则报错)
      1. stage(name):阶段,name指定阶段名称。
        1. when:条件,指定执行阶段的条件
          1. branch <分支>:判断当前构建的代码分支是否与指定的相同
        2. steps:步骤,包含一条或多条命令,按顺序执行
          1. sh <shell命令>:执行命令,命令要用单引号包裹
          2. junit <Junit配置路径>:调用Jenkins的测试插件(Junit配置)
          3. script:
          4. archiveArtifacts: 收集构建产物,指定的文件会在构建结束后展示在[构建产物]中
          5. dir(path: <目录路径>):跳转至该目录再执行步骤,(步骤只执行dir内部包含的)
        3. parallel: 并行,包含多个阶段,所包含阶段会并行执行
    3. post:当每个流水线或阶段结束后都会执行一次
      1. <条件>:always(成功或失败都执行),changed(状态与前一次不同时执行),failure(失败时执行),success(成功时执行)
    4. environment:全局变量,在任一步骤中通过变量名进行引用。也可以声明在阶段内部作为局部变量使用。
      1. 变量名 = 变量值

例子

pipeline { 		 // 声明流水线
 agent any    	 // 设置代理
  stages {			 // 阶段集合
    stage('检出') {	// 阶段1
      steps {	// 步骤
        checkout([	// 从git仓库读取(这段基本不修改,环境变量会由Coding注入)
          $class: 'GitSCM', branches: [[name: env.GIT_BUILD_REF]],
          userRemoteConfigs: [[
            url: env.GIT_REPO_URL,
            credentialsId: env.CREDENTIALS_ID
          ]]
        ])
      }
    }
    stage('构建') { // 阶段2
      steps {	//步骤
        sh 'mvn install -Dmaven.test.skip -s ./setting.xml'	//执行Shell命令
      }
    }
    stage('发布') {
      steps {
        sh 'mvn deploy -s ./setting.xml‘
      }
    }
  }
}

实战

总体流程:创建制品库 =》 配置maven =》 配置项目Pom =》 编写jenkinsfile =》 创建Job =》 上传代码,触发构建
在Coding创建制品库
在这里插入图片描述
2. 创建setting文件
这里使用Coding访问令牌生成配置,供构建使用(放在代码根目录下,不是更新本地的maven配置)
(用于配置连接制品库的账号密码,maven deploy时要先登陆制品库)
在这里插入图片描述得到有<servers>配置的setting.xml文件

依赖制品库内的制品时添加该配置
查看Coding制品库指引,并将<profiles>添加到setting文件
(这里添加这个配置是为了构建时能连接制品库仓库,并拉取里面得制品依赖)
在这里插入图片描述

最后setting文件如下:

<settings>
    <servers>
        <server>
            <!--仓库 ID-->
            <id>id</id>
            <username>username</username>
            <password>password</password>
        </server>
    </servers>
    <!--如果构建依赖制品库内的制品,则需要添加一下配置(如何获取配置看回上面)-->
    <profiles>
        <profile>
            <id>Repository Proxy</id>
            <activation>
                <activeByDefault>true</activeByDefault>
            </activation>
            <repositories>
                <repository>
                    <id>制品库id</id>
                    <name>maven</name>
                    <url>制品库地址</url>
                    <releases>
                        <enabled>true</enabled>
                    </releases>
                    <snapshots>
                        <enabled>true</enabled>
                    </snapshots>
                </repository>
            </repositories>
        </profile>
    </profiles>
</settings>
  1. 配置pom文件:在项目pom.xml添加一下配置
    具体配置可以在Coding制品库的指引中直接获取
	<distributionManagement>
        <repository>
            <!--必须与 settings.xml 的 id 一致-->
            <id>制品库id</id>
            <name>maven</name>
            <url>制品库地址</url>
        </repository>
        <!--有快照需求的可以添加,id和url和上面相同-->
		<snapshotRepository>
		    <id>id</id>
            <name>maven</name>
            <url>制品库地址</url>
		</snapshotRepository>
    </distributionManagement>

ps:我直接将这个配置在了parent项目,<distributionManagement>是可以被继承的

  1. 编写Jenkinsfile文件
    setting.xml我是放在和Jenkinsfile同目录,所以我就直接./setting.xml引用了;
    代理选any就可以,Coding的Jenkins环境自带了maven;
    无论是install或者deploy都要添加 -s setting.xml,不然会出现找不到制品库的错误;
pipeline {
  agent any
  stages {
    stage('检出') {
      steps {
        checkout([
          $class: 'GitSCM', branches: [[name: env.GIT_BUILD_REF]],
          userRemoteConfigs: [[
            url: env.GIT_REPO_URL,
            credentialsId: env.CREDENTIALS_ID
          ]]
        ])
      }
    }
    stage('构建') {
      steps {
        sh 'mvn install -Dmaven.test.skip -s ./setting.xml'
      }
    }
    stage('发布') {
      steps {
        sh 'mvn deploy -s ./setting.xml'
      }
    }
  }
}
  1. 创建Job
    注意Jenkinsfile也需要放在代码根目录
    在这里插入图片描述6. 更新代码,执行构建
    最后我的项目目录是这样的
    在这里插入图片描述

构建镜像和持续部署

==

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
1. 引入SDK 在podfile文件中添加以下代码: ``` pod 'QCloudAiSDK' ``` 执行pod install命令,导入SDK。如果有问题可以尝试更新pod库: ``` pod repo update ``` 2. 获取API密钥 在腾讯云官网控制台开通语音识别服务,并获取API密钥。 3. 引入头文件 在需要使用语音识别功能的文件中引入头文件: ```objective-c #import <QCloudCore/QCloudCore.h> #import <QCloudAiPlatformSDK/QCloudAiPlatformSDK.h> ``` 4. 配置SDK参数 创建一个QCloudAuthentationV2对象,并传入API密钥: ```objective-c QCloudCredential* credential = [QCloudCredential new]; credential.secretID = @"您的API密钥ID"; credential.secretKey = @"您的API密钥Key"; credential.expirationDate = [NSDate dateWithTimeIntervalSinceNow:3600*24*30]; QCloudServiceConfiguration* configuration = [QCloudServiceConfiguration new]; configuration.appID = @"您的APPID"; configuration.regionName = @"ap-guangzhou"; configuration.credential = credential; ``` 修改appID和regionName为对应的信息。 5. 调用语音识别API 创建一个QCloudGetRecognitionResultRequest对象,并传入需要识别的音频文件路径和语音识别接口的配置: ```objective-c QCloudGetRecognitionResultRequest* recognitionRequest = [QCloudGetRecognitionResultRequest new]; recognitionRequest.filePath = @"音频文件路径"; recognitionRequest.engineModelType = QCloudASREngineModelType16k_qc; recognitionRequest.voiceFormat = QCloudASRVoiceFormat_MP3; recognitionRequest.hotwordId = @"0"; recognitionRequest.enableFlush = YES; recognitionRequest.enableVad = YES; recognitionRequest.workMode = QCloudASRWorkModeRecognition; recognitionRequest.filterDirty = NO; recognitionRequest.filterModal = NO; recognitionRequest.filterPunc = NO; recognitionRequest.convertNumMode = QCloudASRConvertNumModeWord; recognitionRequest.queryType = QCloudASRQueryTypeJSON; recognitionRequest.channelNum = 1; recognitionRequest.resType = QCloudASRResType16k; recognitionRequest.source = @"sdk"; [[QCloudAiPlatformOCRService sharedInstance] GetRecognitionResult:recognitionRequest appid:@"您的APPID" region:@"ap-guangzhou" configuration:configuration withCompletionHandler:^(id outputObject, NSError *error) { NSLog(@"output: %@, error: %@", outputObject, error); }]; ``` 注释中有每个参数的说明,根据需要调整。 6. 完整代码 ```objective-c #import "ViewController.h" #import <QCloudCore/QCloudCore.h> #import <QCloudAiPlatformSDK/QCloudAiPlatformSDK.h> @interface ViewController () @end @implementation ViewController - (void)viewDidLoad { [super viewDidLoad]; [self requestSpeechRecognition]; } - (void)requestSpeechRecognition { QCloudCredential* credential = [QCloudCredential new]; credential.secretID = @"您的API密钥ID"; credential.secretKey = @"您的API密钥Key"; credential.expirationDate = [NSDate dateWithTimeIntervalSinceNow:3600*24*30]; QCloudServiceConfiguration* configuration = [QCloudServiceConfiguration new]; configuration.appID = @"您的APPID"; configuration.regionName = @"ap-guangzhou"; configuration.credential = credential; QCloudGetRecognitionResultRequest* recognitionRequest = [QCloudGetRecognitionResultRequest new]; recognitionRequest.filePath = @"音频文件路径"; recognitionRequest.engineModelType = QCloudASREngineModelType16k_qc; recognitionRequest.voiceFormat = QCloudASRVoiceFormat_MP3; recognitionRequest.hotwordId = @"0"; recognitionRequest.enableFlush = YES; recognitionRequest.enableVad = YES; recognitionRequest.workMode = QCloudASRWorkModeRecognition; recognitionRequest.filterDirty = NO; recognitionRequest.filterModal = NO; recognitionRequest.filterPunc = NO; recognitionRequest.convertNumMode = QCloudASRConvertNumModeWord; recognitionRequest.queryType = QCloudASRQueryTypeJSON; recognitionRequest.channelNum = 1; recognitionRequest.resType = QCloudASRResType16k; recognitionRequest.source = @"sdk"; [[QCloudAiPlatformOCRService sharedInstance] GetRecognitionResult:recognitionRequest appid:@"您的APPID" region:@"ap-guangzhou" configuration:configuration withCompletionHandler:^(id outputObject, NSError *error) { NSLog(@"output: %@, error: %@", outputObject, error); }]; } @end ``` 在上述代码中,获取API密钥的部分需要替换成您的实际信息,其他部分根据需要调整。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值