在 Rainbond 上使用 Curve 云原生存储
Curve 是网易主导自研的现代化存储系统, 目前支持文件存储(CurveFS)和块存储(CurveBS)。
CurveBS 的核心应用场景主要包括:
- 虚拟机/容器的性能型、混合型、容量型云盘或持久化卷,以及物理机的远程存储盘
- 高性能存算分离架构:基于RDMA+SPDK的高性能低时延架构,支撑MySQL、kafka等各类数据库、中间件的存算分离部署架构,提升实例交付效率和资源利用率
CurveFS 的核心应用场景主要包括:
- AI训练(含机器学习等)场景下的高性价比存储
- 大数据场景下的冷热数据自动化分层存储
- 公有云上高性价比的共享文件存储:可用于AI、大数据、文件共享等业务场景
- 混合云存储:热数据存储在本地IDC,冷数据存储在公有云
使用 CurveAdm 部署 CurveFS
CurveAdm 是 Curve 团队为提高系统易用性而设计的工具,其主要用于快速部署和运维 CurveBS/CurveFS 集群。主要特性:
- 快速部署 CurveBS/CurveFS 集群
- 容器化服务
- 运维 CurveBS/CurveFS 集群
- 同时管理多个集群
- 一键升级
- 错误精确定位
安装 CurveAdm
bash -c "$(curl -fsSL https://curveadm.nos-eastchina1.126.net/script/install.sh)"
主机列表
主机模块用来统一管理用户主机,以减少用户在各配置文件中重复填写主机 SSH
连接相关配置。我们需导入部署集群和客户端所需的机器列表,以便在之后的各类配置文件中填写部署服务的主机名。
这里采用一台服务器,做单节点集群。
配置免密登陆
生成密钥并配置服务器免密登陆
# 一直回车即可 ssh-keygen # 使用 ssh-copy-id 配置 ssh-copy-id root@172.31.98.243 # 验证免密 ssh root@172.31.98.243 # 无需输入密码登陆成功即可
导入主机列表
准备主机列表文件 hosts.yaml
$ vim hosts.yaml global: user: root # ssh 免密登陆用户名 ssh_port: 22 # ssh 端口 private_key_file: /root/.ssh/id_rsa # 密钥路径 hosts: - host: curve hostname: 172.31.98.243
导入主机列表
$ curveadm hosts commit hosts.yaml
查看主机列表
$ curveadm hosts ls
准备集群拓扑文件
CurveFS 支持单机部署和高可用部署,这里我们采用单机部署验证。
创建 topology.yaml
文件,只需修改 target: curve
,其他都默认即可。
$ vim topology.yaml kind: curvefs global: report_usage: true data_dir: ${home}/curvefs/data/${service_role}${service_host_sequence} log_dir: ${home}/curvefs/logs/${service_role}${service_host_sequence} container_image: opencurvedocker/curvefs:v2.4 variable: home: /tmp target: curve etcd_services: config: listen.ip: ${service_host} listen.port: 2380${service_host_sequence} # 23800,23801,23802 listen.client_port: 2379${service_host_sequence} # 23790,23791,23792 deploy: - host: ${target} - host: ${target} - host: ${target} mds_services: config: listen.ip: ${service_host} listen.port: 670${service_host_sequence} # 6700,6701,6702 listen.dummy_port: 770${service_host_sequence} # 7700,7701,7702 deploy: - host: ${target} - host: ${target} - host: ${target} metaserver_services: config: listen.ip: ${service_host} listen.port: 680${service_host_sequence} # 6800,6801,6802 listen.external_port: 780${service_host_sequence} # 7800,7801,7802 global.enable_external_server: true metaserver.loglevel: 0 braft.raft_sync: false deploy: - host: ${target} - host: ${target} - host: ${target} config: metaserver.loglevel: 0
部署集群
添加 my-cluster
集群,并指定集群拓扑文件
curveadm cluster add my-cluster -f topology.yaml
切换 my-cluster
集群为当前管理集群
curveadm cluster checkout my-cluster
开始部署集群
$ curveadm deploy ...... Cluster 'my-cluster' successfully deployed ^_^.
终端出现 Cluster 'my-cluster' successfully deployed ^_^.
即部署成功。
查看集群运行情况
$ curveadm status Get Service Status: [OK] cluster name : my-cluster cluster kind : curvefs cluster mds addr : 192.168.3.81:6700,192.168.3.81:6701,192.168.3.81:6702 cluster mds leader: 192.168.3.81:6702 / 7f5b7443c563 Id Role Host Replicas Container Id Status -- ---- ---- -------- ------------ ------ 6ae9ac1ae448 etcd curve 1/1 d3ecb4e81318 Up 17 minutes c45e2f0b9266 etcd curve 1/1 8ce9befa54b8 Up 17 minutes 6c6bde442a04 etcd curve 1/1 cbf093c6605f Up 17 minutes 9516d8f5d9ae mds curve 1/1 f338ec63c493 Up 17 minutes fe2bf5d8a072 mds curve 1/1 b423c3351256 Up 17 minutes 7f5b7443c563 mds curve 1/1 7ad99cee6b61 Up 17 minutes e6fe68d23220 metaserver curve 1/1 d4a8662d4ed2 Up 17 minutes b2b4dbabd7bf metaserver curve 1/1 65d7475e0bc4 Up 17 minutes 426ac76e28f9 metaserver curve 1/1 f413efeeb5c9 Up 17 minutes
部署 Rainbond
Rainbond
是一个云原生应用管理平台,使用简单,不需要懂容器、Kubernetes和底层复杂技术,支持管理多个Kubernetes集群,和管理企业应用全生命周期。
可以通过一条命令快速安装 Rainbond 单机版。
curl -o install.sh https://get.rainbond.com && bash ./install.sh
执行完上述脚本后,耐心等待 3-5 分钟,可以看到如下日志输出,表示 Rainbond 已启动完成。
INFO: Rainbond started successfully, Please pass http://$EIP:7070 Access Rainbond
部署 MinIO
由于目前 CurveFS 只支持 S3 作为后端存储,CurveBS 后端即将支持。 所以我们需要部署一个 MinIO 对象存储。
通过 Rainbond 开源应用商店一键部署单机版 MinIO 或者集群版 MinIO。进入到 Rainbond 的 平台管理 -> 应用市场,在开源应用商店中搜索 minio
进行一键安装。
部署完成后,通过 Rainbond 提供的域名访问 MinIO 控制台,默认用户密码 minio/minio123456
。然后需要创建一个 Bucket 供 CurveFS 使用。
部署 CurveFS-CSI
- 前提:Rainbond 版本要在 v5.13+
通过 Rainbond 开源应用商店一键部署,进入到 Rainbond 的 平台管理 -> 应用市场,在开源应用商店中搜索 curve-csi
进行一键安装。
由于 CurveFS-CSI 没有 Rainbond 应用模型类的组件,都属于 k8s 资源类型,可在 应用视图内 -> k8s资源 下看到。
安装完成后,需要修改 curvefs-csi-cluster-role-binding
和 curvefs-csi-role-binding
的 namespace 为当前团队的 namespace,如当前团队 namespace 为 dev
,如下:
# curvefs-csi-role-binding apiVersion: rbac.authorization.k8s.io/v1 kind: RoleBinding metadata: name: curvefs-csi-role-binding ...... subjects: - kind: ServiceAccount name: curvefs-csi-service-account namespace: dev # changed # curvefs-csi-cluster-role-binding apiVersion: rbac.authorization.k8s.io/v1 kind: ClusterRoleBinding metadata: name: curvefs-csi-cluster-role-binding ...... subjects: - kind: ServiceAccount name: curvefs-csi-service-account namespace: dev # changed
创建 storageclass
资源,同样在 应用视图内 -> k8s资源 -> 添加:
kind: StorageClass apiVersion: storage.k8s.io/v1 metadata: name: curvefs-sc provisioner: csi.curvefs.com allowVolumeExpansion: false reclaimPolicy: Delete parameters: mdsAddr: "172.31.98.243:6700,172.31.98.243:6701,172.31.98.243:6702" fsType: "s3" s3Endpoint: "http://9000.grda6567.1frt0lmq.b836cf.grapps.cn" s3AccessKey: "minio" s3SecretKey: "minio123456" s3Bucket: "curve"
mdsAddr:通过
curveadm status
命令获取。$ curveadm status ...... cluster mds addr : 172.31.98.243:6700,172.31.98.243:6701,172.31.98.243:6702
s3Endpoint:填写 MinIO 组件的 9000 端口对外服务域名。
s3AccessKey:MinIO 访问 Key,填 root 用户或生成 AccessKey。
s3SecretKey:MinIO 密钥 Key,填 root 密码或生成 SecretKey。
s3Bucket:MinIO 桶名称。
在 Rainbond 上使用 CurveFS
通过镜像创建一个 Nginx 组件,在 组件 -> 其他设置 修改组件部署类型为 有状态服务
。在 Rainbond 上只有 有状态服务 可以使用自定义存储,无状态服务使用默认的共享存储。
进入到 组件 -> 存储 添加存储,选择类型为 curvefs-sc
,保存并重启组件。
等待组件启动完成后,进入组件的 Web 终端内,测试写入数据。
然后进入到 MinIO 桶内查看,数据已写入。
未来规划
Rainbond 社区未来会使用 Curve 云原生存储作为 Rainbond 底层的共享存储,为用户提供更好、更简单的云原生应用管理平台和云原生存储,共同推进开源社区生态以及给用户提供一体化的解决方案。

