如何用Git來共享文件

這篇文章主要介紹“如何用Git來共享文件”,在日常操作中,相信很多人在如何用Git來共享文件問題上存在疑惑,小編查閱了各式資料,整理出簡單好用的操作方法,希望對大家解答”如何用Git來共享文件”的疑惑有所幫助!接下來,請跟著小編一起來學習吧!

超過10多年行業(yè)經(jīng)驗,技術領先,服務至上的經(jīng)營模式,全靠網(wǎng)絡和口碑獲得客戶,為自己降低成本,也就是為客戶降低成本。到目前業(yè)務范圍包括了:做網(wǎng)站、成都做網(wǎng)站,成都網(wǎng)站推廣,成都網(wǎng)站優(yōu)化,整體網(wǎng)絡托管,小程序設計,微信開發(fā),重慶APP軟件開發(fā),同時也可以讓客戶的網(wǎng)站和網(wǎng)絡營銷和我們一樣獲得訂單和生意!

用于文件共享的 Git

Git 的優(yōu)點之一是它具有固有的分發(fā)能力。它可用來建立共享。即使你只是與自己網(wǎng)絡上的其他計算機共享資源庫,Git 也會為從共享位置獲取文件的行為帶來透明性。

隨著其界面的發(fā)展,Git 變得非常簡單。雖然因用戶而異,他們坐下來完成一些工作時的共同點僅僅是 git pull 或稍微復雜一點的 git pull && git checkout -b my-branch。但是,對于某些人來說,將命令輸入到他們的計算機中的做法完全是令人困惑或煩惱的。計算機旨在使生活變得輕松,它擅長于重復性工作,因此有更簡便的方法可以與 Git 共享文件。

SparkleShare

SparkleShare  項目是一個基于 Git 的跨平臺的、開源的 Dropbox 式的文件共享應用程序。它通過將文件拖放到專門指定的 SparkleShare  目錄中的簡單操作,自動執(zhí)行所有 Git 命令,觸發(fā)添加、提交、推送和拉取過程。因為它基于  Git,所以你可以獲得基于差異(diff)的快速推送和拉取,并且繼承了 Git 版本控制和后端基礎設施(如 Git  掛鉤)的所有優(yōu)點。它可以完全自托管,也可以將其與 GitLab、GitHub、Bitbucket 等 Git 托管服務一起使用。此外,由于它基本上只是一個 Git 的前端,因此你可以在可能沒有 SparkleShare 客戶端但有 Git 客戶端的設備上訪問 SparkleShare 中的文件。

正如你獲得 Git 的所有好處一樣,你也會受到所有常見的 Git 限制:使用 SparkleShare  存儲數(shù)百張照片、音樂和視頻是不切實際的,因為 Git 是為文本而設計和優(yōu)化的。Git  當然可以存儲二進制文件的大文件,但是因為它可以跟蹤歷史記錄,因此一旦將文件添加到其中,幾乎就不可能完全刪除它。這在某種程度上限制了  SparkleShare 對某些人的實用性,但使其非常適合許多工作流程,包括日程安排。

安裝 SparkleShare

SparkleShare 是跨平臺的,可從網(wǎng)站獲得適用于 Windows 和 Mac 的安裝程序。對于 Linux,有一個 Flatpak 安裝包,或者你可以在終端中運行以下命令:

$ sudo flatpak remote-add flathub https://flathub.org/repo/flathub.flatpakrepo$ sudo flatpak install flathub org.sparkleshare.SparkleShare

創(chuàng)建一個 Git 存儲庫

SparkleShare 并不是軟件即服務(SaaS)。你在計算機上運行 SparkleShare 與 Git 存儲庫進行通信,而  SparkleShare 并不存儲你的數(shù)據(jù)。如果你還沒有與文件夾同步的 Git 存儲庫,則必須在啟動 SparkleShare  之前創(chuàng)建一個文件夾。你有三個選擇:托管的 Git、自托管 Git 或自托管 SparkleShare。

托管的 Git

