はじめに
前回の記事の続きで、SourcetreeからGitHubへコードをアップ(push)する手順をまとめてみました。
通常はどなたかが作ったリポジトリをローカルにコピー(Clone)するところからスタートすることが多いそうですが、今回はゼロから始める方法となります。
事前準備
以下の作業を事前に済ませておきます。
- GitHubのアカウントを作成する。
オプションの設定
- Sourcetreeを開いた後、[ツール]>[オプション]と進み、オプション設定画面を開きます。
- オプション設定画面で、フルネームとメールアドレスを入力して[OK]を押します。
ローカルリポジトリの作成
- [+Create]を押して、リポジトリ作成画面を開きます。
- リポジトリのフォルダパスと、使用するバージョン管理システム(※ここではGit)を指定して、[作成]を押します。
- ここでは、リポジトリのフォルダ名と同じ「test」がリポジトリ名となります。
- リポジトリの作成が完了すると、リポジトリのタブが表示されます。
- ここまでで作成したリポジトリは、自分のマシン内に作られる「ローカルリポジトリ」となります。
インデックスへの追加
- 以下のコードをHello.javaという名前のファイルとして、testフォルダ(D:\workspace\test)内に保管します。
Hello.java
public class Hello {
public static void main(String[] args) {
System.out.println("Hello, " + args[0] + "!");
}
}
- testフォルダにHello.javaを置くと、Sourcetreeの画面が自動的にリフレッシュされて、以下のように5パネルの画面になります。
パネルの位置 | パネル名 | 説明 |
---|---|---|
左 | メニューが表示されます。 | |
中央下 | 作業ツリーのファイル | ローカルリポジトリ内にあるすべてのファイルが表示されます。 |
中央上 | Indexにステージしたファイル | インデックスに追加された、コミット対象のファイルが表示されます。 |
右 | 選択中のファイルの中身がプレビューされます。 | |
下 | コミットに関する操作をするパネルです。 |
- ここで、変更のあったファイルを選択して、[選択をインデックスに追加]を押します。
- インデックスに追加する操作は、Subversionだと「当該ファイルをSubversionの管理下に置く(add)」と似ています。
- ですが、Subversionのaddが最初の1回きりなのに対して、Gitの場合はファイルに変更が発生する度にインデックスへ追加する必要があります。
- この点については、SubversionユーザがGitを使った時に勘違いした5つのことにも書かれています。
- Hello.javaがインデックスに追加されると、以下のような表示に変わります。
- 右のパネルで[+]となっている緑色の行が今回追加された行で、[-]となっている赤色の行が今回削除された行となります。
コミット
- インデックスに追加されたファイルの内容に問題が無ければ、コミットメッセージを記入した上で、[コミット]を押して(ローカル)リポジトリにコミットして変更内容を記録します。
- コミットメッセージに適切な変更内容を記入しておかないと、後で何の変更があったのかが分からなくなってしまいます。
- CVSやSubversionも同じですが、様々な変更を1回のコミットで済ませるのではなく、コミットを適切なサイズ(粒度)に保たないと変更内容が分からなくなってしまいます。
- Gitはローカル/リモートの2つにリポジトリが分かれているので、ローカルリポジトリへコミットしただけではリモートリポジトリには反映されません。
- CVSやSubversionだとリポジトリが1個なので、CVSやSubversionに慣れている人だと、ここまでの操作で何となく「終わった感」を感じてしまいますが...
リモートリポジトリの作成
- GitHubで[Repositories]タブを開いて、[New]ボタンを押してリポジトリを追加します。
- リポジトリのオーナー名とリポジトリ名を合わせてFQDNにする都合上、リポジトリ名のチェックが入ります。
- ここで指定したオーナー名とリポジトリ名は、後でSourcetree側で設定する際に使います。
- なお、今回はリモートリポジトリを[Public]で作成しました。
- 業務用の場合は[Private]にした方が良いと思いますが、無料で使うにはユーザー数などの制限があるそうです。
リモートリポジトリへpush
- 左側のパネルで[history]を選んで、history画面を開いた後、画面右上の[設定]を押します。
- 開いた設定画面で[リモート]タブを選択した後、[追加]ボタンを押してリモートリポジトリの情報を入力します。
- リモートの詳細設定画面で、リモートリポジトリの情報を設定します。
- リモート名は、リモートリポジトリ名となります。
- URLパスは、
https://github.com/{リポジトリのオーナー名}/{リモートリポジトリ名}.git
とします。 - 認証にSSHキーを使用する場合は、
git@github.com:{リポジトリのオーナー名}/{リモートリポジトリ名}.git
とします。
- 再びhistoryの画面へ戻り、画面左上の[プッシュ]ボタンを押します。
- [対象]にチェックを入れると、自動的にリモートブランチがmasterにセットされます。
- この状態で[プッシュ]を押すと、リモートリポジトリのプッシュが完了します。
- GitHubのリポジトリの画面を更新すると、プッシュされたファイルが見られるはずです。
備考
2021/08/14にGitHubへPushしようとしたところ、以下のエラーメッセージが出ました。
Support for password authentication was removed on August 13, 2021. Please use a personal access token instead.
このエラーを見る限り、パスワードによる認証は前日の2021/08/13にサポート終了になったようです。
参考URL
- SourceTreeでリモートリポジトリ(GitHub)にプッシュするための設定方法
- SSHキーを使う場合は、こちらの記事が参考になると思います。