CentOS 6.8安装Samba 4作Windows共享服务器

在某些状况下为了实现Windows多台服务器负载均衡,须要使用共享来作图片及附件的上传空间。html

这个时候就须要使用到Samba、IIS虚拟目录等相关技术node

Web服务器使用upload做为上传的目录,如今须要使用2台服务器作负载均衡,后台使用一台Samba服务器做为文件共享存储web

1.创建Samba文件服务器bash

卸载旧的samba组件,CentOS 6默认安装的是3.6的版本服务器

for a in `rpm -qa|grep samba`; do rpm -e --nodeps $a;done

2.安装Samba 4负载均衡

yum -y install samba4 samba4-common samba4-client

3.创建共享用户
ide

说明:因为Windows在IIS中站点下是不能直接经过磁盘映射的方式做为站点路径,必须使用原始的\\192.168.10.2\sns\upload这样的目录,而此时访问共享的用户就是应用程序池的用户。测试


这个时候就能够2种选择:spa

a.samba使用匿名访问可读写unix

b.修改站点应用程序池用户为访问samba用户


第一种:使用匿名方式访问共享

为共享建立系统用户及组

groupadd -g 8800 smbgroup

useradd -g smbgroup -s /sbin/nologin -d /dev/null smbuser

建立共享目录

mkdir /data/share

chown -R smbuser.smbgroup /data/share

chmod -R 755  /data/share


4.配置Samba

/etc/samba/smb.conf

[global]
        workgroup = WORKGROUP
        server string = FileServer
        #hosts allow = 127. 192.168.10
        log file = /var/log/samba/log.%m
        max log size = 50
        
        security = user
        passdb backend = tdbsam
        map to guest = bad user
        guest account = smbuser
        
        create mask = 0775
        force create mode = 0775
        directory mask = 0775
        force directory mode = 0775
        
        unix charset = cp936
        dos  charset = cp936
        
        use sendfile=yes
        write raw = yes
        read raw = yes
        max xmit=65535
        aio read size = 16384
        aio write size = 16384
[upload]
        comment = sns
        path = /var/www/html/upload
        browseable = no
        guest ok = yes
        writable = yes
        #valid users = @smbgroup

说明:在samba 4版本里面security这个值已经废弃了share,server。所以配置匿名访问就须要

        security = user
        map to guest = bad user


5.测试samba

[root@gz17img40 samba]# testparm
Load smb config files from /etc/samba/smb.conf
Processing section "[upload]"
Loaded services file OK.
Server role: ROLE_STANDALONE

Press enter to see a dump of your service definitions

# Global parameters
[global]
        dos charset = cp936
        unix charset = cp936
        server string = FileServer
        security = USER
        map to guest = Bad User
        guest account = smbuser
        log file = /var/log/samba/log.%m
        max log size = 50
        max xmit = 65535
        idmap config * : backend = tdb
        create mask = 0775
        force create mode = 0775
        directory mask = 0775
        force directory mode = 0775
        aio read size = 16384
        aio write size = 16384
        use sendfile = Yes


[upload]
        comment = sns
        path = /var/www/html/upload
        read only = No
        guest ok = Yes
        browseable = No


6.设置启动服务及开机启动

/etc/init.d/nmb start
/etc/init.d/smb start
chkconfig nmb on
chkconfig smb on


第二部分:Windows IIS使用共享做为路径

举例:

我须要在站点的SignPDF路径下创建PDF虚拟路径

1.点击“站点”--》对应的SignPDF目录,右击“SignPDF”,选择“创建虚拟目录”



wKioL1fAAubi488tAABKWHQp_Ww911.png

2.输入别名,咱们这里输入“PDF”,而后选择对应的物理路径。

wKiom1fAA2qy5LSdAAAV2EfHiEI649.png

注意:

  1. 这里的物理路径,若是使用共享的话,不能使用磁盘映射的路径,好比我将共享映射为Z盘,这里选择Z盘是无效的,必须使用共享的全路径

  2. 若是Samba不是使用匿名访问的话,这里就须要选择“链接为”,设置对应的用户及密码,这里的用户须要自行到Windows系统中进行添加,而且用户名密码可访问共享。


第二种:采用用户名和密码的方式访问共享

