热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

jenkins+GitHub实现项目自动化部署

服务器配置:操作系统:CentOS7.664位CPU:1核内存:2GB公网带宽:1Mbps一、安装JavaSDK1、进入根目录,查看是否有Java环境$cd$java-versio

服务器配置:




  • 操作系统:CentOS 7.6 64位

  • CPU:1核

  • 内存:2GB

  • 公网带宽:1Mbps


一、安装 Java SDK


1、进入根目录,查看是否有 Java 环境

$ cd /
$ java -version

有环境:
技术图片

无环境:
技术图片


2、若已经有环境,则直接去安装 nginx,若无环境,这里我们安装 java-1.8.0

// 检索 `yum` 中有没有 `java1.8` 的包
$ yum list java-1.8*

技术图片

// 开始安装
$ yum install java-1.8.0-openjdk* -y

技术图片

// 查看版本
$ java -version

二、安装 nginx


1、通过 rpm 安装 nginx

$ rpm -Uvh?http://nginx.org/packages/centos/7/noarch/RPMS/nginx-release-centos-7-0.el7.ngx.noarch.rpm

技术图片

$ sudo yum install -y nginx

技术图片


2、安装完成后一些文件夹位置和操作如下

// 启动 nginx
$ nginx -c nginx.conf
// 网站文件存放默认目录
$ /usr/share/nginx/html
// 网站默认站点配置
$ /etc/nginx/conf.d/default.conf
// 自定义Nginx站点配置文件存放目录
$ /etc/nginx/conf.d/
// Nginx 全局配置文件
$ /etc/nginx/nginx.conf
// 重启 nginx
$ nginx -s reload
// 基于 nginx 的静态部署
$ server {
$ listen 80;
$ server_name _;
$ root /usr/share/nginx/html;
$ index Home.html;
$ }

3、安装完毕之后,我们需要启动 nginx,启动成功后,访问服务器的 ip 地址,如下图即成功

技术图片


三、安装及启动 jenkins


1、下载安装 jenkins

$ wget?https://mirrors.tuna.tsinghua.edu.cn/jenkins/redhat-stable/jenkins-2.222.3-1.1.noarch.rpm

技术图片

$ yum -y localinstall jenkins-2.222.3-1.1.noarch.rpm

技术图片


2、jenkins 主要目录

// jenkins 安装目录,WAR 包会放在这里
/usr/lib/jenkins/
// jenkins 配置文件,端口,JENKINS_HOME 等都可以在这里配置
/etc/sysconfig/jenkins
// 默认的 JENKINS_HOME
/var/lib/jenkins/
// Jenkins 日志文件
/var/log/jenkins/jenkins.log

3、启动并配置 jenkins

进入配置文件将启动用户修改为 root,默认是 Jenkins

$ vim /etc/sysconfig/jenkins
...
JENKINS USER = "root"
...

// 启动Jenkins
$ systemct1 start jenkins

// 关闭 jenkins
$ systemct1 enable jenkins

在浏览器输入?http://你的ip地址:8080,进入以下界面即成功


注意:这里需要开放 8080 端口


技术图片


4、根据界面提示信息去查看密码

$ cat /var/lib/jenkins/secrets/initialAdminPassword

技术图片


5、将查到的密码粘贴到输入框,点击继续

技术图片


6、出现如下安装插件的界面,选择安装推荐的插件,等待安装完毕

技术图片

技术图片


7、创建第一个用户,实例配置保持默认即可,这样我们就可以开始使用 jenkins

技术图片

技术图片

技术图片


8、出现如下界面,那么 jenkins 就安装成功了

技术图片


四、github?生成 Personal Access Token


1、github --> 头像 --> Settings --> Developer settings --> Personal access tokens --> Generate new token

技术图片


2、勾选如下图所示,最后点击 generate token 生成令牌即可。

技术图片


3、注意!生成令牌之后一点要记录下来,因为只显示一次

技术图片


五、github?设置 GitHub webhooks(具体需要持续集成的项目),新建或者设置现有项目的 webhooks 选项,url:部署的服务器的 IP + 端口 + github-webhook

技术图片


六、设置 jenkinsgithub 配置