SparkleShare 可以使用你能訪問的任何 Git 存儲庫進行存儲,因此,如果你擁有 GitLab 或任何其他托管服務的帳戶(或創(chuàng)建一個),則它可以成為 SparkleShare 的后端。例如,開源 Notabug.org 服務是一個類似于 GitHub 和 GitLab 的 Git 托管服務,但其獨特性足以證明 SparkleShare 的靈活性。根據(jù)用戶界面的不同,不同的托管服務創(chuàng)建新存儲庫的方法也有所不同,但是所有主要存儲庫都遵循相同的通用模型。

首先,在托管服務中找到創(chuàng)建新項目或存儲庫的按鈕,單擊它以開始。然后逐步完成存儲庫的創(chuàng)建過程,為存儲庫提供名稱、隱私級別(存儲庫通常默認為公共),以及是否使用 README 文件初始化存儲庫。無論你是否需要個 README 文件,請初始化建立一個。使用一個文件來創(chuàng)建存儲庫不是絕對必要的,但是它會強制 Git 主機實例化存儲庫中的 master 分支,這有助于確保前端應用程序(例如 SparkleShare)具有要提交并推送的分支。即使文件是幾乎空的 README 文件,也可以用來查看該文件以確認你已連接成功。

如何用Git來共享文件

Creating a Git repository

創(chuàng)建存儲庫后,獲取其用于 SSH 克隆的 URL。就像從 Git 項目獲得其 URL 一樣,你也可以獲取此 URL:導航至存儲庫頁面并查找 “Clone” 按鈕或字段。

如何用Git來共享文件

GitHub 的克隆 URL。

如何用Git來共享文件

GitLab 的克隆 URL。

這是 SparkleShare 用于獲取數(shù)據(jù)的地址,因此請記下它。你的 Git 存儲庫現(xiàn)已配置好。

自托管的 Git

你可以使用 SparkleShare 訪問你有權訪問的任何計算機上的 Git 存儲庫。除了一個 Git 裸存儲庫外,無需任何特殊設置。但是,如果你想將對 Git 存儲庫的訪問權授予其他任何人,則應運行 Gitolite 之類的 Git 管理器或 SparkleShare 自己的 Dazzle 服務器來幫助你管理 SSH 密鑰和帳戶。至少,創(chuàng)建一個特定于 Git 的用戶,以便有權訪問你的 Git 存儲庫的用戶不會自動獲得對服務器其余部分的訪問權限。

以 Git 用戶身份登錄服務器(如果你非常擅長管理用戶和組權限,則可以以自己的用戶登錄)并創(chuàng)建存儲庫:

$ mkdir ~/sparkly.git$ cd ~/sparkly.git$ git init --bare .

你的 Git 存儲庫現(xiàn)已配置好。

Dazzle

SparkleShare 的開發(fā)人員提供了一個名為 Dazzle 的 Git 管理系統(tǒng),以幫助你自托管 Git 存儲庫。

在你的服務器上,將 Dazzle 應用程序下載到你的路徑中的某個位置:

$ curl https://raw.githubusercontent.com/hbons/Dazzle/master/dazzle.sh --output ~/bin/dazzle$ chmod +x ~/bin/dazzle

Dazzle 設置了一個特定于 Git 和 SparkleShare 的用戶,并且還基于 SparkleShare 應用程序生成的密鑰實現(xiàn)了訪問權限。現(xiàn)在,只需設置一個項目:

$ dazzle create sparkly

你的服務器現(xiàn)在已經(jīng)配置好,可以用作 SparkleShare 托管了。

配置 SparkleShare

首次啟動 SparkleShare 時,系統(tǒng)會提示你配置 SparkleShare  用于存儲的服務器。這個過程可能看起來像一個首次運行的安裝向?qū)?,但實際上是在 SparkleShare  中設置新共享位置的通常過程。與許多共享驅(qū)動器應用程序不同,使用 SparkleShare  可以一次配置多個位置。你配置的第一個共享位置并不比你以后可以配置的任何共享位置更重要,并且你也不用注冊 SparkleShare  或任何其他服務。你只是將 SparkleShare 指向 Git 存儲庫,以便它知道如何使第一個 SparkleShare 文件夾保持同步。

