目的
- レガシーな環境でもGitによるバージョン管理を行いたくてUbuntuPCにGitのサーバを立てた時の手順をまとめる
今回使用したもの
- Linux(Ubuntu16.04)のPC2台
- Linuxマシンにリモートからコマンドを送ることのできるターミナルエミュレータ(tertermなど)が入ったWindowsマシン
皆さんが実施する上で最低限で必要なもの
- Linux(Ubuntu)PC: 2台
- Linuxマシンが用意できないけどGitを勉強したい方はこちら
実施条件
- LinuxPCはOSインストールが完了していること。
- LinuxPCの管理者権限がある(sudoコマンドが実行できる)こと。
実施方法概要
- 準備
- リモートリポジトリの作成
- SSH鍵作成と登録
- clone
実施方法詳細
-
準備
-
2台あるLinuxPCからGitサーバとして使用するPCとクライアントPCを決める。
-
git-userユーザの作成
-
GitサーバPCのsudoコマンドが実行できるユーザで下記コマンドを実行してgit-userというユーザを作成する。
$ sudo adduser git-user >Enter new UNIX password: 任意のgit-userのパスワード入力後Enter >Retype new UNIX password: 先に入力した任意のgit-userのパスワード入力後Enter >Full Name[]: 空欄でEnter >Room Number[]: 空欄でEnter >Work Phone[]: 空欄でEnter >Home Phone[]: 空欄でEnter >Other[]: 空欄でEnter >Is the information correct? [Y/n] Yを入力してEnter
-
-
GitサーバPCのsudoコマンドが実行できるユーザで下記コマンドを実行してgit-userユーザでもsudoコマンドが実行できるようにする。
$ sudo gpasswd -a git-user sudo >Adding user git-user to group sudo
-
GitサーバPCのgit-userユーザで下記コマンドを実行してGitをインストールする。
$ sudo apt update $ sudo apt install git $ git --version >git version 2.X.X
-
GitサーバPCのgit-userユーザで下記コマンドを実行して認証情報を自動保存するように設定を変更する。
$ git config --global credential.helper cache
-
GitサーバPCのgit-userユーザで下記コマンドを実行して日本語ファイルでも文字化けしないようにする。
$ git config --global core.quotepath false
-
GitサーバPCのgit-userユーザで下記コマンドを実行して
-
GitサーバPCのgit-userユーザで下記コマンドを実行してsshをインストールする。
$ sudo apt install ssh
-
GitサーバPCのIPアドレス、git-userユーザのパスワードを確認する。
-
クライアントPCの任意のユーザで下記コマンドを実行してGitをインストールする。
$ sudo apt update $ sudo apt install git $ git --version >git version 2.X.X
-
クライアントPCの任意のユーザで下記コマンドを実行して認証情報を自動保存するように設定を変更する。
$ git config --global credential.helper cache
-
クライアントPCの特定のユーザでで下記コマンドを実行して日本語ファイルでも文字化けしないようにする。
$ git config --global core.quotepath false
-
クライアントPCの特定のユーザでで下記コマンドを実行してユーザとメールアドレスを設定する。
$ git config --global user.email "任意のメールアドレス" $ git config --global user.name "任意のユーザ名"
-
クライアントPCの特定のユーザで下記コマンドを実行してsshをインストールする。
$ sudo apt install ssh
-
-
リモートリポジトリの作成
-
GitサーバPCのgit-userユーザで下記コマンドを実行してリモートリポジトリを格納しておくディレクトリを作成する。
$ mkdir ~/remote_repository
-
GitサーバPCのgit-userユーザで下記コマンドを実行してtestという名前のリモートリポジトリを作成する。(外部からのpushを許容するため、共有リポジトリとして使用するために--bareをつけて実行する。)
$ mkdir -p ~/remote_repository/test $ cd ~/remote_repository/test $ git init --bare >Initalized empty Git repository in /home/git-user/remoterepository/test/.git
-
-
SSH鍵作成と登録
-
GitサーバPCのgit-userユーザで下記コマンドを実行してリモート役PCにローカル役PCのSSH鍵を登録しておくファイルを作成する。
$ mkdir ~/.ssh $ touch ~/.ssh/authorized_keys
-
クライアントPCの特定のユーザでで下記コマンドを実行してSSH鍵を発行する。(質問は初回鍵発行なら全て空欄でEnterを押下する。下記の問いは初回時)
$ ssh-keygen -t rsa >Enter file in which to save the key (/home/ユーザ名/.ssh/id_rsa): 空欄でEnter >Created directory '/home/ユーザ名/.ssh'. 空欄でEnter >Enter passphrase (empty for no passphrase): 空欄でEnter
-
>Enter same passphrase again: 空欄でEnter
```
1. クライアントPCの特定のユーザで下記コマンドを実行してSSH公開鍵を表示、コピーする。
```terminal
$ cat ~/.ssh/id_rsa.pub
>ここに出力された内容を語尾のユーザ名@PC名まで含めて全てコピーする
```
1. 先にコピーしたクライアントPCのSSH公開鍵をGitサーバPCのauthorized_keysに記載する。
1. GitサーバPCのgit-userで下記コマンドを実行する。
```terminal
$ echo "先にコピーしたクライアントPCのSSH公開鍵" >> ~/.ssh/authorized_keys
```
-
clone
-
クライアントPCの特定のユーザで下記コマンドを実行してcloneのテストを行う。
$ cd $ git clone ssh://git-use@GitサーバPCのIPアドレス/home/git-user/remote_repository/test >Are you sure you want to continue connecting (yes/no)? yesと入力しEnter >warning: You appear to have clone an empty repository.
-
-
commitとpush
-
クライアントPCの特定のユーザで下記コマンドを実行して
readme.md
ファイルをcommitとpushしてみる。$ cd ~/test $ git commit --allow-empty -m "First commit" $ git push origin master
-
cloneをちょっとだけ楽にしよう
-
cloneを行う時にGitサーバPCのユーザ情報とIPアドレスを打ち込むのは面倒である。
-
SSHのconfigファイルに予めGitサーバPCの情報を記入しておくことでその手間が省ける。
-
下記にクライアントPCのSSHのconfigファイルに情報を記載する方法をまとめる
-
クライアントPCの特定のユーザで下記コマンドを実行しSSHのconfigファイルを修正する。
$ vi ~/.ssh/config
-
下記の内容を開いたconfigファイルに追記する。(host名がこの設定を呼び出す際の識別子になる、お好みの名前を設定して良い。今回は認識しやすいようにGitサーバPCのユーザ名にした)
host git-user user git-user hostname GitサーバPCのIPアドレス identityfile ~/.ssh/id_rsa
データ名 入力データ host ホスト名(任意のものでOK) user 接続先PCのユーザ名 hostname 接続先PCのIPアドレス indentityfile SSH接続に使用するSSH鍵までのフルパス
-
-
SSHのconfigファイルにGitサーバPCの情報が記載されている場合、クライアントPCでcloneするコマンドは下記のようになる。(host名がgit-userの場合)
$ git clone ssh://git-user/home/git-user/remote_repository/test/.git