1、jenkins 创建一个新任务,填写你的任务名称,并选择构建自由风格项目(很奇怪为什么第一条没有汉化 -.-)

技术图片

技术图片


2、Manage Jenkins --> Configure System

技术图片


3、找到 GitHub 选项 --> 添加 Github 服务器 --> GitHub Server

技术图片


4、勾选 “管理 Hook”,添加 --> Jenkins

技术图片


5、在弹出的窗口中,如下图配置,这里需要用到之前生成的令牌

技术图片


6、选择生成的凭证,测试 jenkins 连接 github 服务器,如下图所示则配置成功,记得在页面底部保存配置。

技术图片


七、设置 jenkins 的项目配置


1、进入该项目的配置项

技术图片


2、选择 github 项目,并填入项目 URL(复制你浏览器上的地址即可)

技术图片


3、在 源码管理下选择 git,并输入 Repository URL(克隆下载你项目的地址)

技术图片


4、出现上图中的错误,是我们没有安装 git 的原因。

// 监测是否安装了 git
$ rpm -qa | grep git
// 安装 git
$ yum install git -y

技术图片

技术图片


5、重新刷新 jenkins 页面,重新填入 url,可以看到错误已经消失。

接着我们选择 Credentials,若下拉选项中有,则直接选择即可。
技术图片

若没有,点击添加 --> jenkins,添加一个 Username with passwrod 类型的权限用户,直接用 github 的登陆名称和密码创建。
技术图片

添加完之后会出现下拉选项,最终配置如下图所示。
技术图片


6、构建触发器 + 构建环境 + 绑定配置

点击新增并选择 secret text 选项,在新出现的选项中选择添加的权限用户
技术图片

技术图片


7、构建配置,添加执行 shell

技术图片

既然可以执行 shell 命令,我们先来执行 pwd,看下默认的工作目录是在哪里。
技术图片

保存后,我们点击立即构建,就会在 build history 下面看到本次构建的 ID(蓝色即构建成功,红色即失败)
技术图片

点击构建 ID 右边的小三角,选择控制台输出。
技术图片

可以看到 jenkins 的默认工作目录在 /var/lib/jenkins/workspace/ceshi
技术图片


8、编写 shell 命令。

不同的前端所用的技术框架是不一样的,所以这里需要根据你自己的项目来进行配置。
这里我以打包一个简单的 h5 页面为例,构建打包代码文件并解压到 nginx 的指定目录,命令如下:

// 当前目录
$ pwd
// 压缩所有文件
$ tar -zcvf ceshi.tar.gz *
// 将打包的压缩文件解压到 nginx 映射目录
$ tar -zxvf /var/lib/jenkins/workspace/ceshi/ceshi.tar.gz -C /usr/share/nginx/html
$ cd /var/lib/jenkins/workspace/ceshi
// 删除项目打包后的残留
$ rm -f *

技术图片


八、测试配置结果

还记得我们之前配置 nginx 成功后的页面吗,就是下面这个,现在我们随便写一个页面来替换掉他。
技术图片

将改动的代码提交到 master 分支,可以看到 Jenkins 会自动构建并新增一条构建记录,然后我们访问你的服务器 IP,可以看到页面已经改变
技术图片

技术图片

技术图片

参考文献:


部署Jenkins
一套真实前端开发环境搭建+可持续集成+自动化部署实践(第一篇环境搭建配置)
一套真实前端开发环境搭建+可持续集成+自动化部署实践(第二篇 jenkins关联 GitHub自动打包部署)
jenkins 的参数化构建
GitLab+Jenkins实现持续集成+自动化部署



本文转载至一个人的江湖 链接

jenkins + GitHub 实现项目自动化部署



