标签:认证 复制 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.重建软连接
标签:认证 复制 ssh rsa ret 还需要 部署 roo 脚本
原文地址:https://www.cnblogs.com/oldsjf/p/11734673.html