目录

概览... 2

1.      ranger-admin. 2

2.      ranger-user-sync. 2

3.      ranger-*-plugins. 2

安装... 3

1.      ranger-admin: 3

2.      ranger-user-sync: 4

3.      ranger-hdfs-plugin: 5

4.      ranger-hive-plugin: 6

概览

1.      ranger-admin

ranger的中心节点,所有鉴权访问都必须经过这个节点.

(可load balancer,请求是走HTTP协议的)

2.      ranger-user-sync

同步user/group等信息到admin节点.

比如有些用户和组并不在admin节点的机器上存在的.

但在各个权限控制plugin中又有定义的,是通过这个服务同步.

3.      ranger-*-plugins

各个实际的鉴权组件的hook点实现.

存在在各个服务(如HDFS)等的进程内.

安装

1.      ranger-admin:

  1. 安装mysql,用于存放ranger的各种鉴权定义的存放等.
  2. 解压缩ranger-0.7.1-admin.tar.gz
  3. 准备solr audit(ranger会将audit log写入这个solr)

1)         . cd ./contrib/solr_for_audit_setup

2)         修改install.property

# 所使用的solr的程序安装目录

SOLR_INSTALL_FOLDER=

# ranger对应的solr配置等(只需建立起空目录即可,后面自带脚本会做准备)

SOLR_RANGER_HOME=

# ranger对应的solr的数据存放位置(只需建立起空目录即可,后面自带脚本会做准备)

SOLR_RANGER_DATA_FOLDER=

# ranger audit在solr上的collection名字,默认为ranger_audits

SOLR_RANGER_COLLECTION=

3)         执行./contrib/solr_for_audit_setup/setup.sh

4)         启动(root):

${SOLR_RANGER_HOME}/scripts/start_solr.sh

停止(root):

${SOLR_RANGER_HOME}/scripts/stop_solr.sh

  1. 配置admin.

1)         修改install.property

# 配置所使用的mysql的root用户连接信息(需自行保证mysql这方面的权限).

db_root_user=

db_root_password=

db_host=

# ranger所使用的mysql的数据库和用户信息(后面会有自带脚本创建维护,不需手工建立)

db_name=

db_user=

db_pasword=

# 使用solr存储audit

audit_store=solr

# ranger使用的solr collection地址.

# 如果slor的设置使用默认SOLR_RANGER_COLLECTION即ranger_audit的话.

# 为http://${solr_host}:6083/solr/ranger_audits

audit_solr_urls=

# mysql JDBC的jar包路径

SQL_CONNECTOR_JAR=

2)         执行setup.sh(root)

这个脚本会建立mysql上的库信息

并会放置各个脚本到标准目录(类RPM包install动作)

3)         启动(root):

ranger-admin start

停止(root):

ranger-admin stop

4)         访问:

http://${host}:6080

默认口令admin:admin

2.      ranger-user-sync:

  1. 解压缩ranger-0.7.1-usersync.tar
  2. 修改install.property

# 即ranger admin的地址

# 如http://${host}:6080

POLICY_MGR_URL=

  1. 执行setup.sh(root)

放置各个脚本到标准目录(类RPM包install动作)

  1. 启动(root)

ranger-usersync start

停止(root):

ranger-usersync stop

3.      ranger-hdfs-plugin:

  1. 在各个namenode上解压缩ranger-0.7.1-hdfs-plugin.tar.gz
  2. 修改install.property

# 即ranger admin的地址

# 如http://${host}:6080

POLICY_MGR_URL=

# 配置slor audit log

XAAUDIT.SOLR.ENABLE=true

# ranger使用的solr collection地址.

# 如果slor的设置使用默认SOLR_RANGER_COLLECTION即ranger_audit的话.

# 为http://${solr_host}:6083/solr/ranger_audits

XAAUDIT.SOLR.URL=

# ranger上hdfs的policy ID/名字

# 如hadoopdev

REPOSITORY_NAME=

  1. namenode上的调整.

1)         确保存在HADOOP_HOME环境变量

2)         确保${HADOOP_HOME}/conf存在并指向实际使用的conf目录.

3)         执行./enable-hdfs-plugin.sh(root)

copy ${HADOOP_HOME}/lib下的ranger相关jar和目录到${HADOOP_HOME}/share/hadoop/hdfs/lib

trouble shooting:

这个是保证namenode进程的classpath能找到ranger的jar包.

原理是ranger重新实现了dfs.namenode.inode.attributes.provider.class,hook了namenode上的RPC请求.

所以前面需要知道conf的目录便于重新生成hdfs-site.xml

4)         重新启动namenode和zkfc即可.

5)         验证:

hdfs mkdir等读写操作一下应该可以在admin server的web ui看到相关audit信息

4.      ranger-hive-plugin:

  1. 在hive thrift server上解压缩ranger-0.7.1-hive-plugin.tar.gz
  2. 修改install.property

# 即ranger admin的地址

# 如http://${host}:6080

POLICY_MGR_URL=

# 配置slor audit log

XAAUDIT.SOLR.ENABLE=true

# ranger使用的solr collection地址.

# 如果slor的设置使用默认SOLR_RANGER_COLLECTION即ranger_audit的话.

# 为http://${solr_host}:6083/solr/ranger_audits

XAAUDIT.SOLR.URL=

# ranger上hive的policy ID/名字.如hivedev

REPOSITORY_NAME=

  1. 修改hive-site.xml

添加:

<property>

<name>hive.server2.enable.doAs</name>

<value>false</value>

<description>

在thrift server上关闭doAS.

