经常在linux下需要用到windows下的文件,但是将文件通过ftp上传到linux上又很浪费时间,而且很浪费磁盘的空间,也很难保证两台机器上文件的同步,要是能够像windows之间那样直接进行共享就好了,下面我就们就来看看如何在linuxwindows下面共享文件呢。<?xml:namespace prefix = o ns = "urn:schemas-microsoft-com:office:office" />

本文是一台windows7和两台RedHat5.3机器上进行测试,windows7IP地址为192.168.31.226,机器名为WANGHAIFENG-PCLinuxIP分别是192.168.31.145192.168.31.167

( 一)检查和安装samba是否安装

(1) 分别检查两台机器samba的安装情况,

# uname -r
2.6.18-53.el5                               //192.168.31.145
[root@dhcp_host mnt]# rpm -qa | grep samba
samba-client-3.0.25b-0.el5.4
system-config-samba-1.2.39-1.el5
samba-3.0.25b-0.el5.4
samba-common-3.0.25b-0.el5.4

# uname -r
2.6.18-53.el5                              //192.168.31.167
#rpm -qa | grep samba
samba-common-3.0.25b-0.el5.4
samba-client-3.0.25b-0.el5.4

从上面可以看出,145安装了samba的服务端和客户端,而在167上只安装了samba的客户端,因此在145能够查看和共享文件,而在167上只能查看文件,假如需要共享文件,可以在RedHat的安装光盘中获得samba-3.0.25b-0.el5.4.rpm进行安装,system-config-samba-1.2.39-1.el5samba图形化的配置程序。

2)安装samba Server端,在192.168.31.167上进行安装

#rpm -Uvh samba-3.0.33-3.7.el5.i386.rpm
warning: samba-3.0.33-3.7.el5.i386.rpm: Header V3 DSA signature: NOKEY, key ID 37017186
error: Failed dependencies:
        perl(Convert::ASN1) is needed by samba-3.0.33-3.7.el5.i386
        samba-common = 0:3.0.33-3.7.el5 is needed by samba-3.0.33-3.7.el5.i386

这是由于原先的Samba版本比现有的版本低,因此需要进行升级,否则无法安装。

# rpm -Uvh samba-common-3.0.33-3.7.el5.i386.rpm
warning: samba-common-3.0.33-3.7.el5.i386.rpm: Header V3 DSA signature: NOKEY, key ID 37017186
error: Failed dependencies:
        samba-common = 0:3.0.25b-0.el5.4 is needed by (installed) samba-client-3.0.25b-0.el5.4.i386

由于samba-client依赖于现在的samba-common,因此先删除samba-client,然后再升级安装samba-common

# rpm -e samba-client-3.0.25b-0.el5.4.i386
# rpm -Uvh samba-common-3.0.33-3.7.el5.i386.rpm

warning: samba-common-3.0.33-3.7.el5.i386.rpm: Header V3 DSA signature: NOKEY, key ID 37017186
Preparing...                ########################################### [100%]
   1:samba-common           ########################################### [100%]

继续安装samba-3.0.33-3.7.el5.i386.rpm

#rpm -Uvh samba-3.0.33-3.7.el5.i386.rpm
warning: samba-3.0.33-3.7.el5.i386.rpm: Header V3 DSA signature: NOKEY, key ID 37017186
error: Failed dependencies:
        perl(Convert::ASN1) is needed by samba-3.0.33-3.7.el5.i386

从上图可以看出来还缺少perl(Convert::ASN1) 这个模块,在安装光盘中找到perl-Convert-ASN1-0.20-1.1.noarch.rpm这个文件

# rpm -Uvh perl-Convert-ASN1-0.20-1.1.noarch.rpm
warning: perl-Convert-ASN1-0.20-1.1.noarch.rpm: Header V3 DSA signature: NOKEY, key ID 37017186
Preparing...                ########################################### [100%]
   1:perl-Convert-ASN1      ########################################### [100%]
