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 集群搭建的更多相关文章

  1. ceph集群搭建

    CEPH 1.组成部分 1.1 monitor admin节点安装ceph-deploy工具 admin节点安装ceph-deploy 添加源信息 rm -f /etc/yum.repos.d/* w ...

  2. Ceph集群搭建及Kubernetes上实现动态存储(StorageClass)

    集群准备 ceph集群配置说明   节点名称 IP地址 配置 作用 ceph-moni-0 10.10.3.150 centos7.5 4C,16G,200Disk 管理节点,监视器 monitor ...

  3. CEPH集群搭建(CentOS 7)

    以包含四个节点的集群为例,其中包括一个 ceph-deploy 管理节点和一个三节点的Ceph存储集群. 下图中每个节点代表一台机器. 创建一个 Ceph 存储集群,它有一个 Monitor 和两个 ...

  4. Ceph集群搭建记录

    环境准备 基础环境 node00 192.168.247.144 node00 node01 192.168.247.135 node01 node02 192.168.247.143 node02 ...

  5. docker创建ceph集群

    背景 Ceph官方现在提供两类镜像来创建集群,一种是常规的,每一种Ceph组件是单独的一个镜像,如ceph/daemon.ceph/radosgw.ceph/mon.ceph/osd等:另外一种是最新 ...

  6. ceph-deploy离线部署ceph集群及报错解决FAQ

    ceph-deploy部署ceph集群 环境介绍 主机名 ip地址 操作系统 角色 备注 ceph-node1 10.153.204.13 Centos7.6 mon.osd.mds.mgr.rgw. ...

  7. Ceph部署(一)集群搭建

    背景 Ceph简介 Ceph是一个分布式存储,可以提供对象存储.块存储和文件存储,其中对象存储和块存储可以很好地和各大云平台集成.一个Ceph集群中有Monitor节点.MDS节点(可选,用于文件存储 ...

  8. Ceph 存储集群 - 搭建存储集群

    目录 一.准备机器 二.ceph节点安装 三.搭建集群 四.扩展集群(扩容)   一.准备机器 本文描述如何在 CentOS 7 下搭建 Ceph 存储集群(STORAGE CLUSTER). 一共4 ...

  9. 小型ceph集群的搭建

    了解ceph DFS(distributed file system)分布式存储系统,指文件系统管理的物理存储资源,不一定直接连接在本地节点上,而是通过计算机网络与节点相连,众多类别中,ceph是当下 ...

随机推荐

  1. (Codeforce)Correct Solution?

    One cold winter evening Alice and her older brother Bob was sitting at home near the fireplace and g ...

  2. PHP---无限极分类数组处理

    $array = array(    0=>array('id'=>1,'uid'=>0,'menuname'=>'菜单1','url'=>0,'addtime'=> ...

  3. 『嗨威说』算法设计与分析 - 贪心算法思想小结(HDU 2088 Box of Bricks)

    本文索引目录: 一.贪心算法的基本思想以及个人理解 二.汽车加油问题的贪心选择性质 三.一道贪心算法题点拨升华贪心思想 四.结对编程情况 一.贪心算法的基本思想以及个人理解: 1.1 基本概念: 首先 ...

  4. hdu 1087 Super Jumping! Jumping! Jumping!(动态规划DP)

    Super Jumping! Jumping! Jumping!Time Limit: 2000/1000 MS (Java/Others)    Memory Limit: 65536/32768 ...

  5. VMware虚拟机Linux中增加磁盘空间的扩容操作

    VMwareware虚拟机安装的Red Hat Enterprise Linux系统剩余空间不足,造成软件无法正常安装.如果重新装一遍系统就需要重新配置好开发环境和软件的安装配置.结合自己的实践,总结 ...

  6. NetCore3.0 文件上传与大文件上传的限制

    NetCore文件上传两种方式 NetCore官方给出的两种文件上传方式分别为“缓冲”.“流式”.我简单的说说两种的区别, 1.缓冲:通过模型绑定先把整个文件保存到内存,然后我们通过IFormFile ...

  7. Bootstrap中手指控制轮播图切换

    通过手指的滑动来控制轮播图中的图片内容的切换 // 1. 获取手指在轮播图元素上的一个滑动方向(左右) // 获取界面上的轮播图容器 var $carousels = $('.carousel'); ...

  8. STDN: Scale-Transferrable Object Detection论文总结

    概述 STDN是收录于CVPR 2018的一篇目标检测论文,提出STDN网络用于提升多尺度目标的检测效果.要点包括:(1)使用DenseNet-169作为基础网络提取特征:(2)提出Scale-tra ...

  9. 【漏洞复现】Apache Solr远程代码执行(CVE-2019-0193)

    0x01 概述 Solr简介 Apache Solr 是一个开源的企业级搜索服务器.Solr 使用 Java 语言开发,主要基于 HTTP 和 Apache Lucene 实现.Apache Solr ...

  10. .NET Core 跨平台 GUI 开发之 GTtkSharp 初级篇

    .NET Core 跨平台 GUI 开发之 GTtkSharp 初级篇 本文作为初级篇,适合已经安装好.NET Core 环境以及 Gtk 环境,并具备了 C#开发基础知识,能跑一些简单的例子,希望更 ...