mysql 做为juicefs 的元数据存储

环境准备

  • docker-compose
version: '3'
services:
  db:
    image: mysql:5.6
    environment:
    - MYSQL_ROOT_PASSWORD=dalongdemo
    - MYSQL_DATABASE=juicefs
    - MYSQL_USER=user
    - MYSQL_PASSWORD=password
    ports:
    - "3306:3306"
  s3:
    image: minio/minio
    environment:
      - "MINIO_ACCESS_KEY=minio"
      - "MINIO_SECRET_KEY=minio123"
    command: server /data --console-address ":9001"
    ports:
      - "9000:9000"
      - "9001:9001"

使用

  • 格式化
juicefs format --storage minio \
    --bucket http://127.0.0.1:9000/jfs \
    --access-key minio \
    --secret-key minio123 \
    "mysql://root:dalongdemo@(127.0.0.1:3306)/juicefs" \
    pics
  • 挂载
sudo juicefs mount -d "mysql://root:dalongdemo@(127.0.0.1:3306)/juicefs"  apps

说明

理论上来说oceanbase 也是可以支持的,但是在测试的时候发现是有些问题的,实际上我们有中间的解决方法,就是在一个mysql数据库中
先初始化好,然后迁移到ob,具体还没操作,理论上是支持的,目前基于mysql 的延迟是比较大的,所以在规模比较大的场景问题就比较明显了
推荐的还是redis

参考资料

https://juicefs.com/docs/zh/community/databases_for_metadata#mysql
https://juicefs.com/docs/zh/community/metadata_engines_benchmark

上一篇:PhotoShop打造超具想象力的3D生态系统海报


下一篇:使用juicefs 解决基于s3做为git 存储的问题