为共享建立系统用户及组

groupadd -g 8800 smbgroup

useradd -g smbgroup -s /sbin/nologin -d /dev/null smbuser

建立共享目录

mkdir /data/share

chown -R smbuser.smbgroup /data/share

chmod -R 755 smbuser.smbgroup /data/share

建立smb访问帐号及密码,smb帐号要在系统中有同名帐号,不然建立失败

smbpasswd -a smbuser

输入密码123456


4.配置Samba

/etc/samba/smb.conf

[global]
        workgroup = WORKGROUP
        server string = FileServer
        #hosts allow = 127. 192.168.10
        log file = /var/log/samba/log.%m
        max log size = 50
        
        security = user
        passdb backend = tdbsam
        #map to guest = bad user
        #guest account = smbuser
        
        create mask = 0775
        force create mode = 0775
        directory mask = 0775
        force directory mode = 0775
        
        unix charset = cp936
        dos  charset = cp936
        
        use sendfile=yes
        write raw = yes
        read raw = yes
        max xmit=65535
        aio read size = 16384
        aio write size = 16384
[upload]
        comment = sns
        path = /var/www/html/upload
        browseable = no
        #guest ok = yes
        writable = yes
        valid users = @smbgroup

这里对比上面匿名访问的注释了

                #map to guest = bad user
        #guest account = smbuser
        
        在共享的时候修改了
        #guest ok = yes
                valid users = @smbgroup


5.测试samba

[root@gz17img40 samba]# testparm
Load smb config files from /etc/samba/smb.conf
Processing section "[upload]"
Loaded services file OK.
Server role: ROLE_STANDALONE

Press enter to see a dump of your service definitions

# Global parameters
[global]
        dos charset = cp936
        unix charset = cp936
        server string = FileServer
        security = USER
        log file = /var/log/samba/log.%m
        max log size = 50
        max xmit = 65535
        idmap config * : backend = tdb
        create mask = 0775
        force create mode = 0775
        directory mask = 0775
        force directory mode = 0775
        aio read size = 16384
        aio write size = 16384
        use sendfile = Yes


[upload]
        comment = sns
        path = /var/www/html/upload
        read only = No
        browseable = No
        valid users = @smbgroup

这个时候就能够经过访问\\192.168.10.20\upload,输入用户名密码smbuser,123456


6.设置启动服务及开机启动

/etc/init.d/nmb start
/etc/init.d/smb start
chkconfig nmb on
chkconfig smb on


第二部分:Windows IIS使用共享做为路径

举例:

我须要在站点的SignPDF路径下创建PDF虚拟路径

1.在系统中建立smbuser,密码必定要与上面建立的smbuser的密码一致也为123456

2.点击“站点”--》对应的SignPDF目录,右击“SignPDF”,选择“创建虚拟目录”



wKioL1fAAubi488tAABKWHQp_Ww911.png

3.输入别名,咱们这里输入“PDF”,而后选择对应的物理路径,并点击“链接为”,输入帐号smbuser密码123456

wKiom1fA_AvBm-jZAAAYomSK488146.png


4.如今就能够正常访问共享里的文件及内容了,可是你会发现没法上传。这是由于须要在web.config中定义用户名密码,在<system.web>下增长

<identity impersonate="true" userName="smbuser" password="123456" />

如今就能够正常上传图片了



问题:

1.在配置Samba后发如今A节点创建的目录,B节点没法写入,这是由于2个用户是一致的可是用户的组不一致。好比A服务器主机名为ServerA,B服务器的主机名为ServerB,所以在Samba中的A节点对应的权限就是ServerA\smbuser,B服务器对应的权限就是ServerB\smbuser,这就是形成2台服务器权限不一致的问题。

在smb.conf中添加

        create mask = 0775
        force create mode = 0775
        directory mask = 0775
        force directory mode = 0775

再重启服务便可


2.根据上面处理后仍然没法写入,就多是对.NET临时目录没有设置写入权限

将上面的smbuser给下列目录

C:\Windows\Microsoft.NET\Framework64\v4.0.30319\Temporary ASP.NET Files
C:\Windows\Microsoft.NET\Framework64\v2.0.50727\Temporary ASP.NET Files

写入权限便可