Paho MQTTを用いたC SDK
本ガイドでは、MCP over MQTT C SDK with Paho MQTT を使用して、シンプルなMCP over MQTTサーバーを作成する方法を示します。現時点ではMCPサーバーのみがサポートされています。MCPクライアントを作成してやり取りを行う場合は、Python SDKをご利用ください。
MCPサーバーの作成
C SDK with Paho MQTT README の手順に従い、依存関係とSDKをインストールした後、demo_mcp_server.c というファイルを作成し、以下のコードを追加してください。
c
#include "mcp_server.h"
// 温度取得のコールバック関数
const char* get_temperature_callback(int n_args, property_t *args) {
// センサーからデータを読み取る
float temp = read_temperature_sensor();
// JSON形式の結果を返す
static char result[64];
snprintf(result, sizeof(result), "{\"temperature\": %.2f}", temp);
return result;
}
// MCPツールの定義
mcp_tool_t my_tools[] = {
{
.name = "get_temperature",
.description = "デバイスの温度を取得",
.property_count = 0,
.properties = NULL,
.call = get_temperature_callback
}
};
// MCPサーバーの初期化
mcp_server_t *server = mcp_server_init(
"sensor", // サーバー名
"Sensor MCP Server", // 説明
"mqtt://broker.example.com", // MQTTブローカーURI
"client_001", // クライアントID
"username", // ユーザー名
"password", // パスワード
NULL // 証明書(任意)
);
// ツールの登録
mcp_server_register_tool(server, 1, my_tools);
// サーバーの起動
mcp_server_run(server);Python SDKでMCPクライアントを作成・実行する
上記で作成したMCPサーバーに接続し、get_temperature ツールを呼び出すMCPクライアントの作成方法は、Python SDK のドキュメントをご参照ください。
CMakeによるMCPサーバーのビルドとコンパイル
paho-mcp-over-mqttリポジトリ にあるCMakeの例に従ってビルドを行えます。
ビルド後、生成された実行ファイルを実行してMCPサーバーを起動してください。
bash
./demo_mcp_server