11
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?

チャットでサービス連携!MCP実践編

Last updated at Posted at 2025-06-15

はじめに

基礎編は以下の記事を参照ください。

実践編ではいくつかのサービスを利用してMCPを実際に利用してみます。
利用するサービスは以下の通りです。

  • GitHub
  • AWS
  • Backlog
  • Figma

また、外部連携以外に自分でMCPサーバーを作成して利用する方法も紹介します。

動作環境

今回の実践編では、以下の環境を使用します。

  • Visual Studio Code
  • GitHub Copilot
  • Docker(なくても実行可能)

一部のMCPサーバーでは Python や Node.js などが必要になる場合がありますが、必要になったタイミングで適宜インストールしてください。

本記事ではVisual Studio Code および GitHub Copilot の導入・連携が済んでいることを前提としています。

MCPの使い方

MCPの有効化

まずはVSCodeでMCPを有効化します。

  1. VSCodeの設定を開く(Mac: Cmd + ,, Windows: Ctrl + ,)

  2. 検索バーに「mcp」と入力
    MCPの有効化

  3. 2の画面で「settings.jsonを編集」をクリックする
    ※ワークスペースのみに適用したい場合は「ワークスペース」をクリックしてから「settings.jsonを編集」をクリック
    settings.jsonに以下の設定が追加されます

    "mcp": {
      "inputs": [],
      "servers": {
        "mcp-server-time": {
          "command": "python",
          "args": [
            "-m",
            "mcp_server_time",
            "--local-timezone=America/Los_Angeles"
          ],
          "env": {}
        }
      }
    }
    

これらの設定で時刻とタイムゾーンの変換機能を提供するMCPサーバーを使えるようになります。

MCPの利用

実際に利用してみます。MCPの有効化が完了したら、以下の手順でMCPを利用できます。

  1. GitHub Copilot Chatを開いてAgentモードに切り替える

    Agentモードへの切り替え

  2. 青いリロードボタンが出たらクリックする

    リロードボタンのクリック

  3. Copilotで質問する

    mcp_server_timeを使う場合は事前にインストールが必要です。

    pip install mcp-server-time
    

    mcp_server_timeを使えそうな質問を投げてみます(例: 「東京時間午前9時30分をニューヨーク時間に変換して」)
    途中で実行許可を求められた場合は許可を与えます。常に許可やこのセッションのみなどの設定も可能です。

    convert_timeの実行許可

    MCPサーバを利用して時刻の変換ができました。

    時刻変換結果

チャット欄左下のスパナマークをクリックすることで、エージェントが利用できる機能を確認・選択でき、MCPのツールもここに表示されます。
使いたくない機能はチェックマークを外すことで無効にできます。

ツールを選択する

ツール一覧

時間変換に利用できるconvert_timeを無効にした状態で時間変換をお願いしてみるとget_current_timeだけを利用して変換するようになりました。
convert_time無効.png

MCPサーバーの起動

コマンドを利用して、サーバーへの操作(起動、停止、出力表示、構成表示)ができます。
サーバーが起動していない場合はここから起動します。

  1. コマンドパレットを開く(Mac: Cmd + Shift + P, Windows: Ctrl + Shift + P)

  2. MCP: List Serversを選択

    MCPサーバーの一覧表示

  3. 操作を行いたいサーバーを選択

    MCPサーバーの選択

  4. 行いたい操作を選択する

    サーバーアクション

外部サービスとの連携

mcp_server_timeのようにローカルで動かすタイプのMCPサーバーもあれば、設定だけで外部サービスと連携できるものもあります。
利用できるサービスについてはMCPのドキュメントを参照してください。
いくつかのサービスを実際に使ってみましょう。

利用できるツールが多すぎると一部のツールを認識できないようです。
エラーは出ないのに目的のツールが実行されない場合はツールを整理してみてください。

GitHubとの連携

リポジトリやIssueを作成する、プルリクエストをマージするなどGitHubの様々な操作が可能です。
「GitHub MCP」などで検索すると@modelcontextprotocol/server-githubが見つかりますが、こちらはmodelcontextprotocolリポジトリ内の参考実装で現在はアーカイブ済です。
GitHub公式提供のMCPサーバーが利用可能なので、そちらを使うのが良いでしょう。


