我遇到一个问题,当从 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 访问同一个共享时,可以完美地将目录列为目录。此致!
答案1
我终于解决了这个问题。
当我有时间时,我会尝试更详细地写出这个答案。
该问题与重新共享 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,卸载我们拥有的所有共享,删除当前的 cifs,并安装我们重新编译的 cifs。
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,我在那里学到了很多东西,尽管我最终转向了另一个方向。