#rpm -Uvh samba-3.0.33-3.7.el5.i386.rpm
warning: samba-3.0.33-3.7.el5.i386.rpm: Header V3 DSA signature: NOKEY, key ID 37017186
Preparing...                ########################################### [100%]
   1:samba                  ########################################### [100%]
# rpm -Uvh samba-client-3.0.33-3.7.el5.i386.rpm
warning: samba-client-3.0.33-3.7.el5.i386.rpm: Header V3 DSA signature: NOKEY, key ID 37017186
Preparing...                ########################################### [100%]
   1:samba-client           ########################################### [100%]
# rpm -qa | grep samba
samba-common-3.0.33-3.7.el5
samba-3.0.33-3.7.el5
samba-client-3.0.33-3.7.el5

samba 就已经安装完成了,上面这些安装文件都能够在RedHat的安装CD中找到。

(3 )添加samba用户

使用smbpasswd添加samba用户,用户必须是linux系统中已有的用户,密码则不必和系统用户相同。

# smbpasswd root
New SMB password:
Retype new SMB password:
Failed to find entry for user root.
Failed to modify password entry for user root

出现上面这个错的原因是因为需要为root用户创建一个用户,使用smbpasswd –a root就可以创建一个entry了,再次调用smbpasswd就不需要使用-a选项了, -x上删除用户。

# smbpasswd -a root
New SMB password:
Retype new SMB password:
Added user root.
#smbpasswd root
New SMB password:
Retype new SMB password:

# smbpasswd -a wanghaifeng
New SMB password:
Retype new SMB password:
Failed to modify password entry for user wanghaifeng

出现上述错误的原因是因为在这台系统中不存在wanghaifeng这个用户,假如需要可以使用adduser添加用户。

4samba配置文件

smaba 的配置文件都/etc/samba/下面,smb.conf是主配置文件。

(二)在windows下面开启共享

D盘中新建文件夹samba_test,右击->属性->共享,点击共享按钮,根据需要添加对应的用户,可以选择不同的权限,位置是\\WANGHAIFENG-PC\samba_test WANGHAIFENG-PC是机器名。

(三)在linux下查看共享文件

1)查看所有共享内容

smbclient Samba Linux 客户端,在Linux机器上用来查看服务器上的共享资源,也可以象FTP一样,用户可以登录Samba服务器,也可以上传put和下载get文件[3]。使用下面的命令,其中用户名是指windows系统的用户名,然后输入该用户的密码。

#smbclient -L //IP 或机器名  [-U 用户名]

# smbclient -L //WANGHAIFENG-PC -U wanghaifeng
Password:
Domain=[WANGHAIFENG-PC] OS=[Windows 7 Ultimate 7600] Server=[Windows 7 Ultimate 6.1]

        Sharename       Type      Comment
        ---------       ----      -------
        ADMIN$          Disk     
远程管理
        C$              Disk     
默认共享
        D$              Disk     
默认共享
        E$              Disk     
默认共享
        IPC$            IPC      
远程 IPC
        print$          Disk     
打印机驱动程序
        samba_test      Disk     
        Users           Disk     
Domain=[WANGHAIFENG-PC] OS=[Windows 7 Ultimate 7600] Server=[Windows 7 Ultimate 6.1]

        Server               Comment
        ---------            -------

        Workgroup            Master
        ---------            -------
[root@lcmsp_test samba]# smbclient -L //192.168.31.226 -U wanghaifeng
Password:
Domain=[WANGHAIFENG-PC] OS=[Windows 7 Ultimate 7600] Server=[Windows 7 Ultimate 6.1]

        Sharename       Type      Comment
        ---------       ----      -------
        ADMIN$          Disk     
远程管理
        C$              Disk     
默认共享
        D$              Disk     
默认共享
        E$              Disk     
默认共享
        IPC$            IPC      
远程 IPC
        print$          Disk     
打印机驱动程序
        samba_test      Disk     
        Users           Disk     
