Linux安裝使用eCryptFS加密文件的方法
Linux安裝使用eCryptFS加密文件的方法
eCryptFS是Linux系統(tǒng)中的文件加密系統(tǒng),能夠?qū)ξ募蚰夸涍M(jìn)行加密,且加密級(jí)別高,安全性強(qiáng)于一般軟件,下面學(xué)習(xí)啦小編就給大家介紹下Linux如何使用eCryptFS加密文件。
加密類(lèi)型
我們主要有兩種加密文件和目錄的方法。一種是文件系統(tǒng)級(jí)別的加密,在這種加密中,你可以選擇性地加密某些文件或者目錄(如,/home/alice)。對(duì)我而言,這是個(gè)十分不錯(cuò)的方法,你不需要為了啟用或者測(cè)試加密而把所有一切重新安裝一遍。然而,文件系統(tǒng)級(jí)別的加密也有一些缺點(diǎn)。例如,許多現(xiàn)代應(yīng)用程序會(huì)緩存(部分)文件你硬盤(pán)中未加密的部分中,比如交換分區(qū)、/tmp和/var文件夾,而這會(huì)導(dǎo)致隱私泄漏。
另外一種方式,就是所謂的全盤(pán)加密,這意味著整個(gè)磁盤(pán)都會(huì)被加密(可能除了主引導(dǎo)記錄外)。全盤(pán)加密工作在物理磁盤(pán)級(jí)別,寫(xiě)入到磁盤(pán)的每個(gè)比特都會(huì)被加密,而從磁盤(pán)中讀取的任何東西都會(huì)在運(yùn)行中解密。這會(huì)阻止任何潛在的對(duì)未加密數(shù)據(jù)的未經(jīng)授權(quán)的訪問(wèn),并且確保整個(gè)文件系統(tǒng)中的所有東西都被加密,包括交換分區(qū)或任何臨時(shí)緩存數(shù)據(jù)。
可用的加密工具
在Linux中要實(shí)施加密,有幾個(gè)可供選擇的工具。在本教程中,我打算介紹其中一個(gè):eCryptFS,一個(gè)用戶(hù)空間文件系統(tǒng)加密工具。下面提供了一個(gè)Linux上可用的加密工具摘要供您參考。
文件系統(tǒng)級(jí)別加密
EncFS:嘗試加密的最簡(jiǎn)單方式之一。EncFS工作在基于FUSE的偽文件系統(tǒng)上,所以你只需要?jiǎng)?chuàng)建一個(gè)加密文件夾并將它掛載到某個(gè)文件夾就可以工作了。
eCryptFS:一個(gè)POSIX兼容的加密文件系統(tǒng),eCryptFS工作方式和EncFS相同,所以你必須掛載它。
磁盤(pán)級(jí)別加密
Loop-AES:最古老的磁盤(pán)加密方法。它真的很快,并且適用于舊系統(tǒng)(如,2.0內(nèi)核分支)。
DMCrypt:最常見(jiàn)的磁盤(pán)加密方案,支持現(xiàn)代Linux內(nèi)核。
CipherShed:已停止的TrueCrypt磁盤(pán)加密程序的一個(gè)開(kāi)源分支。
eCryptFS基礎(chǔ)
eCrypFS是一個(gè)基于FUSE的用戶(hù)空間加密文件系統(tǒng),在Linux內(nèi)核2.6.19及更高版本中可用(作為encryptfs模塊)。eCryptFS加密的偽文件系統(tǒng)是掛載到當(dāng)前文件系統(tǒng)頂部的。它可以很好地工作在EXT文件系統(tǒng)家族和其它文件系統(tǒng)如JFS、XFS、ReiserFS、Btrfs,甚至是NFS/CIFS共享文件系統(tǒng)上。Ubuntu使用eCryptFS作為加密其家目錄的默認(rèn)方法,ChromeOS也是。在eCryptFS底層,默認(rèn)使用的是AES算法,但是它也支持其它算法,如blowfish、des3、cast5、cast6。如果你是通過(guò)手工創(chuàng)建eCryptFS設(shè)置,你可以選擇其中一種算法。
就像我所的,Ubuntu讓我們?cè)诎惭b過(guò)程中選擇是否加密/home目錄。好吧,這是使用eCryptFS的最簡(jiǎn)單的一種方法。
Ubuntu提供了一個(gè)用戶(hù)友好的工具集,通過(guò)eCryptFS可以讓我們的生活更輕松,但是在Ubuntu安裝過(guò)程中啟用eCryptFS只創(chuàng)建了一個(gè)指定的預(yù)配置的設(shè)置。所以,如果默認(rèn)的設(shè)置不適合你的需求,你需要進(jìn)行手工設(shè)置。在本教程中,我將介紹如何在主流Linux發(fā)行版上手工設(shè)置eCryptFS。
eCryptFS的安裝
Debian,Ubuntu或其衍生版:
$ sudo apt-get install ecryptfs-utils
注意,如果你在Ubuntu安裝過(guò)程中選擇加密家目錄,eCryptFS應(yīng)該已經(jīng)安裝了。
CentOS, RHEL or Fedora:
# yum install ecryptfs-utils
Arch Linux:
$ sudo pacman -S ecryptfs-utils
在安裝完包后,加載eCryptFS內(nèi)核模塊當(dāng)然會(huì)是一個(gè)很好的實(shí)踐:
$ sudo modprobe ecryptfs
配置eCryptFS
現(xiàn)在,讓我們開(kāi)始加密一些目錄,運(yùn)行eCryptFS配置工具:
$ ecryptfs-setup-private
它會(huì)要求你輸入登錄密碼和掛載密碼。登錄密碼和你常規(guī)登錄的密碼一樣,而掛載密碼用于派生一個(gè)文件加密主密鑰。這里留空可以生成一個(gè)(復(fù)雜的),這樣會(huì)更安全。登出然后重新登錄。
你會(huì)注意到,eCryptFS默認(rèn)在你的家目錄中創(chuàng)建了兩個(gè)目錄:Private和.Private。~/.Private目錄包含有加密的數(shù)據(jù),而你可以在~/Private目錄中訪問(wèn)到相應(yīng)的解密后的數(shù)據(jù)。在你登錄時(shí),~/.Private目錄會(huì)自動(dòng)解密并映射到~/Private目錄,因此你可以訪問(wèn)它。當(dāng)你登出時(shí),~/Private目錄會(huì)自動(dòng)卸載,而~/Private目錄中的內(nèi)容會(huì)加密回到~/.Private目錄。
eCryptFS怎么會(huì)知道你擁有~/.Private目錄,并自動(dòng)將其解密到~/Private目錄而不需要我們輸入密碼呢?這就是eCryptFS的PAM模塊搗的鬼,它為我們提供了這項(xiàng)便利服務(wù)。
如果你不想讓~/Private目錄在登錄時(shí)自動(dòng)掛載,只需要在運(yùn)行ecryptfs-setup-private工具時(shí)添加“--noautomount”選項(xiàng)。同樣,如果你不想要~/Private目錄在登出后自動(dòng)卸載,也可以自動(dòng)“--noautoumount”選項(xiàng)。但是,那樣后,你需要自己手工掛載或卸載~/Private目錄:
$ ecryptfs-mount-private~/.Private ~/Private
$ ecryptfs-umount-private~/Private
你可以來(lái)驗(yàn)證一下.Private文件夾是否被掛載,運(yùn)行:
$ mount
現(xiàn)在,我們可以開(kāi)始把任何敏感文件放進(jìn)~/Private文件夾里頭了,它們會(huì)在我們登出時(shí)自動(dòng)被加密并鎖在~/.Private文件內(nèi)。
所有這一切看起來(lái)是那么得神奇。這主要是ecryptfs-setup-private工具讓一切設(shè)置變得簡(jiǎn)單。如果你想要深究一點(diǎn),對(duì)eCryptFS指定的方面進(jìn)行設(shè)置,那么請(qǐng)轉(zhuǎn)到官方文檔。
結(jié)尾
上面就是Linux使用eCryptFS加密文件的方法介紹了,比較神奇的是,eCryptFS可以對(duì)同一文件進(jìn)行層層加密,你可以對(duì)文件夾中的文件一個(gè)個(gè)的加密,一個(gè)密碼只能打開(kāi)一個(gè)文件包。