DevOps-Jenkins-新手入门级

1. Jenkins概述

1. Jenkins是一个开源持续集成的工具,是由JAVA开发而成

2. Jenkins是一个调度平台,本身不处理任何事情,调用插件来完成所有的工作

1.1 什么是代码部署

代码发布/部署>开发书写的程序代码---->部署测试/生产环境 web服务器(站点目录中)

 2. Jenkins快速上手指南

安装Jenkins只需要简单几步即可完成。

可参考官网:

Jenkins 的安装和设置

2.1 环境准备

主机配置ip
devops_jenkins_xzb

2c4G

jdk 11版本

10.0.0.60/172.16.1.60

2.2 部署JDK

## 安装jenkins
## 安装jdk
yum install -y jdk-17
yum install jenkins
systemctl enable jenkins
systemctl start jenkins## 检查进程端口
ss -lntup ##8080端口
ps -ef |grep java##浏览器解析访问
10.0.0.60:8080

2.3 选择关闭

2.4 提示jenkins已经就绪 

2.5 登录

2.6 安装插件

Jenkins插件安装方式说明
web页面,选择与安装(联网)一个一个找选择,安装重启jenkins
自己下载插件,jenkins替你安装(hpi)web页面一个一个安装,未来批量安装需要脚本
导入插件(手动,批量)去一个机器上面把已经下载安装的插件打包,新机器解压,修改所有者
jenkins不同版本的插件不通用

2.7 修改密码

3. 体验Jenkins-Jenkins-Shell集成

3.1 对jenkins配置

1. 为了方便JK进行操作与管理各种节点,避免出现权限问题

2. 这里把jenkins运行用户改为root。

3. 当然也可以给Jenkins配置sudo权限,这里我们选择修改为root。

##修改所以者
egrep -i '^User|^Group' /usr/lib/systemd/system/jenkins.service
User=root
Group=root##重启daemon
systemctl daemon-reload ##重启jenkins
systemctl restart jenkins

 3.2 创建并运行jenkins项目,执行 Shell命令

1. 通过运行jenkins 任务,提示我们进行选择:

dev   #开发环境

prod #生产环境

2. 把选择结果放在变量中choose

3. jenkins执行脚本

3.3 项目详细步骤 

创建对应的的目录

创建文件夹

 创建freestyle项目

进入到dev目录创建1个项目

补充说明:

自由风格: 一般用于部署静态,各种都可以。

maven项目:java代码

流水线(pipeline):把第1个或第2个任务通过指令(代码)方式实现。 

配置构建保存

配置参数化构建 

添加参数化构建

配置变量与选择的值 

配置构建与shell 

添加执行shell

配置命令或代码 

 3.4 运行任务

运行工程

 检查输出

 

 

 3.5 所有构建记录是否要保留

丢弃旧的构建

4. Jenkins实现Gitee集成

4.1 准备windows环境

安装git-bash

准备代码目录(代码目录绝对路径中不要包含中文字符)

创建密钥并配置gitee

## 创建密钥
ssh-keygen.exe## 查看密钥
cat /c/Users/Administrator/.ssh/id_rsa.pub

创建gitee项目

配置密钥认证 

初始化并上传代码 

##配置基本信息
git config global user.name "Administrator"
git config global user.email "admin@example.com"
git config global list##初始化
git init#配置远程仓库地址
git remote add origin git@gitee.com:xing-zhibang/csdn_-jenkins-xzb.git
git remote -v##上传代码与标签
git add .
git commit -m "CSDN_Jenkins_xzb 项目完成100"
git tag -a 'v1' -m '项目完成100%'
git push  -u origin  master ##上传主分支
git push  -u origin v1      ##上传标签

检查

 4.2 配置jenkins

添加任务

源码管理 

配置git仓库地址(从gitee获取)

 配置访问凭证

 

 把windows下面的私钥写入进去

 

配置下shell命令 

4.3 运行查看结果 

4.4 配置脚本 

1. 这部分配置build步骤,表示对拉取过来的代码进行处理

