持续集成框架jenkins介绍01-简易安装

一。Jenkins介绍

    持续集成是一个开发的实践,需要开发人员定期集成代码到共享存储库(git svn) jenkins定义任务从共享仓库定时抓取 或者用户手工触发抓取仓储库 源码 自动构建到可运行环境

持续集成框架jenkins介绍01-简易安装_第1张图片


二。 安装Jenkins

  1》 安装环境 

   操作系统:centos7  

   jenkins官网 https://jenkins.io/

   jenkins是一个webui程序 下载对应war包即可 下载地址 

https://jenkins.io/download 点击最下方的

   Generic Java package (.war)  

 2》安装运行环境

   安装jdk  省略

   安装tomcat  yum -y install tomcat  安装目录是/usr/share/tomcat

3》安装过程

  将 war包丢入 /usr/share/tomcat/webapps目录

  启动 tomcat  service tomcat start

  使用浏览器访问 http://192.168.58.150:8080/jenkins

出现解锁 jenkins的界面

持续集成框架jenkins介绍01-简易安装_第2张图片

要求你输入一个密码 并且上面文字告诉你 该密码

/usr/share/tomcat/.jenkins/secrets/initialAdminPassword
linux下查看该文件 

[root@node3 tomcat]# more /usr/share/tomcat/.jenkins/secrets/initialAdminPassword
8c98247b3e9044e9b2a531a4ff689ef9

查询到了32位的密码 输入

接下来 定制 jenkins

持续集成框架jenkins介绍01-简易安装_第3张图片

选择第一项 安装建议的插件  联网下载插件

持续集成框架jenkins介绍01-简易安装_第4张图片

等待所有插件 安装完成(需要一定时间)

所有插件安装在 tomcat根目录\.jenkins\plugins目录下

接下来 创建你的用户

持续集成框架jenkins介绍01-简易安装_第5张图片

输入用户名和两次密码(全名和电子邮件随便输入 不输入会卡住)点击Save and Finish

成功界面   点击 start using jenkins

持续集成框架jenkins介绍01-简易安装_第6张图片

三 。用户管理

Jenkins下默认的管理员是admin如果界面上添加了你的首个用户 新用户将替代admin 

查找 tomcat根目录\.jenkins\users\目录下 就是用户名的目录 比如我新建了一个账号liaomin789

该目录下就有一个目录 liaomin789我新建一个账户就可以拷贝一个该文件夹

比如 cp -r liaomin789 jiaozi789  就可以使用jiaozi789作为用户名liaomin789的密码登录发现也可以登录

如果需要修改密码 进入jiaozi789目录 下有个config.xml查看该文件 发现这样几行

hudson.security.HudsonPrivateSecurityRealm_-Details>
      #jbcrypt:$2a$10$PxRfxmGqodLR.5xyPUvNruMdIqniKkHXOGkZnwK08FNgOqEEDxHwK

passwordHash是加密的  加密使用的是jbcrypt 前缀网上搜索该算法

持续集成框架jenkins介绍01-简易安装_第7张图片

点击第一条记录进入官网  下载源码

持续集成框架jenkins介绍01-简易安装_第8张图片

解压 发现只有一个源文件(BCrypt.java) 拷贝到eclipse项目中 添加一个测试类


Test代码拷贝官网 修改测试一下

package org.mindrot.jbcrypt;

public class Test {
	public static void main(String[] args) {
		//原始密码
		String password="123456";
		// 加密
		String hashed = BCrypt.hashpw(password, BCrypt.gensalt());

		//判断原始字符串和加密后的串匹配则验证通过
		if (BCrypt.checkpw(password, hashed))
			System.out.println("验证通过");
		else
			System.out.println("验证失败");
	}
}
其实也到这里 应该最终生成的密码也就是这个 hashed加上那个前缀了 不过我还是得分析到底 找半天官网不知道源代码在哪 

解压  jenkinsWar找到web-infs/lib下的jenkins-core-2.73.2.jar(一般加解密都在core中吧) 反编译该jarjdgui)导出所有源代码

持续集成框架jenkins介绍01-简易安装_第9张图片

Window目录 选项选择搜索文字内容 

持续集成框架jenkins介绍01-简易安装_第10张图片

搜索关键字 jbcrypt


找到类后 重新到jdgui下查看该类  ctrl+shift+T输入刚刚搜索到的类名

持续集成框架jenkins介绍01-简易安装_第11张图片

该类上找到以下代码

 private static final PasswordEncoder JBCRYPT_ENCODER = new PasswordEncoder()
  {
    public String encodePassword(String rawPass, Object _)
      throws DataAccessException
    {
      return BCrypt.hashpw(rawPass, BCrypt.gensalt());
    }
    
    public boolean isPasswordValid(String encPass, String rawPass, Object _)
      throws DataAccessException
    {
      return BCrypt.checkpw(rawPass, encPass);
    }
  };
  public static final PasswordEncoder PASSWORD_ENCODER = new PasswordEncoder()
  {
    private static final String JBCRYPT_HEADER = "#jbcrypt:";
    
    public String encodePassword(String rawPass, Object salt)
      throws DataAccessException
    {
      return "#jbcrypt:" + HudsonPrivateSecurityRealm.JBCRYPT_ENCODER.encodePassword(rawPass, salt);
    }
    
    public boolean isPasswordValid(String encPass, String rawPass, Object salt)
      throws DataAccessException
    {
      if (encPass.startsWith("#jbcrypt:")) {
        return HudsonPrivateSecurityRealm.JBCRYPT_ENCODER.isPasswordValid(encPass.substring("#jbcrypt:".length()), rawPass, salt);
      }
      return HudsonPrivateSecurityRealm.CLASSIC.isPasswordValid(encPass, rawPass, salt);
    }
  };
懂java的都看懂了吧 

发现encodePassword方法加密实际上就是我之前的测试代码 加个前缀

"#jbcrypt:" + BCrypt.hashpw(password, BCrypt.gensalt())

修改我的测试类

package org.mindrot.jbcrypt;

public class Test {
	public static void main(String[] args) {
		//原始密码
		String password="123456";
		// 加密
		String hashed = BCrypt.hashpw(password, BCrypt.gensalt());
		//输出正确密码
		System.out.println("#jbcrypt:" +hashed);
		//判断原始字符串和加密后的串匹配则验证通过
		if (BCrypt.checkpw(password, hashed))
			System.out.println("验证通过");
		else
			System.out.println("验证失败");
	}
}

运行 可以获取到123456的密码 比如我生成的是

#jbcrypt:$2a$10$5Qy7ZvyfNy5UgMs1rh2aoOgaqdpz83wRepky5qx7V52I16UWRhDyy

修改 tomcat根目录下/.jenkins/jiaozi789/config.xml

替换passwordHash内容

#jbcrypt:$2a$10$5Qy7ZvyfNy5UgMs1rh2aoOgaqdpz83wRepky5qx7V52I16UWRhDyy
重启tomcat  service tomcat restart
重新登录网页发现jiaozi789新建用户 使用密码 123456可以正常登录了

你可能感兴趣的:(项目管理,linux,maven)