zoukankan      html  css  js  c++  java
  • centos 5.3 安装(samba 3.4.4)

    随着Linux的普及,如何共享Linux下的文件成为用户关心的问题。其实,几乎所有的Linux发行套件都提供了一个很好的工具Samba——通过它可以轻松实现文件共享。Samba的功能很强大,在Linux服务器上的Samba运行起来以后,Linux就相当于一台文件及打印服务器,向Windows和Linux Samba客户提供文件及打印服务。
       Samba的功能很强大,但易用性也极差。原因是它的配置文件太大而且不容易理解,新手和熟手都对其望而却步。但是,如果仅仅实现文件共享,配置Samba也很简单,下面我们就一起来配置吧。


    wget  http://samba.org/samba/ftp/stable/samba-3.4.4.tar.gz
    tar -xvf samba-3.4.4.tar.gz
    cd samba-3.4.4/source3
    ./configure --prefix=/usr/local/samba
    make 
    make install ----若出现以下表示安装成功
    ==============================================================
    MO files for pam_winbind are installed.
    ==============================================================
    ==============================================================
    All MO files for Samba are installed. You can use "make uninstall"
    or "make uninstallmo" to remove them.
    ==============================================================

    make installbin----若出现以下表示安装成功
    ======================================================================
    The binaries are installed. You may restore the old binaries (if there
    were any) using the command "make revert". You may uninstall the binaries
    using the command "make uninstallbin" or "make uninstall" to uninstall
    binaries, man pages and shell scripts.
    ======================================================================
    cd ..   //返回上级目录
    cp examples/smb.conf.default /usr/local/samba/lib/smb.conf   //复制配置文件到指定目录


    -----------------------以下启动和关闭的方式,只作为参考。后有介绍简单的启动、关闭方式------------------------------------------------------
    启动和关闭samba
    (1)、 启动(其中&表示在后台运行)
    /usr/local/samba/sbin/smbd  start  &   
    /usr/local/samba/sbin/nmbd  start  &

    (2)、关闭
    ps -auxf |grep samba  查找samba 的进程
    效果如下:
    [root@localhost ~]# ps -auxf |grep samba 
    Warning: bad syntax, perhaps a bogus '-'? See /usr/share/doc/procps-3.2.7/FAQ
    root     32355  0.0  0.3   4636   644 pts/2    R+   17:44   0:00          \_ grep samba
    root     32233  0.0  1.2  13420  2536 ?        Ss   17:27   0:00 /usr/local/samba/sbin/smbd start   //这条是主进程
    root     32234  0.0  0.4  13420  1012 ?        S    17:27   0:00  \_ /usr/local/samba/sbin/smbd start
    root     32335  0.0  0.6  11268  1300 ?        Ss   17:41   0:00 /usr/local/samba/sbin/winbindd
    root     32336  0.0  0.4  11268  1052 ?        S    17:41   0:00  \_ /usr/local/samba/sbin/winbindd
    杀掉: kill -9  32233  就可以杀掉了。这个比较麻烦。后面我带大家使用一种更简单的启动和关闭的方法。
    ***************
    报错: /usr/local/samba/sbin/smbd: error while loading shared libraries: libtalloc.so.1: cannot open shared object file: No such file or directory
    解决办法:
    ln -s /usr/local/samba/lib/libtalloc.so.1  /usr/lib/libtalloc.so.1
    ln -s /usr/local/samba/lib/libtdb.so.1  /usr/lib/libtdb.so.1
    ln -s /usr/local/samba/lib/libwbclient.so.0  /usr/lib/libwbclient.so.0
    -----------------------------------------------------------------------------


    **************************配置samba启动和关闭
    (1)、编写启动脚本:也可以以标准服务的形式启动samba,以下是启动脚本
     
    1.建立启动脚本
     vi /etc/init.d/smbd
    **************************添加如下内容:
    #!/bin/sh
    # Source function library.
    . /etc/rc.d/init.d/functions
    # Source networking configuration.
    . /etc/sysconfig/network
    # Check that networking is up.
    [ ${NETWORKING} = "no" ] && exit 0
    # Check that smb.conf exists.
    [ -f /usr/local/samba/lib/smb.conf ] || exit 0         #其中: /usr/local/samba/lib/smb.conf  是我的samba配置文件存放路径
    RETVAL=0
    case "$1" in
      start)
            echo -n "Starting SMB services: "
            /usr/local/samba/sbin/smbd -D  -d 3        # 其中: /usr/local/samba/sbin/smbd -D   启动samba 服务
            RETVAL=$?
            echo
            echo -n "Starting NMB services: "
            /usr/local/samba/sbin/nmbd -D -d 3     # 其中: /usr/local/samba/sbin/nmbd -D   启动samba 服务
            RETVAL2=$?
            echo
            [ $RETVAL -eq 0 -a $RETVAL2 -eq 0 ]  
               RETVAL=1
            ;;
      stop)
            echo -n "Shutting down SMB services: "
            killproc smbd
            RETVAL=$?
            echo
            echo -n "Shutting down NMB services: "
            killproc nmbd
            RETVAL2=$?
            [ $RETVAL -eq 0 -a $RETVAL2 -eq 0 ] 
            echo ""
            ;;
      restart)
            $0 stop
            $0 start
            RETVAL=$?
            ;;
      reload)
            echo -n "Reloading smb.conf file: "
            killproc -HUP smbd
            RETVAL=$?
            echo
            ;;
      status)
            status smbd
            status nmbd
            RETVAL=$?
            ;;
      *)
            echo "Usage: $0 {start|stop|restart|status}"
            exit 1
    esac
    exit $RETVAL


    2.修改权限,使其可执行
         chmod 700 /etc/init.d/smbd
         chown  root:root  /etc/init.d/smbd

    3.加入系统服务,使其开机可以自动运行
       chkconfig --add smbd 
       chkconfig --level 2345 smbd on

    4. 现在启动和关闭以及重新启动
    /etc/init.d/smbd   start 
    /etc/init.d/smbd   stop 
    /etc/init.d/smbd   restart


    *****************************日志存放路径:  /var/log/samba/目录下
    详细说明:vi  /usr/local/samba/lib/smb.conf
    [global] 全局配置
        workgroup = MYHOME     ---- 指定工作组
        server string = File Server ---- 服务器的说明 
        security = share   ----安全级别: 共分3种 
                        1.share (任何用户都不需要密码,直接可以访问)
                        2.user   要提供用户名和密码才能访问
                        3.server 将用户和密码提交到另一服务器验证,如果递交失败,就 退到user安全级。 要求网络上存在一台Windows的主域控制器,samba把用户名和密码递交给它去验证。
    ****************匿名用户
    匿名用户,只要把security = share 修改成这样。就可以访问了。


    ----------------
    window ===打开网上邻居=====\ip地址(比如我的: \192.168.1.131) 如果可以访问,说明配置成功。
    -------------------

    ********************增加用户,验证用户。
    [
    常用参数:
        comment :         目录说明 
        path :             目录路径
        public             开放共享 默认为no , 如果=yes 表示无需身份验证
        browseable:        显示共享名称。
        valid users:       允许列表中的用户访问
        read only:         默认为yes,共享目录只读 。
        write able:        write able =no 与read only = yes 一样的效果
        wire list:        如果前面只读,只有在此里面的用户才有写的权利
        creat mask:       指定在共享目录里面建立文件的权限, 权限最高只能为 766
        directory mask:   指定建立目录的权限
        force user:       指定存取的用户张号
        force group:     指定用户存取组
    ]
    (1)、   增加用户:  useradd  sambashare(用户名)
    (2)、    smbpasswd  -a  sambashare(用户名)  键入回车,提示你输入密码 [必须进入: cd /usr/local/samba/bin/中]

    (3)、----------配置如下:(放在配置文件最下面)
    [sambashare]  
     comment = sambashare directory
     path = /home/sambashare
     public = no
     write list = sambashare
     valid users = @sambashare
    注释:
    (1)、如果其他用户想查看sambashare用户下的文件,只需要把valid users = @sambashare,@用户名就可以了。
    (2)、建立一个文件共享目录, 要求全部人可查看, 但每个人只能删除自己的文件, 不能删除别人。
    [public]
                comment = Public Stuff
                path = /home/forevergao/
                public = yes
                browseable = yes
                writeable = yes


    (4)、 设定public的权限, 因为samba不能做到每个人只能删除自己的文件, 不能删除别人的功能,linux设置目录Sticky bit权限. 目录设定了Sticky的权限,在这个目录下的文件只有root与文件的所有者才能删除, 别的用户可能通过设置,才能查看此用户目录下所有文件,但不能删除,只有本用户才能删除。
    chmod  1777  /home/sambashare

  • 相关阅读:
    python 读写json文件(dump, load),以及对json格式的数据处理(dumps, loads)
    Postman + newman + jenkins 的API自动化测试应用
    Selenium + WebDriver 各浏览器驱动下载地址
    pythonon ddt数据驱动二(json, yaml 驱动)
    python ddt 实现数据驱动一
    Python + logging 输出到屏幕,将log日志写入文件
    python 多线程小练习
    pycharm + git 的集成使用
    Map的遍历方式
    69道Spring面试题和答案
  • 原文地址:https://www.cnblogs.com/isoftware/p/3778410.html
Copyright © 2011-2022 走看看