您的位置:首页 > 运维架构 > Linux

linux挂载windows共享后,网站里的图片不能正常显示

2010-03-12 16:17 411 查看
环境说明

呼叫中心服务器

系统:Centos5

IP:192.168.1.146

http网站跟目录/var/www/html/

我的电脑

系统:windows XP

IP: 192.168.4.98

共享目录:D:/bgcrm (一个php的网站)

bgcrm的网站开发的时候,我想在我的电脑上,然后在windows机器上它跑不起来,因为它需要呼叫中心的软硬件环境,所以,我打算在windows机器上共享这个网站,然后再到linux服务器上挂载这个共享。

如果没有mount.cifs 的话,就要先装这个软件包,方法如下

yum install samba-client


挂载方法如下

mount.cifs  //192.168.4.98/bgcrm/ /var/www/html/tmp/ -o username=staff/zhangtuo,password=mypassword


其中staff是我windows电脑的域,将bgcrm网站挂载到了/var/www/html/tmp 文件夹下,这里不必多说

挂载上去之后,发现php网站可以跑起来,但惟独里面的图片不能正常显示。直接通过地址访问图片也不行,显示的叉烧包,点叉烧包右键属性获得的图片地址确实是正确的http://192.168.1.146/tmp/logo.jpg

难道是数据读取错误?

于是我试着把/var/www/html/tmp/logo.jpg文件夹下的这个图片文件拷到linux另外一个本地目录中。/var/www/html/bugfree/logo.jpg ,然后通过新的URL访问 http://192.168.1.146/bugfree/logo.jpg

神奇的事情出现了,图片能够正常显示。

于是我初步得出结论

1:mount后,linux能正常读取windows共享文件的数据。

2:是apache在捣鬼

于是google一下

照网上说的,把EnableSendfile关闭

即修改httpd.conf 文件,把

#EnableSendfile Off前面的注释去掉,然后重启httpd

问题就解决了

引用这哥们的文章,如下

经过试验,与内核无关,内核是没有问题的.
真正的原因是apache或vsftpd发布的文件目录中如果有mount.cifs挂载上来的,就需要在apache或vsftpd把sendfile选项关闭。
在apache的文档中这样写道:
EnableSendfile 这个指令控制httpd是否可以使用操作系统内核的sendfile支持来将文件发送到客户端。默认情况下,当处理一个请求并不需要访问文件内部的数据时(比如发送一个静态的文件内容),如果操作系统支持,Apache将使用sendfile将文件内容直接发送到客户端而并不读取文件。译者注:Linux2.4/2.6内核都支持。 这个sendfile机制避免了分开的读和写操作以及缓冲区分配,但是在一些平台或者一些文件系统上,最好禁止这个特性来避免一些问题: * 一些平台可能会有编译系统检测不到的有缺陷的sendfile支持,特别是将在其他平台上使用交叉编译得到的二进制文件运行于当前对sendfile支持有缺陷的平台时。 * 在Linux上启用IPv6时,使用sendfile将会触发某些网卡上的TCP校验和卸载bug。 * 当Linux运行在Itanium处理器上的时候,sendfile可能无法处理大于2GB的文件。 * 对于一个通过网络挂载了NFS文件系统的DocumentRoot (比如:NFS或SMB),内核可能无法可靠的通过自己的缓冲区服务于网络文件。 如果出现以上情况,你应当禁用sendfile : EnableSendfile Off 针对NFS或SMB,这个指令可以被针对目录的设置覆盖: <Directory "/path-to-nfs-files"> EnableSendfile Off </Directory>
同样,在vsftpd的配置中也有一个选项就是use_sendfile,在这种情况下,为了mount.cifs挂载上来的目录可以正常工作, 应该在vsftpd.conf写入 use_sendfile=NO 这样就解决了! 至于用老版的mount.smbfs则没有这个问题,也许是mount.cifs更安全吧。
内容来自用户分享和网络整理,不保证内容的准确性,如有侵权内容,可联系管理员处理 点击这里给我发消息
标签: