前言

前一篇介绍了docker在命令行下面进行的ceph部署,本篇用docker的UI进行ceph的部署,目前来说市面上还没有一款能够比较简单就能直接在OS上面去部署Ceph的管理平台,这是因为OS的环境差异化太大,并且包的版本,以及各种软件的适配都可能造成失败,而docker比较固化环境,因此即使一个通用的UI也能很方便的部署出一个Cpeh集群

本篇就是对Docker UI部署集群做一个实践,对ceph了解,对docker了解,对dokcer的UI操作进行一定的了解的情况下,再做实践会比较好,总体上还是比较简单的

安装并运行portainer

安装软件

cd /opt
wget https://github.com/portainer/portainer/releases/download/1.12.1/portainer-1.12.1-linux-amd64.tar.gz
tar xvpfz portainer-1.12.1-linux-amd64.tar.gz
cd portainer

运行软件

./portainer -H unix:///var/run/docker.sock  -p ":9999"

注意下这里-H是指定的docker的连接,也就是要控制哪个docker,这个支持本地的sock的方式,也支持远程的tcp的方式,这个进入ui界面后还可以添加更多的

-p是指定的访问的接口

扩展知识

如何在centos7下面启用 remote api

打开文件

/usr/lib/systemd/system/docker.service

在 $INSECURE_REGISTRY 后面添加 -H tcp://0.0.0.0:2376 -H unix:///var/run/docker.sock

ExecStart=/usr/bin/dockerd-current \
--add-runtime docker-runc=/usr/libexec/docker/docker-runc-current \
--default-runtime=docker-runc \
--exec-opt native.cgroupdriver=systemd \
--userland-proxy-path=/usr/libexec/docker/docker-proxy-current \
$OPTIONS \
$DOCKER_STORAGE_OPTIONS \
$DOCKER_NETWORK_OPTIONS \
$ADD_REGISTRY \
$BLOCK_REGISTRY \
$INSECURE_REGISTRY -H tcp://0.0.0.0:2376 -H unix:///var/run/docker.sock

修改好了后

[root@lab8106 ~]#systemctl daemon-reload
[root@lab8106 ~]#systemctl restart docker

检查端口和asok

[root@lab8106 ~]# netstat -tunlp|grep 2376
tcp6 0 0 :::2376 :::* LISTEN 24484/dockerd-curre
[root@lab8106 ~]# ll /var/run/docker.sock
srw-rw---- 1 root root 0 Mar 16 16:39 /var/run/docker.sock

生成了配置没有问题

portainer的自身数据

默认情况下portainer的数据是存储在/data目录下面的,如果想重新配置密码或者内容的话,删除这个目录里面的数据就行

[root@lab8106 ~]# ll /data/
total 24
-rw------- 1 root root 32768 Mar 16 16:32 portainer.db
drwx------ 2 root root 6 Mar 16 16:32 tls

UI界面登陆

直接访问宿主机的http://ip:9999



输入一个8位数的密码

输入好了以后,登陆即可

检查endpoint,可以看到就是我刚才命令行当中加入的sock

获取image

在上面填写ceph/daemon 然后点击pull

有可能会超时,如果多次失败,就去后台命令行执行,这个地方等同于后台的命令

docker pull ceph/daemon

也可以直接在后台执行这个命令

可以用dstat -n观察下载的速度

下载好了去页面上看下是否好了

配置CEPH集群

配置集群可以都在页面做了,因为之前有篇命令行部署docker的ceph,建议先回顾一下,再看这个比较好

创建MON

点击增加容器

注意创建好两个目录

mkdir -p /etc/ceph
mkdir -p /var/lib/ceph/

这两个目录里面不要有任何东西,保持空目录状态

  • 填写名称为mon,这个是容器名称,可以自定义
  • 填写Image,这个填写下载好的ceph/daemon
  • 填写command,这个填写mon,为固定值
  • 填写Entry Ponit ,这个填写/entrypoint.sh,为固定值
  • 填写Environment variable,这个填写两个变量
    • MON_IP 192.168.8.106
    • CEPH_PUBLIC_NETWORK 192.168.0.0/16

填写完了切换第二个标签页Volumes

  • 填写Volume

    • /etc/ceph /etc/ceph
    • /var/lib/ceph/ /var/lib/ceph/

  • 填写Network为host
  • 填写hostname为宿主机的主机名

    上面都填写完了后就点击create

没出异常的话,就可以进入console进行查询了



点击connect



没有问题

创建OSD

点击增加容器

  • 填写Name,这个为容器名称,可以自定义
  • 填写Image,这个为ceph/daemon,固定的值
  • 填写command,这个为osd_ceph_disk,为定值
  • 填写Entry Ponit ,这个填写/entrypoint.sh,为固定值
  • 填写Environment variable,这个填写一个OSD磁盘变量
  • OSD_DEVICE /dev/sdb

切换到第二个Volume标签页

  • 填写Volume

    • /etc/ceph /etc/ceph
    • /var/lib/ceph/ /var/lib/ceph/
    • /dev/ /dev/

切换到Network标签页

  • 填写Network为host
  • 填写hostname为宿主机的主机名

    上面都填写完了后就点击create



切换到Security/Host标签页

勾选上 privileged ,一定要选上,不然没有权限去格式化磁盘



上面都填写完了后就点击create

没出异常的话,就可以进入console进行查询了

基本上一个简单的集群就配置好了,跨主机的情况,就提前把配置文件拷贝到另外一台主机,还有bootstrap keyring也拷贝过去,就可以了,这里就不做过多的赘述

总结

本篇基于portainer以及一个现有的ceph容器做的部署实践,从整个操作来说,UI的部署,环境的搭建都非常的简单,这个得益于UI环境的简单,还有docker的封装,更多的玩法可以自己去探索,也可以运用这个UI做更多其他的容器操作

