题 当共享已安装的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

/ 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

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

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

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

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

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

任何针对此问题的攻击媒介都将非常感激。

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

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


8
2018-03-26 14:22






答案:


我终于解决了这个问题。

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

该问题与重新共享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

然后我去了 /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);

至:

if(fattr->cf_cifsattrs & ATTR_DIRECTORY)
          set_nlink(inode, 2);
        else
          set_nlink(inode, fattr->cf_nlink);

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

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

这允许我们(在同一个文件夹中): 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

对我来说,这就是诀窍,但是如果你重新开箱,这个改变就不会持久。 当我找到一个很好的方法时,我会添加到这篇文章中。

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

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


7
2018-04-23 14:08



哇,这就是那种让我想知道“当他们写这篇文章时他们在想什么?”的错误。如果要检测属性,请查询属性,不要查看松散的关联。这就像编写一个方法:bool isPirate(){return pegLegs == 1;}。你大部分时间都是正确的,但是有些重要的时候你不会。 - Kennet Belenky
谢谢,这个补丁对我有效 Ubuntu 12.04 kernel 3.11 和 samba 3.6.3。我发现了几个问题:1)我不得不跑 apt-get source linux-image-$(uname -r) 获得适当的来源。 2)为了能够成功运行我复制了 fs/cifs source文件夹下的de headers文件夹,具有相同的子路径,并从头的根目录编译而来 make M=fs/cifs,如下所述: http://www.debian-administration.org/article/640/Rebuilding_a_single_kernel_module - drodsou