zoukankan      html  css  js  c++  java
  • Jenkins系列-Jenkins用户权限和角色配置

    由于jenkins默认的权限管理体系不支持用户组或角色的配置,因此需要安装第三发插件来支持角色的配置,这边将使用Role Strategy Plugin,介绍页面:https://wiki.jenkins-ci.org/display/JENKINS/Role+Strategy+Plugin

    下载插件

     

    进入jenkins的插件管理,讲下好的hpi文件上传:

     

     配置插件

    安装插件后,进入系统设置页面,配置如下:

     

    官网上安全域设置为Servlet容器代理,实际操作发现Jenkins专有用户数据库也是可以的。

    配置权限

    在系统管理页面点击Manage and Assign Roles进入角色管理页面: 

     

    进入之后:

    1、管理角色(Manage Roles)
    选择该项可以创建全局角色、项目角色,并可以为角色分配权限。

     

    各种权限如下(在配置页面将鼠标放到该权限上即可查看帮助):

    Overall(全局) Credentials(凭证) Slave(节点) Job(任务) View(视图)
    Administer Read RunScripts UploadPlugins ConfigureUpdateCenter Create Update View Delete ManageDomains Configure Delete Create Disconnect Connect Build Create Delete Configure Read Discover Build Workspace Cancel Create Delete Configure Read
    管理员(最大) 阅读 运行脚本 升级插件 配置升级中心 创建 更新 查看 删除 管理域 配置 删除 创建 断开连接 连接 构建 创建 删除 配置 阅读 重定向 构建 查看工作区 取消构建 创建 删除 配置 阅读

    如上图,分别创建了admin、anonymous两个全局角色,Online Program、test两个项目角色。

    项目角色与全局角色的区别就是,项目角色只能管理项目,没有管理jenkins的权限配置。

    添加项目角色时,需要制定匹配项目的模式,如上图中的Pattern,官方文档介绍该选项支持正则表达式,如“Roger-.”表示所有以Roger-开头的项目,“(?i)roger-.*”表示以roger-开头的项目并且不区分大小写,如以ABC开头的项目可以配置为“ABC|ABC.*”,也可以使用“abc|bcd|efg”直接匹配多个项目。

    2、创建用户
    在分配角色之前需要先创建用户。

    在系统管理页面,点击管理用户:

     

    点击新建使用者可以创建新用户,如果之前有项目与scm版本管理系统(如svn、git等)连接并获取源码构建过,jenkins会从svn中读取到一些用户信息,可以在查看用户菜单中看到这些用户:

     

    点击用户id或名称都可以修改用户信息。

     

    选择Assign Roles可以为用户分配所属角色,可以分配全局角色和项目角色。

     

    如上图,将不同的用户分别分配给不同的角色,这样用户就可以具有角色所拥有的权限。

    深入了解

    该插件从201110月发布1.1.2版本后就不再维护了,因此会有一些小问题,但不影响使用,比如在分配角色后点击保存按钮时有可能会发生异常,浏览器点击后退按钮后重新提交就可以操作成功。

    另外如果配置失败导致不能登录,可以通过修改配置文件恢复初始设置。

    首先了解一下配置文件。

    进入jenkins安装目录,用户配置信息和角色配置信息都以配置文件的形式存储。

    上图中users目录存放了各个用户的配置信息,每个用户都会创建与用户名相同的文件夹,文件夹中包含config.xml文件,配置示例如下:

        <?xml version='1.0' encoding='UTF-8'?>
        <user>
          <fullName>admin</fullName>
          <properties>
            <jenkins.security.ApiTokenProperty>
              <apiToken>EfowsOP9H5arYxMmuFrbPjjITgu/fjtvHib5okFJ9DmPTu/088cvHxlE9RHwVv+S</apiToken>
            </jenkins.security.ApiTokenProperty>
            <hudson.model.MyViewsProperty>
              <views>
                <hudson.model.AllView>
                  <owner class="hudson.model.MyViewsProperty" reference="http://www.cnblogs.com/.."/>
                  <name>All</name>
                  <filterExecutors>false</filterExecutors>
                  <filterQueue>false</filterQueue>
                  <properties class="hudson.model.View$PropertyList"/>
                </hudson.model.AllView>
              </views>
            </hudson.model.MyViewsProperty>
            <hudson.search.UserSearchProperty>
              <insensitiveSearch>false</insensitiveSearch>
            </hudson.search.UserSearchProperty>
            <hudson.security.HudsonPrivateSecurityRealm_-Details>
              <passwordHash>uAEYii:02e0cd0d78abf90e42b28e7d3d4fe64776ae8fa9500e379f2598cc65e1b0fb70</passwordHash>
            </hudson.security.HudsonPrivateSecurityRealm_-Details>
            <hudson.tasks.Mailer_-UserProperty>
              <emailAddress>gaoliang@esrichina.com.cn</emailAddress>
            </hudson.tasks.Mailer_-UserProperty>
          </properties>
    
    </user>

    角色配置在$Jenkins_home/config.xml文件中,示例如下:

        <useSecurity>true</useSecurity>
        <authorizationStrategy class="com.michelin.cio.hudson.plugins.rolestrategy.RoleBasedAuthorizationStrategy">
          <roleMap type="globalRoles">
            <role name="admin" pattern=".*">
              <permissions>
                <permission>hudson.model.Hudson.Read</permission>
                <permission>hudson.model.Hudson.Administer</permission>
                <permission>hudson.model.View.Delete</permission>
                <permission>hudson.model.Computer.Create</permission>
                <permission>hudson.model.Computer.Delete</permission>
                <permission>hudson.model.Hudson.RunScripts</permission>
                <permission>hudson.model.View.Read</permission>
                <permission>hudson.model.Run.Update</permission>
                <permission>hudson.model.Item.Workspace</permission>
                <permission>hudson.model.Computer.Connect</permission>
                <permission>hudson.model.Computer.Configure</permission>
                <permission>hudson.model.Item.Cancel</permission>
                <permission>hudson.model.Item.Configure</permission>
                <permission>hudson.model.Item.Discover</permission>
                <permission>hudson.model.Item.Create</permission>
                <permission>hudson.model.View.Configure</permission>
                <permission>hudson.model.Computer.Disconnect</permission>
                <permission>hudson.model.Item.Delete</permission>
                <permission>hudson.model.Item.Read</permission>
                <permission>hudson.model.Item.Build</permission>
                <permission>hudson.model.Run.Delete</permission>
                <permission>hudson.model.View.Create</permission>
                <permission>hudson.scm.SCM.Tag</permission>
              </permissions>
              <assignedSIDs>
                <sid>admin</sid>
              </assignedSIDs>
            </role>
            <role name="anonymous" pattern=".*">
              <permissions>
                <permission>hudson.model.Hudson.Read</permission>
              </permissions>
              <assignedSIDs>
                <sid>anonymous</sid>
              </assignedSIDs>
            </role>
          </roleMap>
          <roleMap type="projectRoles">
            <role name="Online Program" pattern="GeoQPortal|GeoQUserPortal">
              <permissions>
                <permission>hudson.model.Item.Read</permission>
                <permission>hudson.model.Item.Build</permission>
                <permission>hudson.model.Run.Delete</permission>
                <permission>hudson.model.Item.Workspace</permission>
                <permission>hudson.model.Run.Update</permission>
                <permission>hudson.scm.SCM.Tag</permission>
                <permission>hudson.model.Item.Cancel</permission>
                <permission>hudson.model.Item.Discover</permission>
              </permissions>
              <assignedSIDs>
                <sid>caox</sid>
                <sid>wangwh</sid>
                <sid>yuh</sid>
                <sid>chenjj</sid>
                <sid>lim</sid>
                <sid>zhangy</sid>
              </assignedSIDs>
            </role>
            <role name="test" pattern="Compress">
              <permissions>
                <permission>hudson.model.Item.Delete</permission>
                <permission>hudson.model.Item.Read</permission>
                <permission>hudson.model.Item.Build</permission>
                <permission>hudson.model.Run.Delete</permission>
                <permission>hudson.model.Item.Workspace</permission>
                <permission>hudson.model.Run.Update</permission>
                <permission>hudson.scm.SCM.Tag</permission>
                <permission>hudson.model.Item.Cancel</permission>
                <permission>hudson.model.Item.Configure</permission>
                <permission>hudson.model.Item.Discover</permission>
              </permissions>
              <assignedSIDs>
                <sid>wangwh</sid>
              </assignedSIDs>
            </role>
          </roleMap>
        </authorizationStrategy>
        <securityRealm class="hudson.security.HudsonPrivateSecurityRealm">
          <disableSignup>false</disableSignup>
          <enableCaptcha>false</enableCaptcha>
        </securityRealm>

    如果发生用户不能登录的情况,可以尝试以下几种方法解决

    1、方法1

    • 删除用户相关的目录
    • 修改$Jenkins_home/config.xml文件:<useSecurity>false</useSecurity>
    • 删除authorizationStrategy、securityRealm节点
    • 重新启动Jenkins

    使用该方法将删除Jenkins的权限管理,恢复成为初始状态。

    2、方法2

    • 修改$Jenkins_home/config.xml文件,修改授权方式为系统自带的安全矩阵方式authorizationStrategy节点class属性修改为hudson.security.GlobalMatrixAuthorizationStrategy
    • 配置示例如下,该示例是分配给admin用户所有权限
        <useSecurity>true</useSecurity>
        <authorizationStrategy class="hudson.security.GlobalMatrixAuthorizationStrategy">
          <permission>hudson.model.Computer.Configure:admin</permission>
          <permission>hudson.model.Computer.Connect:admin</permission>
          <permission>hudson.model.Computer.Create:admin</permission>
          <permission>hudson.model.Computer.Delete:admin</permission>
          <permission>hudson.model.Computer.Disconnect:admin</permission>
          <permission>hudson.model.Hudson.Administer:admin</permission>
          <permission>hudson.model.Hudson.Read:admin</permission>
          <permission>hudson.model.Hudson.Read:anonymous</permission>
          <permission>hudson.model.Hudson.RunScripts:admin</permission>
          <permission>hudson.model.Item.Build:admin</permission>
          <permission>hudson.model.Item.Cancel:admin</permission>
          <permission>hudson.model.Item.Configure:admin</permission>
          <permission>hudson.model.Item.Create:admin</permission>
          <permission>hudson.model.Item.Delete:admin</permission>
          <permission>hudson.model.Item.Discover:admin</permission>
          <permission>hudson.model.Item.Read:admin</permission>
          <permission>hudson.model.Item.Workspace:admin</permission>
          <permission>hudson.model.Run.Delete:admin</permission>
          <permission>hudson.model.Run.Update:admin</permission>
          <permission>hudson.model.View.Configure:admin</permission>
          <permission>hudson.model.View.Create:admin</permission>
          <permission>hudson.model.View.Delete:admin</permission>
          <permission>hudson.model.View.Read:admin</permission>
          <permission>hudson.scm.SCM.Tag:admin</permission>
        </authorizationStrategy>
        <securityRealm class="hudson.security.HudsonPrivateSecurityRealm">
          <disableSignup>false</disableSignup>
          <enableCaptcha>false</enableCaptcha>
        </securityRealm>
    • 重新启动Jenkins

    使用该方法Jenkins将恢复为安全矩阵方式授权。

  • 相关阅读:
    CStringArray序列化处理
    【转】C++ Incorrect Memory Usage and Corrupted Memory(模拟C++程序内存使用崩溃问题)
    【转】Native Thread for Win32 C- Creating Processes(通俗易懂,非常好)
    【转】Native Thread for Win32 B-Threads Synchronization(通俗易懂,非常好)
    【转】Native Thread for Win32 A- Create Thread(通俗易懂,非常好)
    【转】关于OnPaint的工作机制
    Window发声函数Beep、MessageBeep
    Sqlite
    VC++ Splash Window封装类CSplash
    通过代码注册COM、DLL组件
  • 原文地址:https://www.cnblogs.com/zhuochong/p/10082939.html
Copyright © 2011-2022 走看看