变更记录

Why Who When
创建 武汉-运维-磨渣 2017-03-16

/assets/images/blogimg/base-on-docker-ui-deploy-ceph/

基于Docker UI 配置ceph集群的更多相关文章

  1. 庐山真面目之十微服务架构 Net Core 基于 Docker 容器部署 Nginx 集群

    庐山真面目之十微服务架构 Net Core 基于 Docker 容器部署 Nginx 集群 一.简介      前面的两篇文章,我们已经介绍了Net Core项目基于Docker容器部署在Linux服 ...

  2. 配置Ceph集群为OpenStack后端存储

    配置Ceph存储为OpenStack的后端存储 1  前期配置 Ceph官网提供的配置Ceph块存储为OpenStack后端存储的文档说明链接地址:http://docs.ceph.com/docs/ ...

  3. 基于docker虚拟化创建hadoop集群

    最近想用hadoop做一个测试,与性能无关的测试,但是可与屌丝的命,手头没有太多机器,也租不起云主机.这里使用docker进行虚拟化,并搭建hadoop集群,在这里将过程记录如下. 首先安装docke ...

  4. 喵星之旅-狂奔的兔子-基于docker的redis分布式集群

    一.docker安装(略) 二.下载redis安装包(redis-4.0.8.tar.gz) 以任何方式获取都可以.自行官网下载. 三.拉取centos7的docker镜像 命令:docker pul ...

  5. 基于docker快速搭建hbase集群

    一.概述 HBase是一个分布式的.面向列的开源数据库,该技术来源于 Fay Chang 所撰写的Google论文"Bigtable:一个结构化数据的分布式存储系统".就像Bigt ...

  6. 暑假第二弹:基于docker的hadoop分布式集群系统的搭建和测试

    早在四月份的时候,就已经开了这篇文章.当时是参加数据挖掘的比赛,在计科院大佬的建议下用TensorFlow搞深度学习,而且要在自己的hadoop分布式集群系统下搞. 当时可把我们牛逼坏了,在没有基础的 ...

  7. Docker镜像配置redis集群

    redis版本:3.2.3 架构: 3节点redis集群,并为每个节点设置一个备用节点,共6个节点 1.安装redis镜像 docker load < docker.redis.tar.gz 2 ...

  8. 基于docker的spark-hadoop分布式集群之一: 环境搭建

    一.软件准备 1.基础docker镜像:ubuntu,目前最新的版本是18 2.需准备的环境软件包: (1) spark-2.3.0-bin-hadoop2.7.tgz (2) hadoop-2.7. ...

  9. 搭建基于docker 的redis分布式集群在docker for windows

    https://blog.csdn.net/xielinrui123/article/details/85104446 首先在docker中下载使用 docker pull redis:3.0.7do ...

随机推荐

  1. elk-日志方案--使用Filebeat收集日志并输出到Kafka

      1,Filebeat简介 Filebeat是一个使用Go语言实现的轻量型日志采集器.在微服务体系中他与微服务部署在一起收集微服务产生的日志并推送到ELK. 在我们的架构设计中Kafka负责微服务和 ...

  2. spring boot:给接口增加签名验证(spring boot 2.3.1)

    一,为什么要给接口做签名验证? 1,app客户端在与服务端通信时,通常都是以接口的形式实现, 这种形式的安全方面有可能出现以下问题: 被非法访问(例如:发短信的接口通常会被利用来垃圾短信) 被重复访问 ...

  3. 第十五章 nginx七层负载均衡

    一.Nginx负载均衡 1.为什么做负载均衡 当我们的Web服务器直接面向用户,往往要承载大量并发请求,单台服务器难以负荷,我使用多台Web服务器组成集群,前端使用Nginx负载均衡,将请求分散的打到 ...

  4. Business Partner - 供应商与客户的集成 - S/4HANA(2)

    配置 BP配置 激活BP的PPO请求 Cross-Application Components->Master Data Synchronization->Master Data Sync ...

  5. OpenCV开发笔记(七十二):红胖子8分钟带你使用opencv+dnn+tensorFlow识别物体

    前言   级联分类器的效果并不是很好,准确度相对深度学习较低,本章使用opencv通过tensorflow深度学习,检测已有模型的分类.   Demo       可以猜测,1其实是人,18序号类是狗 ...

  6. mysql 必会基础1

    1.cmd --> 开启服务:net start mysql 关闭服务:net stop mysql 没有restart命令;命令格式:net stop serviceName;后面不需要加分号 ...

  7. 开源!一款功能强大的高性能二进制序列化器Bssom.Net

    好久没更新博客了,我开源了一款高性能的二进制序列化器Bssom.Net和新颖的二进制协议Bssom,欢迎大家Star,欢迎参与项目贡献! Net开源技术交流群 976304396,禁止水,只能讨论技术 ...

  8. uniapp使用swiper组件做tab切换动态获取高度

    swiper对高度进行了限制,所以说通常做出了tab切换的效果但是内容经常被截取掉???? 所以我在前端做了一个动态获取高度的功能 选项卡标题也就是tab切换的效果 选项卡内容区域的高度自适应 因为进 ...

  9. 4-Kotlin数据类型与变量

    一. 变量概念 在Kotlin中变量其实对应着内存中特定区域,变量就像是一个装"数据"的容器 1 val num1:Int = 100 2 var num2:Int = 99 关键 ...

  10. 用GitHub Pages搭建博客(二)

    本篇介绍基本GitHub Pages的搭建流程 GitHub账号及仓库创建 登录GitHub,录入用户名.邮箱.密码,创建成功后登录进入. 注册时,邮箱建议不使用QQ邮箱.因为一些第三方部署类网站不支 ...