一、环境配置

192.168.42.8部署gitlab,节点一

192.168.42.9部署git,Jenkins,ansible服务器

192.168.42.10节点二

二、操作演示

  ①gitlab创建新的nginx项目

创建目录及克隆
[root@localhost ~]# mkdir nn
[root@localhost ~]# cd nn
[root@localhost nn]# git clone http://192.168.42.8/root/nginx.git
Cloning into 'nginx'...
warning: You appear to have cloned an empty repository.
[root@localhost nn]# ls
nginx
[root@localhost nn]# cd nginx/
[root@localhost nginx]# ls -a
. .. .git

  ②发送密钥

[root@localhost nginx]# ssh-keygen
[root@localhost nginx]# ssh-copy-id 192.168.42.8
[root@localhost nginx]# ssh-copy-id 192.168.42.10

  ③创建roles相关目录,并编写相关文件

1.创建roles目录
[root@localhost nginx]# mkdir roles/nginx/{files,template,vars,tasks} -p
2.编写vars文件
[root@localhost nginx]# vim roles/nginx/vars/main.yaml
[root@localhost nginx]# cat roles/nginx/vars/main.yaml
conn:
host_user: root
por:
docu_root: /var/www/html
3.复制nginx至template下
[root@localhost nginx]# cp /etc/nginx/nginx.conf roles/nginx/template/nginx.conf.j2
4.编辑nginx.conf,修改变量
[root@localhost nginx]# vim roles/nginx/template/nginx.conf.j2
user {{ host_user }};
worker_connections {{ conn }};
listen {{ por }};
root {{ docu_root }};
5.编辑tasks文件
[root@localhost nginx]# cat roles/nginx/tasks/main.yaml
- template: src=roles/nginx/template/nginx.conf.j2 dest=/etc/nginx/nginx.conf
- yum: name=nginx state=present
- service: name=nginx state=restarted
- copy: src=roles/nginx/files/index.html dest=/var/www/html
6.编写测试文件
[root@localhost nginx]# echo 'I will success' >> roles/nginx/files/index.html
[root@localhost nginx]# ls roles/nginx/files/
index.html
7.编写清单文件
[root@localhost nginx]# cat inventory/jams
[jams]
192.168.42.8
192.168.42.10
8.编写剧本
[root@localhost nginx]# cat jams.yaml
- hosts: all
roles:
- nginx
9.模拟执行剧本
[root@localhost nginx]# ansible-playbook -C -i inventory/jams jams.yaml
[root@localhost nginx]# ansible-playbook -i inventory/jams jams.yaml
10.提交
[root@localhost nginx]# git add .
[root@localhost nginx]# git commit -m v1
[root@localhost nginx]# git push -u origin master

jenkins 实现持续集成

经过上面的一些操作之后,我们已经完成了静态网站的部署,以及代码的上传

但是发现还是每次执行需要输入命令等

现在我们就使用jenkins来实现持续化部署

第一步:jenkins中创建任务

创建了一个自由风格的软件项目

项目名称为item7

第二步:添加源码管理信息

这里的url就是你的项目的地址(即gitlab的仓库链接地址

下面的凭证输入之前添加的全局凭据的账号和密码。

用脚本构建,cd到workspace下。

创建的bubu文件以及此次的任务名目录(任务名是一个worksapce下的目录)都会在workspace目录下。

可以看到我的任务脚本内执行ansible时并没有指定清单inventory/test 这是因为我选择了在/etc/ansible/hosts里面配置主机信息,这也是一种方法。

三:选择立即构建执行任务。

可能会碰到以下报错:

1)这里的失败原因是因为运行jenkins程序的是jenkins用户,我们连接节点的秘钥是root的,所以现在连接不上

打开配置文件/var/lib/jenkins 将jenkins用户改为root用户即可。

2)有时候报错时因为各主机之间的时间不同步,使用ntpdate同步时间后再次尝试。

3)有时候部署gitlab的节点无法启动nginx服务这是因为gitlab会自动启动nginx,使用gitlab-ctl stop nginx,然后再启动即可。

4)更有时候部署gitlab的ip换了,但是仓库的链接地址还是没变,这在gitlab网页上不好修改,我们在做git clone克隆的时候以及用gitlab做持续集成的时候就需要自己手动修改。

5)如果做jenkin持续集成构建时报错 playbook xxx not found (找不到剧本)

或者其中一台节点无法重启nginx服务

在部署jenkins服务的主机上提交推送文件给gitlab仓库