2. 这里可以选择打包

 构建与检查结果

5. Jenkins基于tag标签的代码拉取与部署

案例背景:

1. 上个案例中拉取的代码总是最新的

2. 目前我们需要部署指定的tag标签(版本)的代码

3. 最后代码打包并分发web服务器

5.1 准备代码 

修改index.html,修改标题. 提交,打标签,

创建出v2.0 v3.0版本即可.

修改代码标题 

 提交代码

git add .
git commit  -m v2.0
git tag -a v2.0 -m v2.0
git push -u origin  all
git push -u origin  tags

检查

5.2 安装jenkins获取git tag标签的插件 

5.3 创建Jenkins任务 

添加参数化构建之git参数

配置git参数

配置源码管理 

配置每次构建之前清空工作目录(避免缓存导致问题) 

 配置Build步骤(shell脚本)

检查结果 

 

5.4 部署到web节点

在web主机上编写nginx配置文件

cat /etc/nginx/conf.d/firework.conf 
server{listen 80;server_name firework.oldboylinux.cn;access_log /var/log/nginx/firework/access.log main;error_log /var/log/nginx/firework/errot.log notice;root /app/code/firework;location / {index index.html;}
}

在Jenkins主机上创建密钥认证

ssh-keygen 
ssh-copy-id root@172.16.1.8  ##分发给web主机
ssh  root@172.16.1.8 远程连接web主机

jenkins项目配置(shell部分)

检查部署结果 

5.5 shell实现方式

## 配置jenkins到 web密钥认证
ssh-copy-id -i /root/.ssh/id_rsa.pub 172.16.1.8
ssh-copy-id -i /root/.ssh/id_rsa.pub 172.16.1.5# 下载代码
git clone git@gitee.com:xing-zhibang/csdn_-jenkins-xzb.git## 代码打包 
tar zcf  /tmp/web_html-$(date +%F).tar.gz   csdn_-jenkins-xzb/##查看
ll /tmp/
-rw-r--r-- 1 root root 7498973 Nov 18 14:09 web_html-2024-11-18.tar.gz# 推送代码包scp:推送到web服务器的/opt
for ip in 8 5; 
do  scp /tmp/web_html-2024-11-18.tar.gz  172.16.1.${ip}:/opt;
done## 解压,修改目录名字,创建软连接
for ip in 8 5 ;  
do   ssh 172.16.1.${ip} "cd /opt && tar xf web_html-2024-11-18.tar.gz && mv csdn_-jenkins-xzb csdn_-jenkins-xzb-$(date +%F) && rm -f /app/code/html && ln -s /opt/csdn_-jenkins-xzb-$(date +%F) /app/code/html";  
done 

使用jenkins自动拉取代码并自动上线 (通过jenkins执行脚本)

#!/bin/bash
#author:xzb666
##desc:通过脚本打包,分发,解压,连接,部署
App_time=`date +%F`
App_dir=/tmp
App_dest_dir=/opt
App_web_servers="172.16.1.8 172.16.1.5"app_pack(){
##代码打包tar zcf ${App_dir}/web_html-${App_time}.tar.gz  ${App_dir}/csdn-jenkins-xzb 
}app_scp(){
##代码推送for ip in ${App_web_servers}do  scp ${App_dir}/web_html-${App_time}.tar.gz ${ip}:${App_dest_dir}done
}
app_deploy(){
## 解压,修改目录名for ip in ${App_web_servers}do ssh $ip "cd ${App_dest_dir} && tar xf web_html-${App_time}.tar.gz && rm -f /app/code/html && ln -s ${App_dest_dir}/tmp/csdn-jenkins-xzb  /app/code/html "done 
}
main(){app_packapp_scpapp_deploy
}
main

jenkins 配置 主要修改执行shell部分即可

6. Jenkins部署java项目

由于java编写的代码是无法直接在服务器上运行,需要使用maven工具进行打包。

1. .开发提交代码------>gitee

2. jenkins------->git------->获取Gite代码

3. 代码的质量检测; sonarqube