session request to 192.168.31.226 failed (Called name not present)
session request to 192 failed (Called name not present)
session request to *SMBSERVER failed (Called name not present)
NetBIOS over TCP disabled -- no workgroup available

分别使用IP和主机名进行测试,发现使用主机名进行访问的时候一切正常,使用IP进行访问就会出现上面的那些问题,尚待解决,已经可以在共享内容中看到我们的共享文件samba_test

# smbclient -L //WANGHAIFENG-PC/
Password:
Anonymous login successful
Domain=[WORKGROUP] OS=[Windows 7 Ultimate 7600] Server=[Windows 7 Ultimate 6.1]

        Sharename       Type      Comment
        ---------       ----      -------
cli_rpc_pipe_open: cli_nt_create failed on pipe \srvsvc to machine WANGHAIFENG-PC.  Error was NT_STATUS_ACCESS_DENIED
Error returning browse list: NT_STATUS_ACCESS_DENIED
Anonymous login successful
Domain=[WORKGROUP] OS=[Windows 7 Ultimate 7600] Server=[Windows 7 Ultimate 6.1]

        Server               Comment
        ---------            -------

        Workgroup            Master
        ---------            -------
#smbclient -L //WANGHAIFENG-PC/ -U Guest
Password:
Anonymous login successful
Domain=[WORKGROUP] OS=[Windows 7 Ultimate 7600] Server=[Windows 7 Ultimate 6.1]

        Sharename       Type      Comment
        ---------       ----      -------
cli_rpc_pipe_open: cli_nt_create failed on pipe \srvsvc to machine WANGHAIFENG-PC.  Error was NT_STATUS_ACCESS_DENIED
Error returning browse list: NT_STATUS_ACCESS_DENIED
Anonymous login successful
Domain=[WORKGROUP] OS=[Windows 7 Ultimate 7600] Server=[Windows 7 Ultimate 6.1]

        Server               Comment
        ---------            -------

        Workgroup            Master
        ---------            -------

尝试着匿名登录,但是失败了,Windows上开启了Guest用户后,也是不行,不知道有什么好的方法。

2)登录获取共享内容

使用下面的命令能够登录samba上传和下载文件

#smbclient  //IP 地址或者主机名/共享文件夹    -U 用户

# smbclient  //WANGHAIFENG-PC/samba_test -U wanghaifeng
Password:
Domain=[WANGHAIFENG-PC] OS=[Windows 7 Ultimate 7600] Server=[Windows 7 Ultimate 6.1]
smb: \> ?                           //
登录成功,进入sambashell,输入?查看所有命令
?              altname        archive        blocksize      cancel        
case_sensitive cd             chmod          chown          close         
del            dir            du             exit           get           
getfacl        hardlink       help           history        lcd           
link           lock           lowercase      ls             mask          
md             mget           mkdir          more           mput          
newer          open           posix          posix_open     posix_mkdir   
posix_rmdir    posix_unlink   print          prompt         put           
pwd            q              queue          quit           rd            
recurse        reget          rename         reput          rm            
rmdir          showacls       setmode        stat           symlink       
tar            tarmode        translate      unlock         volume        
vuid           wdel           logon          listconnect    showconnect   
!             
smb: \> ls                        //ls
可以查看有哪些文件
  .                                   D        0  Fri Mar 12 11:37:15 2010
  ..                                  D        0  Fri Mar 12 11:37:15 2010
  test.txt                            A       11  Fri Mar 12 11:37:44 2010

                51199 blocks of size 1048576. 24705 blocks available
smb: \> ? du                 //?
命令        可以查看命令的使用方法
HELP du:
        <mask> computes the total size of the current directory

smb: \> get test.txt          // 使用get进行下载
getting file \test.txt of size 11 as test.txt (3.6 kb/s) (average 3.6 kb/s)
smb: \> put install.log     //
使用put进行上传操作
putting file install.log as \install.log (326.4 kb/s) (average 326.4 kb/s)