今回はDockerを利用してGitHub MCPサーバーを起動します。試す場合はDockerを起動しておいてください。
Dockerを使わない場合の設定方法はこちらを参照してください。

利用にはGitHubのAPIトークンが必要です。用途に合わせてAPIに必要な権限を設定します。
今回はFine-grainedでトークンを作成して、お試し用に作成したリポジトリを指定して以下の権限を付与しています。

  • Contents: Read and Write
  • Issues: Read and Write
  • Pull requests: Read and Write
APIトークンの取得方法
  1. GitHubにログイン
  2. 右上のプロフィールアイコンをクリックし、「Settings」を選択
  3. サイドメニューから「Developer settings」を選択
  4. サイドメニューから「Personal access tokens」を展開
  5. Fine-grained tokens」「Tokens (classic)」のどちらかを選択
  6. 「Generate new token」をクリック

settings.jsonに以下の設定を追加します。inputsを入れる場所に注意してください。

{
  "mcp": {
    "inputs": [
      {
        "type": "promptString",
        "id": "github_token",
        "description": "GitHub Personal Access Token",
        "password": true
      }
    ],
    "servers": {
      "github": {
        "command": "docker",
        "args": [
          "run",
          "-i",
          "--rm",
          "-e",
          "GITHUB_PERSONAL_ACCESS_TOKEN",
          "ghcr.io/github/github-mcp-server"
        ],
        "env": {
          "GITHUB_PERSONAL_ACCESS_TOKEN": "${input:github_token}"
        }
      }
    }
  }
}

mcp-server-timeの設定がある場合は、以下のようになります。サーバーの設定はserversの中に追加していきます。

{
  "mcp": {
    "inputs": [
      {
        "type": "promptString",
        "id": "github_token",
        "description": "GitHub Personal Access Token",
        "password": true
      }
    ],
    "servers": {
      "mcp-server-time": {
        "command": "python",
        "args": [
          "-m",
          "mcp_server_time",
          "--local-timezone=America/Los_Angeles"
        ],
        "env": {}
      },
      "github": {
        "command": "docker",
        "args": [
          "run",
          "-i",
          "--rm",
          "-e",
          "GITHUB_PERSONAL_ACCESS_TOKEN",
          "ghcr.io/github/github-mcp-server"
        ],
        "env": {
          "GITHUB_PERSONAL_ACCESS_TOKEN": "${input:github_token}"
        }
      }
    }
  }
}

MCP: List Serversから"github"を選択し、サーバーを起動します。
この時にGitHubのAPIトークンを入力するよう求められるので、発行したトークンを入力しましょう。

試しにissueの追加を依頼してみます。

issue作成

作成したissue

ざっくりとした指示しか与えていませんでしたがプロンプトの意図を補完してかなり細かな内容まで作成してくれています。プロンプトに書いておけば指定のフォーマットでの作成も可能です。

同じようにプルリクエストの作成などもできるので、
issueを作る → issueを参照する → issue内容をコードに反映する → プルリクエストを作成する
という流れを全てCopilotに任せることも可能です。

AWSとの連携

自然言語によるAWSドキュメントの検索やS3の操作、コスト分析などが可能です。たくさんあるので詳細は上記リポジトリを参照してください。

今回はどれくらいのコストがかかるのかをコードから分析してもらいます。
AWS環境を構築するコードが必要なので、AWSが作成しているGenUというリポジトリをクローンしてきて参照します。

ドキュメントに記載の通りに進めます。AWS Pricing APIへのアクセス権限を持ったプロファイルが必要です。

  1. uvをインストールする

    pip install uv
    
  2. pythonをインストールする

    uv python install 3.10
    
  3. settings.jsonに以下の設定を追加する

    AWS_PROFILEは各自の環境に合わせて設定してください。
    ドキュメントにはdisabledautoApproveが設定されていますがエラーになったため削除しています。

    "awslabs.cost-analysis-mcp-server": {
      "command": "uvx",
      "args": ["awslabs.cost-analysis-mcp-server@latest"],
      "env": {
          "FASTMCP_LOG_LEVEL": "ERROR",
          "AWS_PROFILE": "your-aws-profile"
      },
    }
    

