有没有合理的方法来增加 255 字节的文件名限制?

有没有合理的方法来增加 255 字节的文件名限制?

看起来文件名长度限制在Windows(NTFS)上是255“字符”,但在Linux(ext4,BTRFS)上是255“字节”。我不确定这些文件系统使用什么文本编码作为文件名,但如果是 UTF-8,则一个亚洲字符(例如日语)可能需要 3 个或更多字节。因此,对于英语,255 字节意味着 255 个字符,但对于日语,255 字节可能意味着少得多的字符,并且这种限制在某些情况下可能会出现问题。

除了对一般用户来说几乎不可能的方法(例如修改 Linux 文件系统/内核等)之外,是否有任何实用的方法可以增加限制,以便我可以保证 Linux 上亚洲字符的 255 个字符的文件名容量?

答案1

TL/DR:有办法,但除非你是内核黑客/非常了解 C,否则没有办法。


详细解答:

虽然 glibc#define FILENAME_MAX 4096在 Linux 上定义将路径长度限制为 4096 字节,但 Linux VFS 中存在 255 字节的硬性限制,所有文件系统都必须遵守这一限制。上述限制的定义如下/usr/include/linux/limits.h

/* SPDX-License-Identifier: GPL-2.0 WITH Linux-syscall-note */
#ifndef _LINUX_LIMITS_H
#define _LINUX_LIMITS_H

#define NR_OPEN         1024

#define NGROUPS_MAX    65536    /* supplemental group IDs are available */
#define ARG_MAX       131072    /* # bytes of args + environ for exec() */
#define LINK_MAX         127    /* # links a file may have */
#define MAX_CANON        255    /* size of the canonical input queue */
#define MAX_INPUT        255    /* size of the type-ahead buffer */
#define NAME_MAX         255    /* # chars in a file name */
#define PATH_MAX        4096    /* # chars in a path name including nul */
#define PIPE_BUF        4096    /* # bytes in atomic write to a pipe */
#define XATTR_NAME_MAX   255    /* # chars in an extended attribute name */
#define XATTR_SIZE_MAX 65536    /* size of an extended attribute value (64k) */
#define XATTR_LIST_MAX 65536    /* size of extended attribute namelist (64k) */

#define RTSIG_MAX     32

#endif

下面是一段代码,linux/fs/libfs.c如果您胆敢使用长度超过 255 个字符的文件名,则会抛出错误:


/*
 * Lookup the data. This is trivial - if the dentry didn't already
 * exist, we know it is negative.  Set d_op to delete negative dentries.
 */
struct dentry *simple_lookup(struct inode *dir, struct dentry *dentry, unsigned int flags)
{
    if (dentry->d_name.len > NAME_MAX)
        return ERR_PTR(-ENAMETOOLONG);
    if (!dentry->d_sb->s_d_op)
        d_set_d_op(dentry, &simple_dentry_operations);
    d_add(dentry, NULL);
    return NULL;
}

因此,您不仅必须重新定义此限制,还必须重写文件系统源代码(和磁盘结构)才能使用它。然后在您的设备之外,您将无法安装这样的文件系统,除非您使用其扩展名来存储很长的文件名(如 FAT32 那样)。

答案2

在许多情况下,255 字节的限制已融入磁盘格式中;参见例如外部4它只提供 8 位来编码名称长度。因此,即使您可以解决内核 API 的限制,您也无法存储超过 255 字节的任何内容。

因此,您必须提出一个名称存储扩展(例如,VFAT 样式使用多个目录条目来存储太长的名称,或者 4DOS 样式使用单独的文件来存储长名称),然后您'重新有效地创建一个新的文件系统......

相关内容