命令参考
在终端输入 juicefs
并执行,就能看到所有可用的命令。在每个子命令后面添加 -h/--help
并运行,就能获得该命令的详细帮助信息,例如 juicefs mount -h
。
NAME:
juicefs - A POSIX file system built on object storage.
USAGE:
juicefs [global options] command [command options] [arguments...]
VERSION:
5.1.1 (2024-09-20 1faf43b)
COMMANDS:
help, h Shows a list of commands or help for one command
ADMIN:
auth Authorize a volume
destroy Destroy an existing volume
gc Garbage collector of objects in data storage
fsck Check consistency of a volume
dump Dump metadata into a JSON file
load Load metadata from a previously dumped JSON file
version Show version
quota Manage directory quotas
heal Heal a replicated volume
INSPECTOR:
status Show status of a volume
stats Show real time performance statistics of JuiceFS
profile Show profiling of operations completed in JuiceFS
info Show internal information of a path or inode
summary Show data and files distribution of a directory
debug, doctor Collect and display system static and runtime information
lsof List open files
SERVICE:
mount Mount a volume
umount Unmount a volume
gateway Start an S3-compatible gateway
webdav Start a WebDAV server
TOOL:
bench, benchmark Run benchmarks on a path
objbench Run benchmarks on an object storage
warmup Build cache for target directories/files
clone, snapshot Clone a file/directory without copying data
rmr Remove directories recursively
sync Sync between two storages
import Import existing files from object storage
merge merge files together without copying.
grep parallelized file pattern searcher
compact Trigger compaction of chunks
GLOBAL OPTIONS:
--verbose, --debug, -v enable debug log (default: false)
--quiet, -q show warning and errors only (default: false)
--trace enable trace log (default: false)
--no-agent disable pprof (:6060) agent (default: false)
--pyroscope value pyroscope address
--no-color disable colors (default: false)
--help, -h show help
--version, -V print version only (default: false)
全局选项
项 | 说明 |
---|---|
-q --quiet | 仅显示警告及错误日志。 |
-v --verbose --debug | 开启调试日志。 |
--trace | 开启比 --debug 选项更详细的调试日志。 |
--no-agent | 关闭 pprof 代理。 |
--pyroscope | 配置 Pyroscope 地址,如 http://localhost:4040 。 |
--no-color | 关闭日志的颜色。 |
管理
juicefs auth
向 JuiceFS Web 控制台发起认证并获取文件系统的配置。配置文件会保存为 $HOME/.juicefs/$VOL_NAME.conf
。当需要通过脚本自动化部署 JuiceFS,或使用自建对象存储进行私有化部署时,该命令十分有用。
概览
juicefs auth NAME [options]
juicefs auth myjfs --token xxx --access-key xxx --secret-key xxx
参数
项 | 说明 |
---|---|
NAME | 文件系统的名字。 |
--token=TOKEN | 文件系统的 Token,在网站控制台的文件系统设置中查看。 |
--bucket=BUCKET | 在文件系统创建之初,对象存储桶已经在控制台设置好了。但如果有需要,可以使用该参数覆盖桶设置,比如因为网络环境不同,某些客户端需要使用特定的对象存储服务地址。 和控制台的文件系统的桶设置一样,该参数既可以填写桶名,也可以填写完整 endpoint(以 https:// 或 http:// 开头),这两种填写方法的区别如下:
|
--access-key=ACCESSKEY | 对象存储的密钥,获取方式参见 文档。如不指定则需要交互式录入。如果云主机已经配置免密访问对象存储,则传入空字符串(或者在交互式录入时直接按回车键跳过)即可。 |
--secret-key=SECRETKEY | 对象存储的密钥,获取方式参见 文档。如不指定则需要交互式录入。如果云主机已经配置免密访问对象存储,则传入空字符串(或者在交互式录入时直接按回车键跳过)即可。 |
--session-token=SESSIONTOKEN | 对象存储 session token(可选) |
--storage-class=value | 目标端的新建文件的存储类型(也叫存储级别,可以阅读相应文档了解更多:S3、OSS),如果目标端存储支持的话。 |
--bucket2=BUCKET2 | 用于文件系统复制功能的目标对象存储 Bucket 名称或 endpoint 地址,格式和注意事项同 --bucket 。 |
--access-key2=ACCESSKEY2 | 开启文件系统复制功能时,目标对象存储密钥(可选)。文件系统复制请详见「跨区数据复制」。 |
--secret-key2=SECRETKEY2 | 开启文件系统复制功能时,目标对象存储密钥(可选)。文件系统复制请详见「跨区数据复制」。 |
--session-token2=SESSIONTOKEN2 | 用于文件系统复制功能的对象存储 session token(可选) |
--passphrase=PASSPHRASE | 加密密钥的密码,关于数据加密详见「数据加密」。 |
--encrypt-keys | 加密对象存储认证信息,默认为 false。 |
--subdir=SUBDIR | 对将要挂载的子目录进行认证,如果需要的话,还可以创建出限制只允许访问子目录的客户端令牌,详见「客户端权限控制」。 |
--shards=0 | 与社区版的 --shards 作用相同。企业版 JuiceFS 文件系统一般使用可以方便扩容并提升性能的对象存储,不轻易达到单桶的容量或性能上限,因此该参数更多是为了和社区版保持兼容,如果不是单桶服务能力有限的自建对象存储,一般不主动使用多桶拆分,这样会增加管理复杂度。 |
--conf-dir=CONFDIR | 配置文件目录,默认 ~/.juicefs |
--no-update | 客户端会从默认控制台获取最新的配置,将该参数设为 true 以禁用此行为,客户端挂载时将不再访问 JuiceFS 控制台。 |
juicefs gc
用来处理「对象泄漏」,以及因为覆盖写而产生的碎片数据的命令。
概览
juicefs gc [command options] VOLUME-NAME
# 只检查并打印结果,不进行实际清理
juicefs gc $VOL_NAME
# 删除泄露的对象
juicefs gc $VOL_NAME --delete
参数
项 | 说明 |
---|---|
--delete | 删除泄漏的对象 (默认:false) |
--threads=10, -p 10 | 并发线程数,默认为 10。 |
juicefs fsck
检查文件系统一致性,如果文件对应的对象存储数据块缺失,可以用该命令检查出来。
概览
juicefs fsck [command options] VOLUME-NAME
juicefs fsck $VOL_NAME
参数
项 | 说明 |
---|---|
--threads=10, -p 10 | 并发线程数,默认为 10。 |
--repair | 修复对象命名的哈希前缀。JuiceFS 企业版给每个对象路径命名添加 hash 前缀(用 slice ID 对 256 取模,原理和社区版 --hash-prefix 相同),相当于“打散”对象存储键值,避免在对象存储服务层面创造请求热点。如果文件系统因为某些原因并未启用哈希前缀(比如从社区版导入未启用该特性的文件系统),可以用该参数进行修复。 |
juicefs dump
导出元数据。与社区版不同,JuiceFS 企业版并不需要用导出元数据的方式进行备份——Juicedata 工程师已经在元数据服务层面做好了定期备份。因此该命令通常用于问题排查,以及在社区版、企业版之间相互迁移数据。
如何导入导出元数据,详见「导入文件系统」。
概览
juicefs dump [command options] PATH JSON-PATH
# 导出元数据至 meta-dump.json
juicefs dump /jfs meta-dump.json
# 只导出文件系统的一个子目录的元数据
juicefs dump /jfs/subdir meta-dump.json
参数
项 | 说明 |
---|---|
PATH | 挂载 点路径。 |
JSON-PATH | 导出文件路径。如果文件名以 .gz 结尾,将会自动使用 gzip 进行压缩。 |
--gzip | 用 gzip 压缩导出结果。 |
juicefs load
将元数据导入一个空的文件系统,该命令常用于从社区版迁移数据至企业版,详见「导入文件系统」。
概览
juicefs load [command options] PATH [FILE]
# 将元数据备份文件 meta-dump.json.gz 导入文件系统
juicefs load /mnt/jfs meta-dump.json.gz
juicefs version
显示客户端版本,在 版本更新页 可以查看每个版本的更新详情。
概览
juicefs version [options]
# 用一行命令完成升级、平滑重启
juicefs version -u -r
参数
项 | 说明 |
---|---|
-u --upgrade | 升级客户端到最新版。 |
-r --restart | 如果客户端发生了升级,则执行平滑重新挂载。 |
juicefs quota
管理目录配额的子命令,与社区版不同,企业版通过 Web 控制台来创建和管理配额,用户不应直接使用该命令。这个命令的存在是为了与社区版保持一致,让 CSI 驱动能够以相同的接口来管理 PV 配额。
juicefs heal
「数据复制」场景下修复数据,运行双向数据同步,使两个对象存储数据保持一致。
概览
juicefs heal VOL-NAME [options]
参数
项 | 说明 |
---|---|
--start=value | 用于指定对象存储的同步范围。 |
--upload-limit=0 | 上传数据所用带宽的上限,单位 Mbps,默认为 0(无限制)。 |
--conf-dir | 配置文件目录,默认 ~/.juicefs |
检视
juicefs status
显示文件系统的基本状态,包括活跃的客户端会话列表(FUSE 挂载客户端、Hadoop SDK、S3 网关和 WebDAV)。
概览
juicefs status [command options] VOLUME-NAME
juicefs status $VOL_NAME
参数
项 | 说明 |
---|---|
--session=0 -s 0 | 传入会话 ID(Session ID,也就是 status 命令输出的 SID ),展示指定会话的具体信息。 |
juicefs stats
stats
命令通过读取 JuiceFS 客户端的监控指标,打印各个指标的每秒变化情况。
该命令的更多介绍和用法详见「实时性能监控」。
概览
juicefs stats [options] MOUNTPOINT
参数
项 | 说明 |
---|---|
--schema=ufmco | 控制输出内容的标题字符串,默认为“ufmco”,含义如下: u: usage f: FUSE m: meta c: blockcache o: object g: go |
--interval=1 | 更新间隔,单位为秒,默认为 1。 |
--verbosity=0 | 详细级别,默认为 0,使用更大值以获得更详细输出。 |
juicefs profile
对「文件系统访问日志」进行简单直观的统计,在命令行展示各项操作的耗时统计数据,帮助你迅速判断应用对文件系统的访问模式,评估访问性能。
该命令的更多介绍和用法详见「实时性能监控」。
概览
juicefs profile [options]
参数
项 | 说明 |
---|---|
-x PATH --path=PATH | 日志文件目录,默认 /jfs 。 |
-f FILE --file=FILE | 日志文件名,默认 .ophistory 。参考「访问日志」了解不同的访问日志文件。 |
-g GROUP_BY --group-by=GROUP_BY | 根据指定属性对输出结果进行分组,默认为 cmd ,可选值为:uid 、pid 、cmd 。 |
-s SORT_BY --sort-by=SORT_BY | 根据指定列对输出结果进行排序,默认为 total_time ,可选值为:group 、number 、avg_time 、total_time 。 |
-u FILTER_BY_UID --filter-by-uid=FILTER_BY_UID | 根据 UID 对输出结果进行过滤,多个关键词使用半角逗号(, )分隔。 |
-p FILTER_BY_PID --filter-by-pid=FILTER_BY_PID | 根据 PID 对输出结果进行过滤,多个关键词使用半角逗号(, )分隔。 |
-w WINDOW_SIZE --window-size=WINDOW_SIZE | 统计时间窗口大小,浮点数,单位为秒,默认为 60。 |
-i FLUSH_INTERVAL --flush-interval=FLUSH_INTERVAL | 输出的刷新间隔,浮点数,单位为秒,默认为 2。 |
juicefs info
显示 JuiceFS 文件系统中文件或 inode 的信息。
概览
juicefs info [command options] PATH/INODE
# 查询文件
juicefs info /mnt/jfs/foo
# 查询目录
juicefs info -r /mnt/jfs/bar/
# 通过 inode 反查文件信息
cd /mnt/jfs
juicefs info -i 100
参数
项 | 说明 |
---|---|
PATH/INODE | 要查询的路径或 inode。 |
-i --inode | 通过 inode 查询文件信息,注意当前目录必须在 JuiceFS 挂载点中。 |
-r --recursive | 递归获取目录中所有子目录及文件的信息。 |
--raw | 显示内部原始信息。 |
juicefs summary
显示目标目录树摘要。
概览
juicefs summary [command options] PATH
juicefs summary /jfs/foo
# 显示最大深度为 5
juicefs summary --depth 5 /jfs/foo
# 显示前 20 个 entry
juicefs summary --entries 20 /jfs/foo
参数
项 | 说明 |
---|---|
--depth=2 -d 2 | 显示树的深度,0 表示只显示根,默认为 2。 |
--entries=10 -e 10 | 显示前 N 个 entry,按大小排序,默认为 10。 |
--csv | 以 CSV 格式打印摘要。 |
juicefs doctor
又名 juicefs debug
。全面收集各种用于排查的信息,包括访问日志、客户端日志、CPU 性能统计、Goroutine 堆栈等。遇到一些疑难杂症时,JuiceFS 团队可能会要求你使用该命令打包收集报错信息,来帮助解决你的问题。
我们也鼓励你阅读「问题排查方法」和「问题排查案例」,来尝试自己上手分析和解决一些常见问题。
概览
juicefs doctor MOUNTPOINT
juicefs lsof
列出 JuiceFS 最近(10 分钟内)被打开过的文件。
概览
juicefs lsof PATH
服务
juicefs mount
挂载文件系统。挂载时必须提供文件系统的 Token(在网站控制台的 文件系统设置 中查看),以及访问对象存储 API 的秘钥对(参考文档 如何获取对象存储的 API 密钥)。
如果挂载文件系统之前没有通过 auth
子命令生成配置文件,那么客户端会以命令行交互的方式要求你分别提供文件系统 Token 和访问对象存储 API 的秘钥对。
JuiceFS 支持用 root 以及普通用户挂载,但由于权限不同,挂载时所使用的的缓存目录和日志文件等路径会有所区别,详见下方参数说明。
概览
juicefs mount NAME MOUNTPOINT [options]
参数
项 | 说明 |
---|---|
NAME | 文件系统的名字。 |
MOUNTPOINT | 主机上的挂载路径,比如:/jfs 。 |
--foreground -f | 前台运行,客户端日志也会直接在前台输出,此选项多用于调试。 |
--background -b -d | 后台运行,这也是默认行为。 |
--no-syslog | 禁用 syslog。 |
--log=PATH | 日志存储路径,视挂载用户不同,默认为 /var/log/juicefs.log 或 ~/.juicefs/log/juicefs.log 。 |
--update-fstab | 在 Linux 挂载时,更新 /etc/fstab ,详见 开机自动挂载。 |
--max-space | 限制挂载点的总大小。对于按量付费的用户而言,JuiceFS 并没有实际容量上限,因此 df -h 会显示非常大的值。设置该选项来限制挂载点的容量上限,同时将 df -h 的容量上限设为对你的场景更合理的数值。 |
--prefix-internal | 为内部文件添加 .jfs 前缀,例如 .jfs.stats , .jfs.config 。 |
--hide-internal | 隐藏所有内部文件(.accesslog , .stats 等)。 |
--sort-dir | 通过 readdir 读取挂载点目录内容,默认会返回乱序列表,如果打算在 JuiceFS 挂载点上部署 nfsd 等通过翻页来读取目录的系统,乱序会引起故障,需要启用该参数,然后读取目录返回的文件列表将按命名排序。注意,该选项并不影响 ls 等 Linux 工具的输出,ls 自身便会对结果进行排序。 |
--token=TOKEN | 指定客户端令牌。 |
--no-update | 客户端会从默认控制台获取最新的配置,将该参数设为 true 以禁用此行为,客户端挂载时将不再访问 JuiceFS 控制台。 |
FUSE 相关参数
项 | 说明 |
---|---|
--enable-xattr | 开启扩展文件属性 xattr 的支持。默认为 false,如果没有特殊需要建议关闭,会产生额外开销。 |
--enable-acl | 开启 POSIX Extended ACL 的支持,详见 ACL。 |
--no-bsd-lock | 禁用 BSD lock 支持。 |
--no-posix-lock | 禁用 POSIX lock 支持。 |
--block-interrupt=1 | 中断信号的阻塞时间(单位为秒),默认为 1。 |
--readdir-cache | 在内核中建立 readdir 缓存(需要 Kernel 4.20 及以上)。 |
--allow-other | 允许其他用户访问(当用 root 挂载时默认开启,否则需要在 /etc/fuse.conf 中启用 user-allow-other )。 |
--max-write 新增自 v5.1.0 | FUSE 写请求的单位,默认为 "128K"。修改该选项需要内核 4.20 或以上版本,并且上限为 1MiB。如果系统不存在其他瓶颈,提高该值可以增加顺序写性能,但是相应地也会影响随机写或小追加写的性能,需要充分测试、谨慎调优。 |
-o FUSE_OPTS | 添加其他 FUSE 选项。如通过 -o writeback_cache 开启 FUSE 写缓存可以极大提高随机写入和碎片写入的性能(需要使用 Linux Kernel 3.15 及以上)。 |
元数据相关参数
项 | 说明 |
---|---|
--subdir=SUBDIR | 挂载子目录,如果需要的话,还可以创建出限制只允许访问子目录的客户端令牌,详见「客户端权限控制」。 |
元数据缓存相关参数
项 | 说明 |
---|---|
--metacacheto=300 | 元数据的缓存过期时 间(单位为秒),默认为 300。 |
--metacache | 将元数据缓存在运行客户端的主机的内存里,默认启用。使用 --metacacheto=0 关闭缓存。 |
--max-cached-inodes=5000000 | Inodes 的最大缓存数量,默认为 5000000。 |
--open-cache --opencache | 是否使用缓存的元数据来打开文件,默认为 false,也就是说每次打开文件时都会访问元数据服务,确认文件是否被更改过。因此在需要频繁打开文件,而修改又较少时(建议针对只读场景开启),可以考虑启用 --opencache ,进一步提升读性能。仅对于同一个挂载点,读缓存会根据文件变更自动失效。 |
--attr-cache --attrcacheto=1 | 文件/目录的属性在内核中的缓存时间(秒),默认为“1.0s”。 |
--entry-cache --entrycacheto=1 | 文件项在内核中的缓存时间(秒),默认为“1.0s”。 |
--dir-entry-cache --direntrycacheto=1 | 目录项在内核中的缓存时间(秒),默认为“1.0s”。 |
对象存储相关参数
项 | 说明 |
---|---|
--get-timeout=60 | 下载单个对象的最长时间(秒),默认为 60。低带宽场景下可能需要适当增大,详见读写错误 |
--put-timeout=60 | 上传单个对象的最长时间(秒),默认为 60。低带宽场景下可 能需要适当增大,详见读写错误 |
--ioretries=30 --io-retries=30 | 网络故障的重试次数(默认:30)。重试之间的等待时间是线性增长,但如果设定为超过 30 次,则变为每次固定 10 秒等待。实际使用时的超时时间则与相关请求的 timeout 设置有关。 |
--object-clients=1 新增自 v5.1.0 | 对象存储客户端实例数,默认为 1。大部分对象存储系统不需要调整该参数,但某些存储(比如 Ceph)的 SDK 中,对于单个客户端实例施加了带宽上限,因此不论使用多大的并发,都无法打满单机带宽,如果你的环境遭遇这种情况,可以尝试增加对象存储客户端数量来进一步提升吞吐。 |
--max-uploads=20 | 上传并发度,默认为 20。对于粒度为 4MiB 的写入模式,20 并发已经是很高的默认值,在这样的写入模式下,提高写并发往往需要伴随增大 --buffer-size , 详见「读写缓冲区」。但面对百 K 级别的小随机写,并发量大的时候很容易产生阻塞等待,造成写入速度恶化。如果无法改善应用写模式,对其进行合并,那么需要考虑采用更高的写并发,避免排队等待。 |
--max-downloads=200 | 最大并发下载请求数,默认为 200,这对于客户端已经是很高的默认值,一般无需调整。另外,该选项控制客户端全局的并发度,客户端对于单个文件的预读并发度设置了 128 个分块的硬上限,防止读取大文件时资源占用不受控。 |
--max-deletes=-1 --delete-limit=-1 | 对象存储 DELETE API 调用 上限(QPS),默认为 -1(无限制),设置为 0 以禁用删除。 |
--flush-wait=5s | 持久化到对象存储的时间间隔,默认 5 秒。在大文件写入慢的情况下,过于频繁地调用持久化会导致碎片化,可以考虑增加时间间隔,来减少文件碎片导致的写放大。 |
--upload-limit=0 | 上传数据所用带宽的上限,单位 Mbps,默认为 0(无限制)。除用于主动限速外,大吞吐场景下可能导致机器负载过高,考虑使用该参数控制机器负载。 |
--download-limit=0 | 下载数据所用带宽的上限,单位 Mbps,默认为 0(无限制)。除用于主动限速外,大吞吐场景下可能导致机器负载过高,考虑使用该参数控制机器负载。 |
--external | 客户端默认会使用内网地址访问对象存储,该参数可以显式指定使用对象存储的外网地址。 |
--internal | 显式指定对象存储的内网地址(适用于区分内外网域名的对象存储,比如:阿里云 OSS、UCloud UFile 等)。 |
--rsa-key=PATH | 指定 RSA 私钥路径(PEM),如果秘钥是用密语加密过的,在挂载时会被询问,也可以通过 JFS_RSA_PASSPHRASE 环境变量设置。 |
--flip | 翻转文件系统复制功能的两个对象存储的复制顺序(也就是把第二个对象存储作为源),文件系统复制请详见「跨区数据复制」。 |
本地缓存相关参数
详读缓存以了解 JuiceFS 的缓存设计。
项 | 说明 |
---|---|
--buffer-size=300 | 读写缓冲区大小,单位 MiB,默认 300。详读「读写缓冲区」以了解如何对该参数进行调优。 |
--prefetch=1 | 随机读对象存储块的一小段,会触发异步下载整个块,这个过程在 JuiceFS 中叫做「预取」(prefetch)。该参数用于控制预取的并发度,默认为 1,设为 0 以禁用该行为。需注意: |
--initial-readahead | 设置初始预读窗口大小,单位为 MiB。更大的初始窗口能够加速大文件的顺序读性能。如果该选项未设置,默认的初始窗口为 4096 字节。 |
--writeback | 启用客户端写缓存,数据优先写到本地磁盘,然后在后台异步上传。默认为 false。写缓存带来数据安全风险,谨慎使用。 |
--cache-dir=CACHEDIR | 本地缓存的存储路径,视用户不同,默认为 /var/jfsCache 或 $HOME/.juicefs/cache 。多盘缓存用 : 分割多个目录,目录可包含通配符 * (用引号封闭)。例如 '/data*/jfsCache:/mydata*/jfsCache' 。此外,还支持使用内存作为缓存目录,传入 /dev/shm 使用内存设备(大小默认为内存的一半),也可以传入 memory 使用客户端进程内存。 |
--cache-size=102400 | 本地缓存容量,单位 MiB,默认 102400(100GiB)。当指定了多个缓存目录时,总容量会平均分配到各个目录。 可以将该选项设为 0 以彻底禁用本地磁盘缓存,不过这样会导致客户端额外尝试分配 100MB 的内存用于缓存,详见资源占用问题排查。 从 5.1 起,支持传入 -1 来表示将盘大小设为缓存大小。 |
--free-space-ratio=0.1 | 缓存目录的最小剩余空间占比,默认 0.1(但对于 4.9 版本或更早,默认值为 0.1)。该参数不支持设置为 0,如果希望允许缓存尽可能写满磁盘,可以设置一个接近于 0 的值(比如 0.01)。另外如果启用了「客户端写缓存」,则该参数还控制着写缓存占用空间。 |
--cache-mode=0600 | 缓存目录的权限模式,默认是 0600。 |
--cache-partial-only | 对于读缓存,仅缓存小于一个块大小(默认 4MiB)的数据块,例如小于一个块大小的小文件、大文件末尾不足一个块大小的数据块。默认为 false (即缓存所有读取的数据块)。注意,该选项同时也会对分布式缓存的缓存构建造成影响。 阅读客户端读缓存了解更多关于该选项的说明。 |
--cache-large-write 新增自 v5.1.0 | 对于一个完整块大小的写入数据也进行缓存,默认情况下 JuiceFS 并不缓存顺序写产生的大块内容(大多数场景下,他们并不会被再次读取),如果你的场景需要,则用该选项开启。 |
--verify-cache-checksum=extend | 缓存数据一致性检查级别,启用 Checksum 校验后,生成缓存数据块时会对数据切分做 Checksum 并记录于文件末尾,供读缓存时进行校验。支持以下级别:
|
--cache-eviction=2-random 新增自 v5.0.1 | 缓存淘汰算法,支持以下策略:
|
--cache-expire=0s 新增自 v5.1.0 | 设置缓存淘汰时间,留存长于设定时间的 缓存块将会被自动清理。默认为 0 表示禁用该功能。 |
分布式缓存相关参数
详读分布式缓存以了解更多。
项 | 说明 |
---|---|
--cache-group=CACHEGROUP | 分布式缓存组的组名称,相同组的客户端之间可以相互共享缓存的数据,默认未启用。 |
--subgroups=0 | 一个缓存组中子组的数量,默认为 0。用子组来对缓存组做进一步拆分,实际上就是为缓存组名添加数字前缀。 |
--group-network | 缓存组的监听网卡,默认的监听 IP 是网络设备列表中找到的第一个内网 IP,如果这样的策略不合适,可以使用该参数手动指定网络设备。 |
--group-ip=GROUPIP | 手动设置缓存共享组的 IP 地址,在多网卡节点中,使用该参数来绑定特定网卡。除了指定 IP 地址,还可以直接传入 CIDR 前缀来自动匹配 IP,比如用 172.16.0.0 来匹配 172.16.0.0/16 。 |
--group-port | 缓存组的监听端口,默认为随机端口。如果指定的端口不可用,则会自动 +1 直到绑定成功。 |
--group-weight=100 | 如果节点间缓存空间大小不一致,通过该值来调节节点各自的权重。建议取值范围为 10 到 1000。比如 1TB 和 3TB 的节点搭配成为缓存组,则可将 1TB 节点设置权重 100,3TB 节点设为 300。 |
--group-weight-unit=0 | 如果不希望手动设定 --group-weight ,而是希望从 --cache-size 自动推算,那么可以指定该参数。单位为 MiB,以默认的 --cache-size=102400 为例,配合 --group-weight-unit=1024 ,后者含义是“将 1024MiB 记为 1 权重”,也就是说最终权重为 102400 / 1024 = 100 。 |
--group-backup | 启用“缓存副本”功能,启用该功能的节点如果自身缓存未命中,则会将请求转发给其他节点。请求最终返回后,两个节点都会尝试将数据缓存到本地。阅读「缓存副本」以了解具体原理和适用场景。 |
--no-sharing | 加入缓存组时,从缓存集群获取缓存数据,但却不共享自身缓存数据(只索取、不付出)。该选项用于需要访问缓存集群数据,但自身却不断变动的节点(比如 Kubernetes Pod)。默认为 false。 |
--fill-group-cache | 将客户端写入的数据块尽量发送给缓存组(不保证 100% 缓存),而不再写入本地缓存。如果客户端同时启用了 --no-sharing ,便只会将小于块大小(默认 4MiB)的写入数据发送给缓存组。特别地,从 4.9.22 开始,如果启用了客户端写缓存,那么所有大小的写缓存数据一律会异步发送给缓存组,让组内成员有一定概率读到尚未持久化到对象存储的数据。 |
--cache-group-size=0 | 单位 MiB。考虑到读文件时客户端会进行预读和预取,在开启分布式缓存时,对于小于该值的文件,客户端会尽量将该文件切分的数据块调度到一个节点上,以此来最大化利用缓存数据。 |
--cache-priority=0 新增自 v5.0.14 | 缓存块的优先级,可选值为:0、1、2、3,数字越大优先级越高。缓存淘汰时会优先淘汰优先级更低的数据。 |
--remote-timeout=65s 新增自 v5.1.0 | 缓存组请求超时时间,默认为 65 秒。 |
--group-compress 新增自 v5.1.0 | 压缩分布式缓存请求,默认开启。如果你的数据压缩比不理想,可以关闭压缩以节约 CPU 开销。 |
实验性参数
以下参数属于实验性功能,使用不当存在数据安全隐患,并且使用方法和参数均有可能在未来持续调整,如有使用需要,务必在 Juicedata 工程师的指导下操作。
项 | 说明 |
---|---|
--min-inodes-diff=1048576 | 当前分区与 inodes 最少的分区之间的 inodes 差值超过这个值时,自动均衡元数据。默认值为 1048576。 |
--min-dir-inodes=1048576 | 当前路径的目录数超过这个值时则自动均衡元数据。默认值为 1048576。 |
--max-space=0 | 挂载点展示的总的存储容量上限 GiB。默认为 0,代表展示真实的文件系统总用量。 |
juicefs umount
卸载 JuiceFS 文件系统。该命令跨平台通用,Linux 下使用 umount
来执行卸载,而 macOS 下则一般用 diskutil unmount
。此外,客户端还提供一个相似命令 juicefs unmount
,这个命令仅在 Kubernetes FlexVolume 下使用,其他场景无需关注。
如果卸载文件系统遇到问题,阅读文档进行排查。
概览
juicefs umount PATH [options]
参数
项 | 说明 |
---|---|
PATH | 挂载路径 |
-f --force | 强制卸载 |
juicefs gateway
启动一个 S3 网关,详见「S3 网关」。
概览
juicefs gateway [command options] VOLUME-NAME ADDRESS
export MINIO_ROOT_USER=admin
export MINIO_ROOT_PASSWORD=12345678
juicefs gateway testVolume localhost:9000
参数
除下方列出的参数,该命令还与 juicefs mount
共享参数 ,因此需要结合 mount
一起参考。
Flag | Description |
---|---|
--console-url=URL | Web 控制台 URL,仅在私有部署环境需要使用。 |
--mountpoint=s3gateway | 指定宿主机挂载点,用于解析 JuiceFS 内的绝对路径,默认 s3gateway 。详见 S3 网关和符号链接。 |
--access-log=PATH | 「文件系统访问日志」的文件路径,默认为文件系统根路径的 .accesslog 。 |
--no-banner | 不打印 MinIO 启动信息。 |
--multi-buckets | 将一级目录作为 Bucket 使用,默认为 false。 |
--keep-etag | 保留上传对象的 ETag。 |
--umask="022" | 新文件的 umask,默认 022 。 |
juicefs webdav
启动一个 WebDAV 文件共享服务器。
使用环境变量 WEBDAV_USER
和 WEBDAV_PASSWORD
设置访问 WebDAV 共享的用户名和密码。
概览
juicefs webdav [command options] NAME ADDRESS
# 设置用户名和密码
export WEBDAV_USER=root
export WEBDAV_PASSWORD=1234
# 启动一个 WebDAV 服务器,监听 9007 端口
juicefs webdav myjfs localhost:9007
参数
除下方列出的参数,该命令还与 juicefs mount
共享参数,因此需要结合 mount
一起参考。
项 | 说明 |
---|---|
--cert-file | 指定 TLS 证书文件 |
--key-file | 指定 TLS 密钥文件 |
--gzip | 用 gzip 压缩文件。 |
--disallow-list | 禁止在 WebDAV 中列出目录。 |
工具
juicefs benchmark
简单的性能测试,内容包括大文件和小文件的 read/write/stat。