GenUのコードに対してコスト分析を試してみます。
「このプロジェクトで」のように質問することでコードからタイムアウトなどの設定を取得し、それを基にコストを分析してくれます。

コスト分析結果1

コスト分析結果2

GenUは概算料金を出しており、そこでは$0.64として試算されています。
前提条件を提示していなかったのもあり多少のズレは出ますが同じような値が出ていることがわかります。
必要に応じてプロンプトで利用想定を渡しましょう。

Backlogとの連携

主な機能は以下の通りです。利用にはAPIキーが必要です。

  • プロジェクトツール(作成、読み取り、更新、削除)
  • 課題とコメントの追跡(作成、更新、削除、一覧表示)
  • Wikiページサポート
  • Gitリポジトリとプルリクエストツール
  • 通知ツール
  • 最適化されたレスポンスのためのGraphQLスタイルのフィールド選択
  • 大規模なレスポンスに対するトークン制限

(ヌーラボブログより)

Backlog APIキーの取得方法
  1. Backlogにログイン
  2. 右上のプロフィールアイコンをクリックし、「個人設定」を選択
  3. 左側のメニューから「API」を選択
  4. 「メモ」を入力して「登録」ボタンをクリック

GitHubと同じくDockerを使用した方法で試します。settings.jsonに以下の設定を追加します。
Dockerを使わない場合の設定方法はこちらを参照してください。

your-domain.backlog.comを実際のBacklogドメインに、your-api-keyを実際のBacklog APIキーに置き換えてください。

BacklogドメインはURLのhttps://の後ろにある部分です。例えば、https://your-domain.backlog.comであればyour-domain.backlog.comがドメインになります。

"backlog": {
  "command": "docker",
  "args": [
    "run",
    "--pull", "always",
    "-i",
    "--rm",
    "-e", "BACKLOG_DOMAIN",
    "-e", "BACKLOG_API_KEY",
    "ghcr.io/nulab/backlog-mcp-server"
  ],
  "env": {
    "BACKLOG_DOMAIN": "your-domain.backlog.com",
    "BACKLOG_API_KEY": "your-api-key"
  }
}

ツールが多すぎると認識しない、という話を記事上部でしましたが、私の環境ではGitHubとBacklogの両方を入れた場合に起こりました。
同じ現象になった方は、一度GitHubサーバーの設定を削除してBacklogサーバーを再起動してからお試しください。

試しにタスクを確認してもらいましょう。

直近タスクの確認

実際のタスク内容はお見せできませんが、確認すると過不足なく拾えているようでした。

Figmaとの連携

Figmaのデザインを参照してコードを生成することができます。
こちらも利用にはAPIトークンが必要です。用途に合わせてAPIに必要な権限を設定します。

APIトークンの取得方法
  1. Figmaにログイン

  2. 右上のプロフィールアイコンをクリックし、「設定」を選択

  3. 「セキュリティ」タブを開く

  4. 「新規トークンを発行」をクリック


settings.jsonに以下の設定を追加します。YOUR-KEYには発行したトークンを入力してください。

"Framelink Figma MCP": {
  "command": "npx",
  "args": ["-y", "figma-developer-mcp", "--figma-api-key=YOUR-KEY", "--stdio"]
}

元になるデザインが必要なのであらかじめ用意しておきます。今回はデザインテンプレートをお借りしました(お借りしたのはこちら)。
もちろん自分で作成したデザインも利用可能です。
ファイルサイズが大きすぎるとタイムアウトになる場合があります。動かない場合には一度軽いファイルなどで試してみてください。

ファイルを参照してもらうにはURLを渡します。

画面作成依頼

出来上がったのが以下のページです。

作成された画面

カートアイコンの再現は難しかったようですがフォントや色、ボタンの配置などはほぼ完璧に再現できました。背景模様も全く一緒とまではいきませんが寄せようとはされています。
特に指定していませんでしたが、ログインボタンにはホバー時のアニメーションも設定されています。

自分でMCPサーバーを作成する

ここまで紹介してきた例ではサービス側で用意されたMCPサーバーを利用していましたが、使いたいサービスのMCPサーバーが公開されているとは限りません。
そういった場合には自分でMCPサーバーを作成して利用することも可能です。
試しにサイコロを振った結果を返すMCPサーバーを作成してみます。
コードはClaudeを使って作成しました。