在第一個屏幕上,給出一個身份信息,SparkleShare 將在代表你進行的 Git 提交記錄中使用這些信息。你可以使用任何內(nèi)容,甚至可以使用不代表任何意義的偽造信息。它僅用于提交消息,如果你對審查 Git 后端進程沒有興趣,你可能甚至看不到它們。

下一個屏幕提示你選擇主機類型。如果你使用的是 GitLab、GitHub、Planio 或 Bitbucket,則可以選擇一個適當?shù)?。否則,請選擇“自己的服務器”。

如何用Git來共享文件

Choosing a Sparkleshare host

在此屏幕底部,你必須輸入 SSH 的克隆 URL。如果你是自托管的 Git,則地址類似于 <ssh://username@example.com>,而遠程路徑是為此目的而創(chuàng)建的 Git 存儲庫的絕對路徑。

根據(jù)上面的自托管示例,我虛構的服務器的地址為 ssh://git@example.com:22122:22122 表示一個非標準的 SSH 端口),遠程路徑為 /home/git/sparkly.git。

如果我改用 Notabug.org 帳戶,則上例中的地址為 ssh://git@notabug.org,路徑為 seth/sparkly.git。

SparkleShare 首次嘗試連接到主機時會失敗,因為你尚未將 SparkleShare 客戶端 ID(特定于  SparkleShare 應用程序的 SSH 密鑰)復制到 Git 主機。這是預料之中的,所以不要取消該過程。將 SparkleShare  設置窗口保持打開狀態(tài),并從系統(tǒng)任務欄中的 SparkleShare 圖標處獲取客戶端 ID。然后將客戶端 ID 復制到剪貼板,以便可以將其添加到  Git 主機。

如何用Git來共享文件

Getting the client ID from Sparkleshare

將你的客戶端 ID 添加到托管的 Git 帳戶

除了較小的 UI 差異外,在任何托管服務上添加 SSH 密鑰(所有客戶端 ID 都是這樣)的過程基本上是相同的。在你的 Git 主機的  Web 儀表板中,導航到你的用戶設置,然后找到 “SSH 密鑰”類別。單擊“添加新密鑰”按鈕(或類似按鈕),然后粘貼你的  SparkleShare 客戶端 ID 的內(nèi)容。

如何用Git來共享文件

Adding an SSH key

保存密鑰。如果你希望其他人(例如協(xié)作者或家庭成員)能夠訪問同一存儲庫,則他們必須向你提供其 SparkleShare 客戶端 ID,以便你可以將其添加到帳戶中。

將你的客戶端 ID 添加到自托管的 Git 帳戶

SparkleShare 客戶端 ID 只是一個 SSH 密鑰,因此將其復制并粘貼到 Git 用戶的 ~/.ssh/authorized_keys 文件中。

使用 Dazzle 添加你的客戶 ID

如果你使用 Dazzle 管理 SparkleShare 項目,請使用以下命令添加客戶端 ID:

$ dazzle link

當 Dazzle 提示你輸入該 ID 時,請粘貼在 SparkleShare 菜單中找到的客戶端 ID。

使用 SparkleShare

將客戶端 ID 添加到 Git 主機后,在 SparkleShare 窗口中單擊“重試”按鈕以完成設置??寺〈鎯焱瓿珊?,你可以關閉 SparkleShare 設置窗口,并在你的家目錄中找到一個新的 SparkleShare 文件夾。如果你設置了帶有托管服務的 Git 存儲庫,并選擇包括 README 文件或許可證文件,則可以在 SparkleShare 目錄中看到它們。

如何用Git來共享文件

Sparkleshare file manager

此外,有一些隱藏目錄,你可以通過在文件管理器中顯示隱藏目錄來查看。

如何用Git來共享文件

Showing hidden files in GNOME

使用 SparkleShare 的方式與使用計算機上任何目錄的方式相同:將文件放入其中。每當將文件或目錄放入 SparkleShare 文件夾時,它都會在后臺復制到你的 Git 存儲庫。

