码迷,mamicode.com
首页 > 其他好文 > 详细

git jenkins 基本部署 jenkins持续集成

时间:2019-10-24 22:00:00      阅读:92      评论:0      收藏:0      [点我收藏+]

标签:认证   复制   ssh   rsa   ret   还需要   部署   roo   脚本   

技术图片
1.什么是持续集成?
  持续集成来简化我们的工作 还能让产品可以快速迭代,同时还能保持代码高质量产出。
2.Jenkins的安装配置:
        [root@jenkins ~]# yum install java -y
        [root@jenkins ~]# yum localinstall jenkins-2.176.1-1.1.noarch.rpm -y
        [root@jenkins ~]# systemctl start jenkins
        [root@jenkins ~]# netstat -lntp
        配置Host解析  
            10.0.0.120 jenkins.oldxu.com
        
       解锁Jenkins
            [root@jenkins ~]# cat /var/lib/jenkins/secrets/initialAdminPassword
    
      访问Jenkins
            http://jenkins.oldxu.com:8080/
    
      自定义Jenkins插件!!!!!!
            1.如果网络较好,同时你不清楚要安装哪些插件,通常选择  推荐的插件
            2.网络较差,而且对jenkins比较熟悉,建议自定义选择插件
            3.啥都不选, 简单的说就是一个插件都不安装.   直接关闭这一步 跳过它
        
      跳过插件后,直接就进入了jenkins系统
            1.修改admin的密码
                点击右上角admin--->configure-->Password

jenkins的插件管理:
     1)在安装插件过程中如何进行加速?                阿里云
        https://mirror.tuna.tsinghua.edu.cn/jenkins/updates/update-center.json
    
     2)通过Web页面上传.hpi文件进行插件安装。
        https://mirror.tuna.tsinghua.edu.cn/jenkins/plugins/
        https://plugins.jenkins.io
    
     3)导入之前服务器已安装的插件 (离线安装)。        -----> 
        [root@jenkins ~]# tar xf jenkins_2.176_plugins.tar.gz
        [root@jenkins ~]# cp -rp  plugins/* /var/lib/jenkins/plugins/
        [root@jenkins ~]#  chown -R jenkins.jenkins /var/lib/jenkins/plugins/
        [root@jenkins ~]# systemctl restart jenkins  

Jenkins与Gitlab集成思路:

1.开发提交代码至Gitlab
        需要准备一个仓库-->仓库里面还需要有真实的代码
2.jenkins安装gitlab所需插件
3.jenkins创建freestyle项目,然后配置gitlab仓库项目对应地址。
3.1) 基于SSH方式
            1.需要将Jenkins Root用户的公钥 推送到Gitlab服务器,测试免密
            2.添加一个jenkins的凭证
                添加一个ssh private key
                    描述:            一定要写清楚
                    Username:         root
                    Private Key:     复制/root/.ssh/id_rsa

2.Jenkins实现项目自动化发布
    1.搭建好集群环境   ( 手动搭建  | ansible )
    10.0.0.5   nginx
    10.0.0.7   nginx
    10.0.0.9   nginx    
    2.手动去下载gitlab的代码,推送至web集群
    3.测试访问

3.使用jenkins来实现自动化的上线
    1.jenkins需要拉取gitlab上的仓库代码
    2.jenkins需要将拉取下来的代码推送至web集群    ( 手动 | shell )
    3.编写Shell脚本
        1.拉取代码 (jenkins)  /var/lib/jenkins/workspace/freestyle-monitor
        2.打包到jenkins本地的/opt/
        3.推送公钥至web集群组
        4.推送代码压缩包到web集群组
        5.登录到web集群组
            1.创建站点目录
            2.解压代码至站点目录
            3.删除以前的web站点目录
            4.重新创建软连接
            5.重载服务

5.Jenkins实现项目tag方式发布
    1.需要每次的变更都tag的方式
    2.需要脚本支持进行传递参数  jenkins的参数化构建

6.Jenkins实现项目tag发布与回退
7.Jenkins解决项目能重复发布问题 {扩展}

---------------------------------------------------------------------
jenkins安装
jenkins插件
    1.加速插件  使用清华大学源
    2.如何手动上传一个插件.hpi
    3.导入插件
        ..........
    
jenkins目录结构
jenkins基本的使用
    freestyle  --> 自由软件风格
        1.jenkins调用Shell命令
        2.Jenkins集成Gitlab
            1.准备一份代码
            2.将代码提交到gitlab的仓库
            3.jenkins抓取gitlab仓库代码至本地
                前置条件
                    1.需要有对应的插件
                    2.填写对应的仓库地址
                    3.配置免秘认证
                        1.先推送系统的root的公钥给gitlab  (系统<==>gitlab)
                        2.jenkins添加一个凭据
                            root的私钥    (jenkins<==>gitlab)
        
        3.手动搭建Nginx集群
            三台
                负载均衡    10.0.0.5
                web集群        10.0.0.7 10.0.0.9

            3.1 安装集群环境
            3.2 克隆代码,推送给web集群组
            3.3 测试访问
            3.4 更新代码
            3.5 运维下载代码
            3.6运维推送代码至web集群
            
        3.完整的gitlab+jenkins+shell实现自动化部署代码
            1.下载代码--->jenkins
            2.推送代码--->Shell
                1.打包本地的最新代码
                2.推送至远程web集群组
                3.准备对应的站点目录-->将代码解压至站点目录
                4.删除软连接  重新创建软连接
                
                
        4.完整的  gitlab+jenkins+shell+tag   实现自动化部署代码        
            脚本必须能接收参数的传递   ===> 传递 git的版本号
            
            1.git parameter 插件
            2.添加了一个 git parameter 的参数化构建--->设定一个变量 git_version
            3.修改jenkins拉取gitlab代码不再只拉取最新的master  而是拉取 git_version传入的版本
            4.Shell  --->所有的操作都需要带上git_version的信息

        5.回退:
            1.添加一个选项参数构建  deploy_env   ( deploy | rollback )
            2.修改Shell
                1.添加一个判断条件,判断deploy_env这个变量
                    如果传递的字符串是deploy就调用deploy的函数
                    如果传递的是rollback则调用back函数执行回退
                2.back函数怎么写?
                    1.获取要回退的版本的路径
                    1.删除软连接
                    2.重建软连接

 

 


        


 

git jenkins 基本部署 jenkins持续集成

标签:认证   复制   ssh   rsa   ret   还需要   部署   roo   脚本   

原文地址:https://www.cnblogs.com/oldsjf/p/11734673.html

(0)
(0)
   
举报
评论 一句话评论(0
登录后才能评论!
© 2014 mamicode.com 版权所有  联系我们:gaon5@hotmail.com
迷上了代码!