版权:本文版权归作者和博客园共有,欢迎转载,但未经作者同意必须保留此段声明,且在文章页面明显位置给出原文连接。如有问题,可以邮件:wangxu198709@gmail.com

背景

OpenStack社区一直在尝试用Container技术来部署其各个组件,由此还发展出了kolla这个big tent项目,以及衍生项目kolla-ansible。

最近项目上有些调整,有了些自由时间,于是开始尝试使用container方式部署OpenStack的组件,自然是从最熟悉的Cinder开始。

惊喜的发现Cinder项目自身就有一个简单易上手的脚步,可以帮助理解以container部署Cinder的基本步骤和方式。

 [请在ROOT用户下执行下面所有的命令,主要是docker和后面的local-attach都需要root或者sudo,直接使用root会少掉很多坑]

配置环境

首先clone下来cinder的源代码:

git clone https://github.com/openstack/cinder

cd contrib/block-box/

然后就是安装相关的依赖了,如make, docker,docker-compose

安装make及相关包

sudo apt-get install build-essential

安装docker

https://www.digitalocean.com/community/tutorials/how-to-install-and-use-docker-on-ubuntu-16-04

安装docker-compose

https://www.digitalocean.com/community/tutorials/how-to-install-docker-compose-on-ubuntu-16-04

接下来就是build需要的docker image了

make base

这个过程中,会clone loci-cinder项目,如果遇到不能clone这个项目,你可以把loci-cinder项目clone到本地,然后修改目录下的Makefile, 指向本地的loci-cinder就行。我就遇到这种问题,于是我做了如下修改

# git diff Makefile
diff --git a/contrib/block-box/Makefile b/contrib/block-box/Makefile
index ca173cc..ff60a56
--- a/contrib/block-box/Makefile
+++ b/contrib/block-box/Makefile
@@ -, +, @@
CINDER_BRANCH ?= master # master, stable/ocata, refs/changes///
NAME_PREFIX ?= ""
-PLATFORM ?= debian # ubuntu, centos
+PLATFORM ?= ubuntu # debian, centos
TAG ?= latest all: base lvm devbox base:
- docker build https://git.openstack.org/openstack/loci-cinder.git\#:$(PLATFORM) --tag cinder:$(TAG) --build-arg PROJECT_REF=$(CINDER_BRANCH)
+ docker build /root/containerized/loci-cinder/$(PLATFORM) --tag cinder:$(TAG) --build-arg PROJECT_REF=$(CINDER_BRANCH) lvm:
docker build -t cinder-lvm -f ./docker_files/Dockerfile.cinder-lvm .

Docker 的image build好过后,马上就可以使用docker-compose命令启动cinder的相关service了。

启动docker的相关service

启动之前你要按照自己的需求,修改目录下的etc-cinder/cinder.confdocker-compose.yml文件,你可以参考我的gist文件 cinder.conf 和 docker-compose.yml

docker-compose -f docker-compose.yml up -d

docker-compose up -d
Creating network "blockbox_cindernet" with driver "bridge"
Creating blockbox_mariadb_1 ...
Creating blockbox_rabbitmq_1 ...
Creating blockbox_mariadb_1
Creating blockbox_mariadb_1 ... done
Creating blockbox_rabbitmq_1 ... done
Creating blockbox_cinder-api_1 ... done
Creating blockbox_cinder-scheduler_1 ...
Creating blockbox_cinder-scheduler_1 ... done
Creating blockbox_cinder-volume_1 ...
Creating blockbox_cinder-volume_1 ... done

启动后,查看启动的container,发现cinder-api服务启动后又退出了。

docker ps

最后发现,cinder api的相关code有变动,需要在 当前目录(contrib/block-box)的 etc-cinder/cinder.conf,加入下面绿色内容,cinder-api才能启动成功,不让会因为找不到key manager而退出:

[database]
connection = mysql+pymysql://cinder:password@mariadb/cinder?charset=utf8
[key_manager]
backend = cinder.keymgr.conf_key_mgr.ConfKeyManager

更改后,重新启动所有docker containers

docker-compose -f docker-compose.yml down
docker-compose -f docker-compose.yml up -d