开启的话,一个访问需要同时控制hdfs和hive的访问权限,坏处在于不容易维护.

关闭的话,只需要维护hive的访问权限即可,坏处是所有查询在鉴权后都是以hive用户跑.

</description>

</property>

  1. 执行./enable-hive-plugin.sh(root)

原理类似ranger-hdfs-plugin

  1. 重新启动hive thrift server即可.
  2. 验证:

通过beeline访问thrift做查询读写应该就能在web ui看到相关audit信息

ranger部署文档(记)的更多相关文章

  1. PPTP部署文档

    PPTP部署文档 作者:尹正杰 版权声明:原创作品,谢绝转载!否则将追究法律责任.       欢迎加入:高级运维工程师之路 598432640 前言:这款VPN部署起来特别简单,想对OPENVON配 ...

  2. hadoop2.6.0汇总:新增功能最新编译 32位、64位安装、源码包、API下载及部署文档

    相关内容: hadoop2.5.2汇总:新增功能最新编译 32位.64位安装.源码包.API.eclipse插件下载Hadoop2.5 Eclipse插件制作.连接集群视频.及hadoop-eclip ...

  3. supervisor 部署文档

    supervisor 部署文档 supervisor 需要Python支持,如果不用系统的supervisor,单独安装python python 安装 #依赖 yum install python- ...

  4. centos6 Cacti部署文档

    centos6 Cacti部署文档 1.安装依赖 yum -y install mysql mysql-server mysql-devel httpd php php-pdo php-snmp ph ...

  5. HP DL160 Gen9服务器集群部署文档

    HP DL160 Gen9服务器集群部署文档 硬件配置=======================================================Server        Memo ...

  6. Sqlserver2008安装部署文档

    Sqlserver2008部署文档 注意事项: 如果你要安装的是64位的服务器,并且是新机器.那么请注意,你需要首先需要给64系统安装一个.net framework,如果已经安装此功能,请略过这一步 ...

  7. CDH简易离线部署文档

        CDH 离线简易部署文档       文档说明 本文为开发部署文档,生产环境需做相应调整. 以下操作尽量在root用户下操作,避免权限问题. 目录 文档说明 2 文档修改历史记录 2 目录 3 ...

  8. Ceph分布式存储(luminous)部署文档-ubuntu18-04

    Ceph分布式存储(luminous)部署文档 环境 ubuntu18.04 ceph version 12.2.7 luminous (stable) 三节点 配置如下 node1:1U,1G me ...

  9. rabbitmq 3.7.8基于centos7部署文档

    rabbitmq 3.7.8部署文档 安装erlang 安装依赖环境 yum -y install make gcc gcc-c++ kernel-devel m4 ncurses-devel ope ...

随机推荐

  1. 在一般类中通过XmlWebApplicationContext对象获取应用部署上下文Context

    XmlWebApplicationContext xwac = (XmlWebApplicationContext) ContextLoader.getCurrentWebApplicationCon ...

  2. BZOJ2229[Zjoi2011]最小割——最小割树

    题目描述 小白在图论课上学到了一个新的概念——最小割,下课后小白在笔记本上写下了如下这段话: “对于一个图,某个对图中结点的划分将图中所有结点分成两个部分,如果结点s,t不在同一个部分中,则称这个划分 ...

  3. 【BZOJ2127】happiness 网络流

    题目描述 有\(n\times m\)个人,排成一个\(n\times m\)的矩阵.每个同学和前后左右相邻的同学互相成为了好朋友.这学期要分文理科了,每个同学对于选择文科与理科有着自己的喜悦值,而一 ...

  4. Codeforces Round #502 (in memory of Leopoldo Taravilse, Div. 1 + Div. 2)

    第一次参加cf的比赛 有点小幸运也有点小遗憾 给自己定个小目标 1500[对啊我就是很菜qvq A. The Rank 难度:普及- n位学生 每个学生有四个分数 然鹅我们只需要知道他的分数和 按分数 ...

  5. [CF438D]The Child and Sequence【线段树】

    题目大意 区间取模,区间求和,单点修改. 分析 其实算是一道蛮简单的水题. 首先线段树非常好解决后两个操作,重点在于如何解决区间取模的操作. 一开始想到的是暴力单点修改,但是复杂度就飙到了\(mnlo ...

  6. 自适应PC端网页制作使用REM

    做一个PC端的网页,设计图是1920X1080的. 要在常见屏上显示正常(比例正确可) 1280X720 1366X768 1440X900 1920X1080 使用了几种办法 1.内容在一屏内显示的 ...

  7. <数据结构基础学习>(一)数组

    一.数组基础 1.数组,即把数据码成一排存放. 数组优点:快速查询. 数组最好应用于“索引有语意”的情况,但并非所有有语意的索引都适用于数组,数组也可以处理“索引没有语意”的情况. 2.增.删.改.查 ...

  8. Nginx log日志切割shell

    #!/bin/bash#此脚本用于自动分割Nginx的日志,包括access.log和error.log#每天00:00执行此脚本 将前一天的access.log重命名为access-xxxx-xx- ...

  9. 查看Ubuntu的显卡信息

    lspci -vnn|grep VGA -A 12 查看openGL信息: sudo apt install mesa-utils glxinfo|grep OpenGL -A 12

  10. 生命不息,折腾不止 ~ 旧PC改造之家庭影音

    前言引入 之前把在校园陪伴多年的旧电脑由Win装成了Linux,的确不卡了,基本上日常办公也够了(大项目还是吃不消,日常捣鼓倒是够了),然后把真正的工作游戏本也改成了Linux,那么旧电脑又变成闲置机 ...