4. 代码的编译; mvn clean package ----->jar/war

5. 发布过程:

    摘除节点

    发布代码,创建软连接。

    重载Tomcat服务,curl测试一下;

    加入节点;

6. 继续下一台节点;

6.1 手动实现构建Java项目-手动

## 下载源码
git clone  https://gitee.com/94fzb/zrlog.git##去清华镜像网站下载maven
mv apache-maven-3.8.8-bin.tar.gz  /app/tools## 解压
tar xf apache-maven-3.8.8-bin.tar.gz ## 创建软连接
ln -s /app/tools/apache-maven-3.8.8  /app/tools/maven## 增加环境变量
echo 'export PATH=/app/tools/maven/bin/:$PATH' >>/etc/profile## 查看版本
mvn --version## 配置maven源
vim /app/tools/maven/conf/settings.xml 
147     <mirror>
148      <id>aliyunmaven</id>
149      <mirrorOf>*</mirrorOf>
150      <name>阿里云公共仓库</name>
151      <url>https://maven.aliyun.com/repository/public </url>
152     </mirror>## 使用maven编译java代码  pom.xml所在目录执行.
mvn  clean  package## 检查代码包
ll /tmp/zrlog/package-web/target

6.2 jenkins拉取代码与手动编译代码

创建maven项目

配置源码

根据提示配置maven位置

运行项目检查结果

 6.3 war包的部署

1. 准备好tomcat环境

2. 传输war包到web节点上/opt/

3. 进入/opt/改war包名字 ROOT.war

4. 清理已有的目录和文件rm -fr /app/tools/tomcat/webapps/ROOT*

5. /opt/ROOT.war移动到/app/tools/tomcat/webapps/

6. 重启tomcat

7. 基于docker的案例实现静态代码

7.1 代码准备

7.2 书写dockerfile

1. jenkins机器安装与启动docker

2. 发送代码到jenkins的/app/code/bird/下面

3. 准备开始书写dockerfile

##当代码拉到本地
cd /app/code/cxk
git clone git@gitee.com:xing-zhibang/jenkins-docker.git##书写Dockerfile文件
FROM nginx:1.22-alpine
LABEL author='xzb' 
COPY . /usr/share/nginx/html
EXPOSE 80docker build -t web:ngx_cxk_v1.0 .## 运行容器
docker run -d --name "nginx_cxk" -p 8888:80 --rm web:ngx_cxk_v1.0 

 7.3 准备私有仓库

## 在docker02上拉取仓库,并启动仓库
docker pull registry:latest
docker run -d -p 5000:5000 -v registry:/var/lib/registry --name "xzb_registry" --restart=always registry:latest ## 上传镜像到镜像仓库
docker push reg.oldboylinux.cn:5000/xzb/nginx_cxk_v1.0

7.5 创建jenkins任务

 书写脚本

检查结果

 

web节点上启动对应的docker容器

## 密钥认证##vars
web_server="172.16.1.82"##判断git_tag是否为默认
if [  "$git_tag" = "origin/master" ];thengit_tag=latest
fi## 构建镜像
docker build -t reg.oldboylinux.cn:5000/xzb/web:nginx_cxk${git_tag} .## 推送到私有仓库
docker push reg.oldboylinux.cn:5000/xzb/web:nginx_cxk${git_tag}## 部署web服务器
for ip in ${web_servers}
dossh root@${ip} "docker run -d --name "nginx_cxk${git_tag} " -p 80:80 restart=always reg.oldboylinux.cn:5000/xzb/web:nginx_cxk${git_tag}"
done

最近状态不好,作者想休息一段时间了,后面的待更新吧.....

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.rhkb.cn/news/476977.html

如若内容造成侵权/违法违规/事实不符,请联系长河编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

速通前端篇 —— CSS

找往期文章包括但不限于本期文章中不懂的知识点&#xff1a; 个人主页&#xff1a;我要学编程程(ಥ_ಥ)-CSDN博客 所属专栏&#xff1a;速通前端 目录 CSS的介绍 基本语法规范 CSS选择器 标签选择器 class选择器 id选择器 复合选择器 通配符选择器 CSS常见样式 颜…

