ceph存储 安装部署Ceph Calamari经典示例
2015-01-02 15:35
447 查看
Calamari是管理和监控
Ceph集群的工具,并且提供
REST api。
建议的部署平台是ubuntu,本文使用CentOS 6.5。
安装部署
获取calamari相关代码
# git clone https://github.com/ceph/calamari.git # git clone https://github.com/ceph/calamari-clients.git # git clone https://github.com/ceph/Diamond
生成
calamari-server安装包
# yum install gcc gcc-c++ postgresql-libs python-virtualenv # cd calamari && ./build-rpm.sh
安装
calamari-server
# yum localinstall ../rpmbuild/RPMS/x86_64/calamari-server-<version>.rpm
使用yum可以自动解决依赖,如果手动安装依赖的可以这样:
# yum install postgresql-server salt-master salt-minion supervisor # rpm -ivh ../rpmbuild/RPMS/x86_64/calamari-server-<version>.rpm
生成
calamari-clients安装包
# yum install npm ruby rubygems # npm install -g grunt grunt-cli bower grunt-contrib-compass # gem update --sytem && gem install compass # cd calamari-clients # make build-real # make dist
make dist会在上级目录生成
calamari-client的压缩包;
手动解压缩,建立
mkdir -p opt/calamari/webapp;
在解压生成的目录下,手动更新目录结构和内容:
# for dir in manage admin login dashboard >do >mkdir -p ../opt/calamari/webapp/content/"$dir" >cp -pr "$dir"/dist/* ../opt/calamari/webapp/content/"$dir"/ >done
重新制作压缩包,然后根据
Makefile里面的rpm target手动执行rpmbuild:
# rpmbuild -bb --define "_topdir /xxx/calamari-clients/../rpmbuild" --define "version 1.2" --define "revision rc2_49_g3e3686d" --define "tarname /xxx/rpmbuild/SOURCES/calamari-clients_product_1.2.tar.gz" SPECS/clients.spec
安装
calamari-clients
# yum localinstall RPMS/x86_64/calamari-clients-1.2-rc2_49_g3e3686d.el6.x86_64.rpm
初始化
calamari
# calamari-ctl initialize
这一步在最后重启服务(主要是
cthulhu)的时候一直没有结束,根据搜索到的信息,说是
supervisord的问题,升级到3.0以上就不会有问题了。
生成
diamond安装包
# cd ../Diamond # git checkout origin/calamari # make rpm
将
diamond-<version>.noarch.rpm复制到所有的ceph服务器。
使用
yum localinstall安装,或者
yum install python-configobj然后使用
rpm -ivh安装。
在所有的ceph服务器上安装
salt-minion,创建
/etc/salt/minion.d/calamari.conf,内容为:
master: {fqdn}
{fqdn}对应calamari服务器的域名。
启动salt-minion服务:
# service salt-minion restart
在Calamari服务器上配置防火墙和saltstack认证
防火墙(允许ceph服务器访问salt-master和carbon):
### salt-master # iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 4505 -j ACCEPT # iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 4506 -j ACCEPT ### carbon # iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 2003 -j ACCEPT # iptables -A INPUT -m state --state NEW -m tcp -p tcp --dport 2004 -j ACCEPT
saltstack认证:
当ceph服务器上的salt-minion服务启动之后,会自动向salt-master请求认证。
在Calamari服务器上可以通过下面的命令查看salt-minion密钥的列表:
# salt-key -L
刚刚启动salt-minion服务的ceph服务器会出现在
Unaccepted Keys列表之后,要使得Calamari能够通过saltstack管理ceph服务器,需要对这些密钥进行认证:
# salt-key -A
部署完成之后,可以访问
calamari
后期遇到的问题
SELinux导致500错误:
由于SELinux的限制,访问页面时会出现500错误,原因是
httpd_t对于
anon_inodefs_t没有写入权限,可以根据审计日志生成SELinux模块:
# ausearch -m avc -c httpd -se httpd_t -o anon_inodefs_t | audit2allow -R -M httpd_anon_inodefs # semodule -i httpd_anon_inodefs.pp
生成的SELinux模块规则如下:
require { type httpd_t; } #============= httpd_t ============== fs_rw_anon_inodefs_files(httpd_t)
打开
Manage-->
OSD页面无内容
查看calamari.log看到了异常,原因是httpd没有权限访问/etc/salt/master,修改权限临时解决。
打开
Manage-->
Logs页面无内容
查看日志,发现是访问http://xxx.xxx.xxx.xxx/api/v2/cluster/xxxxxxxx-xxxx-xxxx-xxxx-xxxxxxxxxxxx/log发生503错误:
HTTP 503 SERVICE UNAVAILABLE Vary: Accept Content-Type: text/html; charset=utf-8 Allow: GET, HEAD, OPTIONS { "detail": "No mon servers are responding" }
经过研究还是SELinux的限制,通过ausearch配合audit2allow生成相应的模块,可以解决问题。
生成的SELinux模块的规则如下:
require { type var_run_t; type httpd_t; class sock_file { write getattr }; } #============= httpd_t ============== allow httpd_t var_run_t:sock_file { write getattr }; files_read_var_files(httpd_t) init_stream_connect_script(httpd_t)
打开
graphite/dashboard/页面出现HTTP 500错误
日志中提示找不到graphite的模板,在calamari的bug列表中找到对应的说明——issue 8669
解决方法是:
在/opt/calamari/venv/lib/python2.6/site-packages下找到calamari_web的egg文件,解压缩之后手动修改calamari_web/settings.py,然后重新打包。
重启apache之后可以访问graphite/dashboard/。
相关文章推荐
- Ceph 集群监控之Calamari 安装部署
- calamari + ceph + saltstack 安装部署
- 安装部署Ceph Calamari
- 【Ceph学习之一】Centos7上部署Ceph存储集群以及CephFS的安装
- ceph 存储安装部署
- Centos7上部署Ceph存储集群以及CephFS的安装
- ceph存储 centos系统grub引导多系统示例
- centos6.4 ceph安装部署之ceph object storage
- Installshield2010实现web部署和数据库安装示例
- Spring Roo 实站( 一 )部署安装 & 第一个示例程序
- ceph存储 ceph集群ceph-deploy部署使用说明
- 安装部署VMware vSphere 5.5文档 (6-1) 配置IBM DS4700 共享存储
- Installshield2010 实现web部署和数据库安装示例
- ceph存储 Linux 下安装python软件包(pip、nose、virtualenv、distribute )
- ceph存储 ceph集群ceph-deploy安装说明
- ceph存储 centos7+0.87源码安装ceph集群问题汇总
- Installshield2010实现web部署和数据库安装示例
- Installshield2010 实现web部署和数据库安装示例
- ceph详细安装部署教程(多监控节点)