等一段时间,重新检查所有的docker containers

docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
67180a6e8056 cinder "bash -c 'pip inst..." seconds ago Up seconds blockbox_cinder-volume_1
d963f200be2a cinder "cinder-scheduler" seconds ago Up seconds blockbox_cinder-scheduler_1
5166d688bbbd cinder "sh /init-scripts/..." seconds ago Up seconds blockbox_cinder-api_1
a14757b40830 mariadb "docker-entrypoint..." seconds ago Up seconds 0.0.0.0:->/tcp blockbox_mariadb_1
b23d77e10bad rabbitmq "docker-entrypoint..." seconds ago Up seconds /tcp, /tcp, /tcp, 0.0.0.0:->/tcp blockbox_rabbitmq_1

所有服务都启动成功,后面使用cinder client请求cinder volume

TIPS: 可以使用下面命令查看docker里面的log。

docker logs <container id> -f 

使用cinder volume

安装cinder client

接下来,在host上新建virtual environment并在venv中安装最新的cinder client(只有最新的cinder client才有对noauth这种认证方式的支持)

# 创建venv
virtualenv pyenv . pyenv/bin/activate
git clone https://github.com/openstack/python-cinderclient
pip install -e python-cinderclient

直接请求请求cinder api

(pyenv) peter@ubuntu16:~/pyenv$ cinder --os-auth-type=noauth --os-endpoint="http://127.0.0.1:8776/v3" --os-user-id=admin --os-tenant-id=admin list
+--------------------------------------+-----------+--------+------+-------------+----------+-------------+
| ID | Status | Name | Size | Volume Type | Bootable | Attached to |
+--------------------------------------+-----------+--------+------+-------------+----------+-------------+
| 0fefa93d-475e-4cde--cc5666fde991 | available | peter1 | | - | false | |
+--------------------------------------+-----------+--------+------+-------------+----------+-------------+

注意上面使用了--os-auth-type-noauth,这就是让它直接请求cinder api,而不是先到keystone去认证。使用--os-endpoint=127.0.0.1:8776/v3是因为cinder-api同时暴露在了host上的这个端口上。

这样,就可以使用很多cinder的命令,比如cinder create,list,snapshot-create等等,相关的storage就可以被这个standalone的cinder来管理了。

使用local-attach

volume创建好后,这里不能给到VM直接使用,因为没有nova:)。尴尬,难道volume就不能给host用了吗?当然可以。opestack社区提供了一个cinder client的plugin,让volume可以直接attach给一个host

安装python-brick-cinderclient-ext

git clone https://github.com/openstack/python-brick-cinderclient-ext
pip install -e python-brick-cinderclient-ext/

现在我把刚才创建的volume暴露给host使用(记得在host上安装open-iscsi包)

cinder --os-auth-type=noauth --os-endpoint="http://127.0.0.1:8776/v3" --os-user-id=admin --os-tenant-id=admin local-attach 0fefa93d-475e-4cde--cc5666fde991

注意,要保证--os-user-id和--os-tenant-id使用与create volume一样的参数,否则会出现NotVolumeFound类似的error

参考文献:

https://thenewstack.io/deploying-cinder-stand-alone-storage-service/

https://gorka.eguileor.com/standalone-cinder/

