CDH集群手动导入scm库

1、手动导入 scm 库

背景:正常安装 cloudera-scm-server 时,安装 scm 库是经过脚本 /usr/share/cmf/schema/scm_prepare_database.sh 来自动建库的。html

/usr/share/cmf/schema/scm_prepare_database.sh mysql -h<mysql-host> -u<mysql-user> -p<mysql-pwd> --scm-host <scm-host> <scm-user> <scm-dbname> <scm-pwd>

其中mysql

  • <mysql-host>,<mysql-user> <mysql-pwd> 是须要建立的 scm 库所在的 mysql 位置,对应的 mysql 的主机名,用户名和登陆密码;
  • <scm-host>,<scm_user>,<scm-dbname>,<scm-pwd>分别对应 cloudera-scm-server 部署在的主机名,scm 库的登陆用户,scm 库的库名,scm 库的登陆密码。

可是,当在使用云服务器的 rds 实例做为远程 mysql 时,执行以上脚本会报权限不够的错误。而在本地部署的 mysql 实例执行以上脚本则不会报错,主要缘由是<mysql-user>是经过 grant all 命令来受权的,而使用 rds 实例时 grant all 命名是没法执行的,也就是使用 rds 时只能 grant 指定权限给用户,这样可能会致使一部分权限丢失,执行上面的自动建库脚本就会报权限错误。sql

解决方法:服务器

因为 cloudera-scm-server 服务在启动时会初始化 scm 库,自动建立须要的表,所以,能够考虑将已经建好表的 sql 语句 dump 到本地,而后导入到 rds 实例中。oracle

步骤一:在本地一台机器部署mysql,安装 clouder-scm-server 服务,将初始的 scm 表 sql 导出。post

mysqldump -uroot -p <scm-dbname> > A_dump.sql

步骤二:将备份的 sql 语句导入到线上 scm 库所在的地址。spa

mysql -h<mysql-host> -u<mysql-user> -p<mysql-pwd> <scm-dbname> < A_dump.sql

至此,scm 库的初始表已手到导入,配置 cloudera-scm-server 的 db 地址并启动服务便可。postgresql

2、配置服务的db地址并启动服务

1. 配置 cloudera-scm-server 的 db 地址code

经过 ‘ yum install cloudera-manager-daemons cloudera-manager-server‘ 安装好 cloudera-scm-server 服务后,会生成一个 db 配置文件 /etc/cloudera-scm-server/db.properties ,修改配置文件的内容,执行 mysql 所在地址。 server

# Copyright (c) 2012 Cloudera, Inc. All rights reserved.
#
# This file describes the database connection.
#

# The database type
# Currently 'mysql', 'postgresql' and 'oracle' are valid databases.
#com.cloudera.cmf.db.type=mysql

# The database host
# If a non standard port is needed, use 'hostname:port'
#com.cloudera.cmf.db.host=localhost

# The database name
#com.cloudera.cmf.db.name=cmf

# The database user
#com.cloudera.cmf.db.user=cmf

# The database user's password
#com.cloudera.cmf.db.password=

# The db setup type
# By default, it is set to INIT
# If scm-server uses Embedded DB then it is set to EMBEDDED
# If scm-server uses External DB then it is set to EXTERNAL
#com.cloudera.cmf.db.setupType=INIT

com.cloudera.cmf.db.type=mysql
com.cloudera.cmf.db.host=<mysql-host>
com.cloudera.cmf.db.name=<scm-dbname>
com.cloudera.cmf.db.user=<scm-user>
com.cloudera.cmf.db.setupType=EXTERNAL
com.cloudera.cmf.db.password=<scm-pwd>

2. 启动 cloudera-scm-server 服务

/etc/init.d/cloudera-scm-server start

观察 cloudera-scm-server 服务是否正常运行,正常则表示手动导入的 scm 库没问题,登陆 http://<scm-host>:7180/ 访问访问,初始帐号 admin/admin。

  

【参考资料】

[1]. https://www.cloudera.com/documentation/enterprise/5-14-x/topics/cm_ig_installing_configuring_dbs.html#cmig_topic_5_2

相关文章
相关标签/搜索