引言

本文档用户指导新手如何部署GitLab+Jenkins自动化构建GitBook,并使用Nginx发布资料。在部署过程中,如遇到任何问题,请自行百度。

注意: 此文章的环境和数据,仅为用于调试的片段,很可能有版本,路径不一致等情况,请部署者不必过于考究其中的细节。

以下教程使用的环境如下:

环境 版本
System CentOS 6
GitLab gitlab-ce-10.8.4-ce.0.el6.x86_64.rpm
Jenkins jenkins-2.121.1-1.1.noarch.rpm
Nginx nginx-1.14.0.tar.gz
nodejs node-v8.11.3-linux-x64.tar.xz
npm 3.10.10
GitBook 2.3.2

GitLab安装

官网:https://about.gitlab.com/installation/

官网有针对各系统的安装教程,很详细,这里主要拿CentOS 6来说

  • 安装必要的依赖项(root用户不用sudo开头)
  1. sudo yum install -y curl policycoreutils-python openssh-server cronie
  2. sudo lokkit -s http -s ssh
  3.  
  4. sudo yum install postfix
  5. sudo service postfix start
  6. sudo chkconfig postfix on
  • 添加GitLab软件包库

  1. curl https://packages.gitlab.com/install/repositories/gitlab/gitlab-ee/script.rpm.sh | sudo bash
  • 安装GitLab

  1. sudo yum -y install gitlab-ee

GitLab本地配置

GitLab包含了众多插件,要配置端口等信息,打开/etc/gitlab/gitlab.rb

  1. vim /etc/gitlab/gitlab.rb
  • 配置外部URL

    默认情况下,外部URL为 'http://gitlab.example.com' ,这个域名外部是无法访问的,除非你做了映射,如果不想做什么映射,直接将该域名改成本机IP:Nginx_port,以8.5为例

  1. external_url 'http://192.168.8.5'
  • 配置Nginx端口

    GitLab集成Nginx插件,默认端口与是80,如果该端口被占用,则要修改端口,修改的端口与要和外部URL端口相同,不然会引起git无法使用http/https,将 ‘nginx['listen_port'] = 80’ 解注释, 再修改其端口,以 8899
    端口为例

  1. nginx['listen_port'] =
  • 配置Unicorn端口

    GitLab还集成了Unicorn插件,默认端口与是8080,如果该端口被占用,则要修改端口,将 ‘unicorn['port'] = 8080’ 解注释, 再修改其端口,以 8988端口为例

  1. unicorn['port'] =
  • 保存配置

    配置文件修改后,保存不是立刻生效的,还需要命令去修改

  1. gitlab-ctl reconfigure
  • 关闭防火墙

如果系统还开了防火墙,可能会导致后台访问不到,要关闭防火墙,或者设置过滤端口,以下选择关闭防火墙比较方便,如果选择端口设置,则需要看哪个端口要使用,再去设置

  1. service iptables stop

GitLab后台配置

本地配置完成后,还需要登录后台配置

  • 打开gitlab 后台,后台地址为
  1. http://gitlab_url:nginx_port
  • 第一次打开后台需要设置密码,再登录,自行设置

登陆用户名为 root,密码为刚刚设置的

  • 配置本地网络可访问,配置地址为
  1. http://'gitlab_url:nginx_port'/admin/application_settings

  • 添加SSH公钥

用以下命令生成rsa密钥

  1. ssh-keygen -t rsa

将生成的公钥复制到GitLab中

Jenkins安装

官网:https://jenkins.io/

直接在官网上下载,选择相应系统版本的安装包,以我下载的 “jenkins-2.121.1-1.1.noarch.rpm” 为例。

  • 调用命令安装
  1. rpm -ivh jenkins-2.121.-1.1.noarch.rpm

Jenkins本地配置

  • 修改端口

Jenkins默认端口为8080,若该端口被占用,可通过修改"/etc/sysconfig/jenkins"文件中的 JENKINS_PORT 字段的值达到修改端口的目的

  • 启动Jenkins

Jenkins安装后,作为服务而存在,通过调用服务启动的命令去启动

  1. service jenkins start
  • 修改Jenkins用户权限

Jenkins构建需要使用Jenkins用户去执行命令,调用sudo命令去执行命令,需要面输入密码,则需要添加jenkins用户免密执行sudo权限,在 /etc/sudoers 文件中文件底部追加

  1. jenkins ALL=(ALL) NOPASSWD:ALL

Jenkins 后台配置

本地配置完成后,还需要登录后台配置

  • 打开Jenkins 后台,后台地址为
  1. http://jenkins_url:port
  • 第一次打开后台需要解锁,界面有提示

  • 安装推荐插件并等待安装完成

  • 创建一个管理员账户,也可继续使用admin账户,我选择了后者

  • 创建url,直接保存下一步

  • 设置Jenkins可访问

此设置可解决GitLab访问Jenkins 403错误

GitBook安装

官网:https://www.gitbook.com/

  • 安装nodejs

在nodejs官网上下载,然后解压并编译安装

  1. ./configure
  2. make
  3. make install
  • 安装gitbook

