更新:2016-05-20 09:36

通过向Elastic了解,他们目前开发的5.0版本支持更好的权限定制,粒度达到字段级别。他们预计今年就可以上线,如果你不是有一个旧版本的kibanba非要维护不可,那么可以考虑这个新版本。kibanba5.0 被寄希望是一个革命性的版本,同时logstash、Elasticsearch 都将版本号升级为5.0方便用户在使用ELK架构的时候,容易的选择兼容的版本。

写在前面

好像在github上面有人开发了kibana插件,可以支持登录、权限控制等等,不过我自己对nodejs了解有限(其实就是不喜欢用)。所以我决定用代理方式来控制权限。

kibana和Elasticsearch是通过http协议连接

所以,你只需要让kibana以为你的某个web Server 是Elasticsearch就行了,这个就是改改配置文件搞定。

elasticsearch.url: "http://admin.com"

如果你希望kibana并入你的某个后台权限

假设你的后台访问地址如下:

http://admin.com

在你的Nginx服务器里,将所有发往http://admin.com/app/kibana的请求 转发到kibana的服务器,比如

proxy_pass 192.168.1.12:5601;

这样一来访问kibana的时候,会带上你的后台的Cookie,也就可以使用后台的登录权限了。

kibana访问Elasticsearch的时候,肯定要指定索引

所以,你只需要判断索引的名字是否是这个用户可以查看就行。获取索引名字有点麻烦,kibana一般在请求体的Json中的比如index,docs,_index 等字段放索引名字。

你得分析json,都取出来。有时候它会发多个json,每行一个,你得处理这种情况。

拿到索引后,你可以自己决定,怎么控制权限了。

注意:.kibana 索引和一些插件索引,不应该被权限屏蔽。

怎么做到每个人或每个项目组操作一台独立的kibana的感觉?

  1. 架设多台kibana,分配不同端口就行了
  2. 你可能觉得这样维护有点蛋疼那下面再说怎么处理多用户

kibana将所有的配置、用户数据都放在一个叫做.kibana的索引中

当然,这个名字可以改,但是只能有一个。

如果我能够在kibana访问.kibana的时候,将.kibana改为另一个索引的名字,比如.kibana-1 那么我就可以给所有分组为1的用户,使用一个独立的kibana数据库。

最简单的办法就是找到所有json中的.kibana数据 ,替换成你想要的索引名字,在返回数据的时候,记得再换回来。

漏洞和缺陷

由于Elasticsearch的查询方法非常丰富,所以这种权限体现最多是保证登录安全,索引的权限控制,可能还需要在使用中慢慢完善。

比如,当用户查询 apache-log-* 的时候,你可能可以发现,他没有这个权限,

但是如果他什么索引都不传,在Elasticsearch中并不是搜不到任何东西,它会搜索所有索引。

这种情况下,权限就被绕过。然而kibana会发出许多不带索引的请求,比如获取服务器全局状态等等。

要区分这些请求并不容易。

注意点

1. 路径

kibana 代理的路径在4.2以后,kibana的访问地址变了:原先可能是localhost:5601 现在是localhost:5601/app/kibana,设计者将整个kibana作为一个插件来管理。

2. json

如果你使用php ,json_decode($json,第二个参数)

如果你要改造kibana的查询请求,第二个参数特别重要,因为,如果你将它设置为true的时候,经过decode -> encode 两次转换后,空对象会变成空数组。比如:

{"fields":{}}
//变成
{"fields":[]}

导致语句报错。

