打开APP
userphoto
未登录

开通VIP,畅享免费电子书等14项超值服

开通VIP
elasticsearch7.8权限控制和规划
由于在版本7开始,x-pack可以免费使用了,但是权限控制免费的不够细,但是控制到索引级别都基本够用了。付费的可以体验更细致的权限控制。本文的基础是已经有了es集群的基础上进行的。
官网:https://www.elastic.co/guide/en/elasticsearch/reference/7.8/secure-cluster.html
一、集群权限配置
假设你已经安装了elasticsearch7.8的集群,并且能够正常的运行。接下就是来配置权限;
在elasticsearch.yml配置文件中新增(每个节点):
xpack.security.enabled: truexpack.security.transport.ssl.enabled: truexpack.security.transport.ssl.verification_mode: certificatexpack.security.transport.ssl.keystore.path: elastic-certificates.p12xpack.security.transport.ssl.truststore.path: elastic-certificates.p12
然后在一台节点上运行:
注意:如下操作都统一使用默认的命名:如下内容可参考官网:https://www.elastic.co/guide/en/elasticsearch/reference/7.8/configuring-tls.html
./bin/elasticsearch-certutil ca #创建集群认证机构,需要交互输入密码
./bin/elasticsearch-certutil cert --ca elastic-stack-ca.p12 #为节点颁发证书,与上面密码一样
执行./bin/elasticsearch-keystore add xpack.security.transport.ssl.keystore.secure_password 并输入第一步输入的密码
执行./bin/elasticsearch-keystore add xpack.security.transport.ssl.truststore.secure_password 并输入第一步输入的密码
将生成的elastic-certificates.p12、elastic-stack-ca.p12文件移动到config目录下
最后把elastic-certificates.p12、elastic-stack-ca.p12、elasticsearch.keystore三个文件复制到其他的节点的config目录下,启动es。然后去登陆es的时候就需要密码了。接下设置内置用户的密码:
设置内置密码可参考官网:https://www.elastic.co/guide/en/elasticsearch/reference/7.8/setup-passwords.html
然后./bin/elasticsearch-setup-passwords interactive 配置默认用户的密码:(有如下的交互),可以使用auto自动生成
[test@lgh01 elasticsearch-7.8.1]$ ./bin/elasticsearch-setup-passwords interactiveInitiating the setup of passwords for reserved users elastic,apm_system,kibana,kibana_system,logstash_system,beats_system,remote_monitoring_user.You will be prompted to enter passwords as the process progresses.Please confirm that you would like to continue [y/N]yesDid not understand answer 'yes'Please confirm that you would like to continue [y/N]yEnter password for [elastic]:Reenter password for [elastic]:Enter password for [apm_system]:Reenter password for [apm_system]:Enter password for [kibana_system]:Reenter password for [kibana_system]:Enter password for [logstash_system]:Reenter password for [logstash_system]:Enter password for [beats_system]:Reenter password for [beats_system]:Enter password for [remote_monitoring_user]:Reenter password for [remote_monitoring_user]:Changed password for user [apm_system]Changed password for user [kibana_system]Changed password for user [kibana]Changed password for user [logstash_system]Changed password for user [beats_system]Changed password for user [remote_monitoring_user]Changed password for user [elastic]
做完如上的操作就完成了一些特定账号的密码设置:比如elastic超级管理员的密码,这样就可以对权限进行管理了,到这里为止,就可以去通过elastic用户去登陆es集群了,elastic用户时超级用户,在开发的过程中不建议使用,所以需要自己管理和配置角色和用户,请继续看下文
二、用户和角色管理
权限控制:主要是先把权限赋给角色,该角色就拥有了赋有的权限了,然后指定用户为该角色,这样该用户也就有了该角色的权限。大概可以理解为,权限和用户之间的桥梁就是角色,把不同的权限赋给角色,然后把用户对应什么样子的角色就有该角色的权限。
2.1、Security privileges(权限管理)
可参考官网:https://www.elastic.co/guide/en/elasticsearch/reference/7.8/security-privileges.html
权限这里分为集群的权限和索引的权限,集群权限有所有的权限,有快照的权限,管理权限,监控权限等。索引权限有创建,删除,读,写等权限。这里我大概列一些出来,更具体还是查看官网比较合适:
部分集群权限如下:
集群权限
描述
all
所有群集管理操作,例如快照,节点关闭/重新启动,设置更新,重新路由或管理用户和角色
create_snapshot
为现有存储库创建快照的特权。也可以列出和查看有关现有存储库和快照的详细信息
manage
建立monitor并添加更改群集中值的群集操作。这包括快照,更新设置和重新路由。它还包括获取快照和还原状态。此特权不包括管理安全性的能力
monitor
所有群集只读操作,例如群集运行状况和状态,热线程,节点信息,节点和群集统计信息以及待处理的群集任务
部分索引权限如下:
all
对索引的任何操作
create
索引文件的权限。还授予对更新映射操作的访问权限。
delete
删除文件的权限
create_index
创建索引的权限。创建索引请求可能包含要在创建索引后添加到索引的别名
delete_index
删除索引的权限
manage
所有monitor特权以及索引管理(别名,分析,缓存清除,关闭,删除,存在,刷新,映射,打开,强制合并,刷新,设置,搜索分片,模板,验证)
monitor
监视所需的所有操作(恢复,段信息,索引统计信息和状态)
read
对后面这些操作只读访问(计数,解释,获取,管理,获取索引脚本,诸如此类,多过滤/搜索/术语向量,过滤,滚动,clear_scroll,搜索)
write
具有对文档执行所有写操作的特权,包括对文档进行索引,更新和删除以及执行批量操作的权限。还授予对更新映射操作的访问权限。
2.2、role(角色)介绍和操作
elasticsearch7内置了很多角色,可以查看官网:https://www.elastic.co/guide/en/elasticsearch/reference/7.8/built-in-roles.html
但是很多内置角色都不是我们想要的,每个公司的需求都是不一样,如果集群很小,则可以简单控制权限就可以,如果集群大,用户多,则需要比较细粒度的控制权限,所以我们要根据自己的需求定义自己的所要的角色 。角色的配置有两种方式,一种是界面的操作(kibana方式),这样就傻瓜式的操作,很简单。还有就是通过API的方式控制权限,这样的话需要花点时间熟悉下,操作相对来说复杂点,但是不需要额外的kibana。这里两种方式都简单介绍下。
方式一(kibana方式):
1、登录kibana
2、点击role
3、点击新建
4、配置权限
到这里为止通过kibana方式配置role的步骤就完了,很简单的,下面介绍API的方式
方式二(API)
可参考官网:https://www.elastic.co/guide/en/elasticsearch/reference/7.8/security-api-put-role.html
配置语法:
{ "run_as": [ ... ], "cluster": [ ... ], "global": { ... }, "indices": [ ... ], "applications": [ ... ] }
其实使用基本的配置就可以了,这里我们只用到cluster和indices这两种,其他的可参考官网的配置方式,根据需求配置即可。
例如配置一个名为testb的role,集群权限为monitor,索引只有对test-开头的索引有只读权限:
post _security/role/testb{ "cluster": [ "monitor" ], "indices": [ { "names": [ "test-*" ], "privileges": [ "read" ] } ]}
其实多去试试,也很简单的。
2.3、user(用户)介绍和操作
elasticsearch7内置了很多用户,还记得前面那步设置密码就是给里面的内置用户配置密码,详细的内置用户参考官网:https://www.elastic.co/guide/en/elasticsearch/reference/7.8/built-in-users.html
在日常es开发中,内置用户基本不使用,所以主要自定义用户,自定义用户也同样有两种方式,同样是kibana和API方式,这两种方式也很简单。
方式一(kibana方式)
1、登录kibana,点击users,然后点击新建
2、配置用户的基本信息和指定配置的角色
傻瓜式的操作,是真的很简单,不过还是要熟悉里面的role到底有什么样子的权限
方式二(API方式)
详情可参考官网:https://www.elastic.co/guide/en/elasticsearch/reference/7.8/security-api-put-user.html
put _security/user/tony{ "password": "j@rV1s", "roles": [ "test1" ], "full_name": "tony", "email": "jacknich@example.com", "metadata": { "intelligence": 7 }}
到这里,role和user的基本创建就介绍完了,如果想知道更多role和user相关的操作请见官网:https://www.elastic.co/guide/en/elasticsearch/reference/7.8/security-api.html
三、简单权限规划
话说知道了集群权限配置、role和user的基本用法,那如何根据需求控制权限呢?这些都是根据实际情况确定的,因为用户配置有很多,也支持ldap,这里只是用了最简单的方式,若想超级细粒度或者ldap方式或者其他方式对权限进行控制,最好去研究下官网,本文说的很简单,只是对基本的权限的控制。设计都是基于现有的业务场景或者用户的数量,或者是集群的规模确定权限是否细粒度。所以这里仅提供下个人的思考。
背景:这里是一个比较小的集群,10 个数据节点,用户数量很少,也没有多种业务,一个集群就一种,所以控制起来也很简单,这里对索引做了一个强制的命名规范:{开头:固定的写方}-{业务种类}-{业务名称}-{版本},这些都可以体现在权限控制里面。
根据如上情况,相关角色规划如下:
角色
描述
超级管理员角色(superuser)
集群索引全部权限
索引管理角色(indexrole)
只负责test开头的索引全部权限,还有集群的读权限
读写角色(writerole)
只有读写test开头的全部索引权限,还有集群的读权限
只读角色(readrole)
只读test开头的全部索引权限,还有集群的读权限
备份角色(snapshotrole)
负责所有索引的快照创建,进行备份
相关用户规划如下:
用户
角色
描述
elastic
superuser
超级管理员:正常情况下不允许使用
snapshot
snapshotrole
负责所有索引的快照备份
es_index
indexrole
只负责test开头的索引全部权限,还有集群的读权限
es_write
writerole
只有读写test开头的全部索引权限,还有集群的读权限
es_read
readrole
只读test开头的全部索引权限,还有集群的读权限
建议大家多去看官网,毕竟那里才是更全更详细的,写博客很难面面俱到,只能说仅供参考
来源:https://www.icode9.com/content-4-846001.html
本站仅提供存储服务,所有内容均由用户发布,如发现有害或侵权内容,请点击举报
打开APP,阅读全文并永久保存 查看更多类似文章
猜你喜欢
类似文章
【热】打开小程序,算一算2024你的财运
Elasticsearch 主从同步之跨集群复制
docker安装Elasticsearch7.6集群并设置密码的方法步骤
ElasticSearch 集群搭建
Elasticsearch学习与使用【面试+工作】
Linux 下 Docker 安装elasticsearch并配置密码使用X-pack做安全验证
如何对你的 ELK 生产安全部署?本文交给你~
更多类似文章 >>
生活服务
热点新闻
分享 收藏 导长图 关注 下载文章
绑定账号成功
后续可登录账号畅享VIP特权!
如果VIP功能使用有故障,
可点击这里联系客服!

联系客服