然后试试关闭防火墙和重启jenkins服务。

6)如果报错找不到repository或者master分支,这是因为gitlab创建新项目的时候没有创建搭建本地仓库。

四:如果构建成功的话,可以去linux下的/var/lib/jenkins/workspace/下去查看是否含有bubu文件。

来证明gitlab+ansible+jenkins的持续集成实验成功。

jenkins+git+gitlab+ansible实现持续集成自动化部署的更多相关文章

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

    项目前言 在上一篇博客<Jenkins+Git+Gitlab+Ansible实现持续化集成一键部署静态网站(一)--技术流ken>中已经详细讲解了如何使用这四个工具来持续集成自动化部署一个 ...

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

    项目前言 在上一篇博客<Jenkins+Git+Gitlab+Ansible实现持续化集成一键部署静态网站(一)–技术流ken>中已经详细讲解了如何使用这四个工具来持续集成自动化部署一个静 ...

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

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

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

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

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

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

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

    引言:首先我们可以实现一键部署网站,但在实际生产环境网站部署完成之后,我们的开发隔三差五要修改下网站的内容,难道都要我们运维手动执行命令吗?没有一种方法使得开发人员修改完代码自己测试,部署上线呢,那这 ...

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

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

  8. Git+Gitlab+Ansible剧本实现一键部署动态网站(二)--技术流ken

    项目前言 之前已经写了一篇关于git和ansible的博客<Git+Gitlab+Ansible剧本实现一键部署Nginx--技术流ken>.关于git,gitliab,ansible在我 ...

  9. Git+Gitlab+Ansible剧本实现一键部署动态网站(5)

    项目前言 之前已经写了一篇关于git和ansible的博客<Git+Gitlab+Ansible剧本实现一键部署Nginx–技术流ken>.关于git,gitliab,ansible在我以 ...

随机推荐

  1. Python——变量的作用域

    原创声明:本文系博主原创文章,转载及引用请注明出处. 1. 在编程语言中,变量都有一定的作用域,用来限定其生命周期,且不同类型的变量作用域不同. 在Python中解释器引用变量的顺序(优先级)为:当前 ...

  2. dockerfile 与 docker-compose的区别

    https://blog.csdn.net/londa/article/details/91815208 先简单理解 docker 的使用过程,它分为镜像构建与容器启动. 镜像构建:即创建一个镜像,它 ...

  3. Java动态绑定与多态

    在面向对象的程序设计语言中,多态是继数据抽象和继承之后的第三种基本特性.多态通过分离做什么和怎么做,从另一个角度将接口和实现分离开来.在一开始接触多态这个词的时候,我们或许会因为这个词本身而感到困惑, ...

  4. PHP swoole UDP服务端和客户端

    服务端 <?php $serv = ,SWOOLE_PROCESS,SWOOLE_SOCK_UDP); $serv->on('Packet',function ($serv,$data,$ ...

  5. 【vs2015发布程序】

    1.选中网站右键,选择发布Web应用 2.发布目标选择自定义 3.配置文件名称 4.发布方式选择File System,选择发布的程序存放路径 5.

  6. [Angular 8] Take away: Web Components with Angular Elements: Beyond the Basics

    This post is based on the NG-CONF talk, check the talk by yourself. 1. Dynamiclly add Angular Elemen ...

  7. .net大文件传输断点续传源码

    IE的自带下载功能中没有断点续传功能,要实现断点续传功能,需要用到HTTP协议中鲜为人知的几个响应头和请求头. 一. 两个必要响应头Accept-Ranges.ETag 客户端每次提交下载请求时,服务 ...

  8. Mockito 2 关于打标(stubbing)

    请参考下面有关于打标的代码. //You can mock concrete classes, not just interfaces LinkedList mockedList = mock(Lin ...

  9. 关于项目在网页中运行部分jsp出现乱码(由request.getRequestDispatcher("XXX.jsp").forward(request, response)造成)的解决方法

    在写jsp的时候发现部分的jsp在浏览器预览时出现乱码,为一堆问号,如图: 当时问了同学,只有部分jsp会出现乱码,因为重新建一个jsp在运行就没有错误,可以显示出来,所以发现是jsp头部的错误,当新 ...

  10. Spring Boot教程(三十五)使用MongoDB数据库(1)

    MongoDB简介 MongoDB是一个基于分布式文件存储的数据库,它是一个介于关系数据库和非关系数据库之间的产品,其主要目标是在键/值存储方式(提供了高性能和高度伸缩性)和传统的RDBMS系统(具有 ...