使用npm安装gitbook

  1. npm install gitbook-cli -g

GitBook配置

GitBook包含众多插件,有些功能需要插件支持,这里就展示要用到的几个插件的安装,其他插件可自行百度。

插件的安装分两步

  1. 用你npm安装插件
  2. 在gitbook工程下,调用以下命令安装
  1. gitbook install
  • 页脚插件tbfed-pagefooter

npm安装

  1. npm install gitbook-plugin-tbfed-pagefooter

在gitbook工程下安装

  1. gitbook install

Nginx安装

官网:http://nginx.org/en/

  • 安装

在官网上下载Nginx后,解压并进入解压目录调用命令安装

  1. ./configure
  2. make
  3. make install
  • 启动

直接调用nginx命令启动

  1. nginx

GitLab插件安装

  • 安装Gitlab Hook Plugin, Build Authorization Token Root Plugin和Gitlab Plugin

PS: 没有安装Gitlab Hook Plugin就没办法和gitlab使用webhook

没有安装Build Authorization Token,后面gitlab在Test hook时会报403错误

没有Gitlab Plugin就没办法构建Gitlab触发器

  • 安装完后,返回主界面

  • 创建GitLab仓库

  • 创建Jenkins工程

  • 构建脚本

  1. gitbook_build(){
  2. cd $
  3. sudo gitbook install
  4. sudo gitbook build
  5. cd ..
  6. }
  7.  
  8. mv_nginx()
  9. {
  10. sudo mkdir -p /opt/nginx/html/${JOB_NAME}/$
  11. sudo cp -af $/_book/* /opt/nginx/html/${JOB_NAME}/$1
  12. }
  13.  
  14. sub_log=($(git diff --name-only HEAD HEAD~ | awk '{print $0}'))
  15. for((i=0;i<${#sub_log[@]};i++))
  16. do
  17. for((j=0;j<=${#arr_folder[@]};j++))
  18. do
  19. sub_folder=${sub_log[$i]%%/*}
  20. if [[ $sub_folder == ${arr_folder[$j]} ]]; then
  21. break;
  22. elif [ $j == ${#arr_folder[@]} ]; then
  23. arr_folder[$j]=${sub_log[$i]%%/*}
  24. gitbook_build ${arr_folder[$j]}
  25. mv_nginx ${arr_folder[$j]}
  26. break;
  27. fi
  28. done
  29. done
  • 为GitLab仓库添加webhook

第一次测试webhook会报错,提示先提交一次,字面意思,就先push一次

提交文件

  • 使用git命令提交修改和新增的内容,push后可查看结果

查看结果

  • 在Jenkins可查看到构建记录

  • 打开Nginx,可访问到该文档

Calibre插件安装

官网:https://calibre-ebook.com/

GitBook不自带转PDF功能,需要安装Calibra

  • 升级libGL

安装Calibre会遇到如下错误:

  1. ImportError: /lib64/libGL.so.: undefined symbol: drmFreeDevice

需要先升级libGL,以本文的环境为例,仅需要使用yum升级即可

  1. yum update libGL
  • 安装Calibre

官网有安装教程,很简单,但要求python版本在2.7.9和3之间,如果没有,请安装升级,此处不po出升级方式,读者自行百度。Celibra安装命令:

  1. sudo -v && wget -nv -O- https://download.calibre-ebook.com/linux-installer.sh | sudo sh /dev/stdin

中文支持

GitBook导出的PDF不支持中文,需要安装插件和字体

  • 安装插件

插件"gitbook-plugin-yahei",与其他插件安装方式一样

  1. npm install gitbook-plugin-yahei

并在gitbook工程下安装

  1. gitbook install
  • 字体

将微软雅黑字体("msyh.ttc"和"msyh.ttf"文件)拷到Linux系统"/usr/share/fonts/truetype"目录下,没有该目录就创一个,没有该字体就下一个

  • 配置

在book.json中添加插件"yahei",并配置"fontSettings"

  1. "plugins": [
  2. "yahei",
  3. ],
  4. "pluginsConfig": {
  5. "fontSettings": {
  6. "theme": "white",
  7. "family": "msyh",
  8. "size": 2
  9. }
  10. }

封面

gitbook 的封面可以通过插件auto cover自动生成,也可以自己配置。

如果要使用自定义的封面,在书籍的根目录下放置"cover.jpg",如果想要缩略图可以放置"cover_small.jpg",文件格式必须为 jpg。

导出

导出并不是调用calibre命令,还是调用gitbook命令

  1. gitbook <pdf|epub|mobi> [path] [bookname]

以pdf为例

  • 直接导出pdf
  1. gitbook pdf
  • 导出指定书籍名
  1. gitbook pdf . mybook.pdf

gitbook一仓库多本书持续化部署的更多相关文章

  1. Docker+GitLab+Jenkins+kubernetes实现DevOps 持续化集成和持续化部署概念图

    Docker+GitLab+Jenkins+kubernetes实现DevOps 持续化集成和持续化部署概念图 转载自:原创 IT综合 作者:百联达 时间:2017-05-09 15:48:08 41 ...

  2. jenkins+Docker持续化部署(笔记)

    参考资料:https://www.cnblogs.com/leolztang/p/6934694.html (Jenkins(Docker容器内)使用宿主机的docker命令) https://con ...

  3. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(一)--技术流ken

    前言 在之前已经写了关于Git,Gitlab以及Ansible的两篇博客<Git+Gitlab+Ansible剧本实现一键部署Nginx--技术流ken>,<Git+Gitlab+A ...

  4. jenkins+git+gitlab+ansible实现持续集成自动化部署

    一.环境配置 192.168.42.8部署gitlab,节点一 192.168.42.9部署git,Jenkins,ansible服务器 192.168.42.10节点二 二.操作演示 ①gitlab ...

  5. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站

    环境准备 三台主机: 一台主机部署jenkins和作为ansible的管理主机 一台主机部署gitlab和ansible的节点1 一台主机为ansible的节点2 防火墙和apache服务关闭 第一步 ...

  6. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(一)

    在之前已经写了关于Git,Gitlab以及Ansible的两篇博客<Git+Gitlab+Ansible剧本实现一键部署Nginx--技术流ken>,<Git+Gitlab+Ansi ...

  7. Jenkins+Git+Gitlab+Ansible实现持续集成自动化部署静态网站(6)

    前言 在之前已经写了关于Git,Gitlab以及Ansible的两篇博客<Git+Gitlab+Ansible剧本实现一键部署Nginx–技术流ken>,<Git+Gitlab+An ...

  8. (转)持续化集成工具CruiseControl.NET

    持续化集成工具CC.NET[ 引言: 团队开发需要 进行集中的项目文件管理与有效的协调,我们采用源代码管理工具协助我们管理,卓有成效.限定重要文件的访问权限.使用悲观锁杜绝成员同时编辑同一份文件. 不 ...

  9. [dotnet core]落地微服务特色的DevOps管道,持续集成/部署到kubernetes。

    目录 前言 目标 工具 - 最小的学习成本 方案 - 愿景 1. 持续集成 - CI 2. 持续部署 - CD 部署环境 1. 部署gitlab-runner 2. 注册gitlab-runner 搭 ...

随机推荐

  1. 搭建基于MinGW平台的《OpenGL蓝皮书(OpenGL SuperBibe 5th)》示例代码编译环境

    副标题:搭建基于MinGW平台的<OpenGL超级宝典>(OpenGL蓝皮书第5版)GLTools 编译环境.示例代码:Triangle.cpp @ SB5.zip 以下内容以及方法均参考 ...

  2. 后置处理器----JSON提取器

    JSON提取器可以很方便的让你从JSON响应格式中提取数据. 1)Name:JSON提取器的名称. 2)Apply to:应用范围,有些采样器还嵌套子采样器,可以在此处设置JSON提取器是作用与主采样 ...

  3. 快速理解mysql主从,主主备份原理及实践

    感谢大家在上一篇 学一点Git--20分钟git快速上手 里的踊跃发言.这里再次分享干货, 简单介绍mysql双机,多机异地热备简单原理实战. 双机热备的概念简单说一下,就是要保持两个数据库的状态自动 ...

  4. docker kubernetes swarm spring cloud结合学习资源

    http://www.docin.com/p-2062732301.html https://blog.csdn.net/michael_hm/article/details/79213839 htt ...

  5. Dancing Links算法(舞蹈链)

    原文链接:跳跃的舞者,舞蹈链(Dancing Links)算法——求解精确覆盖问题 作者:万仓一黍 出处:http://grenet.cnblogs.com/ 本文版权归作者和博客园共有,欢迎转载,但 ...

  6. SDUT OJ 顺序表应用3:元素位置互换之移位算法

    顺序表应用3:元素位置互换之移位算法 Time Limit: 1000 ms Memory Limit: 570 KiB Submit Statistic Discuss Problem Descri ...

  7. Linux 常用命令大全(长期更新)

    常见指令 打包压缩相关命令 关机/重启机器 Linux管道 vim使用 用户及用户组管理 文件权限管理 更改文件的用户及用户组 更改权限 常用指令 ls 显示文件或目录 -l 列出文件详细信息l(li ...

  8. Linux系统管理之硬盘管理

    硬盘是计算的重要组成部件之一,硬盘为操作系统提供持久话存储的功能,在Linux硬盘设备的性能和好坏可能关系到生成线的安全和用户体验等等.熟练的掌握硬盘管理相关的信息能让我们处理起这些问题来得心应手. ...

  9. 浅谈C#中的委托、事件与异步

    从刚接触c#编程到现在,差不多快有一年的时间了.在学习过程中,有很多地方始终似是而非,直到最近才弄明白. 本文将先介绍用法,后评断功能. 一.委托 基本用法: 1.声明一个委托类型.委托就像是‘类'一 ...

  10. redux超易学三篇之二(开始使用react-redux)

    其实 redux 真正让人感到混乱的还是在 react-redux 的使用中. 请配合完整代码参考~:完整源代码 也不是说混乱,主要是网上 推崇 最佳实践.学习一个新东西的时候,本来就很陌生,上来就用 ...