容器 & 服务:Jenkins本地及docker安装部署

简介: jenkins是常用的开源持续继承工具,现在所在的工作场景,也是使用jenkins进行基于github代码的拉取、打包、构建、部署的一系列流程,并结合了容器和函数计算实现金丝雀部署。本文先从基础的jenkins环境搭建开始。

系列文章:

容器 & 服务:开篇,压力与资源

前言

   jenkins是常用的开源持续继承工具,现在所在的工作场景,也是使用jenkins进行基于github代码的拉取、打包、构建、部署的一系列流程,并结合了容器和函数计算实现金丝雀部署。本文先从基础的jenkins环境搭建开始。

一 jenkins本地安装部署

jenkins官网的下载速度太慢,可使用下面镜像:

清华镜像

jenkins ci

官网文档,jenkins入门,下载jenkins.war之后,使用下面命令启动和访问:

1.下载 Jenkins.

  • 2.打开终端进入到下载目录.
  • 3.运行命令 java -jar jenkins.war --httpPort=8080.
  • 4.打开浏览器进入链接 http://localhost:8080.
  • 5.按照说明完成安装.

按照说明,java -jar jenkins.war --httpPort=8080 后控制台输出如下:

-rw-r--r--@ 1 qingclass  staff  66175731  2  7 16:28 jenkins.war
bogon:jenkins qingclass$ 
bogon:jenkins qingclass$ 
bogon:jenkins qingclass$ java -jar jenkins.war --httpPort=8080
Running from: /Users/qingclass/develop/mine/projects/container/jenkins/jenkins.war
webroot: $user.home/.jenkins
2021-02-07 08:28:58.638+0000 [id=1] INFO  org.eclipse.jetty.util.log.Log#initialized: Logging initialized @450ms to org.eclipse.jetty.util.log.JavaUtilLog
2021-02-07 08:28:58.751+0000 [id=1] INFO  winstone.Logger#logInternal: Beginning extraction from war file
2021-02-07 08:29:00.126+0000 [id=1] WARNING o.e.j.s.handler.ContextHandler#setContextPath: Empty contextPath
2021-02-07 08:29:00.180+0000 [id=1] INFO  org.eclipse.jetty.server.Server#doStart: jetty-9.4.25.v20191220; built: 2019-12-20T17:00:00.294Z; git: a9729c7e7f33a459d2616a8f9e9ba8a90f432e95; jvm 1.8.0_212-b10
2021-02-07 08:29:00.447+0000 [id=1] INFO  o.e.j.w.StandardDescriptorProcessor#visitServlet: NO JSP Support for /, did not find org.eclipse.jetty.jsp.JettyJspServlet
2021-02-07 08:29:00.486+0000 [id=1] INFO  o.e.j.s.s.DefaultSessionIdManager#doStart: DefaultSessionIdManager workerName=node0
2021-02-07 08:29:00.486+0000 [id=1] INFO  o.e.j.s.s.DefaultSessionIdManager#doStart: No SessionScavenger set, using defaults
2021-02-07 08:29:00.491+0000 [id=1] INFO  o.e.j.server.session.HouseKeeper#startScavenging: node0 Scavenging every 600000ms
2021-02-07 08:29:00.768+0000 [id=1] INFO  hudson.WebAppMain#contextInitialized: Jenkins home directory: /Users/qingclass/.jenkins found at: $user.home/.jenkins
2021-02-07 08:29:02.331+0000 [id=1] INFO  o.e.j.s.handler.ContextHandler#doStart: Started w.@1cf2fed4{Jenkins v2.220,/,file:///Users/qingclass/.jenkins/war/,AVAILABLE}{/Users/qingclass/.jenkins/war}
2021-02-07 08:29:02.363+0000 [id=1] INFO  o.e.j.server.AbstractConnector#doStart: Started ServerConnector@1a4927d6{HTTP/1.1,[http/1.1]}{0.0.0.0:8080}
2021-02-07 08:29:02.363+0000 [id=1] INFO  org.eclipse.jetty.server.Server#doStart: Started @4176ms
2021-02-07 08:29:02.364+0000 [id=23]  INFO  winstone.Logger#logInternal: Winstone Servlet Engine running: controlPort=disabled
2021-02-07 08:29:03.159+0000 [id=30]  INFO  jenkins.InitReactorRunner$1#onAttained: Started initialization
2021-02-07 08:29:03.174+0000 [id=50]  INFO  jenkins.InitReactorRunner$1#onAttained: Listed all plugins
2021-02-07 08:29:04.066+0000 [id=37]  INFO  jenkins.InitReactorRunner$1#onAttained: Prepared all plugins
2021-02-07 08:29:04.071+0000 [id=37]  INFO  jenkins.InitReactorRunner$1#onAttained: Started all plugins
2021-02-07 08:29:04.076+0000 [id=45]  INFO  jenkins.InitReactorRunner$1#onAttained: Augmented all extensions
2021-02-07 08:29:04.637+0000 [id=50]  INFO  jenkins.InitReactorRunner$1#onAttained: System config loaded
2021-02-07 08:29:04.637+0000 [id=40]  INFO  jenkins.InitReactorRunner$1#onAttained: System config adapted
2021-02-07 08:29:04.637+0000 [id=48]  INFO  jenkins.InitReactorRunner$1#onAttained: Loaded all jobs
2021-02-07 08:29:04.638+0000 [id=48]  INFO  jenkins.InitReactorRunner$1#onAttained: Configuration for all jobs updated
2021-02-07 08:29:04.647+0000 [id=64]  INFO  hudson.model.AsyncPeriodicWork#lambda$doRun$0: Started Download metadata
2021-02-07 08:29:04.656+0000 [id=64]  INFO  hudson.util.Retrier#start: Attempt #1 to do the action check updates server
2021-02-07 08:29:05.281+0000 [id=31]  INFO  o.s.c.s.AbstractApplicationContext#prepareRefresh: Refreshing org.springframework.web.context.support.StaticWebApplicationContext@b824f1b: display name [Root WebApplicationContext]; startup date [Sun Feb 07 16:29:05 CST 2021]; root of context hierarchy
2021-02-07 08:29:05.281+0000 [id=31]  INFO  o.s.c.s.AbstractApplicationContext#obtainFreshBeanFactory: Bean factory for application context [org.springframework.web.context.support.StaticWebApplicationContext@b824f1b]: org.springframework.beans.factory.support.DefaultListableBeanFactory@5dd6b4ad
2021-02-07 08:29:05.290+0000 [id=31]  INFO  o.s.b.f.s.DefaultListableBeanFactory#preInstantiateSingletons: Pre-instantiating singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@5dd6b4ad: defining beans [authenticationManager]; root of factory hierarchy
2021-02-07 08:29:05.427+0000 [id=31]  INFO  o.s.c.s.AbstractApplicationContext#prepareRefresh: Refreshing org.springframework.web.context.support.StaticWebApplicationContext@11ce086b: display name [Root WebApplicationContext]; startup date [Sun Feb 07 16:29:05 CST 2021]; root of context hierarchy
2021-02-07 08:29:05.427+0000 [id=31]  INFO  o.s.c.s.AbstractApplicationContext#obtainFreshBeanFactory: Bean factory for application context [org.springframework.web.context.support.StaticWebApplicationContext@11ce086b]: org.springframework.beans.factory.support.DefaultListableBeanFactory@79f651d3
2021-02-07 08:29:05.427+0000 [id=31]  INFO  o.s.b.f.s.DefaultListableBeanFactory#preInstantiateSingletons: Pre-instantiating singletons in org.springframework.beans.factory.support.DefaultListableBeanFactory@79f651d3: defining beans [filter,legacy]; root of factory hierarchy
2021-02-07 08:29:05.561+0000 [id=31]  INFO  jenkins.install.SetupWizard#init: 
*************************************************************
*************************************************************
*************************************************************
Jenkins initial setup is required. An admin user has been created and a password generated.
Please use the following password to proceed to installation:
1072ca47a779473dbad450aee6d6946e
This may also be found at: /Users/qingclass/.jenkins/secrets/initialAdminPassword