上述的命令和ftp的命令非常的类似,可以使用put上传,get进行下载操作。

3)挂载共享文件夹到Linux目录

我们也可以使用mount命令将共享的Windows文件挂载到Linux目录下面,命令格式如下面所示,usernamepassword都是指,windows系统的用户名和密码,与samba用户名和密码无关

# mount -t cifs -o username=xxx,password=xxx //hostname/dir /mnt/tmp

# mount -t cifs -o username=wanghaifeng //192.168.31.226/samba_test /mnt
Password:
#cd /mnt/
[root@lcmsp_test mnt]# ls
install.log  test.txt
#ls -l
总计 37
-rwxrwSrwt 1 root root 36099 03-12 11:46 install.log
-rwxrwSrwt 1 root root    11 03-12 11:37 test.txt
#df -k
文件系统               1K-        已用     可用 已用% 挂载点
/dev/mapper/VolGroup00-LogVol00
                      36216640  25681808   8665420  75% /
/dev/hdc1               101086     22173     73694  24% /boot
tmpfs                   517308         0    517308   0% /dev/shm
//192.168.31.226/samba_test
                      52428796  27130460  25298336  52% /mnt

假如用下面这种方式挂载,便会报错,由于在RedHat5上已经默认不知道smbfs

# mount -t smbfs -o username=wanghaifeng //192.168.31.226/samba_test /mnt
mount: unknown filesystem type 'smbfs'

(四)在linux下共享文件

那如何在linux下共享文件呢,这都是在samba的配置文件smb.conf里面设置的,默认是访问samba用户的的HOME目录。

可以根据需求将配置共享目录,是否匿名,具体的配置可以查看参考资料【3】和【4

(五)在windows下查看linux共享文件

windows查看linux下的共享文件就很方便了,在文件浏览器里直接输入\\IP就可以直接查看文件内容了,比如\\192.168.31.145,输入用户名和密码,这里用户名和密码就是在开始设置的samba用户名和密码

参考资料:

[1] mount: unknown filesystem type "smbfs" http://hi.baidu.com/joe266/blog/item/a2ddfdef94729211fdfa3ce8.html

 
# [global]
# workgroup = LinuxSir
# netbios name = LinuxSir05
# server string = Linux Samba Server TestServer
# security = share
# [linuxsir]
#         path = /opt/linuxsir
#         writable = yes
#         browseable = yes
#         guest ok = yes
# 注解:
# [global]这段是全局配置,是必段写的。其中有如下的几行;
# workgroup 就是Windows中显示的工作组;在这里我设置的是LINUXSIR (用大写);
# netbios name 就是在Windows中显示出来的计算机名;
# server string 就是Samba服务器说明,可以自己来定义;这个不是什么重要的;
# security 这是验证和登录方式,这里我们用了share ;验证方式有好多种,这是其中一种;另外一种# 常用的是user的验证方式;如果用share呢,就是不用设置用户和密码了;
# [linuxsir] 这个在Windows中显示出来是共享的目录;
# path = 可以设置要共享的目录放在哪里;
# writable 是否可写,这里我设置为可写;
# browseable 是否可以浏览,可以;可以浏览意味着,我们在工作组下能看到共享文件夹。如果您不想# 显示出来,那就设置为 browseable=no
# guest ok 匿名用户以guest身份是登录;
 
#成功配置实例
[global]
workgroup = Linux
netbios name = RHEL5
server string = Linux Samba Server TestServer
security = user
 
[test]
        path = /share/test
        writable = yes
        valid users = user1,user2
        browseable = yes

 

[111]
        path = /share/test/111
        writable = yes
        valid users = user1
        browseable = yes
#test与111目录的权限如下
#drwxr-xr-x 3 user1 user1   4096 07-30 14:30 test
#drwxr-x--- 2 root root 4096 07-30 13:34 111
#user1对test目录的权限为rwx,user2的权限为r-x
#user1对111目录的权限为---,user2的权限为---