低调大师中文资讯倾力打造互联网数据资讯、行业资源、电子商务、移动互联网、网络营销平台。
持续更新报道IT业界、互联网、市场资讯、驱动更新,是最及时权威的产业资讯及硬件资讯报道平台。
转载内容版权归作者及来源网站所有,本站原创内容转载请注明来源。
- 上一篇
2022 年大前端总结来了,我们能抓住什么?
低代码、WebAssembly、小程序、跨端、PWA、Flutter、Dart、RN、Vue、Angular…… 这些技术越来越火。IT 技术发展日新月异,在前端领域更是如此。框架、库、工具的选择越来越广泛,今年流行的框架,也许在明年就会被另一种取代。尽管如此,我们还是要尝试总结一下 2022 年大前端领域的发展情况,以期能够抓住些什么。以下观点来自 《2022中国开源开发者报告》。 JavaScript Container 淘宝高级技术专家九十认为,过去一二十年,将 Javascript 跑在服务端的方式一直都存在,比如 Node.js、ASP 等。但近年来,这种将标准 Web API 规范跑在服务器上,进而实现 JavaScript Workload 的云边端同构的技术方案,被提炼成了一个新概念——JavaScript Container 或者说 W3C Web-interoperable Runtime 的在线运行时。目前,很多厂商都参与在其中,比如国内的阿里、字节,海外的 Cloudflare、Shopify、Vercel。 在标准与具体实现方面,JavaScript C...
- 下一篇
layui-vue 1.9.7 发布,一个 Vue 3 UI 框架
layui-vue 1.9.7 发布,一个 Vue 3 UI 框架。 更新内容: [新增] table 组件 autoColsWidth 属性,列宽自动计算,最大程度利用空间,默认为 false。 [新增] date-picker 组件 range 属性为 true 且 type 属性为 time 的时间范围选择面板。 [新增] layui-vue 安装的 options 选项 zIndex 配置,用于设置 layer 的 z-index 起始值。 [修复] datepicker 组件 range 启用时,内容没有沾满实际宽度,从而导致诡异的后边距。 [修复] dropdown 组件 disabled 属性,修改值报错。 [修复] selectr,date-picker 组件 disabled 属性,修改值报错。 [优化] table 组件 default-expand-all 属性,使其具备响应式的能力。 更多详情:http://www.layui-vue.com
相关文章
文章评论
共有0条评论来说两句吧...
文章二维码
点击排行
推荐阅读
最新文章
- CentOS7安装Docker,走上虚拟化容器引擎之路
- SpringBoot2编写第一个Controller,响应你的http请求并返回结果
- CentOS关闭SELinux安全模块
- CentOS7,CentOS8安装Elasticsearch6.8.6
- Jdk安装(Linux,MacOS,Windows),包含三大操作系统的最全安装
- Linux系统CentOS6、CentOS7手动修改IP地址
- Windows10,CentOS7,CentOS8安装MongoDB4.0.16
- CentOS8安装Docker,最新的服务器搭配容器使用
- Docker快速安装Oracle11G,搭建oracle11g学习环境
- SpringBoot2配置默认Tomcat设置,开启更多高级功能