Jenkins 如何重新启动
在这篇文章中,我们将了解什么是Jenkins以及它如何进一步发展我们的DevOps持续集成环境。
在Jenkins之前,我们是能够编写代码、将代码提交到代码库并开始编写单元测试的开发人员。尽管我们运行了单元测试,但实际提交到代码仓库的代码应该更稳定。作为开发人员,我们可能被分散在不同的地方。在印度有一个开发人员,在菲律宾有一个开发人员,在英国有一个领导者,在北美有一个开发团队。因此,我们工作的时间不同,代码库中进入的代码量也不同;存在集成问题,我们遇到了一种我们称之为改进的情况。
以前,我们必须等待整个软件代码构建和测试完成,然后才能开始检查错误,这增加了我们在项目中可能遇到的问题数量。软件交付流程可能会更快,我们可能无法强调我们的产品。
什么是Jenkins
Jenkins是一个源于我们可能听说过的持续集成理念的产品,根据这个理念,两个开发人员可以坐在一起针对同一段信息进行编码;他们能够不断改进自己的代码并测试自己的代码。
Jenkins是一个持续集成工具,它允许持续开发、测试和部署新创建的代码。
Jenkins是一个允许我们整个团队在源代码环境中可靠地提交代码的工具。因此,我们可以通过两种方式实现持续交付,一种是通过每日构建,另一种是通过持续集成。
我们可以通过改变传统的构建解决方案来实现持续交付。
什么是持续集成
持续集成的概念是,作为开发人员,我们可以从代码库中拉取我们正在处理的代码,然后随时将正在处理的代码提交到一个持续集成服务器。
持续集成服务器旨在验证和完成分析师进行的任何测试。
如果在持续集成服务器上未通过测试,该代码将被退回给开发人员,开发人员可以进行更改。它还使开发人员能够做一些事情。它允许开发人员不破坏构建,我们都不愿意破坏已经创建的构建。但它允许开发人员在他们的计算机上仅运行一些测试。
假设我们有很多测试,我们可以在持续集成服务器等其他环境中推送该支持。这提高了我们开发人员的效率。
假设我们遇到了任何超出标准CI测试范围的代码错误,可能是我们编写的冲突代码,这些错误可以从分析师轻松地传递给开发人员。
进行这种测试的目标是我们能够发布和部署,我们的客户能够更快地获取新代码,并且当他们获取到该代码时,它可以正常工作。
一致加入设备
与一致加入设备一起工作的事情是它们是开源的。
Bamboo
Bamboo是一个恒定的混合设备,可以运行多种形式以实现更快的组合。它具有与存储区连接的内置功能,并为错误、专家等构建任务提供了内部任务。
Buildbot
Buildbot是一个用于自动化软件、构建、测试和交付过程的开源框架。它使用Python编写,并支持在多个平台上适当、并行执行任务。
Apache Gump
Apache Gump是专门用于构建和测试所有开源Java项目的工具。它确保每个项目在API和功能两个级别上都是可行的。
Travis CI
Travis CI是一个托管的、分布式的持续集成服务,用于构建和测试托管在GitHub上的软件项目。它适用于各种规模的项目和团队,并支持20多种语言。
存储代码和构建代码的一个著名地点是GitHub,这是一项在线服务,最近被微软收购。如果我们将项目存储在GitHub中,我们可以使用Travis CI的无限集成功能,这是一款专为托管项目设计的工具。
Jenkins
Jenkins是一个用Java编写的开源自动化服务器。它通过持续集成自动化软件开发流程,并支持持续交付。
它还是我们操作的整体自动化的中心工具。在使用Jenkins时,我们有时会找到提到“Hudson”产品的文档。Hudson是最初成为Jenkins的产品的第一个版本,后来被Oracle收购;当收购发生时,Hudson背后的团队担心Oracle可能会对Hudson采取什么方向,因此他们将Hudson进行了一次分叉,并将其命名为Jenkins。
因此,我们正在将新功能添加为我们CI环境的核心工具。
Jenkins的元素
Jenkins提供了一些不同的功能。因此,Jenkins围绕简单安装、简单配置、模块、可扩展性和交付这五个重要领域。
让我们简要地讨论这五个功能。
1. 简单安装 Jenkins是一个独立的基于Java的程序,可以在Windows、Mac操作系统和Unix软件包上运行。我们甚至可以在Linux上运行它。
2. 简单配置 它可以通过其web界面轻松设置和配置,包括错误检查和内置帮助。
3. 模块 在更新社区中,有许多模块,并与每个工具在持续集成和Disc工具链中进行集成。
4. 可扩展 Jenkins可以通过其模块化设计进行扩展,并为其提供几乎无限的可能。
5. 分布式 它可以将工作分布到多台机器上,在多个平台上进行更快的构建、测试和部署。
Jenkins Pipeline
在我们的PC上创建和编码时,与Jenkins管道一起工作时,我们应该做的主要事情是提交我们的代码。作为一名工程师,我们已经在做这个,简单地将我们的代码保存到一个Git服务器、svn服务器或类似的服务中。
在这种情况下,我们将Jenkins作为提交我们代码的地方。
然后,Jenkins将生成我们代码的一个版本;版本的其中一部分是经过测试的。
作为工程师,他们已经可以运行单元测试并编写这些测试来验证我们的代码。然而,Jenkins可能会运行额外的测试。例如,我们可能有一套标准的测试来检验我们编写的代码,以便每个同事都可以理解该代码。这些测试也可以包含在Jenkins环境中的测试框架中。
如果评估一切都完成了,我们可以在Jenkins中设置一个阶段,并在其中创建一个准备好的环境。
最后,我们准备好将我们的代码部署到生产环境中了。
Jenkins将是帮助我们将代码发送到生产环境的服务器环境的工具。结果是,我们可以快速从开发人员切换到生产代码。
因此,这个过程可以自动化,而不是依赖人们测试我们的代码或进行每日构建。我们必须专注于我们的代码并不断审查这个测试和发布过程。
Jenkins技术工程
Jenkins内部的工程允许我们有效地应用持续交付的DevOps环境。
服务器架构分为两个部分。在段的左侧是代码,工程师正在进行操作并将该代码提交到源代码库中。
此后,Jenkins成为我们的持续集成服务器,它会从源代码库中提取任何发送给它的代码并对其进行测试。它会使用构建服务器(如Expert)构建代码,并且在Jenkins的每个阶段中都有连续的测试。
例如,如果构建失败,将反馈给开发人员,以便他们可以更改代码,使构建环境能够成功运行。
最后一个阶段是执行特定的测试脚本,可以使用Selenium编写。值得一提的是,Mavin和Selenium是Jenkins环境中的模块,而Mavin和Selenium是扩展Jenkins环境的两个流行实例。
通过再次将这个整个过程作为自动化流程来进行,我们可以尽快生成完全测试和无错误的代码。因此,提到Jenkins环境的一个重要信息是,如果我们有多个代码构建需要进行管理和分发,那么将需要多个不同版本的Jenkins运行在不同的服务器环境中。
我们如何检查Jenkins中的专家从属系统架构
Jenkins专家从属系统架构
上述概述显示了Jenkins ace从属工程的概述。远程源代码存档位于左侧,可以是GitHub、团队组建福利、新的Sky Blue DevOps代码库,或者我们的Git保险库。Jenkins服务器充当左侧的专家环境,该专家环境然后可以推送到多个其他Jenkins从属环境。
Jenkins上下文分析
让我们来看一个有效利用了Jenkins的组织的短篇故事。以下是一个利用案例情况。在过去的10到15年里,汽车业发生了重大转变,制造商从生产复杂的机械转向了创建软件。我们可以看到像特斯拉这样的公司,他们构建软件来管理他们的车辆。
我们在一些公司中也看到了同样的情况,比如通用汽车的不间断程序。
段落
段落最近重新定位自己为技术公司而不仅仅是汽车公司。这意味着这些车辆内部的软件越来越复杂,需要更多的测试来增加核心软件的功能和改进。
博世公司
因此,博世公司特别遇到了这个问题。他们的挑战是通过采用持续集成和持续交付的最佳实践来简化越来越复杂的汽车软件,以取悦并超越最终用户的期望。因此,博世公司使用了CloudBees,它是企业Jenkins环境。为了减少像构建、部署和测试这样的手动步骤,博世引入了CloudBees来自Jenkins的使用,它是企业Jenkins平台的一部分。
CloudBees
因此,CloudBees Jenkins平台帮助他们通过减少手动步骤和工作重复来满足需求,在构建、部署和测试过程中提高了效率。Jenkins平台在自动化的可靠性和透明度方面显著改善,因为Jenkins变成了一个自我检测的环境。
结果是明显的。之前需要三天才能完成一个构建过程。现在采用了相同的三天策略,并将其缩短到不到三个小时,这是非常重要的。
大规模的解决方案现在保持了竞争力,并得到了专业支持。
Jenkins工具在整个项目中具有清晰的可见性和透明度。
重新启动Jenkins
在使用Jenkins时,用户可能需要手动重新启动它。这可能是由于故障排除或安装模块等各种原因,并且Jenkins提供了多种方法来执行手动重新启动。
通过URL重新启动Jenkins
如果我们在网络浏览器中打开Jenkins仪表板,通过输入相关URL并使用默认的重启URL来重新启动Jenkins,将立即重新启动,而不需要等待任何构建完成。
[Jenkins URL]/restart
利用安全重启选项,在重启之前完成所有当前正在运行的任务。新的位置将排队并继续执行,直到重启完成。
[Jenkins URL]/safeRestart
这两个选择需要通过点击“是”按钮来确认重新启动。
Jenkins的URL包含了框架的主机名和Jenkins运行的端口。如果我们正在我们的框架上登录Jenkins的仪表板,我们使用以下内容:
http://localhost:8080/restart
http://localhost:8080/safeRestart