51c大模型~合集76

我自己的原文哦~ https://blog.51cto.com/whaosoft/12617524 #诺奖得主哈萨比斯新作登Nature&#xff0c;AlphaQubit解码出更可靠量子计算机 谷歌「Alpha」家族又壮大了&#xff0c;这次瞄准了量子计算领域。 今天凌晨&#xff0c;新晋诺贝尔化学奖得主、DeepMind 创始人哈萨…

怎么只提取视频中的声音?从视频中提取纯音频技巧

在数字媒体的广泛应用中&#xff0c;提取视频中的声音已成为一项常见且重要的操作。无论是为了学习、娱乐、创作还是法律用途&#xff0c;提取声音都能为我们带来诸多便利。怎么只提取视频中的声音&#xff1f;本文将详细介绍提取声音的原因、工具、方法以及注意事项。 一、为什…

IDEA如何设置编码格式,字符编码,全局编码和项目编码格式

前言 大家好&#xff0c;我是小徐啊。我们在开发Java项目&#xff08;Springboot&#xff09;的时候&#xff0c;一般都是会设置好对应的编码格式的。如果设置的不恰当&#xff0c;容易造成乱码的问题&#xff0c;这是要避免的。今天&#xff0c;小徐就来介绍下我们如何在IDEA…

Unable to find image ‘hello-world:latest‘ locally

网上对于这个问题的解答有很多了&#xff0c;我尝试了后并有解决&#xff0c;最后发现重启指令并没有使用sudo导致的。这里写一下总的解决方法&#xff1a; 1 查看是否已经有了hello-world sudo docker info如果有hello-world&#xff0c;就先删除 sudo docker rmi hello-w…

Web3.0安全开发实践:Clarity最佳实践总结

在过去的一段时间里&#xff0c;CertiK团队对比特币生态系统及其发展进行了深入研究。同时&#xff0c;团队还审计了多个比特币项目以及基于不同编程语言的智能合约&#xff0c;包括OKX的BRC-20钱包和MVC DAO的sCrypt智能合约实现。 现在&#xff0c;我们的研究重点转向了Clar…

Chrome离线安装包下载

1、问Chrome的官网&#xff1a;https://www.google.cn/chrome/ 直接下载的是在线安装包&#xff0c;安装需要联网。 2、如果需要在无法联网的设备上安装Chrome&#xff0c;需要在上面的地址后面加上?standalone1。 Chrome离线安装包下载地址&#xff1a;https://www.google.c…

【从零开始的LeetCode-算法】3232. 判断是否可以赢得数字游戏

给你一个 正整数 数组 nums。 Alice 和 Bob 正在玩游戏。在游戏中&#xff0c;Alice 可以从 nums 中选择所有个位数 或 所有两位数&#xff0c;剩余的数字归 Bob 所有。如果 Alice 所选数字之和 严格大于 Bob 的数字之和&#xff0c;则 Alice 获胜。 如果 Alice 能赢得这场游…

前端速通(JavaScript)

1 初识JavaScript 1 JavaScript是什么 JavaScript 是一种高层的、轻量级的、解释型的编程语言&#xff0c;最初由 Netscape 公司于 1995 年开发。它的特点包括&#xff1a; 动态性&#xff1a;JavaScript是动态类型语言&#xff0c;允许开发者灵活地操作数据。跨平台&#xf…

分层架构 IM 系统之架构演进

在电商业务日活几百万的情况下&#xff0c;IM 系统采用分层架构方式&#xff0c;如下图。 分层架构的 IM 系统&#xff0c;整体上包含了【终端层】、【入口层】、【业务逻辑层】、【路由层】、【数据访问层】和【存储层】&#xff0c;我们在上篇文章&#xff08;分层架构 IM 系…

基于ToLua的C#和Lua内存共享方案保姆级教程

