17
11

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

More than 3 years have passed since last update.

SageMakerとGitHubのプライベートリポジトリを連携させる

Last updated at Posted at 2020-01-09

AI.RL.LYsのcursheyです。
今回はAmazon SageMakerとGitHubのプライベートリポジトリのGit連携をさせるのに詰まってしまったので、その時の手順を備忘録として記事にしたいと思います。大まかな手順は、

  1. GitHubの個人用アクセストークンの作成
  2. SageMakerのGitリポジトリの作成
  3. SageMakerのノートブックインスタンスの作成

となります。

GitHubの個人用アクセストークンの作成

 GitHubのプライベートリポジトリをユーザ名とパスワードを入力する必要がありますが、このパスワードは個人用アクセストークンを入力するのがベストプラクティスとして推奨されています。なので、まずはこれを作ります。なお、1年以上使われていないトークンは自動的に削除されますので注意してください。

  1. GitHubの個人アカウントにログインします。

  2. 右上の隅にあるプロフィールアイコンをクリックし、メニューから「Settings」をクリックします。
    github_settings.png

  3. 左側のサイドバーから「Developer settings」をクリックします。
    github_developer_settings.png

  4. 左側のサイドバーから「Personal access tokens」をクリックします。
    github_personal_access_token.png

  5. 「Generate new token」をクリックします。
    github_generate_new_token.png

  6. トークンに命名をします。

  7. トークンに付与する権限を選択します。特に、コマンドラインからリポジトリにアクセスする場合は「repo」を選択します
    github_token_scope.png

  8. 「Generate token」をクリックしてトークンを作成します。
    github_generate_token.png

  9. トークンが作成されます。この時、別ページに移動すると、このトークンを再確認することはできないので、必ず控えておきます

  10. 作成したトークンの「Enable SSO」をクリックし、「Authorize」をクリックします。

    10-1. トークンをアップデートした時も、「Disable SSO」をクリックし、「Authorize」をクリックする必要があります。

Gitリポジトリの作成

 ここではAmazon SageMakerコンソールに入り、Gitリポジトリを作成します。Gitリポジトリは必ずしも必要ではなく、Jupyter上のターミナルからsshキーを作成し、公開鍵をリポジトリのdeploy keyに登録することでもgit連携をすることができます。しかし、ノートブックインスタンスを落とすたびにこの操作をやり直す必要があります。また、アクセストークンは操作のスコープを決定でき、SageMakerからは実行したくない操作を制限できますのでこちらの方がおすすめです。

  1. AWS環境にログインし、SageMakerのコンソールを開きます。

  2. 左側のサイドバーから「Git リポジトリ」をクリックします。
    sagemaker_git_repository.png

  3. 「リポジトリの追加」をクリックします。
    sagemaker_add_repository.png

  4. 「GitHub または他の Git ベースのリポジトリ」を選択します。
    sagemaker_select_repository.png

  5. 「Amazon SageMaker リポジトリ名」を命名します。この命名はGitHubに作成しているリポジトリ名と一致させる必要はありませんが、アカウントおよびAWSリージョン内で一意にする必要があります。

  6. 「Git リポジトリの URL」に連携させるリポジトリのURLを入力します。このとき、URLに**.git**は付けないようにしてください。

  7. Git 認証情報を選択します。「シークレットがありません」を選択した場合、プライベートリポジトリと連携ができないので選択しないようにしてください。

    7a. 「既存のシークレットの使用」を選択した場合

     7a-1.「シークレットの検索」から使用するシークレットを探して選択します。
    

    7b. 「シークレットの作成」を選択した場合

     7b-1. 「シークレット名」を命名し、GitHubのユーザー名を「ユーザー名」、作成した個人用アクセストークンを「パスワード」にそれぞれ入力します。
    

make_secret.png

    7b-2. 「シークレットの作成」をクリックします。
  1. 「リポジトリの追加」をクリックし、Git リポジトリを作成します。
    sagemaker_make_repository.png

SageMakerの設定

ここでのGit連携に必要な操作はGitリポジトリを選択することだけですが、IAMロールの設定は必要に応じて設定するようにしてください。また、ネットワークは一度設定してしまうと後から変更できなくなりますので、制限がある場合は確認してから設定するようにしてください。

  1. AWS環境にログインし、SageMakerのコンソールを開きます。

  2. 左側のサイドバーから「ノートブックインスタンス」をクリックします。
    sagemaker_notebook_instance.png

  3. 「ノートブックインスタンスの作成」をクリックします。
    sagemaker_make_notebook.png

  4. 「ノートブックインスタンス名」を命名し、任意の「ノートブックインスタンスのタイプ」を選択します。
    sagemaker_setting.png

  5. 「アクセス許可と暗号化」は必要に応じて設定します。

  6. 「Git リポジトリ」で上記で作成したGitリポジトリを選択します。

  7. 「ノートブックインスタンスの作成」をクリックし、作成されます。

一連の手順が終わりましたらノートブックインスタンスの管理画面に戻ります。作成したノートブックインスタンスのステータスが「InService」になりましたら起動できますので、Jupyterを開いてgit連携ができているか確認しましょう。

参考

17
11
0

Register as a new user and use Qiita more conveniently

  1. You get articles that match your needs
  2. You can efficiently read back useful information
  3. You can use dark theme
What you can do with signing up
17
11

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?