Gitは、バージョン管理システムとして基本的な操作(clonecommitpushpull)を習得するだけでも大いに役立ちますが、さらに進んだ使い方を覚えることで、複雑なプロジェクトやコラボレーション作業でも効率よく対応できます。このブログでは、Gitの高度な使い方やテクニックをいくつかご紹介します。


1. インタラクティブな rebase

リベース(rebase)は、コミット履歴を整えるための非常に便利なツールです。
特にgit rebase -i(インタラクティブリベース)は、以下の操作を可能にします:

  • コミットの編集
    古いコミットメッセージの変更や、誤ったコードを修正できます。
  • コミットのマージ(squash)
    複数の小さなコミットを一つにまとめて履歴をすっきりさせます。
  • コミットの削除
    不要なコミットを取り除くことができます。

使用例:

git rebase -i HEAD~3

上記コマンドは直近3つのコミットを対象にリベースを開始します。
エディタが開き、操作対象のコミットを編集できます。


2. スタッシュで作業を一時保存

複数の作業を並行して行う必要がある場合、未完了の作業状態を「スタッシュ」に保存できます。
これにより、作業内容を一時的に保存し、ブランチ切り替えや他のタスクに取り掛かることが可能です。

使用例:

git stash         # 現在の作業内容をスタッシュに保存
git stash list    # スタッシュの一覧を表示
git stash apply   # スタッシュを適用
git stash drop    # スタッシュを削除

3. git cherry-pick:特定のコミットだけを適用

他のブランチにある特定のコミットだけを現在のブランチに適用する場合、git cherry-pickが便利です。
例えば、バグ修正コミットだけを取り込みたい場合に使用できます。

使用例:

git cherry-pick <コミットハッシュ>

4. 複雑なマージの解決

Gitを使っていると、時折、マージコンフリクトが発生します。以下のコマンドでマージコンフリクトを
効率よく解決しましょう:

使用例:

git merge <branch_name>

# コンフリクトが発生したら
git status  # どのファイルでコンフリクトが発生したか確認

# コンフリクト解消後
git add <file_name>  # 解消したファイルをステージに追加
git merge --continue # マージを続行

5. ログを活用して履歴を解析

Gitのlogコマンドは履歴の確認だけでなく、詳細な解析にも役立ちます。以下のオプションを活用すると便利です:

  • グラフ形式で表示 git log --oneline --graph --all 履歴を簡潔に見やすく表示します。
  • 特定ファイルの変更履歴を確認 git log -p <file_name>
  • 特定のコミットや時期を検索 git log --since="2 weeks ago" git log --author="Your Name"

6. Gitフックで自動化を強化

Gitフックを活用すれば、特定の操作(例:コミットやプッシュ)の前後に自動でスクリプトを実行できます。これにより、コード品質を担保したり、ルール違反を防ぐことが可能です。

使用例:

  • コミット時にテストを実行 .git/hooks/pre-commitにスクリプトを追加します。
#!/bin/bash
make test
if [ $? -ne 0 ]; then
    echo "テスト失敗!コミットを中止します。" exit 1
fi

7. サブモジュール(Submodules)の利用

プロジェクト内で別のGitリポジトリを参照したい場合、サブモジュールを活用できます。例えば、大規模プロジェクトで外部ライブラリを分離して管理する場合に便利です。

使用例:

git submodule add <リポジトリURL>
git submodule update --init --recursive

8. 安全なリポジトリクリーンアップ

不要なファイルや履歴を削除する際、慎重に行う必要があります。以下のコマンドで安全に操作しましょう:

  • ローカルの古いブランチを削除 git branch --merged | grep -v "\*" | xargs -n 1 git branch -d
  • 未使用のオブジェクトを削除してリポジトリサイズを削減 git gc --prune=now --aggressive

まとめ

Gitを深く使いこなすことで、コード管理の効率とチームワークが大幅に向上します。今回紹介したテクニックを活用し、日々の開発をさらに快適にしましょう! Gitの知識は経験とともに深まりますので、まずは使いながら習得を進めてください。

参考サイト

https://kinsta.com/jp/blog/advanced-git/

ほかのブログ

ReactのVirtual DOMとは?その仕組みとメリットを解説