怎么给kibana加上权限?的更多相关文章

  1. Kibana访问权限控制

    ELK平台搭建完成后,由于Kibana的服务也是暴露在外网,且默认是没有访问限制的(外部所有人都可以访问到),这明显不是我们想要的,所以我们需要利用Nginx接管所有Kibana请求,通过Nginx配 ...

  2. 为mongodb加上权限

    我们知道mysql在安装的时候需要我们设置一个数据库默认的用户名和密码,mongodb也不例外,不过mongodb是默认的没有设置访问限制的,不需要输入用户名和密码都可以访问的,但是这样会十分的不安全 ...

  3. ELK菜鸟手记 (三) - X-Pack权限控制之给Kibana加上登录控制以及index_not_found_exception问题解决

    0. 背景 我们在使用ELK进行日志记录的时候,通过网址在Kibana中查看我们的应用程序(eg: Java Web)记录的日志, 但是默认是任何客户端都可以访问Kibana的, 这样就会造成很不安全 ...

  4. X-Pack权限控制之给Kibana加上登录控制以及index_not_found_exception问题解决

    无法查看索引下的日志问题解决 好事多磨,我们还是无法在Kibana下看到数据,究竟是怎么一回事呢? 笔者再次查看了logstash的控制台,又发现了如下错误: logstash outputs ela ...

  5. mongon库加上权限认证后,java程序连接异常

    现象: linux库中mongo库,用超级管理员添加了一个超级管理员,并加了认证. 通过spring等相关的配置文件获取Mongo数据库连接,抛出异常,如下: Caused by: org.sprin ...

  6. 使用nginx 的反向代理 给 kibana加上basic的身份认证

    第一步准备工作 准备用户名密码: 更改host文件 第二步,安装nginx ubuntu安装Nginx之后的文件结构大致为:所有的配置文件都在/etc/nginx下,并且每个虚拟主机已经安排在了/et ...

  7. android权限

    一.WebView 访问internet 的权限: 1.在layout中增加一个WebView 控件: <WebView android:layout_width="match_par ...

  8. MongoDB(四)mongodb设置用户访问权限

    我们知道MySQL在安装的时候需要我们设置一个数据库默认的用户名和密码,mongodb也不例外,不过mongodb是默认的没有设置访问限制的,不需要输入用户名和密码都可以访问的,但是这样会十分的不安全 ...

  9. MongoDB 权限 验证

    在MongoDB中,服务启动默认是没有权限验证的,就安全性方面来说,这肯定是不行的,所以需要加上权限验证. 既然是要进行权限验证,那肯定是得有用户的吧,所以权限验证的第一步就是给MongoDB库添加用 ...

随机推荐

  1. jQuery获取所有父级元素及同级元素及子元素的方法

    jQuery获取所有父级元素及同级元素及子元素的方法 1.获取父级元素 $("#id").parent() 获取其父级元素 $("#id").parents() ...

  2. ArrayList的去重问题

    面试被问及arraylist的去重问题,现将自己想的两种解决方案写在下面 /** * Description: * ClassName:Uniq * Package:com.syd.interview ...

  3. Oracle安装时出错,TNS-04612 :"XXX"的RHS 为空

    安装Oracle11g时到最后一步,一直出现 “Oracle Net Configuration Assistant 失败” 试了好多次一直都没成功,在日志文件中的找到这几个错误: TNS-04404 ...

  4. 浅析OC语言

    学习一门开发语言,首先要掌握的它的基本语法,这可能几天就能学会,但如果要融会贯通,就得去学习这门语言的框架和一些库,再结合一些项目的应用,这可能需要花几年的时间. OC是C语言的一个超集,是一门面向对 ...

  5. C++ Primer学习笔记_1_快速入门

    C++快速入门 一 编写简单程序 // main是操作系统唯一显示调用的函数int main() {/**return返回的值是一个状态指示器 0:成功 非0:返回错误给OS*以echo $?命令可以 ...

  6. JFinal DB.tx()事务回滚及lambda表达式应用

    JFinal DB.tx()事务回滚 在要往数据库操作多条数据时,就需要用到事务,JFinal中有封装好的事务应用 写法: Db.tx(new IAtom(){ @Override public bo ...

  7. Java性能优化的50个细节

    在JAVA程序中,性能问题的大部分原因并不在于JAVA语言,而是程序本身.养成良好的编码习惯非常重要,能够显著地提升程序性能. 1. 尽量在合适的场合使用单例 使用单例可以减轻加载的负担,缩短加载的时 ...

  8. Nginx(haproxy)+keepalived+Tomcat双主高可用负载均衡

    周末的时候一个正在学Linux的朋友问我,高可用怎么玩?我和他微信了将近三个小时,把Nginx和haproxy双主高可用教给他了,今天突然想把这个给写进博客里,供给那些正在学习Linux系统的朋友们, ...

  9. 使用Wamp搭建Php本地开发环境,HBuilder调试

    初涉Php,此处做点笔记,希望下次不要能够轻松应对,至少不要在入同一个坑 本文摘要: wamp和HBuilder和Mysql5.7的安装包 Wamp的使用,包括80端口,443端口的占用问题 HBui ...

  10. HaoheDI让ETL变得简单

    HaoheDI(昊合数据整合平台)http://www.haohedi.com,产品基于BS架构,开发运维均极为简单,可快速搭建ETL平台,广泛支持各种数据库.文本文件.SAP和Hadoop,开发数据 ...