这里持续集成基于GitHub搭建的博客为项目

工具:

  1. zqz@ubuntu:~$ node --version
  2. v4.2.6
  3. zqz@ubuntu:~$ git --version
  4. git version 2.7.4
  5. zqz@ubuntu:~$ travis --version
  6. 1.8.4

Travis CI简介


Travis CI 是目前新兴的开源持续集成构建项目,它与jenkins,GO的很明显的特别在于采用yaml格式,简洁清新独树一帜。目前大多数的github项目都已经移入到Travis CI的构建队列中,据说Travis CI每天运行超过4000次完整构建。

注意:开始安装一大堆东西之前,你需要去Travis CI上注册一个账号。(一般都会使用github账号)

Linux下的安装(强烈建议不要使用windows来CI)

Deploy Key


生成ssh密钥用于跟仓库通信

  1. ssh-keygen -t rsa -C "youremail@example.com"

成功后,将.pub结尾的文件添加到github仓库中

最后将id_rsa文件复制到我们项目的根目录,这样便于生成密钥。

  1. cp /home/zqz/.ssh_ci/id_rsa /home/zqz/study/zhaoqize.github.io

安装并登陆travis


安装

  1. gem install travis

安装成功后,登陆travis

  1. travis login --auto

登陆成功:

  1. Successfully logged in as zhaoqize!

接着,登陆网页版,设置仓库。

点击仓库名称左边的齿轮,设置开启下面三个。

加密


在加密之前我们先在项目跟目录下新建一个.travis.yml文件。

加密的就是第一步生成的密钥id_rsa,由于前面我们将密钥复制到了项目目录,所以现在这里有id_rsa文件。

  1. //进入项目目录
  2. cd study/study/zhaoqize.github.io
  3. //进行加密
  4. travis encrypt-file ssh_key --add

加密成功:

  1. zqz@ubuntu:~/study/zhaoqize.github.io$ travis encrypt-file id_rsa --add
  2. Detected repository as zhaoqize/blog, is this correct? |yes|
  3. encrypting id_rsa for zhaoqize/blog
  4. storing result as id_rsa.enc
  5. storing secure env variables for decryption
  6. Make sure to add id_rsa.enc to the git repository.
  7. Make sure not to add id_rsa to the git repository.
  8. Commit all changes to your .travis.yml.

这时候看最后一句**Commit all changes to your .travis.yml.

我们新建的文件一句发生了变化,多了一句:(私人内容使用XXX代替)

  1. - openssl aes-256-cbc -K $encrypted_XXXXXXXX_key -iv $encrypted_XXXXXXXX_iv -in id_rsa.enc -out ~/.ssh/id_rsa -d

再次查看我们的travis ci网页,发现多了一些变化

.travis文件夹


删除我们之前复制到根目录的id_rsa文件

在项目根目录下新建一个.travis的文件夹

将生成的.enc文件移动至.travis文件

ssh_config


在.travis下建立ssh_config文件。

并填写如下信息:

  1. Host github.com
  2. User git
  3. StrictHostKeyChecking no
  4. IdentityFile ~/.ssh/id_rsa
  5. IdentitiesOnly yes

注意这里的~/.ssh/id_rsa的路径是根据个人设置而变化的。

.travis.yml


最后需要着重配置.travis.yml文件,以为travis ci就是按照这个文件来执行。

具体配置:

  1. # 使用的语言
  2. language: node_js
  3. # 使用的nodejs版本
  4. node_js:
  5. - 4.4.4
  6. # 仓库的分支
  7. branches:
  8. only:
  9. - master
  10. # 执行isntall前需要执行的命令
  11. before_install:
  12. # 配置解密信息
  13. - openssl aes-256-cbc -K $encrypted_4bba640059d8_key -iv $encrypted_4bba640059d8_iv -in .travis/id_rsa.enc -out ~/.ssh/id_rsa -d
  14. # 改变文件权限
  15. - chmod 600 ~/.ssh/id_rsa
  16. # 配置 ssh
  17. - eval $(ssh-agent)
  18. - ssh-add ~/.ssh/id_rsa
  19. - cp .travis/ssh_config ~/.ssh/config
  20. # 配置git 的个人信息
  21. - git config --global user.name 'zqz'
  22. - git config --global user.email zqz@zhaoqize.com
  23. # 执行install
  24. install:
  25. - npm install hexo-cli -g
  26. - npm install
  27. # 执行命令脚本
  28. script:
  29. - hexo clean
  30. - hexo g -d

成功


安装与使用中遇到的问题


安装travis失败

使用sudo权限操作

  1. zqz@ubuntu:~$ gem install travis
  2. Fetching: ffi-1.9.14.gem (100%)
  3. ERROR: While executing gem ... (Gem::FilePermissionError)
  4. You don't have write permissions for the /var/lib/gems/2.3.0 directory.
  5. zqz@ubuntu:~$ sudo gem install travis
  6. Building native extensions. This could take a while...
  7. ...

修改travis的目录

  1. zqz@ubuntu:~$ travis --version
  2. bash: /usr/bin/travis: 没有那个文件或目录
  3. zqz@ubuntu:~$ sudo ln -s /usr/local/bin/travis /usr/bin/travis
  4. [sudo] zqz 的密码:
  5. zqz@ubuntu:~$ travis --version
  6. 1.8.4
  7. zqz@ubuntu:~$

生成.enc文件密钥失败

有时候会失败。这时候我们需要在后面加上一些参数

  1. travis encrypt-file ssh_key --add -r zhaoqize/blog

