Elasticsearch 如何设置细节权限

我们的系统安装了 X-Pack 用于控制访问权限,他可以通过设定 Roles,然后建立用户关联这些 Roles 来完成一个用户的指定权限设定。

我们通过一个 AWS Lambda 程序来备份指定日期的 Index 文件到 AWS S3 系统当中,并且处理所有 Index Aliases 内容。这样我们就需要分配一个 Cluster 中的 Manager 权限,并且对指定的 Indices 给出 Manager 权限。

但是通过官方 Security Privileges 说明可以看到,这两个 manager 权限实在都太大了。这个用户分配给 Lambda 程序后,用户名口令相当于是明文存在的。会对系统产生较高的风险。但是整个系统中 Build-In 的权限设定比较少。所以需要对这个账户的 Role 进行更细颗粒度的限定。

X-Pack Security 结构

在这个系统中,权限管理是下面这么个层次结构:

Privileges --> Roles --> User

其中 Privileges 分为针对整个 Cluster 或者针对特定的 Indices 设定。

如果能够知道更详细的 Privileges 列表,那么将其通过 _xpack/security/role API 就可以创建一个自定义的 Roles,如何创建请参考 Defining Roles 的说明。

但是问题是查遍官方文档,没有任何地方对系统中都提供了什么 Privileges 有列表。官方给出的答复是并不公开提供这个列表内容。

Privileges 列表

在老版本的 Elasticsearch 2.2 中找到了 Action Level Privileges 的列表,这个在 2.3、2.4、5.x 的文档中都不在存在了。

我们测试过部分的 Cluster:admin 功能设定,在 5.6.3 的系统中是能够正常工作和限定的。对于 Indices 的部分,因为我们对 Indices 的控制没有需求,就没多看了。应该这个部分都是正常的,就是可能有缺少而已。

列表的规则很简单,第一个标记的是针对哪个进行权限设定,Cluster 或者 Indices,第二列表示了是用于管理还是数据访问,也就是 admin 或者 data,然后后面的内容跟具体操作的 RESTful API 的路径基本一致。

按照我们的需求:执行 snapshot 并且对 alias 进行一些管理,我们设置了两个自定义 Roles:

POST _xpack/security/role/snap-creator
{
    "cluster": [
      "cluster:admin/snapshot/status",
      "cluster:admin/snapshot/create"
    ]
}

POST _xpack/security/role/alias-manager
{
  "indices":[
    {
      "names": ["metric-*"],
      "privileges": [
        "indices:admin/aliases",
        "indices:admin/get"
      ]
    }
  ]
}

其中 indices:admin/get 权限若不设定, _aliases 指令无法执行,应该是拿不到 Indices 的列表导致的。但是并不知道这个 indices:admin/get 权限的具体范畴,因为我们对数据读取没有那么大的安全控制需要,就没有多加尝试。

如何知道我的指令需要什么权限?

在测试我们的 Role 处理的过程中,突然注意到:如果没有权限执行一个操作的时候,Elasticsearch 自己就会告诉你他需要哪个 Privileges 的定义。

curl -XGET -u test-rule:123456 https://localhost:9200/metric-\*/_aliases
{
  "error": {
    "root_cause": [
      {
        "type": "security_exception",
        "reason": "action [indices:admin/get] is unauthorized for user [test-rule]"
      }
    ],
    "type": "security_exception",
    "reason": "action [indices:admin/get] is unauthorized for user [test-rule]"
  },
  "status": 403
}

上面 [indices:admin/get] 的提示内容,就是我们应该设定的 Privileges 的内容。我平时都是在 Kibana Console 中用 Supper-User 做操作,从来没有见过这个,真是坑啊。😂

大家如果在权限设定上需要更加细节的权限控制,完全可以 curl 指令去测试一下,看看给出哪些 Privileges 能够让他正常工作。

不过要特别注意,官方特别强调:Although rarely needed ,并且我们咨询过他们的 Support,他们也说如果不是特别必须,建议我们不要这么设定 Privileges 的内容,还是使用他们的 Build-In Privileges。

不过实在想不明白为什么官方要这么做。就看他们一个 Manager 的描述:

All monitor privileges plus index administration (aliases, analyze, cache clear, close, delete, exists, flush, mapping, open, force merge, refresh, settings, search shards, templates, validate).

为了一个 Alias 操作,给这个权限出去,实在是能吓死我。

其他参考

在找 X-Pack Security 资料的过程中找到了 Search Guard 这么一个 Opensource 软件,从媒体报道和他自己的说明上看,完全可以替代 X-Pack 的使用。

他的相关文档在一个独立的 Github Repository 里面。这个可以看看,整个的工作逻辑跟 X-Pack Security 应该是非常类似的。

我们直接在 Elastic Cloud 上启动了 X-Pack 就没有尝试这个东西。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 220,192评论 6 511
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,858评论 3 396
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 166,517评论 0 357
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 59,148评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 68,162评论 6 397
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,905评论 1 308
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,537评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,439评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,956评论 1 319
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 38,083评论 3 340
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,218评论 1 352
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,899评论 5 347
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,565评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,093评论 0 23
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,201评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,539评论 3 375
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,215评论 2 358

推荐阅读更多精彩内容