Ceph 集群搭建
1.Ceph部署
1.1 Ceph 安装前准备,环境与拓扑图如下:
主机名 |
外网IP |
内网IP |
安装组件 |
磁盘块 |
c720181 |
172.22.69.84 |
192.168.20.181 |
ceph-deploy osd |
sdb |
c720182 |
172.22.69.85 |
192.168.20.182 |
mon osd |
sdb |
c720183 |
172.22.69.86 |
192.168.20.183 |
mon osd |
sdb |
c720184 |
172.22.69.95 |
192.168.20.184 |
cli |
============每台主机都需要配置============
配置主机名,IP地址(略)
关闭防护墙和selinux(略)
配置主机名解析,使用/etc/hosts
cat >>/etc/hosts>>EOF
192.168.20.181 c720181
192.168.20.182 c720182
192.168.20.183 c720183
192.168.20.184 c720184
1.2 部署安装
安装方式如下:
官网安装方式:https://docs.ceph.com/docs/master/start/
Ansilbe安装方式:https://docs.ceph.com/ceph-ansible/master/
使用官方推荐的ceph-deploy部署集群:
============每台主机都需要配置============
配置环境变量:
export username="ceph-admin"
export passwd="ceph-admin"
export node1="c720181"
export node2="c720182"
export node3="c720183"
export node4="c720184"
export node1_ip="192.168.20.181"
export node2_ip="192.168.20.182"
export node3_ip="192.168.20.183"
export node4_ip="192.168.20.184"
配置rpm
wget -O /etc/yum.repos.d/ceph.repo https://raw.githubusercontent.com/aishangwei/ceph-demo/master/ceph-deploy/ceph.repo
或者直接在/etc/yum/repos.d/目录下,创建ceph.repo,添加内容如下:
[ceph]
name=ceph
baseurl=http://mirrors.aliyun.com/ceph/rpm-luminous/el7/x86_64/
gpgcheck=0
priority=1
[ceph-noarch]
name=cephnoarch
baseurl=http://mirrors.aliyun.com/ceph/rpm-luminous/el7/noarch/
gpgcheck=0
priority=1
[ceph-source]
name=Ceph source packages
baseurl=http://mirrors.aliyun.com/ceph/rpm-luminous/el7/SRPMS
enabled=0
gpgcheck=1
type=rpm-md
gpgkey=http://mirrors.aliyun.com/ceph/keys/release.asc
priority=1
配置NTP
yum -y install ntpdate ntp
ntpdate cn.ntp.org.cn
systemctl restart ntpd ntpdate &&
systemctl enable ntpd ntpdate
创建部署用户和ssh免密码登陆
useradd ${username}
echo "${passwd}" | passwd --stdin
${username}
echo "${username} ALL = (root)
NOPASSWD:ALL" | sudo tee /etc/sudoers.d/${username}
chmod 0440 /etc/sudoers.d/${username}
配置sudo 不需要tty
sed -i 's/Default requiretty/#Default requiretty/' /etc/sudoers
============只在管理节点192.168.20.181上配置============
su - ceph-admin
export username=ceph-admin
ssh-keygen
ssh-copy-id ${username}@c720181
ssh-copy-id ${username}@c720182
ssh-copy-id ${username}@c720183
ssh-copy-id ${username}@c720184
1.2.1 安装 ceph-deploy
su - ceph-admin
sudo yum install -y ceph-deploy python-pip
如果提示没有python-pip安装包,则切换到root用户安装epel-release,然后再尝试安装python-pip
1.2.2 部署节点
su - ceph-admin
mkdir my-cluster
cd my-cluster
ceph-deploy new c720181 c720182 c720183
编辑ceph.conf配置文件
cat ceph.conf
[global]
……
public network = 172.22.69.0/24
cluster network = 192.168.20.0/24
============每台主机都需要配置============
安装ceph包,替代再管理端使用ceph-deploy install node1 node2 node3,因为使用ceph-deploy安装的话通过官网yum源去安装,这样会很慢而且容易报错
yum install -y ceph ceph-radosgw
如果有遇到上述报错的话,是因为yum源没有相关依赖包,则切换到root用户安装epel-release,然后再尝试安装 yum install -y ceph ceph-radosgw
============只在管理节点192.168.20.181上配置============
配置初始化monitor(s)、并收集所有密钥
su - ceph-admin
cd my-cluster
ceph-deploy mon create-initial
如果出现上述报错:
解决办法:在各个节点上执行sudo pkill ceph,然后再在deploy节点执行ceph-deploy mon create-initial
ls -l *.keyring
然后发现ERROR报错消失了,配置初始monitor(s)、并收集到了所有密钥,当前目录下可以看到下面这些密钥环
ceph.bootstrap-mds.keyring
ceph.bootstrap-mgr.keyring
ceph.bootstrap-osd.keyring
ceph.bootstrap-rgw.keyring
ceph.client.admin.keyring
把配置信息拷贝到各节点
ceph-deploy admin c720181 c720182 c720183
配置osd
for dev in /dev/sdb
do
ceph-deploy disk zap c720181
$dev
ceph-deploy osd create c720181
--data $dev
ceph-deploy disk zap c720182
$dev
ceph-deploy osd create c720182
--data $dev
ceph-deploy disk zap c720183
$dev
ceph-deploy osd create c720183
--data $dev
done
如果有多个硬盘,可以将
for dev in /dev/sdb 改为
for dev in /dev/sdb, /dev/sdc, /dev/sdd
部署mgr(新版本监控UI, L版以后才需要部署)
ceph-deploy mgr create c720181 c720182 c720183
开启dashboard模块,用于UI查看
ceph mgr module enable dashboard
上述报错是因为/etc/ceph 目录权限是root,而不是ceph-admin
所以用所属用户权限改成ceph-admin即可:sudo chown -R ceph-admin
/etc/ceph/
再执行启用dashboard模块命令:ceph mgr module enable
dashboard
访问监控面板地址:http://192.168.20.181:7000/servers
问题处理:
1、 访问速度慢,输入链接访问,退出lab非常慢,通过F12发现访问跳转到fonts.googleapis.com CSS文件特别久。
解决办法:取消访问http://fonts.googleapis.com 站点的CSS静态文件。
路径:/usr/lib64/ceph/mgr/dashboard/static/AdminLTE-2.3.7/dist/css
需改下面两个文件,注释掉访问http://fonts.googleapis.com的行
vim AdminLTE.min.css
# @import url(https://fonts.googleapis.com/css?family=Source+Sans+Pro:300,400,600,700,300italic,400italic,600italic);/*!
* AdminLTE v2.3.7
* Author: Almsaeed Studio
* Website: Almsaeed Studio <http://almsaeedstudio.com>
* License: Open source - MIT
* Please visit http://opensource.org/licenses/MIT for more information
重启服务:
[ceph-admin@c720181 my-cluster]$ ceph mgr module disable dashboard
[ceph-admin@c720181 my-cluster]$ ceph mgr module enable dashboard
Ceph 集群搭建的更多相关文章
- ceph集群搭建
CEPH 1.组成部分 1.1 monitor admin节点安装ceph-deploy工具 admin节点安装ceph-deploy 添加源信息 rm -f /etc/yum.repos.d/* w ...
- Ceph集群搭建及Kubernetes上实现动态存储(StorageClass)
集群准备 ceph集群配置说明 节点名称 IP地址 配置 作用 ceph-moni-0 10.10.3.150 centos7.5 4C,16G,200Disk 管理节点,监视器 monitor ...
- CEPH集群搭建(CentOS 7)
以包含四个节点的集群为例,其中包括一个 ceph-deploy 管理节点和一个三节点的Ceph存储集群. 下图中每个节点代表一台机器. 创建一个 Ceph 存储集群,它有一个 Monitor 和两个 ...
- Ceph集群搭建记录
环境准备 基础环境 node00 192.168.247.144 node00 node01 192.168.247.135 node01 node02 192.168.247.143 node02 ...
- docker创建ceph集群
背景 Ceph官方现在提供两类镜像来创建集群,一种是常规的,每一种Ceph组件是单独的一个镜像,如ceph/daemon.ceph/radosgw.ceph/mon.ceph/osd等:另外一种是最新 ...
- ceph-deploy离线部署ceph集群及报错解决FAQ
ceph-deploy部署ceph集群 环境介绍 主机名 ip地址 操作系统 角色 备注 ceph-node1 10.153.204.13 Centos7.6 mon.osd.mds.mgr.rgw. ...
- Ceph部署(一)集群搭建
背景 Ceph简介 Ceph是一个分布式存储,可以提供对象存储.块存储和文件存储,其中对象存储和块存储可以很好地和各大云平台集成.一个Ceph集群中有Monitor节点.MDS节点(可选,用于文件存储 ...
- Ceph 存储集群 - 搭建存储集群
目录 一.准备机器 二.ceph节点安装 三.搭建集群 四.扩展集群(扩容) 一.准备机器 本文描述如何在 CentOS 7 下搭建 Ceph 存储集群(STORAGE CLUSTER). 一共4 ...
- 小型ceph集群的搭建
了解ceph DFS(distributed file system)分布式存储系统,指文件系统管理的物理存储资源,不一定直接连接在本地节点上,而是通过计算机网络与节点相连,众多类别中,ceph是当下 ...
随机推荐
- ubuntu开机自启动服务
ubuntu下一个用来管理开机自启动服务的程序,今天在ss vps上安装时老是提示这个错误,百度后,下面的这个方法可行: vi /etc/apt/source.list 输入i,进入Insert模式 ...
- T-SQL Part V: Locks
写SQL最常见的问题就是Dead Lock了.本篇简单介绍入门级别的Lock使用和排查. 首先来看MSDN上的官方文档(https://technet.microsoft.com/en-us/libr ...
- gitbook的插件配置
原生的gitbook样式比较单一,美观度和功能欠佳,可通过相关插件进行拓展. 插件地址:https://plugins.gitbook.com/ 主目录下新建book.json: { "au ...
- 通过myclipse建立一个简单的Hibernate项目(PS:在单元测试中实现数据的向表的插入)
Hibernate的主要功能及用法: Ⅰ.Hibernate封装了JDBC,使Java程序员能够以面向对象的思想对数据库进行操作 Ⅱ.Hibernate可以应用于EJB的J2EE架构,完成数据的持久化 ...
- pat 1046 Shortest Distance(20 分) (线段树)
1046 Shortest Distance(20 分) The task is really simple: given N exits on a highway which forms a sim ...
- pat 1015 Reversible Primes(20 分)
1015 Reversible Primes(20 分) A reversible prime in any number system is a prime whose "reverse& ...
- nyoj 82-迷宫寻宝(一) (多重BFS)
82-迷宫寻宝(一) 内存限制:64MB 时间限制:1000ms 特判: No 通过数:3 提交数:5 难度:4 题目描述: 一个叫ACM的寻宝者找到了一个藏宝图,它根据藏宝图找到了一个迷宫,这是一个 ...
- nyoj 599-奋斗的小蜗牛 (double ceil(); (temp - 1) / 5)
599-奋斗的小蜗牛 内存限制:64MB 时间限制:1000ms 特判: No 通过数:0 提交数:96 难度:1 题目描述: 传说中能站在金字塔顶的只有两种动物,一种是鹰,一种是蜗牛.一只小蜗牛听了 ...
- nyoj 244-16进制的简单运算 (scanf("%x%c%x", &a, &b, &c); printf("%o", a ± b))
244-16进制的简单运算 内存限制:64MB 时间限制:1000ms 特判: No 通过数:12 提交数:13 难度:1 题目描述: 现在给你一个16进制的加减法的表达式,要求用8进制输出表达式的结 ...
- java中hashmap容量的初始化
HashMap使用HashMap(int initialCapacity)对集合进行初始化. 在默认的情况下,HashMap的容量是16.但是如果用户通过构造函数指定了一个数字作为容量,那么Hash会 ...