Travis CI用来持续集成你的项目的更多相关文章

  1. 利用Travis CI+GitHub实现持续集成和自动部署

    前言 如果你手动部署过项目,一定会深感持续集成的必要性,因为手动部署实在又繁琐又耗时,虽然部署流程基本固定,依然容易出错. 如果你很熟悉持续集成,一定会同意这样的观点:"使用它已经成为一种标 ...

  2. 【持续集成】GitLab CI + Docker 实现持续集成

    GitLab CI + Docker 实现持续集成 一.持续集成(Continuous Integration, CI)的基本概念 概述 在传统软件的开发中,代码的集成工作通常是在所有人都将工作完成后 ...

  3. CI / CD /CD 持续集成 持续交付 持续部署

    CI / CD /CD 持续集成 持续交付 持续部署 CI CD 是啥?干了啥? CI continuous integration 持续集成 CD continuous delivery 持续交付 ...

  4. 【下一代核心技术DevOps】:(五)微服务CI与Rancher持续集成

    1. 引言 DevOps的核心魅力是快速的持续集成交付,降低研发和实施运维之间的交互,使得传统的各种扯皮现象统统消失.最重要的是降低成本 保障产品交付可靠性. 使用Rancher作为持续集成的关键环节 ...

  5. GitLab CI/CD 进行持续集成

    简介 从 GitLab 8.0 开始,GitLab CI 就已经集成在 GitLab 中,我们只要在项目中添加一个 .gitlab-ci.yml 文件,然后添加一个 Runner,即可进行持续集成. ...

  6. CI实践_Android持续集成

    之前已经实现了Android的持续集成,并在项目中应用了一段时间.恰逢现在有几分钟时间,把之前的一些零散的点滴记录和整理一下,供有需要的朋友参考,或后续复用. 需要的准备知识:gitlab.Jenki ...

  7. windows部署jenkins持续集成maven测试项目不能访问测试报告

    买了一台阿里云的服务器用于练习maven test项目,系统版本wiondows server 2012,将jenkins war包部署在Tomcat服务器上,项目构建后,生成的报告在C:\Windo ...

  8. Jenkins持续集成构建自动化测试项目

    1.配置内容安全策略(配置一次): 1.1.构建一个自由风格的软件项目 1.2.Build Triggers:Build when job nodes start 1.3.Build:Execute ...

  9. jenkins(8): 实战jenkins+gitlab持续集成发布php项目(代码不需要编译)

    一. jenkins 的配置 1.前提条件安装了GitLab Plugin (源码管理使用),GitLab Hook(gitlab webhook需要) Manage Jenkins--->Ma ...

随机推荐

  1. nodejs进阶(6)—连接MySQL数据库

    1. 建库连库 连接MySQL数据库需要安装支持 npm install mysql 我们需要提前安装按mysql sever端 建一个数据库mydb1 mysql> CREATE DATABA ...

  2. JAVA回调机制(CallBack)详解

    序言 最近学习java,接触到了回调机制(CallBack).初识时感觉比较混乱,而且在网上搜索到的相关的讲解,要么一言带过,要么说的比较单纯的像是给CallBack做了一个定义.当然了,我在理解了回 ...

  3. Linux虚拟机的安装(使用Centos6.3)

    1.什么是虚拟机? 虚拟机指通过软件模拟的具有完整硬件系统功能的.运行在一个完全隔离环境中的完整计算机系统 2.安装Linux虚拟机前要做的准备 2.1:一台windows环境的pc 2.2:下载VM ...

  4. iOS---iOS10适配iOS当前所有系统的远程推送

    一.iOS推送通知简介 众所周知苹果的推送通知从iOS3开始出现, 每一年都会更新一些新的用法. 譬如iOS7出现的Silent remote notifications(远程静默推送), iOS8出 ...

  5. HTML文档头部

    前面的话   在声明文档类型之后,HTML文档的下一部分为<html>标签,告知浏览器应将括在<html>...</html>内的所有内容解析为HTML.然后是HT ...

  6. javascript:逆波兰式表示法计算表达式结果

    逆波兰式表示法,是由栈做基础的表达式,举个例子: 5 1 2 + 4 * + 3 -  等价于   5 + ((1 + 2) * 4) - 3 原理:依次将5 1 2 压入栈中, 这时遇到了运算符 + ...

  7. C#多线程之线程池篇1

    在C#多线程之线程池篇中,我们将学习多线程访问共享资源的一些通用的技术,我们将学习到以下知识点: 在线程池中调用委托 在线程池中执行异步操作 线程池和并行度 实现取消选项 使用等待句柄和超时 使用计时 ...

  8. PHP 获取 特定时间范围 类

    目录  前序 用途 功能及事项 使用方法 代码及注释 前序: 总体来说,我更应该是一个 android 移动开发者,而不是一个 phper,如果说只做移动端的 APP ,我也不会学这么多,这 2年来, ...

  9. dagger2系列之依赖方式dependencies、包含方式(从属方式)SubComponent

    本篇是实战文章,从代码的角度分析这两种方式.本文参考自下列文章: http://www.jianshu.com/p/1d42d2e6f4a5 http://www.jianshu.com/p/94d4 ...

  10. iOS架构一个中型普通App的一些经验总结

    这一版比较完善的的App终于提交审核了.有时间写写自己的一些经验的总结了.自己主导的从0到比较成型的app到目前来说也只有两个,但是其中的很多东西都是大同小异.基本上是想到了什么就写什么,感觉写的不到 ...