0
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

Claude DesktopからDocker上のMCPサーバーを使ってGithubのIssueを作成する

Last updated at Posted at 2025-04-01

はじめに

Claude DesktopからDocker上のMCPサーバーを使って、自分が管理するGithubリポジトリにIssueを作成する方法を紹介します。
例えば、Claude Desktopを使ってClaudeに「○○リポジトリに古いライブラリがあるかを調べ、Issueを作成してください。」という指示を出したとします。このとき、ClaudeはMCPサーバに接続してリポジトリ内の古いライブラリを調べ、それが存在すればIssueを作成します。このように、MCPサーバーを使ってツールを呼び出しすことでコードの実行やデータの取得を行うことができます。

参考情報

MCPとは

MCP(Model Context Protocol)は、異なるシステムやアプリケーション間でデータやコンテキストを効率的に共有するために設計された標準化されたプロトコルです。
公式サイトのドキュメントでは、以下のように説明されています:

MCP is an open protocol that standardizes how applications provide context to LLMs. Think of MCP like a USB-C port for AI applications. Just as USB-C provides a standardized way to connect your devices to various peripherals and accessories, MCP provides a standardized way to connect AI models to different data sources and tools.

アプリケーションが LLM にコンテキストを提供する方法を標準化するオープン プロトコルです。MCP は、AI アプリケーション用の USB-C ポートのようなものです。USB-C がデバイスをさまざまな周辺機器やアクセサリに接続するための標準化された方法を提供するのと同様に、MCP は AI モデルをさまざまなデータ ソースやツールに接続するための標準化された方法を提供します。

従来は、LLMと様々なツールを連携させるためには、それぞれのツールに対応したAPIを使って連携を行っていました。しかし、MCPはそれらのAPIを統一することで、LLMと様々なツールを橋渡しし容易に連携させることができるようになります。公式サイトでは、多様なAIツールやシステム間の連携を'USB-C ポート'に例えて説明しています。

MCPを使うことで、ClaudeなどのLLMがPC上のデータや外部ツールと連携し、リアルタイムで情報を処理・提供する場面などで活用が見込まれます。例えば、Claude Desktopなどのチャット上で最新情報を取得したり、ファイル検索や共有が可能になるなど、業務効率化にも寄与します。

前提条件

  • Docker Desktopがインストールされていること
    • MCPサーバーをDockerで起動するために必要です
  • 自分が管理するGithubリポジトリが存在すること
    • このリポジトリにIssueを作成するために必要です
  • Claude Desktop 0.9.0以降(この記事ではWindows版 0.9.0を使用)

Claude Desktopのセットアップ

インストール

Claude.ai公式サイトからインストーラーをダウンロードしてインストールします。

Claude Desktop

GitHubアクセストークンの作成

GithubのMCPサーバーがリポジトリにアクセスしIssueを作成するためのアクセストークンを作成します。

  1. GithubのFine-grained personal access tokensにアクセス
  2. 「Generate new token」をクリック
  3. 以下の項目を設定:
    • トークンの名前と説明
    • トークンの有効期限
    • Repository Access: All repositories(自分が管理するリポジトリすべてにアクセス可能)
    • Repository permissions:
      • Contents: Read-only
      • Issues: Read and Write
      • Metadata: Read-only(自動設定)

New Fine-grained personal access token

Repository permissions

「Generate token」をクリックすると権限の確認が表示されます。確認後、再度「Generate token」をクリックしてトークンを発行します。

重要: 発行されたトークンは一度しか表示されないため、必ずコピーして安全な場所に保存してください。

トークン発行

MCPサーバーの設定

  1. Claude Desktopを起動し、左上のハンバーガーメニューから「ファイル」→「設定」を選択
  2. 設定ウィンドウから「開発者」を選択
  3. 「構成を編集」をクリックしてエクスプローラーを開く
  4. claude_desktop_config.jsonを編集(場所: C:\Users\{ユーザー名}\AppData\Roaming\Claude\claude_desktop_config.json

以下の設定を追加します(<YOUR_TOKEN>を実際のトークンに置き換えてください):

{
  "mcpServers": {
    "github": {
      "command": "docker",
      "args": [
        "run",
        "-i",
        "--rm",
        "-e",
        "GITHUB_PERSONAL_ACCESS_TOKEN",
        "mcp/github"
      ],
      "env": {
        "GITHUB_PERSONAL_ACCESS_TOKEN": "<YOUR_TOKEN>"
      }
    }
  }
}

設定後、Claude Desktopを再起動します。メニューから終了を選択して閉じ、再度起動します。ウィンドウを閉じただけでは設定が反映されないため注意してください。

Claude Desktopを終了する

Docker Desktopの起動

MCPサーバーのコンテナを実行するため、Docker Desktopを起動します。

Docker Desktop

動作確認

Claude Desktopを起動すると、チャット画面にハンマーのアイコンが表示され、設定した権限に応じて利用可能なMCPツールが表示されます。
ハンマーアイコン

ハンマーのアイコンをクリックすると、利用可能なMCPツールが表示されます。

利用可能なMCPツール

使用例:リポジトリの分析とIssue作成

以下のような質問を試してみましょう:

revsystem/{リポジトリ名}に古いライブラリがあるかを調べてください。存在する場合はIssueを作成してください。

プロンプト実行

Claudeは最初にGithubのリポジトリを参照するツールの実行許可を求めます。

ツール実行の許可

許可を与えると、Claudeはリポジトリを分析し、古いライブラリの有無を調査します。

古いライブラリの調査

調査結果はチャット画面に表示され、必要に応じてIssueが作成されます。

調査結果

作成されたIssueの例:

GithubのIssue

なお、Claudeの分析結果は実行ごとに異なる場合があり、以下のように表形式で情報が整理されることもあります:

GithubのIssue_2

Dockerコンテナの確認

このようにDockerコンテナが起動していることを確認できます。
Docker containerが起動している

まとめ

MCPサーバーを使うことで、ノーコードでClaude DesktopからGithubのリポジトリを参照し、必要に応じてIssueを作成することができました。この機能は、Slack連携など他のMCPサーバーと組み合わせることで、より高度な自動化も可能です。例えば、Issueが作成されたときにSlackに通知を送信し、チーム全体で情報を共有するといったワークフローも実現できます。

MCPの活用により、AIアシスタントと開発ツールの連携がより簡単になり、開発者の生産性向上に貢献することが期待できます。

0
2
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
0
2

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?