使用docker部署standalone cinder的更多相关文章

  1. Docker 部署前后端项目

    Docker 部署前后端项目 平生不会相思,才会相思,便害相思. 简介:都是被逼的,从零开始一个Docker 部署九个微服务和三个前端项目.其中,这些服务需要用到Nacos.MySQL.Nginx.E ...

  2. ASP.NET Core开发-Docker部署运行

    ASP.NET Core开发Docker部署,.NET Core支持Docker 部署运行.我们将ASP.NET Core 部署在Docker 上运行. 大家可能都见识过Docker ,今天我们就详细 ...

  3. Docker部署Hadoop集群

    Docker部署Hadoop集群 2016-09-27 杜亦舒 前几天写了文章"Hadoop 集群搭建"之后,一个朋友留言说希望介绍下如何使用Docker部署,这个建议很好,Doc ...

  4. 程序开发使用docker部署

    我们公司自己研发了一套 grand-line 系统,使用 docker 来部署项目. 我是第一批小白鼠,一开始网络差,build 一次要半个小时,连接进入 web shell 也很慢,部署一个微信项目 ...

  5. 我使用celery以及docker部署遇到的问题

    首先我本机测试时没有问题的,但是在线上docker中,任务一直显示 "Sending due task".超时的任务是 django orm update 操作,本地不会出现这样的 ...

  6. Docker部署SDN环境

    2014-12-03 by muzi Docker image = Java class Docker container = Java object 前言 5月份的时候,当我还是一个大学生的时候,有 ...

  7. 在生产环境使用Docker部署应用

    导读 Docker现在越来越流行,但是真正在生产环境部署Docker还是个比较新的概念,还没有一个标准的流程.作者是ROR的程序员,作者结合平时的部署经验,联系Docker的特点,向大家分享了其在生产 ...

  8. Docker 使用指南 (六)—— 使用 Docker 部署 Django 容器栈

    版权声明:本文由田飞雨原创文章,转载请注明出处: 文章原文链接:https://www.qcloud.com/community/article/98 来源:腾云阁 https://www.qclou ...

  9. NET Core Docker部署

    NET Core Docker部署 前言 在前面文章中,介绍了 ASP.NET Core在 macOS,Linux 上基于Nginx和Jexus的发布和部署,本篇文章主要是如何在Docker容器中运行 ...

随机推荐

  1. 我理解的Java中重载与重写

    程序中我们用方法来实现对对象的操作,但是对象可能有不同的数据类型,这时候对不同的数据类型,进行相同的操作,我们就可以用到方法的重载,即方法名相同,但是具有不同的参数列表. 方法的重载可以根据传递参数的 ...

  2. 深度学习在 CTR 中应用

    欢迎大家前往腾讯云技术社区,获取更多腾讯海量技术实践干货哦~ 作者:高航 一. Wide&&Deep 模型 首先给出Wide && Deep [1] 网络结构: 本质上 ...

  3. jQuery实现鼠标滑过导航栏呈现不同的样式

    素材图片 源码: <!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://ww ...

  4. awk知识点全回顾

    本文目录:1.awk简介和基本语法格式2.print和printf格式化输出3.输入行的字段分隔符和行分隔符4.BGEIN和END5.数组6.流程控制语句 6.1 条件判断语句 6.2 while循环 ...

  5. Intellij Idea 13 快捷键(与Eclipse比对)以及基本的设置

    详见:http://blog.yemou.net/article/query/info/tytfjhfascvhzxcyt404 刚到新公司,用的台式机配置不给力,Eclipse很不给力,几个项目一起 ...

  6. Day-9: 面对对象高级编程

    数据封装.继承和多态只是面向对象编程中最基础的3个概念. 下面整理面向对象高级编程的更为强大的技巧. 使用__slots__:Python属于动态语言,可以允许已创建好的类动态地绑定任何属性和方法.但 ...

  7. 201521123069 《Java程序设计》 第7周学习总结

    1. 本周学习总结 以你喜欢的方式(思维导图或其他)归纳总结集合相关内容. 参考资料: XMind List列表:元素以线性方式存放,允许有重复的对象. Set集:集合中的对象不按特定的方式排序,并且 ...

  8. 201521123105 第七周Java学习总结

    1. 本周学习总结 2. 书面作业 1.ArrayList代码分析 1.1 解释ArrayList的contains源代码 以下是ArrayList的contains源代码: public boole ...

  9. 201521123068《Java程序设计》第3周学习总结

    1. 本周学习总结 点击查看大图->(http://naotu.baidu.com/file/7921c1cda46d65d08f2ef0d7a6af6651?token=3a35cbe7720 ...

  10. 201521123036 《Java程序设计》第14周学习总结

    本周学习总结 以你喜欢的方式(思维导图或其他)归纳总结多数据库相关内容. 书面作业 MySQL数据库基本操作 1.1 建立数据库,将自己的姓名.学号作为一条记录插入.(截图,需出现自己的学号.姓名) ...