浏览器访问,注意,页面会提示等待初始化,结束后会自动跳转到首页,这个过程会花1-2分钟时间,并非出错。

image.png

待弹出上面这个输入秘钥页面时,输入上面的1072ca47a779473dbad450aee6d6946e 完成安装,进入后续操作即可。

完成后,进入熟悉的页面:

image.png

二 docker下的安装部署

注,这里不再介绍docker的安装方式,默认已完成本地的docker部署。

笔者使用的docker版本如下:

flamingskys:logs $ docker --version
Docker version 19.03.5, build 633a0ea

在docker中下载并安装jenkins,可参照说明: docker中安装jenkins,使用镜像: jenkinsci/blueocean,这是来自 Docker Hub repository 的jenkins Docker镜像。

安装步骤:

1、使用下面命令直接运行:

docker run -p 8080:8080 jenkinsci/blueocean

2、run成功后,当看到下面输出时,代表已经启动完成。浏览器中通过http://localhost:8080端口访问,与本地部署相同:密码: d71cb009aa2e4343896110ccbc86778d

相关文章
|
4月前
|
Linux 网络安全 Docker
盘古栈云,创建带ssh服务的linux容器
创建带ssh服务的linux容器
366 146
|
4月前
|
监控 Kubernetes 安全
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
蒋星熠Jaxonic,技术探索者,以代码为笔,在二进制星河中书写极客诗篇。专注Docker与容器化实践,分享从入门到企业级应用的深度经验,助力开发者乘风破浪,驶向云原生新世界。
还没搞懂Docker? Docker容器技术实战指南 ! 从入门到企业级应用 !
|
4月前
|
监控 Linux 调度
【赵渝强老师】Docker容器的资源管理机制
本文介绍了Linux CGroup技术及其在Docker资源管理中的应用。通过实例演示了如何利用CGroup限制应用程序的CPU、内存和I/O带宽使用,实现系统资源的精细化控制,帮助理解Docker底层资源限制机制。
455 6
|
4月前
|
NoSQL 算法 Redis
【Docker】(3)学习Docker中 镜像与容器数据卷、映射关系!手把手带你安装 MySql主从同步 和 Redis三主三从集群!并且进行主从切换与扩容操作,还有分析 哈希分区 等知识点!
Union文件系统(UnionFS)是一种**分层、轻量级并且高性能的文件系统**,它支持对文件系统的修改作为一次提交来一层层的叠加,同时可以将不同目录挂载到同一个虚拟文件系统下(unite several directories into a single virtual filesystem) Union 文件系统是 Docker 镜像的基础。 镜像可以通过分层来进行继承,基于基础镜像(没有父镜像),可以制作各种具体的应用镜像。
636 5
|
4月前
|
存储 关系型数据库 MySQL
MySQL Docker 容器化部署全指南
MySQL是一款开源关系型数据库,广泛用于Web及企业应用。Docker容器化部署可解决环境不一致、依赖冲突问题,实现高效、隔离、轻量的MySQL服务运行,支持数据持久化与快速迁移,适用于开发、测试及生产环境。
773 5
|
jenkins Java Shell
使用 Docker 安装 Jenkins 并实现项目自动化部署
Jenkins 是一款开源的持续集成(DI)工具,广泛用于项目开发,能提供自动构建,测试,部署等功能。作为领先的开源自动化服务器,Jenkins 提供了数百个插件来支持构建、部署和自动化任何项目。
36568 3
使用 Docker 安装 Jenkins 并实现项目自动化部署
|
Ubuntu jenkins 持续交付
Ubuntu系统 用docker安装jenkins
Ubuntu系统 用docker安装jenkins