• <ins id="pjuwb"></ins>
    <blockquote id="pjuwb"><pre id="pjuwb"></pre></blockquote>
    <noscript id="pjuwb"></noscript>
          <sup id="pjuwb"><pre id="pjuwb"></pre></sup>
            <dd id="pjuwb"></dd>
            <abbr id="pjuwb"></abbr>

            Thronds

            一問你會什么 二問你做出過什么 三問你為了什么

              C++博客 :: 首頁 :: 新隨筆 :: 聯系 :: 聚合  :: 管理 ::
              36 隨筆 :: 0 文章 :: 56 評論 :: 0 Trackbacks
            需求:在linux下訪問局域網絡中另一臺計算機的共享資源,另一臺計算機的系統可能為windows或者linux。我首先想到的是用mount命令掛載共享資源,后經群里朋友提醒,直接用samba更方便。另外windows訪問linux資源也需要運用samba。Linux/Unix之間的文件互訪用NFS網絡文件系統。

            一、mount
                在mount共享文件之前,需要要先安裝smbfs工具包。原因是Windows網絡共享的核心是SMB/CIFS,在linux下要掛接(mount)windows的磁盤共享,就必須安裝和使用samba軟件包(參看下面的提問)。既然windows網絡共享的核心是smb/cifs,那么下面的兩條命令都可以實現掛載共享文件了:
                #mount -t smbfs //ip/sharefile /mountpoint
                #mount -t cifs //ip/sharefile /mountpoint
            上面的命令掛載正常,英文路徑下互訪正常;但中文路徑出現亂碼,不能正?;ピL。原因是互訪編碼不一致,中文用utf8,用下面的命令可以正常識別中文:
                #mount -t smbfs -o codepage=cp936,iocharset=utf8 //ip/sharefile /mountpoint
            中文文件正?;ピL,但有Warning: ignoring deprecated smbfs option 'codepage=cp936'。知道原因的朋友留個解釋:)
            如果有用戶名和密碼的話:
                #mount -t smbfs -o username=****,password=*****,codepage=cp936,iocharset=utf8 //ip/sharefile /mountpoint
            卸載命令是:
                #umount /mountpoint 或者
                #umount //ip/sharefile

                提問時間:smb/cifs是什么玩意兒?[1]在mount之前不安裝smbfs工具包,能否用-t cifs實現互訪?

            二、samba
                在前一部分中已經用到了samba,雖然已經非常的方便(嘎嘎,mount很強大),但只能要在linux下訪問windows文件,我們還要能夠在 windows下訪問linux共享文件。samba采用server/client架構。通過使用samba客戶端可以讓linux訪問windows 共享資源;通過在linux上配置samba服務器,可以讓windows訪問linux共享資源。

                在linux環境下訪問windows共享資源
                首先,查看系統中是否已經安裝samba.在ubuntu下用#dpkg -l | grep samba [2],在redhat中用rpm -qa | grep samba. [3] 如果沒有安裝好samba包,redhat下的安裝方法參考[3],ubuntu下使用#apt-get install samba。
                現在就可以使用samba訪問windows共享資源拉。訪問的方式也有兩種:
                 (1)命令方式
                命令方式如同第一部分介紹的那樣。它不用考慮對中文支持的問題,因為samba能很好的實現中文支持。它的使用命令如下:
                查詢windows主機共享資源:#smbclient -L SEU-PPCHEN(主機名)或者#smbclient -L //ip
                連接共享目錄:#smbclient //SEU-PPCHEN/sharefile 或者//ip/sharefile;然后就進入了smb模式,在smb模式下支持大部分的常用命令,可以用help查看有哪些命令。
            另外使用smbmount可以實現和第一部分一樣的掛載效果。
                (2)圖形方式(相當于windows下的網絡鄰居)
                在ubuntu的現在版本8.04中,在file browser中就能很好的支持網絡鄰居了。一,可以通過菜單places->network直接訪問;二,也可以在file browser的locate中輸入smb:///(查看有哪些主機)或smb://ip(訪問具體的主機)。
                在redhat和KDE下,參考[3]。

                windows下訪問linux共享資源
                linux提供共享服務,需要配置samba服務器實現共享功能。配置方法參考來自網絡上的一篇文章[4],作者不祥。為了能夠讓windows下的用戶通過以太網訪問Linux下的共享文件,需要開啟Samba服務器,Samba服務器詳細配置步驟如下:

                1.打開samba的配置文件
                vim /etc/samba/smb.conf

                2.其中存在如下幾個域
                [global](全局參數的設置,它對samba的功能具有很大的影響,主要用來設置整個系統規則。
                workgroup= 這是你在windows中的域。
                server string= 這是在windows中看到你的samba的解釋。
                netbios name =最好是你的機器名,如果把改句注消,默認的是你LINUX機器名,不過,最好還是自己填上
                dos charset=cp936
                unix charset=cp936 加上這二句就可以正確顯示中文了。
                hosts allow 允許登錄的linux-samba的主機名單,用IP地址給出,多個IP地址用空格分開,不在名單中的主機將不能得到samba提供的服務,這也是網絡安全的一個方面。
                printcap name 指定printcap文件地址,通常為/etc/printcap,包含了linux打印機的配置信息。
                load printers 允許使用共享打印機時,默認值為yes。
                printing 如果使用的打印機是非標準的,那么應該指出打印機系統類型。
                log file = /usr/local/samba/var/log.%m
                max log size = 0

                上面這兩行則是Samba日志的相關定義。其記錄文件的位置是放在/var/log/samba/%m.log,安裝目錄不一樣,日志可不一樣,后面的一條是定義日志記錄文件的大小,單位是KB,如果是0的話就不限大小。
                guest acount 來賓帳戶,表示用哪一個Linux用戶作為所要的客戶連接,定義Samba缺省的用戶賬號,這個賬號必須在/etc/passwd中。
                security 指定安全模式。大多數用戶使用user級的安全模式,samba用本地linux口令文件驗證。
                security = security_level

                定義Samba的安全級別,按從低到高分為四級:share,user,server,domain。它們對應的驗證方式如下:
                share:沒有安全性的級別,任何用戶都可以不要用戶名和口令訪問服務器上的資源。
                user:samba的默認配置,要求用戶在訪問共享資源之前資源必須先提供用戶名和密碼進行驗證。
                server:和user安全級別類似,但用戶名和密碼是遞交到另外一個服務器去驗證,比如遞交給一臺NT服務器。如果遞交失敗,就退到user安全級。
                domain:這個安全級別要求網絡上存在一臺Windows的主域控制器,samba把用戶名和密碼遞交給它去驗證。
                后面三種安全級都要求用戶在本linux機器上也要系統帳戶。否則是不能訪問的。
                主要修改和添加的域如下:

                2.1列出允許訪問的主機ip
                hosts allow = 192.168.0.1 192.168.0.88
                2.2安全模式
                security = share
                2.3指定共享文件名稱和共享文件
                [glx_linux]
                comment = This is Glx Linux #備注說明
                path = /mnt/e_win
                guest ok = yes
                writable = yes
                2.4創建Samba專用用戶
                創建用戶gliet_linux
                addusr gliet_linux
                passwd gliet_linux
                之后將該用戶添加到samba中
                /etc/samba/smbpasswd -a gliet_linux
                2.5清除ip鏈
                service iptables stop
                清除所有鏈: [ 確定 ]
                刪除用戶定義的鏈: [ 確定 ]
                將內建鏈重設為默認的“ACCEPT”策略: [ 確定 ]
                2.6重啟網卡
                service network restart
                正在關閉接口 eth0: [ 確定 ]
                關閉環回接口: [ 確定 ]
                設置網絡參數: [ 確定 ]
                彈出環回接口: [ 確定 ]
                彈出界面 eth0: [ 確定 ]

                3.重啟Samba

                /etc/rc.d/init.d/smb restart (重啟samba)

                4.好了,在win_xp下登錄

                //192.168.0.5
                輸入用戶名:gliet_linux和密碼后,就可以看到目錄glx_linux,該目錄是可以被windows用戶修改的。
                哈哈,windows可以對linux進行操作了,以下是我的一個配置文件:
                security = user
                [glx_linux_write_win_share]
                comment = This is Write test
                path = /home/gliet/win
                guest ok = yes
                writable = yes
                [glx_linux_read_win_tar_share]
                comment = This is Read test
                path = /home/gliet/tar
                guest ok = yes
                read only = yes
              
            三、NFS(Networks File System)
            [5]

            四、當Linux已經存在亂碼文件時,可以通過iconv命令將文件內容的編碼轉換成utf8.

                原Windows rar壓縮的文件,Linux系統下解壓后打開里邊的文件,內容全部亂碼。其他類似的情況都可以按照如此辦法解決。

                之所以出現亂碼是因為所壓縮的文件中,有的文件是以中文命名。而在windows下中文的編碼一般為gbk,而linux下中文的編碼一般為utf8,所以在windows下正常打開的文件,到linux下很可能會出現亂碼。解決辦法為:使用命令iconv對文件內容編碼進行轉換。例如我有一個文件"linux常用命令"在windows下打開正常,而在linux下打開則會亂碼,其解決辦法為在終端輸入:

              iconv -f gbk -t utf8 linux常用命令.txt > linux常用命令.txt.utf8

              之后再打開"linux常用命令.txt.utf8"這個文件,該文見的亂碼問題就解決了。


            reference
            [1]http://zhidao.baidu.com/question/7819626.html?fr=qrl
            [2]http://wiki.ubuntu.org.cn/UbuntuSkills
            [3]http://www.chinaitpower.com/2005September/2005-09-13/205372.html
            [4]http://www.linux-cn.com/html/linux/beginner/20070524/41617.html
            [5]http://blog.163.com/liang8421@126/blog/static/894819572008102774710496/
            posted on 2008-12-07 16:55 thronds 閱讀(1781) 評論(0)  編輯 收藏 引用 所屬分類: Linux/Unix高級技術
            亚洲精品乱码久久久久久中文字幕 | 狠狠色婷婷久久一区二区三区| 国产视频久久| 亚洲综合久久综合激情久久| 99久久国语露脸精品国产| 久久国产亚洲精品无码| 久久人人爽人人爽人人AV| 久久久噜噜噜久久熟女AA片| 国产高潮国产高潮久久久| 久久精品国产亚洲AV无码偷窥| 久久精品欧美日韩精品| 精品久久久久久无码中文字幕一区 | 国产aⅴ激情无码久久| 一本一本久久A久久综合精品 | 精品多毛少妇人妻AV免费久久| 一本色综合网久久| 韩国免费A级毛片久久| 久久综合综合久久97色| 久久国产成人亚洲精品影院| 日本亚洲色大成网站WWW久久| 亚洲精品无码久久久久去q| 九九精品99久久久香蕉| 观看 国产综合久久久久鬼色 欧美 亚洲 一区二区 | 亚洲国产日韩欧美综合久久| 久久中文字幕人妻熟av女| 久久精品a亚洲国产v高清不卡| 久久免费精品视频| 人人狠狠综合久久亚洲| 国产精品9999久久久久| 亚洲另类欧美综合久久图片区| 日韩精品无码久久久久久| 久久精品一区二区三区不卡| 伊人久久国产免费观看视频| 国产精品一久久香蕉国产线看| 欧洲性大片xxxxx久久久| 精品久久久久久中文字幕人妻最新| 久久久久久噜噜精品免费直播 | 精品少妇人妻av无码久久| 久久免费观看视频| 国产精品毛片久久久久久久| 综合人妻久久一区二区精品|