升級到 OpenSUSE 13.2 之後,原來配置為可自動掛載並進行寫入操作的 Windows NTFS 分區現在不會自動掛載了,在磁碟管理中配置了自動掛載且不勾選“Mount Read-Only”居然也無法直接寫入。又折騰了好久才根據坎離楓整理的博文搞明白了。
要在 Windows + Linux 雙系統中的 Linux 系統裡使用 Windows 分區,需要先將 Windows 分區掛載到 Linux 系統中。掛載可以在需要的時候通過命令列操作,也可以在管理控制中心,如 OpenSUSE 的 YaST Control Center 中設定每次開機的時候自動掛載。
下面假設要將 Windows 中的 C 和 D 兩個分區,都是 NTFS 格式,分別掛載到 Linux 系統(這裡以 OpenSUSE 13.2 為例)中的 /winc 和 /wind 兩個目錄。並假設當前 Linux 普通使用者為 linuxuser。
0. 準備工作
準備工作很簡單,就是保證 Linux 中有我們需要掛載到的這兩個目錄,並讓 linuxuser 擁有可讀寫權限。
建立目錄,
# sudo mkdir /winc
# sudo mkdir /wind
更改所有者為 linuxuser,使用者組為 users,
# chown linuxuser:users /winc
# chown linuxuser:users /wind
還要知道 Windows 中那兩個分區在 Linux 中的位置(訪問路徑),這裡是用它們的裝置路徑,分別為,
/dev/sda1
/dev/sda5
如果不知道,可以通過命令列指令查看(需要 root 許可權),
# sudo fdisk -l
Disk /dev/sda: ...
Device Boot Start End Sectors Size Id Type
/dev/sda1 ... HPFS/NTFS/exFAT
/dev/sda2 * ... Extended
/dev/sda5 ... HPFS/NTFS/exFAT
/dev/sda6 ...
/dev/sda7 ...
/dev/sda8 ...
這裡略去了一些不必要的資訊。
1. 命令列操作¶
同樣需要 root 許可權。
掛載,
mount /dev/sda1 /winc
mount /dev/sda5 /wind
這樣直接就是可寫入的了。但是每次關機就沒有了。
取消掛載,
umount /winc
umount /wind
2. 圖形介面操作 + 開機自動掛載
還是圖形介面看著順眼,並且設定開機自動掛載也方便。同樣需要 root 許可權。
YaST –> System –> Partitioner,單擊 yes 確認警告;
按右鍵某 Windows NTFS 分區,比如 C 分區(/dev/sda1),選編輯(Edit);
在 Mount partition 中 Mount Point 裡輸入 /winc;
單擊下面的 Fstab Options 開啟設定頁,只勾選一個 Mountable by User 就可以了,
與前面命令列不同的就在於這一步,當然這一步也可以通過命令列來操作,那就是直接命令列修改 /etc/fstab 檔案,形如,
<partition> <mount point> ntfs-3g <options> 0 0
例如,
/dev/sda5 /wind ntfs-3g user,users,gid=users,fmask=002,dmask=002,locale=en_US.UTF-8 0 0
/dev/sda1 /winc ntfs-3g user,users,gid=users,fmask=133,dmask=022,locale=en_US.UTF-8 0 0
單擊 OK 儲存 Fstab Options 設定;
單擊 Finish 儲存 /dev/sda1 的設定。
同樣可以對 D 分區進行設定。但是僅僅按照上面的設定是無法對這些分區進行 寫入 操作的,儘管沒有勾選上面的“Mount Read-Only”那一項。如果要使之可寫入,還需要修改上圖中下面那一行裡面的 Arbitrary Option Value(其實就是 ntfs-3g 的選項參數),
users,gid=users,fmask=133,dmask=022,locale=en_US.UTF-8
關鍵就是其中的 fmask(檔案許可權)和 dmask(目錄許可權),改為,
users,gid=users,fmask=002,dmask=002,locale=en_US.UTF-8
其中 locale 是用來設定成中文環境以顯示中文的,可以改為 locale=zh_CN.UTF-8。
這裡的設定需要重啟電腦生效。
建議為了 Windows 系統的安全和穩定,不要對系統硬碟執行可寫入設定。
3. 附註
典型 ntfs-3g 選項:
users – 假如 ntfs-3g 可執行檔設定了 SUID root(命令:chmod u+s /bin/ntfs-3g),則允許任何人掛載/卸載 NTFS 分區。注意要用 users 而不是 user
noauto – 啟動時不要自動掛載分區
uid – 指定 NTFS 分區中檔案和目錄的擁有者(用十進位數表示)
gid – 指定 NTFS 分區中檔案和目錄的使用者組(用十進位數表示)
fmask – 檔案許可權(八位元掩碼)
dmask – 目錄許可權(八位元掩碼)
locale – 通常用來讓使用國際化字元集的檔案可見
掩碼:
可通過 umask 設定
掩碼 002 對應的檔案/檔案夾屬性就是 775,775 許可權對應為 ug:rwx,o:rx
u/g/o = user/group/everybody
r/w/x = read/write/execute
Read 4 – 允許讀檔案
Write 2 – 允許寫/修改檔案
eXecute 1 – 讀/寫/刪除/修改/目錄
簡單點的關係就是 002+775=777,許可權最大值就是 777,表示任何人都可執行 1、寫 2、讀 4,1+2+4=7
113 對應的就是 664