分享

解析Cloudera Manager内部结构、功能包括配置文件、目录位置等

nettman 发表于 2014-9-16 16:55:56 [显示全部楼层] 只看大图 回帖奖励 阅读模式 关闭右栏 24 213781
本帖最后由 nettman 于 2014-9-17 00:10 编辑
问题导读
1.CM的安装目录在什么位置?


2.hadoop配置文件在什么位置?


3.Cloudera manager运行所需要的信息存在什么位置?

4.CM结构和功能是什么?




1. 相关目录
  • /var/log/cloudera-scm-installer : 安装日志目录。
  • /var/log/* : 相关日志文件(相关服务的及CM的)。
  • /usr/share/cmf/ : 程序安装目录。
  • /usr/lib64/cmf/ : Agent程序代码。
  • /var/lib/cloudera-scm-server-db/data : 内嵌数据库目录。
  • /usr/bin/postgres : 内嵌数据库程序。
  • /etc/cloudera-scm-agent/ : agent的配置目录。
  • /etc/cloudera-scm-server/ : server的配置目录。
  • /opt/cloudera/parcels/ : Hadoop相关服务安装目录。
  • /opt/cloudera/parcel-repo/ : 下载的服务软件包数据,数据格式为parcels。
  • /opt/cloudera/parcel-cache/ : 下载的服务软件包缓存数据。
  • /etc/hadoop/* : 客户端配置文件目录。

2. 配置
  • Hadoop配置文件
    配置文件放置于/var/run/cloudera-scm-agent/process/目录下。如:/var/run/cloudera-scm-agent/process/193-hdfs-NAMENODE/core-site.xml。这些配置文件是通过Cloudera Manager启动相应服务(如HDFS)时生成的,内容从数据库中获得(即通过界面配置的参数)。
    在CM界面上更改配置是不会立即反映到配置文件中,这些信息会存储于数据库中,等下次重启服务时才会生成配置文件。且每次启动时都会产生新的配置文件。
    CM Server主要数据库为scm基中放置配置的数据表为configs。里面包含了服务的配置信息,每一次配置的更改会把当前页面的所有配置内容添加到数据库中,以此保存配置修改历史。
    scm数据库被配置成只能从localhost访问,如果需要从外部连接此数据库,修改vim /var/lib/cloudera-scm-server-db/data/pg_hba.conf文件,之后重启数据库。运行数据库的用户为cloudera-scm。


  • 查看配置内容

    • 直接查询scm数据库的configs数据表的内容。
    • 访问REST API: http://hostname:7180/api/v4/cm/deployment,返回JSON格式部署配置信息。


  • 配置生成方式
    CM为每个服务进程生成独立的配置目录(文件)。所有配置统一在服务端查询数据库生成(因为scm数据库只能在localhost下访问)生成配置文件,再由agent通过网络下载包含配置文件的zip包到本地解压到指定的目录。


  • 配置修改
    CM对于需要修改的配置预先定义,对于没有预先定义的配置,则通过在高级配置项中使用xml配置片段的方式进行配置。而对于/etc/hadoop/下的配置文件是客户端的配置,可以在CM通过部署客户端生成客户端配置。

3. 数据库
Cloudera manager主要的数据库为scm,存储Cloudera manager运行所需要的信息:配置,主机,用户等。

4. CM结构
CM分为Server与Agent两部分及数据库(自带更改过的嵌入Postgresql)。它主要做三件事件:
  • 管理监控集群主机。
  • 统一管理配置。
  • 管理维护Hadoop平台系统。
实现采用C/S结构,Agent为客户端负责执行服务端发来的命令,执行方式一般为使用python调用相应的服务shell脚本。Server端为Java REST服务,提供REST API,Web管理端通过REST API调用Server端功能,Web界面使用富客户端技术(Knockout)。
  • Server端主体使用Java实现。
  • Agent端主体使用Python, 服务的启动通过调用相应的shell脚本进行启动,如果启动失败会重复4次调用启动脚本。
  • Agent与Server保持心跳,使用Thrift RPC框架。


5. 升级
在CM中可以通过界面向导升级相关服务。升级过程为三步:
  • 下载服务软件包。
  • 把所下载的服务软件包分发到集群中受管的机器上。
  • 安装服务软件包,使用软链接的方式把服务程序目录链接到新安装的软件包目录上。


6. 卸载
sudo /usr/share/cmf/uninstall-scm-express.sh, 然后删除/var/lib/cloudera-scm-server-db/目录,不然下次安装可能不成功。


7. 开启postgresql远程访问
CM内嵌数据库被配置成只能从localhost访问,如果需要从外部查看数据,数据修改vim /var/lib/cloudera-scm-server-db/data/pg_hba.conf文件,之后重启数据库。运行数据库的用户为cloudera-scm。








加微信w3aboutyun,可拉入技术爱好者群

已有(25)人评论

跳转到指定楼层
vanking 发表于 2015-1-26 09:44:28
楼主好,用cloudera manager安装的hbase之后如何在哪个目录下设置hbase的log4jproperties文件呀?让Hbase的日志文件每天滚动一个文件?
回复

使用道具 举报

desehawk 发表于 2015-3-7 08:28:48
vanking 发表于 2015-1-26 09:44
楼主好,用cloudera manager安装的hbase之后如何在哪个目录下设置hbase的log4jproperties文件呀?让Hbase的 ...

HLog默认情况下每个小时会滚动,这是通过参数hbase.regionserver.logroll.period控制的,这个参数的默认值是1小时。
此外,hbase.regionserver.hlog.blocksize和fs_local.block.size控制当HLog的大小超过32M的时候,会滚动。
Hbase.regionserver.logroll.multiplier,默认值是95%,表示日志达到95%的时候,也会进行滚动。

回复

使用道具 举报

saybar 发表于 2015-4-8 14:52:14
学习了谢谢楼主了
回复

使用道具 举报

roywang1024 发表于 2015-4-15 20:33:05
最近在搭建CDH碰上些问题请教一下~
1.添加flume服务时,有3个机器部署agent,flume的配置文件需要bind机器名,在CM的配置界面中,如何填写每台机器的IP或机器名?我使用localhost或127.0.0.1,连不上flume
2.HUE中想要添加rdbms,但是在hue的safety_value编辑中,不知道mysql对应的key/value应该填什么
3.hdfs的用户组是hdfs的,flume是用户flume,写入的时候提示权限错误,这个是要什么配置?
回复

使用道具 举报

ashic 发表于 2015-7-27 12:28:50
请问,如果我想手动修改配置文件,比如修改fs.trash.interval,应该修改那个文件?
回复

使用道具 举报

ashic 发表于 2015-7-28 10:04:16
楼主您好,假设我通过一台服务气的IP: A,也就是 A:7180访问CM web页面
如果这台服务器彻底损坏,那么我的CM web页面也就无法访问了吧?
那么在这种情况下,如何再另一台服务器重建CM?
回复

使用道具 举报

guxingyu 发表于 2016-6-20 11:32:15
ashic 发表于 2015-7-27 12:28
请问,如果我想手动修改配置文件,比如修改fs.trash.interval,应该修改那个文件?

你好,我也遇到了 同样的问题,不知道你是否解决,请问你是怎么解决的?  

回复

使用道具 举报

123下一页
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

关闭

推荐上一条 /2 下一条