Simple Hosting 的 GIT 存取

先決條件

  • git 存取方式適合給那些熟悉 git 版本控制系統的人使用。 我們建議您閱讀 git 相關適用文件,以確保您能正確的使用 git 存取方式。
  • {vhost} == 創建於您的 instance 上的虛擬主機
  • {login} == 您唯一的登入方式。 這是一組由多個數字所組成的號碼,我們會在您 instance 的創建過程中,透過電子郵件的方式寄送給您。您也可以在您 instance 的管理頁面上查看。這不是您的 Gandi 帳號。這與您用來登入 sftp、管理頁面及 SSH 主控台等等是同一個登入方式 。
  • {datacenter_location} == 代表您的 instance 的資料中心位置: dc0 代表巴黎, dc1 代表巴爾的摩, dc2 代表盧森堡

您只要在 instance 的主控台頁面上,將滑鼠游標放置在 git “登入”的連結上,就可以在提示訊息內看到{vhost}{login}{datacenter_location} 的參數。

創建一個儲存庫

我們目前實施每個虛擬主機只能有一個儲存庫的機制。這裡提供您在本地機器上進行測試的小範例:

$ mkdir {vhost}
$ cd {vhost}
$ git init
$ git remote add origin ssh+git://{login}@git.{datacenter_location}.gpaas.net/{vhost}.git
$ mkdir htdocs
$ echo "Hello world" > htdocs/index.html
$ git add htdocs
$ git commit -m "first version of index.html" htdocs
$ git push origin master

一旦儲存庫創建完成,您就可以透過工具 gitweb 在您的 Simple Hosting 的管理界面上看到它。

如果這是您第一個儲存庫,您必須重新啟動您的 instance ,您才能在您 Simple Hosting 的管理界面上看到它。

htdocs 目錄

使用 PHP 的 instance, 儲存庫的根目錄並非 web 伺服器所使用的目錄,同時,為了確保您所有的檔案都可以被存取,您必須將它們都在放一個叫做 htdocs 的目錄底下,該目錄需放置於您的儲存庫根目錄底下。

複製儲存庫

您可以透過以下這個指令將您的儲存庫複製到您的本機機器上。

$ git clone ssh+git://{login}@git.{datacenter_location}.gpaas.net/{vhost}.git

佈署您的代碼

這個指令會在您的虛擬主機目錄執行 git checkout ,並佈署您的代碼。 您也可以選擇指定一個 git 物件作為標記。

$ ssh {login}@git.{datacenter_location}.gpaas.net 'deploy {vhost}.git [ {git_object} ]'

目前並不支援使用 Git 子組件

在您的虛擬主機已經存在的 “htdocs” 的目錄,必須至少具有與使用者相同的寫入權限,檔案在佈署期間才可以被置換。(比如 'chmod 644')。 這個動作在您遇到類似以下這樣的錯誤時將被執行:

錯誤: 無法分開舊的 'htdocs/sites/default/settings.php' (權限不足)

此外,您可以清理您的虛擬主機目錄。下面的指令可以在您的目錄執行一個git 清理作業。

請注意!這個指令會刪除所有未跟隨 git 的檔案!

$ ssh {login}@git.{datacenter_location}.gpaas.net 'clean {vhost}.git'

如果您要保留某些檔案或目錄,即時它們沒有跟隨 git,則您必須為它們在一個檔案裡新增一個列表,.gitignore 即放置於您儲存庫的根目錄底下。這是一個很實用的方法,舉例來說,如果您有檔案是透過您的網站所建立的。

存取方法

您可以使用您通常在使用的密碼來存取您的儲存庫(這跟您用來登入 sftp、管理頁面及 SSH 主控台等等是同一個登入密碼 ),您也可以選擇添加您的公開 SSH 金鑰到您的磁碟上 (更多 SSH 相關資訊)。

刪除儲存庫

如果您要刪除儲存庫,您可以透過 sftp 直接刪除 /lamp0/vcs/git/{vhost}.git 這個目錄(Node.js 及 Python instance 家族是 /lamp0/vcs/git/default.git)。

有關 Node.js / Python 或 Ruby instance 家族

有關這些 instance,在您的虛擬主機裡有一個單獨的目錄 default ,就好像以下這個 URL 一樣

ssh+git://{login}@git.{datacenter_location}.gpaas.net/default.git

每個佈署 (請參見佈署指令) 會自動重啟 node 流程,以便取得請求。 您的應用程式的依賴關係也將被更新。 此外,在 PHP 的 instance 就再也不需要一個類似 htdocs 的目錄了。

Windows 方面

我們近期將新增關於如何透過 Windows 使用 “msysgit” 來存取 Git 方面的文件: http://msysgit.github.com/

以下網址提供您上述之教學指南: http://guides.beanstalkapp.com/version-control/git-on-windows.html

其他相關資訊

上一次變更: 2016/05/31 10:23 (外部編輯)