如何用Git來共享文件?
SparkleShare 是一個(gè)開源的基于 Git 的 Dropbox 風(fēng)格的文件共享應(yīng)用程序。在我們的系列文章中了解有關(guān) Git 鮮為人知的用法。
Git 是一個(gè)少有的能將如此多的現(xiàn)代計(jì)算封裝到一個(gè)程序之中的應(yīng)用程序,它可以用作許多其他應(yīng)用程序的計(jì)算引擎。雖然它以跟蹤軟件開發(fā)中的源代碼更改而聞名,但它還有許多其他用途,可以讓你的生活更輕松、更有條理。在這個(gè) Git 系列中,我們將分享七種鮮為人知的使用 Git 的方法。
今天,我們將看看 SparkleShare,它使用 Git 作為文件共享的基礎(chǔ)。
用于文件共享的 Git
Git 的優(yōu)點(diǎn)之一是它具有固有的分發(fā)能力。它可用來建立共享。即使你只是與自己網(wǎng)絡(luò)上的其他計(jì)算機(jī)共享資源庫,Git 也會(huì)為從共享位置獲取文件的行為帶來透明性。
隨著其界面的發(fā)展,Git 變得非常簡單。雖然因用戶而異,他們坐下來完成一些工作時(shí)的共同點(diǎn)僅僅是 git pull
或稍微復(fù)雜一點(diǎn)的 git pull && git checkout -b my-branch
。但是,對于某些人來說,將命令輸入到他們的計(jì)算機(jī)中的做法完全是令人困惑或煩惱的。計(jì)算機(jī)旨在使生活變得輕松,它擅長于重復(fù)性工作,因此有更簡便的方法可以與 Git 共享文件。
SparkleShare
SparkleShare 項(xiàng)目是一個(gè)基于 Git 的跨平臺(tái)的、開源的 Dropbox 式的文件共享應(yīng)用程序。它通過將文件拖放到專門指定的 SparkleShare 目錄中的簡單操作,自動(dòng)執(zhí)行所有 Git 命令,觸發(fā)添加、提交、推送和拉取過程。因?yàn)樗? Git,所以你可以獲得基于差異(diff)的快速推送和拉取,并且繼承了 Git 版本控制和后端基礎(chǔ)設(shè)施(如 Git 掛鉤)的所有優(yōu)點(diǎn)。它可以完全自托管,也可以將其與 GitLab、GitHub、Bitbucket 等 Git 托管服務(wù)一起使用。此外,由于它基本上只是一個(gè) Git 的前端,因此你可以在可能沒有 SparkleShare 客戶端但有 Git 客戶端的設(shè)備上訪問 SparkleShare 中的文件。
正如你獲得 Git 的所有好處一樣,你也會(huì)受到所有常見的 Git 限制:使用 SparkleShare 存儲(chǔ)數(shù)百張照片、音樂和視頻是不切實(shí)際的,因?yàn)?Git 是為文本而設(shè)計(jì)和優(yōu)化的。Git 當(dāng)然可以存儲(chǔ)二進(jìn)制文件的大文件,但是因?yàn)樗梢愿櫄v史記錄,因此一旦將文件添加到其中,幾乎就不可能完全刪除它。這在某種程度上限制了 SparkleShare 對某些人的實(shí)用性,但使其非常適合許多工作流程,包括日程安排。
安裝 SparkleShare
SparkleShare 是跨平臺(tái)的,可從網(wǎng)站獲得適用于 Windows 和 Mac 的安裝程序。對于 Linux,有一個(gè) Flatpak 安裝包,或者你可以在終端中運(yùn)行以下命令:
$ sudo flatpak remote-add flathub https://flathub.org/repo/flathub.flatpakrepo
$ sudo flatpak install flathub org.sparkleshare.SparkleShare
創(chuàng)建一個(gè) Git 存儲(chǔ)庫
SparkleShare 并不是軟件即服務(wù)(SaaS)。你在計(jì)算機(jī)上運(yùn)行 SparkleShare 與 Git 存儲(chǔ)庫進(jìn)行通信,而 SparkleShare 并不存儲(chǔ)你的數(shù)據(jù)。如果你還沒有與文件夾同步的 Git 存儲(chǔ)庫,則必須在啟動(dòng) SparkleShare 之前創(chuàng)建一個(gè)文件夾。你有三個(gè)選擇:托管的 Git、自托管 Git 或自托管 SparkleShare。
托管的 Git
SparkleShare 可以使用你能訪問的任何 Git 存儲(chǔ)庫進(jìn)行存儲(chǔ),因此,如果你擁有 GitLab 或任何其他托管服務(wù)的帳戶(或創(chuàng)建一個(gè)),則它可以成為 SparkleShare 的后端。例如,開源 Notabug.org 服務(wù)是一個(gè)類似于 GitHub 和 GitLab 的 Git 托管服務(wù),但其獨(dú)特性足以證明 SparkleShare 的靈活性。根據(jù)用戶界面的不同,不同的托管服務(wù)創(chuàng)建新存儲(chǔ)庫的方法也有所不同,但是所有主要存儲(chǔ)庫都遵循相同的通用模型。
首先,在托管服務(wù)中找到創(chuàng)建新項(xiàng)目或存儲(chǔ)庫的按鈕,單擊它以開始。然后逐步完成存儲(chǔ)庫的創(chuàng)建過程,為存儲(chǔ)庫提供名稱、隱私級(jí)別(存儲(chǔ)庫通常默認(rèn)為公共),以及是否使用 README
文件初始化存儲(chǔ)庫。無論你是否需要個(gè) README
文件,請初始化建立一個(gè)。使用一個(gè)文件來創(chuàng)建存儲(chǔ)庫不是絕對必要的,但是它會(huì)強(qiáng)制 Git 主機(jī)實(shí)例化存儲(chǔ)庫中的 master
分支,這有助于確保前端應(yīng)用程序(例如 SparkleShare)具有要提交并推送的分支。即使文件是幾乎空的 README
文件,也可以用來查看該文件以確認(rèn)你已連接成功。
Creating a Git repository
創(chuàng)建存儲(chǔ)庫后,獲取其用于 SSH 克隆的 URL。就像從 Git 項(xiàng)目獲得其 URL 一樣,你也可以獲取此 URL:導(dǎo)航至存儲(chǔ)庫頁面并查找 “Clone” 按鈕或字段。
GitHub 的克隆 URL。
GitLab 的克隆 URL。
這是 SparkleShare 用于獲取數(shù)據(jù)的地址,因此請記下它。你的 Git 存儲(chǔ)庫現(xiàn)已配置好。
自托管的 Git
你可以使用 SparkleShare 訪問你有權(quán)訪問的任何計(jì)算機(jī)上的 Git 存儲(chǔ)庫。除了一個(gè) Git 裸存儲(chǔ)庫外,無需任何特殊設(shè)置。但是,如果你想將對 Git 存儲(chǔ)庫的訪問權(quán)授予其他任何人,則應(yīng)運(yùn)行 Gitolite 之類的 Git 管理器或 SparkleShare 自己的 Dazzle 服務(wù)器來幫助你管理 SSH 密鑰和帳戶。至少,創(chuàng)建一個(gè)特定于 Git 的用戶,以便有權(quán)訪問你的 Git 存儲(chǔ)庫的用戶不會(huì)自動(dòng)獲得對服務(wù)器其余部分的訪問權(quán)限。
以 Git 用戶身份登錄服務(wù)器(如果你非常擅長管理用戶和組權(quán)限,則可以以自己的用戶登錄)并創(chuàng)建存儲(chǔ)庫:
$ mkdir ~/sparkly.git
$ cd ~/sparkly.git
$ git init --bare .
你的 Git 存儲(chǔ)庫現(xiàn)已配置好。
Dazzle
SparkleShare 的開發(fā)人員提供了一個(gè)名為 Dazzle 的 Git 管理系統(tǒng),以幫助你自托管 Git 存儲(chǔ)庫。
在你的服務(wù)器上,將 Dazzle 應(yīng)用程序下載到你的路徑中的某個(gè)位置:
$ curl https://raw.githubusercontent.com/hbons/Dazzle/master/dazzle.sh --output ~/bin/dazzle
$ chmod +x ~/bin/dazzle
Dazzle 設(shè)置了一個(gè)特定于 Git 和 SparkleShare 的用戶,并且還基于 SparkleShare 應(yīng)用程序生成的密鑰實(shí)現(xiàn)了訪問權(quán)限。現(xiàn)在,只需設(shè)置一個(gè)項(xiàng)目:
$ dazzle create sparkly
你的服務(wù)器現(xiàn)在已經(jīng)配置好,可以用作 SparkleShare 托管了。
配置 SparkleShare
首次啟動(dòng) SparkleShare 時(shí),系統(tǒng)會(huì)提示你配置 SparkleShare 用于存儲(chǔ)的服務(wù)器。這個(gè)過程可能看起來像一個(gè)首次運(yùn)行的安裝向?qū)?,但?shí)際上是在 SparkleShare 中設(shè)置新共享位置的通常過程。與許多共享驅(qū)動(dòng)器應(yīng)用程序不同,使用 SparkleShare 可以一次配置多個(gè)位置。你配置的第一個(gè)共享位置并不比你以后可以配置的任何共享位置更重要,并且你也不用注冊 SparkleShare 或任何其他服務(wù)。你只是將 SparkleShare 指向 Git 存儲(chǔ)庫,以便它知道如何使第一個(gè) SparkleShare 文件夾保持同步。
在第一個(gè)屏幕上,給出一個(gè)身份信息,SparkleShare 將在代表你進(jìn)行的 Git 提交記錄中使用這些信息。你可以使用任何內(nèi)容,甚至可以使用不代表任何意義的偽造信息。它僅用于提交消息,如果你對審查 Git 后端進(jìn)程沒有興趣,你可能甚至看不到它們。
下一個(gè)屏幕提示你選擇主機(jī)類型。如果你使用的是 GitLab、GitHub、Planio 或 Bitbucket,則可以選擇一個(gè)適當(dāng)?shù)?。否則,請選擇“自己的服務(wù)器”。
Choosing a Sparkleshare host
在此屏幕底部,你必須輸入 SSH 的克隆 URL。如果你是自托管的 Git,則地址類似于 <ssh://username@example.com>
,而遠(yuǎn)程路徑是為此目的而創(chuàng)建的 Git 存儲(chǔ)庫的絕對路徑。
根據(jù)上面的自托管示例,我虛構(gòu)的服務(wù)器的地址為 ssh://git@example.com:22122
(:22122
表示一個(gè)非標(biāo)準(zhǔn)的 SSH 端口),遠(yuǎn)程路徑為 /home/git/sparkly.git
。
如果我改用 Notabug.org 帳戶,則上例中的地址為 ssh://git@notabug.org
,路徑為 seth/sparkly.git
。
SparkleShare 首次嘗試連接到主機(jī)時(shí)會(huì)失敗,因?yàn)槟闵形磳?SparkleShare 客戶端 ID(特定于 SparkleShare 應(yīng)用程序的 SSH 密鑰)復(fù)制到 Git 主機(jī)。這是預(yù)料之中的,所以不要取消該過程。將 SparkleShare 設(shè)置窗口保持打開狀態(tài),并從系統(tǒng)任務(wù)欄中的 SparkleShare 圖標(biāo)處獲取客戶端 ID。然后將客戶端 ID 復(fù)制到剪貼板,以便可以將其添加到 Git 主機(jī)。
Getting the client ID from Sparkleshare
將你的客戶端 ID 添加到托管的 Git 帳戶
除了較小的 UI 差異外,在任何托管服務(wù)上添加 SSH 密鑰(所有客戶端 ID 都是這樣)的過程基本上是相同的。在你的 Git 主機(jī)的 Web 儀表板中,導(dǎo)航到你的用戶設(shè)置,然后找到 “SSH 密鑰”類別。單擊“添加新密鑰”按鈕(或類似按鈕),然后粘貼你的 SparkleShare 客戶端 ID 的內(nèi)容。
Adding an SSH key
保存密鑰。如果你希望其他人(例如協(xié)作者或家庭成員)能夠訪問同一存儲(chǔ)庫,則他們必須向你提供其 SparkleShare 客戶端 ID,以便你可以將其添加到帳戶中。
將你的客戶端 ID 添加到自托管的 Git 帳戶
SparkleShare 客戶端 ID 只是一個(gè) SSH 密鑰,因此將其復(fù)制并粘貼到 Git 用戶的 ~/.ssh/authorized_keys
文件中。
使用 Dazzle 添加你的客戶 ID
如果你使用 Dazzle 管理 SparkleShare 項(xiàng)目,請使用以下命令添加客戶端 ID:
$ dazzle link
當(dāng) Dazzle 提示你輸入該 ID 時(shí),請粘貼在 SparkleShare 菜單中找到的客戶端 ID。
使用 SparkleShare
將客戶端 ID 添加到 Git 主機(jī)后,在 SparkleShare 窗口中單擊“重試”按鈕以完成設(shè)置??寺〈鎯?chǔ)庫完成后,你可以關(guān)閉 SparkleShare 設(shè)置窗口,并在你的家目錄中找到一個(gè)新的 SparkleShare
文件夾。如果你設(shè)置了帶有托管服務(wù)的 Git 存儲(chǔ)庫,并選擇包括 README
文件或許可證文件,則可以在 SparkleShare 目錄中看到它們。
Sparkleshare file manager
此外,有一些隱藏目錄,你可以通過在文件管理器中顯示隱藏目錄來查看。
Showing hidden files in GNOME
使用 SparkleShare 的方式與使用計(jì)算機(jī)上任何目錄的方式相同:將文件放入其中。每當(dāng)將文件或目錄放入 SparkleShare 文件夾時(shí),它都會(huì)在后臺(tái)復(fù)制到你的 Git 存儲(chǔ)庫。
排除某些文件
由于 Git 從設(shè)計(jì)上就是要記住一切,因此你可能希望從記錄中排除特定的文件類型。排除一些文件是有原因的。通過定義擺脫 SparkleShare 管理的文件,可以避免意外復(fù)制大文件。你還可以為自己設(shè)計(jì)一種方案,使你可以將存儲(chǔ)在一個(gè)目錄中的邏輯上屬于同一個(gè)文件(例如,MIDI 文件及其 .flac 導(dǎo)出文件),但是可以自己手動(dòng)備份大文件,而同時(shí)讓 SparkleShare 備份基于文本的文件。
如果在系統(tǒng)的文件管理器中看不到隱藏的文件,請顯示它們。導(dǎo)航到你的 SparkleShare 文件夾,然后到代表你的存儲(chǔ)庫的目錄,找到一個(gè)名為 .gitignore
的文件,然后在文本編輯器中將其打開。你可以在 .gitignore
中輸入文件擴(kuò)展名或文件名(每行一個(gè)),任何與你列出的文件匹配的文件都會(huì)被忽略(如文件名所示)。
Thumbs.db
$RECYCLE.BIN/
.DS_Store
._*
.fseventsd
.Spotlight-V100
.Trashes
.directory
.Trash-*
*.wav
*.ogg
*.flac
*.mp3
*.m4a
*.opus
*.jpg
*.png
*.mp4
*.mov
*.mkv
*.avi
*.djvu
*.epub
*.od{s,t}
*.cbz
你知道最經(jīng)常遇到哪些文件類型,因此請集中精力處理最有可能潛入你的 SparkleShare 目錄的文件。如果你想稍微矯枉過正一些,可以在 Notabug.org 以及整個(gè)網(wǎng)上找到 .gitignore
文件的好集合。
通過將這些條目保存在 .gitignore
文件中,你可以將不需要發(fā)送到 Git 主機(jī)的大文件放在 SparkleShare 目錄中,SparkleShare 將完全忽略它們。當(dāng)然,這意味著你需要確保它們可以備份或通過其他方式分發(fā)給你的 SparkleShare 協(xié)作者。
自動(dòng)化
自動(dòng)化 是我們與計(jì)算機(jī)達(dá)成的默契之一:計(jì)算機(jī)執(zhí)行重復(fù)的、無聊的工作,而我們?nèi)祟愐床簧瞄L做這些,要么不擅長記憶這些。SparkleShare 是一種很好的、簡單的自動(dòng)執(zhí)行例行數(shù)據(jù)分發(fā)的方法。但不管怎么說,這并不適合每個(gè) Git 存儲(chǔ)庫。它沒有用于高級(jí) Git 功能的接口,它沒有暫停按鈕或手動(dòng)管理的操作。沒關(guān)系,因?yàn)樗氖褂梅秶怯幸庀拗频摹parkleShare 可以完成它計(jì)劃要做的事情,它做得很好,而且它是你無需關(guān)心的一個(gè) Git 存儲(chǔ)庫。
如果你想使用這種穩(wěn)定的、看不見的自動(dòng)化,請嘗試一下 SparkleShare。