MCPサーバーの作成

今回はTypeScriptでMCPサーバーを作成します。Pythonなどの別言語でも作成可能です。

必要なパッケージをインストールします。

npm install  @modelcontextprotocol/sdk zod

以下の内容でapp.tsファイルを作成します。ファイル名は任意です。
コードが長いので折りたたみます。

app.tsの内容
import { McpServer } from "@modelcontextprotocol/sdk/server/mcp.js";
import { StdioServerTransport } from "@modelcontextprotocol/sdk/server/stdio.js";
import { z } from "zod";

// サイコロを振る関数
function rollDice(sides: number): number {
  return Math.floor(Math.random() * sides) + 1;
}

// Create an MCP server
const server = new McpServer({
  name: "DiceRoller",
  version: "1.0.0"
});

// 1. シンプルなサイコロを振るツール
server.tool("rollSimpleDice",
  {
    sides: z.number().describe("サイコロの面数"),
    count: z.number().describe("振るサイコロの個数")
  },
  async ({ sides, count }) => {
    try {
      // サイコロを指定回数振る
      const results: number[] = [];
      for (let i = 0; i < count; i++) {
        results.push(rollDice(sides));
      }

      // 合計値を計算
      const sum = results.reduce((acc, val) => acc + val, 0);

      return {
        content: [{
          type: "text",
          text: `${results.join(", ")}(合計: ${sum})`
        }]
      };
    } catch (error) {
      return {
        content: [{ type: "text", text: `エラーが発生しました: ${error.message}` }]
      };
    }
  }
);

// 2. 目標値に対してサイコロを振るツール
server.tool("rollAgainstTarget",
  {
    sides: z.number().describe("サイコロの面数"),
    count: z.number().describe("振るサイコロの個数"),
    target: z.number().describe("成功とみなす最小値")
  },
  async ({ sides, count, target }) => {
    try {
      if (target > sides) {
        return {
          content: [{ type: "text", text: `目標値${target}${sides}面サイコロでは達成不可能です。` }]
        };
      }

      // サイコロを振る
      const results: number[] = [];
      for (let i = 0; i < count; i++) {
        results.push(rollDice(sides));
      }

      // 判定
      const success = results.some(result => result >= target);
      const resultText = count === 1 ?
        `出目: ${results[0]}${success ? "成功" : "失敗"}` :
        `出目: ${results.join(", ")}${success ? "成功" : "失敗"}`;

      return {
        content: [{ type: "text", text: resultText }]
      };
    } catch (error) {
      return {
        content: [{ type: "text", text: `エラーが発生しました: ${error.message}` }]
      };
    }
  }
);

// Start receiving messages on stdin and sending messages on stdout
const transport = new StdioServerTransport();
await server.connect(transport);

軽くコードの説明をすると、以下のような処理をしています。

  • new McpServer()
    MCPサーバーを初期化します。nameversionは任意の値を設定します
  • server.tool()
    LLMが呼び出すツールを定義します。今回であればサイコロを振った結果を返却するツールを定義しています
  • server.connect()
    標準入力からメッセージを受け取り、標準出力にメッセージを送信します

他のMCPサーバーと同じようにsettings.jsonに設定を追加します。argsには作成したapp.tsのパスを指定してください。

"DiceRoller": {
    "command": "node",
    "args": ["/your/path/to/app.ts"]
}

これでLLMは会話からサイコロの振り方を判断し、結果を返せるようになります。

複数サイコロを振る

サイコロの出目が目標値を超えるかを判定する

このように、APIを利用したMCPサーバーを自分で用意することが可能です。

まとめ

「AIが勝手にやってくれたら楽なのに」が少しだけ現実に近づくのがMCPのいいところです。
公式のサーバーもいろいろ用意されていて、導入するのもsettings.jsonの編集くらいで済むので思ったより手軽でした。
興味が湧いた方はぜひご自身でも試してみてください。

11
4
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
11
4

Delete article

Deleted articles cannot be recovered.

Draft of this article would be also deleted.

Are you sure you want to delete this article?