Apache Ranger不使用root密码进行初始化

櫰木2年前技术文章830

1、背景

由于使用的数据库由dba进行管理,我们无法获取到对应的ranger数据库的root密码。需要使用数据库普通用户对表进行初始化

2、解决

  • ranger admin每次修改配置(install.properties)都需要重新的编译(./setup.sh),编译过程会把配置重新写入,不然怎么重启ranger admin都不生效的。

  • 编译过程主要代码逻辑是执行dba_script.py, ranger_credential_helper.py,db_setup.py三个py脚本,其中需要root权限是在dba_script.py中使用到的。

  • dba_script.py执行授权的过程,使用root权限除了一些对元数据的select请求外,核心作用是为用户授予库的权限。如假设我当前是A用户,那么会使用root用户去执行命令

grant all privileges on ranger.* to 'ranger'@'%' with grant option;
grant all privileges on ranger.* to 'ranger'@'localhost' with grant option;
  • 从setup.sh中查看调用dba_script.py执行的代码

run_dba_steps(){
    getPropertyFromFileNoExit 'setup_mode' $PROPFILE setup_mode false
    if [ "x${setup_mode}x" == "xSeparateDBAx" ]; then
        log "[I] Setup mode is set to SeparateDBA. Not Running DBA steps. Please run dba_script.py before running setup..!";
    else
        log "[I] Setup mode is not set. Running DBA steps..";
                python dba_script.py -q
        fi
}
  • 因为知道ranger使用root密码的目的是为用户授予库的权限,如果我们已经授权好,那么root密码应该可以是非必须的。从上面看如果setup_mode设置为xSeparateDBAx的话,则if逻辑不会走dba_script.py这个脚本(前提是我们先把授权操作做了)

  • 关于如何将setup_mode,从setup.sh可以指定这个install.properties中的配置项,因此只要设置它的值即可。

#------------------------- DB CONFIG - BEGIN ----------------------------------
# Uncomment the below if the DBA steps need to be run separately
setup_mode=SeparateDBA

例子

  • 如下创建用户并授权,然后重新执行./setup.sh就可以编译通过了。下例演示的是本地mysql的例子,如果是平时生产应用由DBA提供的话,则只有确保对应用户拥有库的全部权限即可。

#修改install.properties中的配置
setup_mode=SeparateDBA

#用root登陆本地mysql服务器
CREATE USER 'ranger'@'localhost' IDENTIFIED BY 'Ranger123';
grant all privileges on ranger141.* to 'ranger'@'%' with grant option;
grant all privileges on ranger141.* to 'test'@'localhost' with grant option;
FLUSH PRIVILEGES;

#修改install.properties中的配置
db_root_user=test
db_root_password=******
db_user=test
db_password=******


相关文章

Spark优化之配置参数

Spark优化之配置参数

一、资源参数优化所谓的Spark资源参数调优,其实主要就是对Spark运行过程中各 个使用资源的地方,通过调节各种参数,来优化资源使用的效率,从而提升Spark作业的执行性能。以下参数就是Spark中...

CDP实操--配置Hive/Impala的Ranger策略验证(二)

CDP实操--配置Hive/Impala的Ranger策略验证(二)

1.1Hive/impala的Ranger策略验证确保hive-on-tez的配置页面里已经勾选了“Ranger Service”在terminal中,kerberos登录到hive,用如下命令登录b...

datahub安装部署

datahub安装部署

背景:由于某客户需要建立sparksql的血缘关系,于是乎提出datahub,由于网上关于datahub资料较少,因此这里做以记录datahub作为一个元数据管理平台,他可以对数据资产进行有效的组织,...

SpringBootWeb 篇-深入了解 SpringBoot + Vue 的前后端分离项目部署上线与 Nginx 配置文件结构(1)

SpringBootWeb 篇-深入了解 SpringBoot + Vue 的前后端分离项目部署上线与 Nginx 配置文件结构(1)

  1.0 云服务器的准备        使用云服务是为了可以得到一个 Linux 环境,比如说常用到的 Ubuntu 的配套程序。  &n...

trino容器对接alluxio(四)

trino容器对接alluxio(四)

前提:本文是基于已经部署了trino容器和 集群中部署了alluxio组件的基础上,进行的trino与alluxio的组件对接,alluxio已经开启了高可用模式。本文的冒烟测试是在trino对接ld...

压测实操--nnbench压测hdfs_namenode负载方案

压测实操--nnbench压测hdfs_namenode负载方案

本次压测使用nnbench对namenode负载进行性能测试。nnbench生成很多与HDFS相关的请求,给NameNode施加较大的压力,这个测试能在HDFS上创建、读取、重命名和删除文件操作。对应...

发表评论    

◎欢迎参与讨论,请在这里发表您的看法、交流您的观点。