openstack 配置ceph

准备工作

在配置openstack 之前,需要将使用ceph的节点设置为ceph 客户端

  1. 修改改客户端的/etc/hosts,/etc/hostname两个文件

  2. 将部署机的公钥发送到客户端

ssh-copy-id {userame}@node1
  1. 修改部署机的~/.ssh/config 文件,指定链接的用户

  2. 首先更新客户端的yum源,使客户端可以安装ceph

  3. 在部署机(10.19.19.1)上执行下列命令:

在/my_cluster/目录下执行

ceph-deploy install client.{客户端名字}
ceph-deploy admin client.{客户端名字}

(安装地址)[http://docs.ceph.com/docs/master/rbd/rbd-openstack/]
(官方中文文档)[http://docs.ceph.org.cn/rbd/rbd-openstack/]

CREATE A POOL

默认情况下,Ceph块设备使用rbd池。您可以使用任何可用的池。我们建议创建一个用于Cinder的池和一个用于Glanc的池。确保Ceph集群正在运行,然后创建池。

ceph osd pool create volumes 128
ceph osd pool create images 128
ceph osd pool create backups 128
ceph osd pool create vms 128

新创建的池必须在使用之前进行初始化。使用rbd工具初始化池

rbd pool init volumes
rbd pool init images
rbd pool init backups
rbd pool init vms

CONFIGURE OPENSTACK CEPH CLIENTS

运行glous -api、cinders -volume、nova-compute和cinbackup备份的节点充当Ceph客户机。每个都需要ceph配置文件:

ssh {your-openstack-server} sudo tee /etc/ceph/ceph.conf </etc/ceph/ceph.conf

INSTALL CEPH CLIENT PACKAGES

在glance-api 节点,需要为librbd安装 Python bindings

sudo yum install python-rbd

在 nova-compute, cinder-backup 及 cinder-volume 节点, use both the Python bindings and the client command line tools:

sudo yum install ceph-common

SETUP CEPH CLIENT AUTHENTICATION
添加认证信息

  1. 创建新的用户
  • 监视器能力: 监视器能力包括 r 、 w 、 x 和 allow profile {cap} ,例如
  • OSD 能力: OSD 能力包括 r 、 w 、 x 、 class-read 、 class-write 和 profile osd 。另外, OSD 能力还支持存储池和命名空间的配置。

创建client.glance用户

ceph auth get-or-create client.glance mon 'profile rbd' osd 'profile rbd pool=images'

创建client.cinder用户

ceph auth get-or-create client.cinder mon 'profile rbd' osd 'profile rbd pool=volumes, profile rbd pool=vms, profile rbd-read-only pool=images'

创建client.cinder-backup用户

ceph auth get-or-create client.cinder-backup mon 'profile rbd' osd 'profile rbd pool=backups'

  1. 添加key

为glance 添加key

ceph auth get-or-create client.glance | ssh {your-glance-api-server} sudo tee /etc/ceph/ceph.client.glance.keyring

ssh {your-glance-api-server} sudo chown glance:glance /etc/ceph/ceph.client.glance.keyring

在192.168.125.125机器上执行如下
ceph auth get-or-create client.glance | ssh 192.168.125.125 sudo tee /etc/ceph/ceph.client.glance.keyring
ssh 192.168.125.125 sudo chown glance:glance /etc/ceph/ceph.client.glance.keyring

为cinder添加key

ceph auth get-or-create client.cinder | ssh {your-volume-server} sudo tee /etc/ceph/ceph.client.cinder.keyring

ssh {your-cinder-volume-server} sudo chown cinder:cinder /etc/ceph/ceph.client.cinder.keyring

为cinder-backup添加key

ceph auth get-or-create client.cinder-backup | ssh {your-cinder-backup-server} sudo tee /etc/ceph/ceph.client.cinder-backup.keyring

ssh {your-cinder-backup-server} sudo chown cinder:cinder /etc/ceph/ceph.client.cinder-backup.keyring

运行 nova-compute的节点需要keyring文件

ceph auth get-or-create client.cinder | ssh {your-nova-compute-server} sudo tee /etc/ceph/ceph.client.cinder.keyring

还需要存储 client.cinder 的秘密密钥在libvirt中。libvirt进程需要它访问集群,同时从Cinder附加块设备。
在运行nova-compute的节点上创建密钥的临时副本:

ceph auth get-key client.cinder | ssh {your-compute-node} tee client.cinder.key

然后,在计算节点上,向libvirt添加密钥,并删除密钥的临时副本:

uuidgen
9191d801-4d57-476e-acfb-84bf55d0bd54
cat > secret.xml <<EOF
<secret ephemeral='no' private='no'>
  <uuid>9191d801-4d57-476e-acfb-84bf55d0bd54</uuid>
  <usage type='ceph'>
    <name>client.cinder secret</name>
  </usage>
</secret>
EOF
sudo virsh secret-define --file secret.xml
Secret 9191d801-4d57-476e-acfb-84bf55d0bd54 created

sudo virsh secret-set-value --secret 9191d801-4d57-476e-acfb-84bf55d0bd54 --base64 $(cat client.cinder.key)&&rm client.cinder.key secret.xml

稍后保存秘密的uuid,以便配置nova-compute。


CONFIGURE OPENSTACK TO USE CEPH

配置GLANCE

Glance可以使用多个后端来存储镜像。要默认使用Ceph块设备,请像下面这样配置Glance。
KILO 及之后版本

编辑 /etc/glance/glance-api.conf文件

[glance_store]
stores = rbd
default_store = rbd
rbd_store_pool = images
rbd_store_user = glance
rbd_store_ceph_conf = /etc/ceph/ceph.conf
rbd_store_chunk_size = 8

ENABLE COPY-ON-WRITE CLONING OF IMAGES(开启)
注意,这将通过Glance的API公开后端位置,因此启用此选项的端点不应公开访问。
如果你想允许使用 image 的写时复制克隆,MITAKA 之外的版本。还可以在[DEFAULT]部分下添加:

[DEFAULT]
show_image_direct_url = True

DISABLE CACHE MANAGEMENT

关闭 the Glance cache management 以防止镜像cached 在 /var/lib/glance/image-cache/, 假设您的配置文件flavor = keystone+cachemanagement:

[paste_deploy]
flavor = keystone

IMAGE PROPERTIES

建议使用如下设置

增加virtio-scsi控制器,获得更好的性能和对丢弃操作的支持

hw_scsi_model=virtio-scsi

链接控制节点的每一个cinder block devices

hw_disk_bus=scsi

开启QEMU guest agent

hw_qemu_guest_agent=yes

通过QEMU客户代理发送fs-freeze/thaw调用

os_require_quiesce=yes

重启glance

systemctl restart openstack-glance-api

验证

 rados -p images ls

配置 CINDER

OpenStack需要驱动程序与Ceph块设备进行交互。还必须为块设备指定池名。
在OpenStack 节点上, 编辑文件 /etc/cinder/cinder.conf 并添加一下内容

[DEFAULT]
...
enabled_backends = ceph
glance_api_version = 2
...
[ceph]
volume_driver = cinder.volume.drivers.rbd.RBDDriver
volume_backend_name = ceph
rbd_pool = volumes
rbd_ceph_conf = /etc/ceph/ceph.conf
rbd_flatten_volume_from_snapshot = false
rbd_max_clone_depth = 5
rbd_store_chunk_size = 4
rados_connect_timeout = -1

如果添加了身份认证,

rbd_user = cinder
rbd_secret_uuid = 9191d801-4d57-476e-acfb-84bf55d0bd54

配置 NOVA

为了将所有虚拟机直接引导到Ceph,必须配置Nova的临时后端。建议在Ceph配置文件中启用RBD缓存(默认情况下启用,因为是Giant)。此外,启用管理套接字在进行故障排除时带来了很多好处。使用Ceph块设备让每个虚拟机有一个套接字将有助于调查性能和/或错误行为。
这个套接字可以这样访问:

ceph daemon /var/run/ceph/ceph-client.cinder.19195.32310016.asok help

在每一个计算节点编辑 Ceph配置文件 :

[client]
rbd cache = true
rbd cache writethrough until flush = true
admin socket = /var/run/ceph/guests/$cluster-$type.$id.$pid.$cctid.asok
log file = /var/log/qemu/qemu-guest-$pid.log
rbd concurrent management ops = 20

为这些路径配置permissions权限

mkdir -p /var/run/ceph/guests/ /var/log/qemu/
chown qemu:libvirtd /var/run/ceph/guests /var/log/qemu/

JUNO
在 Juno 版中, Ceph 块设备移到了 [libvirt] 段下。编辑所有计算节点上的 /etc/nova/nova.conf 文件,在 [libvirt] 段下添加:

(6982行)
[libvirt]
images_type = rbd
images_rbd_pool = vms
images_rbd_ceph_conf = /etc/ceph/ceph.conf
rbd_user = cinder
rbd_secret_uuid = 9191d801-4d57-476e-acfb-84bf55d0bd54
disk_cachemodes="network=writeback"

禁用文件注入也是一个好习惯。启动一个实例时, Nova 通常试图打开虚拟机的根文件系统。然后, Nova 会把比如密码、 ssh 密钥等值注入到文件系统中。然而,最好依赖元数据服务和 cloud-init 。

编辑所有计算节点上的 /etc/nova/nova.conf 文件,在 [libvirt] 段下添加:

inject_password = false
inject_key = false
inject_partition = -2
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 203,456评论 5 477
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 85,370评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 150,337评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,583评论 1 273
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,596评论 5 365
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,572评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 37,936评论 3 395
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,595评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 40,850评论 1 297
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,601评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,685评论 1 329
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,371评论 4 318
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 38,951评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,934评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,167评论 1 259
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 43,636评论 2 349
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,411评论 2 342

推荐阅读更多精彩内容