排除某些文件

由于 Git 從設計上就是要記住一切,因此你可能希望從記錄中排除特定的文件類型。排除一些文件是有原因的。通過定義擺脫  SparkleShare  管理的文件,可以避免意外復制大文件。你還可以為自己設計一種方案,使你可以將存儲在一個目錄中的邏輯上屬于同一個文件(例如,MIDI 文件及其  .flac 導出文件),但是可以自己手動備份大文件,而同時讓 SparkleShare 備份基于文本的文件。

如果在系統(tǒng)的文件管理器中看不到隱藏的文件,請顯示它們。導航到你的 SparkleShare 文件夾,然后到代表你的存儲庫的目錄,找到一個名為 .gitignore 的文件,然后在文本編輯器中將其打開。你可以在 .gitignore 中輸入文件擴展名或文件名(每行一個),任何與你列出的文件匹配的文件都會被忽略(如文件名所示)。

Thumbs.db$RECYCLE.BIN/.DS_Store._*.fseventsd.Spotlight-V100.Trashes.directory.Trash-**.wav*.ogg*.flac*.mp3*.m4a*.opus*.jpg*.png*.mp4*.mov*.mkv*.avi*.pdf*.djvu*.epub*.od{s,t}*.cbz

你知道最經(jīng)常遇到哪些文件類型,因此請集中精力處理最有可能潛入你的 SparkleShare 目錄的文件。如果你想稍微矯枉過正一些,可以在 Notabug.org 以及整個網(wǎng)上找到 .gitignore 文件的好集合。

通過將這些條目保存在 .gitignore 文件中,你可以將不需要發(fā)送到 Git 主機的大文件放在 SparkleShare 目錄中,SparkleShare 將完全忽略它們。當然,這意味著你需要確保它們可以備份或通過其他方式分發(fā)給你的 SparkleShare 協(xié)作者。

自動化

自動化  是我們與計算機達成的默契之一:計算機執(zhí)行重復的、無聊的工作,而我們?nèi)祟愐床簧瞄L做這些,要么不擅長記憶這些。SparkleShare  是一種很好的、簡單的自動執(zhí)行例行數(shù)據(jù)分發(fā)的方法。但不管怎么說,這并不適合每個 Git 存儲庫。它沒有用于高級 Git  功能的接口,它沒有暫停按鈕或手動管理的操作。沒關系,因為它的使用范圍是有意限制的。SparkleShare  可以完成它計劃要做的事情,它做得很好,而且它是你無需關心的一個 Git 存儲庫。

如果你想使用這種穩(wěn)定的、看不見的自動化,請嘗試一下 SparkleShare。

到此,關于“如何用Git來共享文件”的學習就結束了,希望能夠解決大家的疑惑。理論與實踐的搭配能更好的幫助大家學習,快去試試吧!若想繼續(xù)學習更多相關知識,請繼續(xù)關注創(chuàng)新互聯(lián)網(wǎng)站,小編會繼續(xù)努力為大家?guī)砀鄬嵱玫奈恼拢?/p>

網(wǎng)站標題:如何用Git來共享文件
地址分享:http://bm7419.com/article12/iihhdc.html

成都網(wǎng)站建設公司_創(chuàng)新互聯(lián),為您提供域名注冊服務器托管、ChatGPT、定制開發(fā)、自適應網(wǎng)站、網(wǎng)站內(nèi)鏈

廣告

聲明:本網(wǎng)站發(fā)布的內(nèi)容(圖片、視頻和文字)以用戶投稿、用戶轉(zhuǎn)載內(nèi)容為主,如果涉及侵權請盡快告知,我們將會在第一時間刪除。文章觀點不代表本網(wǎng)站立場,如需處理請聯(lián)系客服。電話:028-86922220;郵箱:631063699@qq.com。內(nèi)容未經(jīng)允許不得轉(zhuǎn)載,或轉(zhuǎn)載時需注明來源: 創(chuàng)新互聯(lián)

網(wǎng)站托管運營