共享已安装的 cifs 驱动器时显示为文件的目录

Joh*_*kov 8 samba cifs

我有一个问题,当从 Windows 机器访问 samba 共享(在 Ubuntu 12.10 上)时,目录显示为文件。

在linuxbox上的文件夹中ls -ll输出如下:

chubby@chubby:/media/blackhole/_Arkiv$ ls -ll
total 0
drwxrwxrwx 0 jv users 0 Jun 18  2012 _20
drwxrwxrwx 0 jv users 0 Apr 17  2012 _2006
drwxrwxrwx 0 jv users 0 Apr 17  2012 _2007
drwxrwxrwx 0 jv users 0 May 12  2011 _2008
drwxrwxrwx 0 jv users 0 Feb 19 09:53 _2009
drwxrwxrwx 0 jv users 0 Dec 20  2011 _2010
drwxrwxrwx 0 jv users 0 May  8  2012 _2011
drwxrwxrwx 0 jv users 0 Mar  5 11:37 _2012
drwxrwxrwx 0 jv users 0 Feb 28 10:09 _2013
drwxrwxrwx 0 jv users 0 Feb 28 11:18 _Mailarkiv
drwxrwxrwx 0 jv users 0 Jan  3  2011 _Praktikanter
Run Code Online (Sandbox Code Playgroud)

/etc/fstab 中的条目是:

# Mounting blackhole
//192.168.0.50/kunder/ /media/blackhole cifs uid=jv,gid=users,credentials=/home/chubby/.smbcredentials,iocharset=utf8,file_mode=0777,dir_mode=0777 0 0
Run Code Online (Sandbox Code Playgroud)

当我直接从 Windows 机器上的 NAS 访问共享时,没有任何问题。

Samba 的版本是 3.6.6,但我在更改日志中找不到任何似乎相关的内容。

我尝试将它安装在具有不同权限、用户和组的不同位置,但我没有取得任何进展

由于我在 serverfault 上的声誉很低(主要是 stackoverflow 用户),我无法发布显示目录显示为文件的屏幕截图。

如果我在资源管理器中键入完整路径,则目录列表效果很好,除了随后显示为文件的任何子目录。

任何针对此问题的攻击向量将不胜感激。

如果我提供的详细信息不足,请告诉我。

编辑:从 OS X 访问时,相同的共享可以完美地将目录列为目录。此致!

Joh*_*kov 7

我终于解决了这个问题。

当我有时间时,我会尝试更多地写出这个答案。

该问题与重新共享 cifs 文件系统,然后从 Windows7 计算机访问有关。

samba 错误在这里:https : //bugzilla.samba.org/show_bug.cgi? id =9346

这显然源于在 cifs 中在 inode 上设置信息的方式。

在这里查看错误:https : //bugzilla.kernel.org/show_bug.cgi?id=52791

因此,Samba 确定(对于其 Windows 客户端)的方式是通过计算硬链接的数量,而不是测试属性。由于 cifs(出于某种晦涩的原因)总是将其设置为零,其中一个目录总是至少有两个,因此该目录将作为 Windows 客户端的文件出现。

所以为了“修复”这个我安装了我当前的内核头文件和 linux 源代码:

sudo apt-get install linux-headers-$(uname -r) linux-source
Run Code Online (Sandbox Code Playgroud)

然后我去/usr/src/linux-source-3.5.0那里提取档案。

找到文件夹/usr/src/linux-source-3.5.0/linux-source-3.5.0/fs/cifs 我在文件中更改以下内容inode.c(第 135 行):

set_nlink(inode, fattr->cf_nlink);
Run Code Online (Sandbox Code Playgroud)

到:

if(fattr->cf_cifsattrs & ATTR_DIRECTORY)
          set_nlink(inode, 2);
        else
          set_nlink(inode, fattr->cf_nlink);
Run Code Online (Sandbox Code Playgroud)

然后我创建了一个 makefile 来简化编译(并避免烦人的 insmod 错误) Makefile2::

obm-m := cifs.o
KDIR := /lib/modules/$(shell uname -r)/build
PWD := $(shell pwd)
default:
        $(MAKE) -C $(KDIR) SUBDIRS=$(PWD) modules
Run Code Online (Sandbox Code Playgroud)

这允许我们做(在同一个文件夹中): sudo make -f Makefile2

这给了我们一个名为cifs.ko.

所以现在我们可以停止 Samba,卸载我们拥有的任何共享,删除当前的 cif,并安装我们重新编译的。

sudo service smbd stop
sudo umount /path/to/share
sudo rmmod cifs
sudo insmod cifs.ko
sudo mount -a
sudo service smbd start
Run Code Online (Sandbox Code Playgroud)

对我来说,这成功了,如果你重新启动盒子,这个变化将不会持续。当我想出一个好的方法来做到这一点时,我会添加到这篇文章中。

请提出您需要的任何问题或说明,我可能会从中学习:)

还要感谢 freenode 上 #samba 中的 kukks,我在那里学到了很多东西,尽管我最终转向了另一个方向。

  • 哇,这种错误让我想知道“他们写那个的时候到底在想什么?” 如果要检测属性,请查询该属性,不要查看松散的相关性。这就像编写一个方法:bool isPirate() {return pegLegs == 1;}。大多数时候你会是对的,但也有一些重要的时候你不会。 (3认同)