推荐阅读
  • CentOS 7部署KVM虚拟化环境之一架构介绍
    本文介绍了CentOS 7部署KVM虚拟化环境的架构,详细解释了虚拟化技术的概念和原理,包括全虚拟化和半虚拟化。同时介绍了虚拟机的概念和虚拟化软件的作用。 ... [详细]
  • 本文介绍了使用Java实现大数乘法的分治算法,包括输入数据的处理、普通大数乘法的结果和Karatsuba大数乘法的结果。通过改变long类型可以适应不同范围的大数乘法计算。 ... [详细]
  • 本文讨论了如何优化解决hdu 1003 java题目的动态规划方法,通过分析加法规则和最大和的性质,提出了一种优化的思路。具体方法是,当从1加到n为负时,即sum(1,n)sum(n,s),可以继续加法计算。同时,还考虑了两种特殊情况:都是负数的情况和有0的情况。最后,通过使用Scanner类来获取输入数据。 ... [详细]
  • 本文介绍了OC学习笔记中的@property和@synthesize,包括属性的定义和合成的使用方法。通过示例代码详细讲解了@property和@synthesize的作用和用法。 ... [详细]
  • Mac OS 升级到11.2.2 Eclipse打不开了,报错Failed to create the Java Virtual Machine
    本文介绍了在Mac OS升级到11.2.2版本后,使用Eclipse打开时出现报错Failed to create the Java Virtual Machine的问题,并提供了解决方法。 ... [详细]
  • 在说Hibernate映射前,我们先来了解下对象关系映射ORM。ORM的实现思想就是将关系数据库中表的数据映射成对象,以对象的形式展现。这样开发人员就可以把对数据库的操作转化为对 ... [详细]
  • 本文详细介绍了Linux中进程控制块PCBtask_struct结构体的结构和作用,包括进程状态、进程号、待处理信号、进程地址空间、调度标志、锁深度、基本时间片、调度策略以及内存管理信息等方面的内容。阅读本文可以更加深入地了解Linux进程管理的原理和机制。 ... [详细]
  • 1,关于死锁的理解死锁,我们可以简单的理解为是两个线程同时使用同一资源,两个线程又得不到相应的资源而造成永无相互等待的情况。 2,模拟死锁背景介绍:我们创建一个朋友 ... [详细]
  • 本文介绍了通过ABAP开发往外网发邮件的需求,并提供了配置和代码整理的资料。其中包括了配置SAP邮件服务器的步骤和ABAP写发送邮件代码的过程。通过RZ10配置参数和icm/server_port_1的设定,可以实现向Sap User和外部邮件发送邮件的功能。希望对需要的开发人员有帮助。摘要长度:184字。 ... [详细]
  • Java验证码——kaptcha的使用配置及样式
    本文介绍了如何使用kaptcha库来实现Java验证码的配置和样式设置,包括pom.xml的依赖配置和web.xml中servlet的配置。 ... [详细]
  • 猜字母游戏
    猜字母游戏猜字母游戏——设计数据结构猜字母游戏——设计程序结构猜字母游戏——实现字母生成方法猜字母游戏——实现字母检测方法猜字母游戏——实现主方法1猜字母游戏——设计数据结构1.1 ... [详细]
  • 本文介绍了lua语言中闭包的特性及其在模式匹配、日期处理、编译和模块化等方面的应用。lua中的闭包是严格遵循词法定界的第一类值,函数可以作为变量自由传递,也可以作为参数传递给其他函数。这些特性使得lua语言具有极大的灵活性,为程序开发带来了便利。 ... [详细]
  • 高质量SQL书写的30条建议
    本文提供了30条关于优化SQL的建议,包括避免使用select *,使用具体字段,以及使用limit 1等。这些建议是基于实际开发经验总结出来的,旨在帮助读者优化SQL查询。 ... [详细]
  • 本文介绍了一种解析GRE报文长度的方法,通过分析GRE报文头中的标志位来计算报文长度。具体实现步骤包括获取GRE报文头指针、提取标志位、计算报文长度等。该方法可以帮助用户准确地获取GRE报文的长度信息。 ... [详细]
  • PDF内容编辑的两种小方法,你知道怎么操作吗?
    本文介绍了两种PDF内容编辑的方法:迅捷PDF编辑器和Adobe Acrobat DC。使用迅捷PDF编辑器,用户可以通过选择需要更改的文字内容并设置字体形式、大小和颜色来编辑PDF文件。而使用Adobe Acrobat DC,则可以通过在软件中点击编辑来编辑PDF文件。PDF文件的编辑可以帮助办公人员进行文件内容的修改和定制。 ... [详细]
author-avatar
修竹
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有