C#和Lua内存共享方案保姆级教程 前言 在介绍C#和Lua内存共享方案之前,先介绍下面两个点来支撑这个方案的必要性 跨语言交互很费 Lua和C#交互最早是基于反射的方式实现的,后来为了提升性能发展成Luajit+C#静态方法导出注入到lua虚拟机的方式至此Lua+Unity的性能才达到了实…

SpringSecurity创建一个简单的自定义表单的认证应用

1、SpringSecurity 自定义表单 在 Spring Security 中创建自定义表单认证应用是一个常见的需求&#xff0c;特别是在需要自定义登录页面、认证逻辑或添加额外的表单字段时。以下是一个详细的步骤指南&#xff0c;帮助你创建一个自定义表单认证应用。 2、基于 SpringSecurity 的…

创客匠人老蒋:个人IP如何获取有效流量?

大家好&#xff0c;我是老蒋。 为什么我反复强调说&#xff0c;如果你想把个人IP、创始人IP做起来&#xff0c;想把自己直播间的流量变大变活&#xff0c;一定要去参加这场将在2024年底举办的《全球创始人IP领袖高峰论坛》&#xff1f;一定要走出去看看更高的世界&#xff1f;…

华三(H3C)T1020 IPS服务器硬件监控指标解读

在日益复杂的网络环境中&#xff0c;服务器的稳定运行对于保障业务的连续性和安全性至关重要。华三&#xff08;H3C&#xff09;T1020 IPS作为一款高性能的入侵防御系统&#xff0c;其运行状态和性能监控显得尤为重要。监控易作为一款专业的监控软件&#xff0c;为华三T1020 IP…

【Unity3D插件】Unity3D HDRP Outline高亮发光轮廓描边插件教程

推荐阅读 CSDN主页GitHub开源地址Unity3D插件分享QQ群&#xff1a;398291828小红书小破站 大家好&#xff0c;我是佛系工程师☆恬静的小魔龙☆&#xff0c;不定时更新Unity开发技巧&#xff0c;觉得有用记得一键三连哦。 一、前言 最近用Unity3D的HDRP&#xff08;高清渲染管…

数据结构-7.Java. 对象的比较

本篇博客给大家带来的是java对象的比较的知识点, 其中包括 用户自定义类型比较, PriorityQueue的比较方式, 三种比较方法...... 文章专栏: Java-数据结构 若有问题 评论区见 欢迎大家点赞 评论 收藏 分享 如果你不知道分享给谁,那就分享给薯条. 你们的支持是我不断创作的动力 .…

OpenCV相机标定与3D重建(3)校正鱼眼镜头畸变的函数calibrate()的使用

操作系统&#xff1a;ubuntu22.04 OpenCV版本&#xff1a;OpenCV4.9 IDE:Visual Studio Code 编程语言&#xff1a;C11 算法描述 cv::fisheye::calibrate 函数是 OpenCV 中用于校正鱼眼镜头畸变的一个重要函数。该函数通过一系列棋盘格标定板的图像来计算相机的内参矩阵和畸变…

GitLab使用操作v1.0

1.前置条件 Gitlab 项目地址&#xff1a;http://******/req Gitlab账户信息&#xff1a;例如 001/******自己的分支名称&#xff1a;例如 001-master&#xff08;注&#xff1a;master只有项目创建者有权限更新&#xff0c;我们只能更新自己分支&#xff0c;然后创建合并请求&…

机器学习阶段学习Day31

KNN分类算法 KNN算法原理 根据K个邻居样本来判断当前样本属于哪个类别&#xff1a;K个最相似邻居中大多数所属类别即为当前样本的类别。但是对于数据量巨大或者高纬度的数据样本不太合适&#xff0c;数据量大的数据样本需要进行大量计算&#xff0c;而高纬度数据计算距离不具…

【Android、IOS、Flutter、鸿蒙、ReactNative 】实现 MVP 架构

Android Studio 版本 Android Java MVP 模式 参考 模型层 model public class User {private String email;private String password;public User(String email, String password) {this.email = email;this.password = password;}public String getEmail() {return email;}…