百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术资源 > 正文

在 Rainbond 上使用 Curve 云原生存储

off999 2025-02-03 14:31 40 浏览 0 评论

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-bindingcurvefs-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
  • 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 底层的共享存储,为用户提供更好、更简单的云原生应用管理平台和云原生存储,共同推进开源社区生态以及给用户提供一体化的解决方案。

相关推荐

一个人拿枪打丧尸单机2d(一个人拿枪打丧尸单机破解版大全)

僵尸之林,拇指玩gameloft下载器里有,可以联网,可以单机我力荐你死亡扳机1或2,虽然是单机,好玩NOVA3近地联盟先遣队、我的世界、AR机甲战士在背包里应该是有虚拟键盘的,打开后有两个开关,一个...

360抢票(360抢票王六代)

要使用360抢票王来抢票,您可以按照以下步骤操作:1.打开手机应用商店(如应用宝、appstore、360手机助手等),搜索并下载安装360抢票王应用。2.安装完成后,打开应用并进行登录或注册。...

autocad2007入门教程(cad2007初级入门教程)

1、复制或剪切文字符号时,先将十字光标单击操作对象,待其变成虚线状态时,按快捷键ctrl+C或ctrl+X,然后按快捷键ctrl+V,即可实现复制或剪切。若要退出复制或剪切,按e...

360浏览器网页版入口网址(360浏览器网址大全)

360浏览器在线网页的入口是www.360.com右击“360浏览器”,然后选择“打开”。在“电脑端360浏览器”的页面右上角当中选择“打开菜单”。在随后出现的功能选项当中,选择“帮助”。然后我们就可...

青禾影视(青禾影视丝袜诱惑小说)

青禾影视传媒师资力量雄厚,信誉良好,是一家靠谱的传媒公司。杭州青禾影视传媒有限公司成立于2018年7月12号,是内地长三角省会城市,杭州多元化少儿艺术影视平台。青禾影视传媒集少儿综艺电视节目,真人秀节...

12306长途汽车票查询(汽车票12308官网)

可以通过手机12306查看列车车型、列车长度、运行速度、餐车位置等车辆信息,1、打开手机12306首页、有车站大屏2、点击车站大屏,里面可显示本地车站或者选择异地车站的当前信息,也可以在车次里输入...

诺基亚手机官网(洛基亚手机机型大全)

可以去诺基亚官网www.nokia.com或者就去淘宝,找那些淘宝认真卖家,一般会出现在搜索结果页面的前两个,一般都保证假一赔十。诺基亚公司(NokiaCorporation)是一家总部位于芬兰埃斯...

我们的2018在线观看免费高清

"2028比2018距离我们更近"意味着当前时间与即将到来的2028年之间的时间距离较短,与已经过去的2018年相比,2028年更接近我们。这句话强调了时间的前进,并提醒我们时光飞逝。...

qq牧场(qq牧场网页版入口)
qq牧场(qq牧场网页版入口)

农场种的是植物、牧场养的是动物。牧场可以把好友所养的动物捉去生产、当然如果在它生产完成后,你也可以偷所产出来的成品。但记住在对方动物饥饿的情况下,必须要为它增添牧草才可以捉它去生产,牧草也一定要是在自己农场种的或者偷的才可以加进去。每加10...

2026-01-21 09:51 off999

旧版安卓模拟器(旧版安卓模拟器vmos)

安卓模拟器有很多,我给你推荐一下目前4款主流的安卓模拟器作为参考吧,让你可以更好地在电脑上玩各种手机游戏。1、逍遥安卓模拟器,推荐:☆☆☆☆☆逍遥安卓模拟器是目前市面上功能上是很全面的模拟器,无论低配...

pubg正版手游下载(pubg手游下载安装)

要下载PUBG国际服手游,您可以按照以下步骤操作:1.在您的手机或平板电脑上打开应用商店(例如,AppStore或GooglePlay)。2.在搜索框中输入“PUBG”。3.搜索结果将包括多...

高德地图导航下载2025新版(高德地图导航下载2021)

如果手机需要下载安装软件应用,建议尝试:1.使用手机功能表中自带的浏览器上网,直接搜索需要的软件进行下载安装(下载安卓版本格式为apk)。2.使用电脑下载APK格式的安装包,连接数据线传输至手机,操...

中国足球今晚比赛cctv5直播(中超足球比赛直播)

今晚没有,明晚有。北京时间2021年11月10日星期三消息。再有一天,国足就将开启2022年世界杯亚洲区12强赛,第三个比赛阶段的比赛。前面两个阶段,第一阶段0-3澳大利亚,0-1日本。第二个阶段3-...

帝国塔防2单机版下载中文版(帝国塔防2单机版下载中文版无广告)

帝国塔防2还能玩这是一款以三国故事为背景的塔防类游戏,玩家在游戏中可以依据三国里的精彩剧情战役,自己个性化定制线路玩法,即由武将的移动方向来决定,根据武将可以自动移动来布置敌人的行进路径特征,玩家可以...

搜狗输入法ios版下载(搜狗输入法2020最新版下载苹果手机)

方法/步骤首先在手机上下载并安装搜狗输入法。然后打开手机设置,点击“通用”,点击“键盘”。最后选择“键盘”,点击“添加新键盘”,点击“搜狗输入法”即可。1、百度输入法是百度公司免费提供的输入软件。20...

取消回复欢迎 发表评论: