{"id":3667,"date":"2026-04-23T11:13:14","date_gmt":"2026-04-23T02:13:14","guid":{"rendered":"https:\/\/persc.jp\/blog\/?p=3667"},"modified":"2026-04-23T15:29:25","modified_gmt":"2026-04-23T06:29:25","slug":"comfyui-api-guide","status":"publish","type":"post","link":"https:\/\/persc.jp\/blog\/comfyui-api-guide\/","title":{"rendered":"ComfyUI API\u5b8c\u5168\u30ac\u30a4\u30c9\uff5c\/prompt\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3067\u5b9f\u52d9\u81ea\u52d5\u5316"},"content":{"rendered":"<p>ComfyUI\uff08\u30ce\u30fc\u30c9\u3092\u3064\u306a\u3044\u3067\u753b\u50cf\u751f\u6210AI\u3092\u52d5\u304b\u3059\u30c4\u30fc\u30eb\uff09\u3092GUI\u3060\u3051\u3067\u64cd\u4f5c\u3057\u3066\u3044\u308b\u3068\u3001\u5927\u91cf\u306e\u753b\u50cf\u751f\u6210\u306b\u6642\u9593\u304c\u304b\u304b\u308a\u307e\u3059\u3002\u30d7\u30ed\u30b0\u30e9\u30e0\u304b\u3089ComfyUI API\u3092\u547c\u3073\u51fa\u305b\u3070\u3001\u6570\u767e\u679a\u30fb\u6570\u5343\u679a\u306e\u753b\u50cf\u3092\u30d0\u30c3\u30c1\u51e6\u7406\u3067\u81ea\u52d5\u751f\u6210\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>\u4e2d\u6838\u3068\u306a\u308b\u306e\u304c <code>\/prompt<\/code> \u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3067\u3059\u3002\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u306eJSON\u3092HTTP POST\u3067\u9001\u4fe1\u3057\u3001WebSocket\u3067\u9032\u6357\u3092\u76e3\u8996\u3057\u306a\u304c\u3089\u7d50\u679c\u3092\u53d6\u5f97\u3059\u308b\u6d41\u308c\u304c\u57fa\u672c\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<p>\u3053\u306e\u8a18\u4e8b\u3067\u306f\u3001ComfyUI API\u306e\u4e3b\u8981\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u306e\u5f79\u5272\u304b\u3089\u3001Python\u3084Node.js\u3067\u306e\u5b9f\u88c5\u3001<code>extra_data<\/code> \u7d4c\u7531\u306eAPI Key\u8a8d\u8a3c\u307e\u3067\u9806\u3092\u8ffd\u3063\u3066\u89e3\u8aac\u3057\u307e\u3059\u3002<\/p>\n<h2>ComfyUI API\u306e\u57fa\u672c\u69cb\u6210\u3068\u4e3b\u8981\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8<\/h2>\n<p>ComfyUI\u306f\u30ed\u30fc\u30ab\u30eb\u30b5\u30fc\u30d0\u30fc\u3068\u3057\u3066\u8d77\u52d5\u3057\u3001\u65e2\u5b9a\u3067\u306f <code>http:\/\/127.0.0.1:8188<\/code> \u3067API\u30ea\u30af\u30a8\u30b9\u30c8\u3092\u53d7\u3051\u4ed8\u3051\u307e\u3059\u3002\u30d7\u30ed\u30b0\u30e9\u30e0\u304b\u3089\u64cd\u4f5c\u3059\u308b\u5834\u9762\u3067\u62bc\u3055\u3048\u3066\u304a\u304d\u305f\u3044\u4e3b\u8981\u306a\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u306f5\u3064\u3067\u3059\u3002<\/p>\n<h3>\/prompt\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u306e\u5f79\u5272\u3068\u4ed5\u7d44\u307f<\/h3>\n<p><code>\/prompt<\/code> \u306fComfyUI API\u306e\u4e2d\u6838\u3067\u3059\u3002\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u306eJSON\uff08API\u5f62\u5f0f\uff09\u3092POST\u30ea\u30af\u30a8\u30b9\u30c8\u3067\u9001\u308b\u3068\u3001\u305d\u306e\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u304c\u5b9f\u884c\u30ad\u30e5\u30fc\u306b\u8ffd\u52a0\u3055\u308c\u307e\u3059\u3002<\/p>\n<p>\u30ea\u30af\u30a8\u30b9\u30c8\u306e\u6700\u5c0f\u5f62\u306f\u6b21\u306e\u3068\u304a\u308a\u3067\u3059\u3002<\/p>\n<pre><code class=\"language-json\">{\n  &quot;prompt&quot;: { ... },\n  &quot;client_id&quot;: &quot;\u4efb\u610f\u306eUUID&quot;,\n  &quot;extra_data&quot;: { ... }\n}\n<\/code><\/pre>\n<p><code>prompt<\/code> \u30d5\u30a3\u30fc\u30eb\u30c9\u306b\u306f\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u5168\u4f53\u306eJSON\uff08API\u5f62\u5f0f\uff09\u3092\u683c\u7d0d\u3057\u307e\u3059\u3002<code>client_id<\/code> \u306fWebSocket\u63a5\u7d9a\u3067\u9032\u6357\u3092\u81ea\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u5b9b\u306b\u30d5\u30a3\u30eb\u30bf\u3059\u308b\u305f\u3081\u306e\u8b58\u5225\u5b50\u3067\u3059\u3002<code>extra_data<\/code> \u306f\u4efb\u610f\u3067\u3059\u304c\u3001\u5f8c\u8ff0\u3059\u308bAPI Node\u5229\u7528\u6642\u306bAPI Key\u3092\u6e21\u3059\u516c\u5f0f\u30d5\u30a3\u30fc\u30eb\u30c9\u3068\u3057\u3066\u4f7f\u3044\u307e\u3059\uff082026\u5e744\u6708\u73fe\u5728\uff09\u3002<\/p>\n<p>\u9001\u4fe1\u304c\u6210\u529f\u3059\u308b\u3068\u3001\u30ec\u30b9\u30dd\u30f3\u30b9\u3067 <code>prompt_id<\/code>\uff08\u30b8\u30e7\u30d6\u306e\u4e00\u610fID\uff09\u3068 <code>number<\/code>\uff08\u30ad\u30e5\u30fc\u5185\u306e\u9806\u756a\uff09\u304c\u8fd4\u308a\u307e\u3059\u3002\u30d0\u30ea\u30c7\u30fc\u30b7\u30e7\u30f3\u30a8\u30e9\u30fc\u304c\u3042\u308c\u3070 <code>error<\/code> \u3068 <code>node_errors<\/code> \u304c\u8fd4\u308b\u305f\u3081\u3001\u30c7\u30d0\u30c3\u30b0\u306b\u3082\u5f79\u7acb\u3061\u307e\u3059\u3002<\/p>\n<h3>\/queue\u30fb\/history\u30fb\/view\u30fb\/upload\u306e\u4f7f\u3044\u5206\u3051<\/h3>\n<p>\u6b8b\u308a\u306e4\u3064\u306e\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u306f\u3001\u30b8\u30e7\u30d6\u7ba1\u7406\u30fb\u7d50\u679c\u53d6\u5f97\u30fb\u5165\u529b\u753b\u50cf\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u306b\u4f7f\u3044\u307e\u3059\u3002<\/p>\n<table>\n<thead>\n<tr>\n<th>\u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8<\/th>\n<th>\u30e1\u30bd\u30c3\u30c9<\/th>\n<th>\u7528\u9014<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td><code>\/queue<\/code><\/td>\n<td>GET<\/td>\n<td>\u5b9f\u884c\u4e2d\u30fb\u5f85\u6a5f\u4e2d\u306e\u30b8\u30e7\u30d6\u4e00\u89a7\u3092\u53d6\u5f97<\/td>\n<\/tr>\n<tr>\n<td><code>\/history\/{prompt_id}<\/code><\/td>\n<td>GET<\/td>\n<td>\u5b8c\u4e86\u30b8\u30e7\u30d6\u306e\u51fa\u529b\u30d5\u30a1\u30a4\u30eb\u60c5\u5831\u3092\u53d6\u5f97<\/td>\n<\/tr>\n<tr>\n<td><code>\/view<\/code><\/td>\n<td>GET<\/td>\n<td>\u751f\u6210\u753b\u50cf\u3092\u30d5\u30a1\u30a4\u30eb\u540d\u30fb\u30b5\u30d6\u30d5\u30a9\u30eb\u30c0\u6307\u5b9a\u3067\u30c0\u30a6\u30f3\u30ed\u30fc\u30c9<\/td>\n<\/tr>\n<tr>\n<td><code>\/upload\/image<\/code><\/td>\n<td>POST<\/td>\n<td>\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u3067\u4f7f\u3046\u5165\u529b\u753b\u50cf\u3092\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\uff08img2img\u30fbControlNet\uff08\u30b3\u30f3\u30c8\u30ed\u30fc\u30eb\u30cd\u30c3\u30c8\uff09\u7b49\u3067\u5fc5\u9808\uff09<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><code>\/prompt<\/code> \u3067\u30b8\u30e7\u30d6\u3092\u6295\u5165\u3057\u3001<code>\/history\/{prompt_id}<\/code> \u3067\u5b8c\u4e86\u3092\u78ba\u8a8d\u3057\u3066\u304b\u3089 <code>\/view<\/code> \u3067\u753b\u50cf\u3092\u53d6\u5f97\u3059\u308b\u6d41\u308c\u304c\u57fa\u672c\u30d1\u30bf\u30fc\u30f3\u3067\u3059\u3002<code>\/queue<\/code> \u306f\u30c7\u30d0\u30c3\u30b0\u6642\u306b\u30ad\u30e5\u30fc\u306e\u8a70\u307e\u308a\u5177\u5408\u3092\u78ba\u8a8d\u3059\u308b\u7528\u9014\u3067\u5f79\u7acb\u3061\u307e\u3059\u3002<\/p>\n<p>img2img \u3084 ControlNet \u306e\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u3067\u306f\u3001LoadImage\u30ce\u30fc\u30c9\u304c\u53c2\u7167\u3059\u308b\u5165\u529b\u753b\u50cf\u3092\u4e8b\u524d\u306b <code>\/upload\/image<\/code> \u3078 <code>multipart\/form-data<\/code> \u3067\u9001\u308a\u3001\u30b5\u30fc\u30d0\u30fc\u5074\u306e <code>input<\/code> \u30d5\u30a9\u30eb\u30c0\u306b\u7f6e\u304f\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002\u30a2\u30c3\u30d7\u30ed\u30fc\u30c9\u3067\u304d\u305f\u753b\u50cf\u540d\u3092\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u5074\u306eLoadImage\u5165\u529b\u306b\u5dee\u3057\u8fbc\u3081\u3070\u3001API\u7d4c\u7531\u306eimg2img\u304c\u6210\u7acb\u3057\u307e\u3059\u3002<\/p>\n<h2>\u30ef\u30fc\u30af\u30d5\u30ed\u30fcJSON\u3092API\u5f62\u5f0f\u306b\u5909\u63db\u3059\u308b\u65b9\u6cd5<\/h2>\n<p>ComfyUI\u306eGUI\u3067\u4f5c\u3063\u305f\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u3092\u3001\u305d\u306e\u307e\u307eAPI\u306b\u9001\u4fe1\u3067\u304d\u308b\u306e\u3067\u3057\u3087\u3046\u304b\u3002\u5b9f\u306f\u3001API\u5c02\u7528\u306e\u5f62\u5f0f\u306b\u5909\u63db\u3059\u308b\u5fc5\u8981\u304c\u3042\u308a\u307e\u3059\u3002<\/p>\n<p>\u624b\u9806\u306f3\u30b9\u30c6\u30c3\u30d7\u3067\u3059\uff082026\u5e744\u6708\u73fe\u5728\u306eUI\u306b\u6e96\u62e0\uff09\u3002<\/p>\n<ol>\n<li>ComfyUI\u753b\u9762\u53f3\u4e0a\u306e\u6b6f\u8eca\u30a2\u30a4\u30b3\u30f3\u304b\u3089\u8a2d\u5b9a\u3092\u958b\u304f<\/li>\n<li>\u300cEnable Dev mode Options\u300d\u306b\u30c1\u30a7\u30c3\u30af\u3092\u5165\u308c\u308b<\/li>\n<li>\u30e1\u30cb\u30e5\u30fc\u306b\u8868\u793a\u3055\u308c\u308b\u300cSave (API Format)\u300d\u3092\u30af\u30ea\u30c3\u30af<\/li>\n<\/ol>\n<p>\u901a\u5e38\u306e\u30ef\u30fc\u30af\u30d5\u30ed\u30fcJSON\u306b\u306f\u30ce\u30fc\u30c9\u306e\u5ea7\u6a19\u3084\u30b0\u30eb\u30fc\u30d7\u60c5\u5831\u306a\u3069\u3001UI\u5411\u3051\u306e\u30c7\u30fc\u30bf\u304c\u542b\u307e\u308c\u3066\u3044\u307e\u3059\u3002\u4e00\u65b9\u3001API\u5f62\u5f0f\u306eJSON\u306f\u30ce\u30fc\u30c9ID\u3092\u30ad\u30fc\u3068\u3057\u305f\u5b9f\u884c\u5c02\u7528\u306e\u69cb\u9020\u3067\u3059\u3002\u5404\u30ce\u30fc\u30c9\u306e <code>class_type<\/code>\u30fb<code>inputs<\/code> \u3060\u3051\u304c\u542b\u307e\u308c\u3001\u30ce\u30fc\u30c9\u9593\u306e\u63a5\u7d9a\u306f <code>[\"\u30ce\u30fc\u30c9ID\", \u51fa\u529b\u30b9\u30ed\u30c3\u30c8\u756a\u53f7]<\/code> \u3067\u8868\u73fe\u3055\u308c\u307e\u3059\u3002<\/p>\n<p>API\u5f62\u5f0f\u306eJSON\u3092\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u3068\u3057\u3066\u4fdd\u5b58\u3057\u3001Python\u30b9\u30af\u30ea\u30d7\u30c8\u304b\u3089\u30d7\u30ed\u30f3\u30d7\u30c8\u3084\u30b7\u30fc\u30c9\u5024\u3060\u3051\u3092\u5dee\u3057\u66ff\u3048\u308b\u904b\u7528\u304c\u3001\u518d\u5229\u7528\u6027\u3092\u9ad8\u3081\u3084\u3059\u3044\u9032\u3081\u65b9\u3067\u3059\u3002\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u5316\u3057\u3066\u304a\u3051\u3070\u3001\u540c\u3058\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u3092\u4f55\u767e\u56de\u3067\u3082\u518d\u5229\u7528\u3067\u304d\u307e\u3059\u3002<\/p>\n<h2>Python\u304b\u3089ComfyUI API\u3092\u5b9f\u884c\u3059\u308b\u624b\u9806<\/h2>\n<p>Python\u3067ComfyUI API\u3092\u64cd\u4f5c\u3059\u308b\u306b\u306f\u3001<code>requests<\/code> \u3068 <code>websocket-client<\/code> \u306e2\u3064\u306e\u30e9\u30a4\u30d6\u30e9\u30ea\u304c\u8981\u308a\u307e\u3059\u3002<\/p>\n<h3>requests + websocket-client\u306b\u3088\u308b\u57fa\u672c\u5b9f\u88c5<\/h3>\n<p>\u307e\u305a\u30a4\u30f3\u30b9\u30c8\u30fc\u30eb\u3057\u307e\u3059\u3002<\/p>\n<pre><code class=\"language-bash\">pip install requests websocket-client\n<\/code><\/pre>\n<p>\u57fa\u672c\u7684\u306a\u5b9f\u884c\u30d5\u30ed\u30fc\u306f\u4ee5\u4e0b\u306e4\u6bb5\u968e\u3067\u3059\u3002<\/p>\n<pre><code class=\"language-python\">import json\nimport uuid\nimport requests\nimport websocket\n\nSERVER = &quot;127.0.0.1:8188&quot;\nCLIENT_ID = str(uuid.uuid4())\n\n# 1. WebSocket\u63a5\u7d9a\u3092\u78ba\u7acb\uff08client_id\u3067\u81ea\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u5b9b\u306b\u30d5\u30a3\u30eb\u30bf\uff09\nws = websocket.WebSocket()\nws.connect(f&quot;ws:\/\/{SERVER}\/ws?clientId={CLIENT_ID}&quot;)\n\n# 2. \/prompt\u306b\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u3092\u9001\u4fe1\nwith open(&quot;workflow_api.json&quot;, &quot;r&quot;) as f:\n    prompt = json.load(f)\n\nres = requests.post(\n    f&quot;http:\/\/{SERVER}\/prompt&quot;,\n    json={&quot;prompt&quot;: prompt, &quot;client_id&quot;: CLIENT_ID}\n)\nprompt_id = res.json()[&quot;prompt_id&quot;]\n\n# 3. WebSocket\u3067\u5b8c\u4e86\u3092\u5f85\u6a5f\nwhile True:\n    msg = ws.recv()\n    if isinstance(msg, str):\n        data = json.loads(msg)\n        if data[&quot;type&quot;] == &quot;executing&quot;:\n            d = data[&quot;data&quot;]\n            if d[&quot;prompt_id&quot;] == prompt_id and d[&quot;node&quot;] is None:\n                break\n\n# 4. \/history\u304b\u3089\u51fa\u529b\u60c5\u5831\u3092\u53d6\u5f97\nhistory = requests.get(\n    f&quot;http:\/\/{SERVER}\/history\/{prompt_id}&quot;\n).json()\n<\/code><\/pre>\n<p>WebSocket\u30e1\u30c3\u30bb\u30fc\u30b8\u306b\u306f\u4e3b\u306b4\u7a2e\u985e\u306e <code>type<\/code> \u304c\u3042\u308a\u307e\u3059\u3002<code>status<\/code> \u306f\u30ad\u30e5\u30fc\u72b6\u614b\u3001<code>executing<\/code> \u306f\u5b9f\u884c\u4e2d\u30ce\u30fc\u30c9\u3001<code>progress<\/code> \u306f\u9577\u5c3a\u30ce\u30fc\u30c9\uff08KSampler\uff08\u753b\u50cf\u751f\u6210\u306e\u4e2d\u6838\u30ce\u30fc\u30c9\uff09\u7b49\uff09\u306e\u30b9\u30c6\u30c3\u30d7\u9032\u6357\u3001<code>executed<\/code> \u306f\u30ce\u30fc\u30c9\u5b8c\u4e86\u6642\u306e\u51fa\u529b\u60c5\u5831\u3067\u3059\u3002\u30b8\u30e7\u30d6\u5168\u4f53\u306e\u5b8c\u4e86\u5224\u5b9a\u306f <code>executing<\/code> \u306e <code>node<\/code> \u30d5\u30a3\u30fc\u30eb\u30c9\u304c <code>None<\/code> \u306b\u306a\u3063\u305f\u77ac\u9593\u304c\u6700\u3082\u78ba\u5b9f\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<p><code>client_id<\/code> \u3092\u4ed8\u4e0e\u3057\u3066\u304a\u304f\u3068\u3001\u81ea\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u5b9b\u306e\u30e1\u30c3\u30bb\u30fc\u30b8\u3060\u3051\u3092\u30b5\u30fc\u30d0\u30fc\u304c\u9001\u3063\u3066\u304f\u308c\u308b\u305f\u3081\u3001\u8907\u6570\u30af\u30e9\u30a4\u30a2\u30f3\u30c8\u3067\u540c\u3058ComfyUI\u3092\u5171\u6709\u3059\u308b\u5834\u9762\u3067\u3082\u53d6\u308a\u9055\u3048\u307e\u305b\u3093\u3002<\/p>\n<h3>\u30d0\u30c3\u30c1\u753b\u50cf\u751f\u6210\u306e\u5b9f\u88c5\u4f8b<\/h3>\n<p>CSV\u30d5\u30a1\u30a4\u30eb\u304b\u3089\u30d7\u30ed\u30f3\u30d7\u30c8\u3092\u8aad\u307f\u8fbc\u307f\u3001\u9023\u7d9a\u3067\u753b\u50cf\u3092\u751f\u6210\u3059\u308b\u5b9f\u88c5\u4f8b\u3067\u3059\u3002<\/p>\n<pre><code class=\"language-python\">import csv\nimport time\nimport copy\n\nwith open(&quot;prompts.csv&quot;, &quot;r&quot;, encoding=&quot;utf-8&quot;) as f:\n    reader = csv.DictReader(f)\n    for i, row in enumerate(reader):\n        workflow = copy.deepcopy(prompt_template)\n        # KSampler\u30ce\u30fc\u30c9\u306e\u30b7\u30fc\u30c9\u3092\u5909\u66f4\n        workflow[&quot;3&quot;][&quot;inputs&quot;][&quot;seed&quot;] = int(time.time()) + i\n        # CLIP\uff08\u30c6\u30ad\u30b9\u30c8\u3092\u6570\u5024\u5316\u3059\u308b\u51e6\u7406\uff09\u30c6\u30ad\u30b9\u30c8\u30ce\u30fc\u30c9\u306e\u30d7\u30ed\u30f3\u30d7\u30c8\u3092\u5dee\u3057\u66ff\u3048\n        workflow[&quot;6&quot;][&quot;inputs&quot;][&quot;text&quot;] = row[&quot;prompt&quot;]\n\n        res = requests.post(\n            f&quot;http:\/\/{SERVER}\/prompt&quot;,\n            json={&quot;prompt&quot;: workflow, &quot;client_id&quot;: CLIENT_ID}\n        )\n\n        if res.status_code != 200:\n            print(f&quot;\u30a8\u30e9\u30fc: \u884c{i+1} - {res.text}&quot;)\n            continue\n\n        # \u5b8c\u4e86\u3092\u5f85\u6a5f\u3057\u3066\u304b\u3089\u6b21\u306e\u30b8\u30e7\u30d6\u3078\n        wait_for_completion(ws, res.json()[&quot;prompt_id&quot;])\n        print(f&quot;\u5b8c\u4e86: {i+1}\u884c\u76ee&quot;)\n<\/code><\/pre>\n<p>\u5b9f\u52d9\u3067\u306f\u30011,000\u679a\u4ee5\u4e0a\u306e\u30d0\u30c3\u30c1\u751f\u6210\u3092\u884c\u3046\u5834\u5408\u306b\u30ea\u30c8\u30e9\u30a4\u51e6\u7406\u3092\u8ffd\u52a0\u3057\u3066\u304a\u304f\u3068\u5b89\u5fc3\u3067\u3059\u3002\u30cd\u30c3\u30c8\u30ef\u30fc\u30af\u5207\u65ad\u3084VRAM\uff08GPU\u306e\u4f5c\u696d\u30e1\u30e2\u30ea\uff09\u67af\u6e07\u3067\u5931\u6557\u3057\u305f\u884c\u3092\u8a18\u9332\u3057\u3001\u518d\u5b9f\u884c\u3067\u304d\u308b\u4ed5\u7d44\u307f\u306b\u3057\u3066\u304a\u304f\u3068\u904b\u7528\u304c\u5b89\u5b9a\u3057\u307e\u3059\u3002\u672c\u756a\u904b\u7528\u306e\u898f\u6a21\u306b\u306a\u308b\u3068\u3001<code>\/queue<\/code> \u3092\u30dd\u30fc\u30ea\u30f3\u30b0\u3057\u3066FIFO\u3067\u6295\u5165\u5236\u5fa1\u3059\u308b\u304b\u3001Redis\u3084RQ\u306a\u3069\u306e\u5916\u90e8\u30ad\u30e5\u30fc\u3092\u524d\u6bb5\u306b\u631f\u3080\u69cb\u6210\u304c\u5b9a\u756a\u3067\u3059\u3002<\/p>\n<h2>Node.js\u304b\u3089\u306e\u5b9f\u884c\u3068WebSocket\u76e3\u8996<\/h2>\n<p>Node.js\u304b\u3089ComfyUI API\u3092\u64cd\u4f5c\u3059\u308b\u5834\u5408\u3082\u3001\u57fa\u672c\u7684\u306a\u6d41\u308c\u306fPython\u3068\u540c\u3058\u3067\u3059\u3002<\/p>\n<pre><code class=\"language-javascript\">const WebSocket = require(&quot;ws&quot;);\n\nconst SERVER = &quot;127.0.0.1:8188&quot;;\nconst CLIENT_ID = crypto.randomUUID();\n\n\/\/ WebSocket\u63a5\u7d9a\nconst ws = new WebSocket(`ws:\/\/${SERVER}\/ws?clientId=${CLIENT_ID}`);\n\n\/\/ \/prompt\u306b\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u3092\u9001\u4fe1\nasync function queuePrompt(workflow) {\n  const res = await fetch(`http:\/\/${SERVER}\/prompt`, {\n    method: &quot;POST&quot;,\n    headers: { &quot;Content-Type&quot;: &quot;application\/json&quot; },\n    body: JSON.stringify({\n      prompt: workflow,\n      client_id: CLIENT_ID,\n    }),\n  });\n  return await res.json();\n}\n\n\/\/ WebSocket\u3067\u5b8c\u4e86\u3092\u76e3\u8996\nws.on(&quot;message&quot;, (data) =&gt; {\n  const msg = JSON.parse(data.toString());\n  if (msg.type === &quot;executing&quot; &amp;&amp; msg.data.node === null) {\n    console.log(&quot;\u30b8\u30e7\u30d6\u5b8c\u4e86:&quot;, msg.data.prompt_id);\n  }\n});\n<\/code><\/pre>\n<p>Python\u3068\u306e\u9055\u3044\u306f\u3001Node.js\u3067\u306f\u30a4\u30d9\u30f3\u30c8\u30c9\u30ea\u30d6\u30f3\u3067WebSocket\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u51e6\u7406\u3059\u308b\u70b9\u3067\u3059\u3002\u8907\u6570\u30b8\u30e7\u30d6\u3092\u540c\u6642\u306b\u30ad\u30e5\u30fc\u30a4\u30f3\u30b0\u3059\u308b\u5834\u5408\u306fPromise\u30d9\u30fc\u30b9\u306e\u7ba1\u7406\u304c\u9069\u3057\u3066\u3044\u307e\u3059\u3002Web\u30a2\u30d7\u30ea\u30b1\u30fc\u30b7\u30e7\u30f3\u306e\u30d0\u30c3\u30af\u30a8\u30f3\u30c9\u3068\u3057\u3066ComfyUI\u3092\u7d44\u307f\u8fbc\u3080\u5834\u5408\u306b\u306f\u3001Node.js\u306e\u307b\u3046\u304c\u89aa\u548c\u6027\u304c\u9ad8\u3044\u69cb\u6210\u306b\u306a\u308a\u307e\u3059\u3002<\/p>\n<h2>\u8a8d\u8a3c\u30fb\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u8a2d\u5b9a\u306e\u30dd\u30a4\u30f3\u30c8<\/h2>\n<p>ComfyUI API\u3092\u30cd\u30c3\u30c8\u30ef\u30fc\u30af\u7d4c\u7531\u3067\u516c\u958b\u3059\u308b\u5834\u5408\u3001\u30bb\u30ad\u30e5\u30ea\u30c6\u30a3\u5bfe\u7b56\u304c\u6b20\u304b\u305b\u307e\u305b\u3093\u3002<\/p>\n<p>\u65e2\u5b9a\u3067\u306f <code>127.0.0.1<\/code>\uff08localhost\uff09\u304b\u3089\u306e\u30a2\u30af\u30bb\u30b9\u306e\u307f\u8a31\u53ef\u3055\u308c\u3066\u3044\u307e\u3059\u3002<code>--listen 0.0.0.0<\/code> \u30aa\u30d7\u30b7\u30e7\u30f3\u3067\u5916\u90e8\u30a2\u30af\u30bb\u30b9\u3092\u958b\u653e\u3067\u304d\u307e\u3059\u304c\u3001\u8a8d\u8a3c\u306a\u3057\u306e\u72b6\u614b\u3067\u306f\u8ab0\u3067\u3082\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u3092\u5b9f\u884c\u3067\u304d\u3066\u3057\u307e\u3046\u72b6\u614b\u3067\u3059\u3002<\/p>\n<h3>security_level\u306e4\u6bb5\u968e\u3068\u63a8\u5968\u8a2d\u5b9a<\/h3>\n<p><code>config.ini<\/code> \u306e <code>security_level<\/code> \u306f\u30012026\u5e744\u6708\u73fe\u5728\u30674\u6bb5\u968e\u304c\u5b9a\u7fa9\u3055\u308c\u3066\u3044\u307e\u3059\u3002<\/p>\n<table>\n<thead>\n<tr>\n<th>\u30ec\u30d9\u30eb<\/th>\n<th>\u6982\u8981<\/th>\n<th>\u7528\u9014<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td><code>normal<\/code><\/td>\n<td>\u65e2\u5b9a\u5024\u3002LAN\u304b\u3089\u306e\u30a2\u30af\u30bb\u30b9\u306f\u62d2\u5426<\/td>\n<td>\u30ed\u30fc\u30ab\u30eb\u5358\u72ec\u5229\u7528<\/td>\n<\/tr>\n<tr>\n<td><code>normal-<\/code><\/td>\n<td>LAN\u304b\u3089\u306e\u30a2\u30af\u30bb\u30b9\u3092\u8a31\u53ef\uff08<code>--listen<\/code>\u4f7f\u7528\u6642\u306f\u3053\u306e\u5024\u4ee5\u4e0b\u304c\u5fc5\u8981\uff09<\/td>\n<td>LAN\u5171\u6709<\/td>\n<\/tr>\n<tr>\n<td><code>middle<\/code><\/td>\n<td>\u4e00\u90e8\u306e\u6a29\u9650\u30c1\u30a7\u30c3\u30af\u3092\u7de9\u548c<\/td>\n<td>\u691c\u8a3c\u74b0\u5883<\/td>\n<\/tr>\n<tr>\n<td><code>high<\/code><\/td>\n<td>\u4efb\u610f\u30d5\u30a1\u30a4\u30eb\u8aad\u307f\u66f8\u304d\u306a\u3069\u3092\u8a31\u53ef\uff08\u5371\u967a\uff09<\/td>\n<td>\u975e\u63a8\u5968<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p><code>--listen<\/code> \u3092\u6307\u5b9a\u3057\u3066\u3082LAN\u304b\u3089\u7e4b\u304c\u3089\u306a\u3044\u5834\u5408\u3001<code>security_level<\/code> \u304c <code>normal<\/code> \u306e\u307e\u307e\u306b\u306a\u3063\u3066\u3044\u308b\u30b1\u30fc\u30b9\u304c\u5927\u534a\u3067\u3059\u3002\u305d\u306e\u969b\u306f <code>normal-<\/code> \u306b\u4e0b\u3052\u308b\u3060\u3051\u3067\u89e3\u6d88\u3057\u307e\u3059\u3002<code>weak<\/code> \u3078\u306e\u5909\u66f4\u3084 <code>high<\/code> \u3067\u306e\u516c\u958b\u306f\u907f\u3051\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<h3>\u30ea\u30d0\u30fc\u30b9\u30d7\u30ed\u30ad\u30b7\u30fb\u30d5\u30a1\u30a4\u30a2\u30a6\u30a9\u30fc\u30eb\u306b\u3088\u308b\u88dc\u5f37<\/h3>\n<p>ComfyUI\u5358\u4f53\u306e\u8a8d\u8a3c\u6a5f\u80fd\u306b\u983c\u3089\u305a\u3001\u524d\u6bb5\u306bWeb\u30b5\u30fc\u30d0\u30fc\u3092\u7f6e\u304f\u69cb\u6210\u304c\u5b9f\u904b\u7528\u3067\u306f\u5b89\u5b9a\u3057\u307e\u3059\u3002<\/p>\n<table>\n<thead>\n<tr>\n<th>\u5bfe\u7b56<\/th>\n<th>\u65b9\u6cd5<\/th>\n<\/tr>\n<\/thead>\n<tbody>\n<tr>\n<td>\u30ea\u30d0\u30fc\u30b9\u30d7\u30ed\u30ad\u30b7<\/td>\n<td>nginx\u3084Caddy\u3067Basic\u8a8d\u8a3c\u30fbOAuth\u8a8d\u8a3c\u3092\u524d\u6bb5\u306b\u8ffd\u52a0<\/td>\n<\/tr>\n<tr>\n<td>\u30d5\u30a1\u30a4\u30a2\u30a6\u30a9\u30fc\u30eb<\/td>\n<td>\u7279\u5b9aIP\u30a2\u30c9\u30ec\u30b9\u306e\u307f\u30dd\u30fc\u30c88188\u3092\u8a31\u53ef<\/td>\n<\/tr>\n<tr>\n<td>VPN<\/td>\n<td>Tailscale\u7b49\u3067LAN\u76f8\u5f53\u306e\u9589\u57df\u7db2\u3092\u4f5c\u308a\u3001\u305d\u3053\u306b\u306e\u307f\u516c\u958b<\/td>\n<\/tr>\n<\/tbody>\n<\/table>\n<p>\u672c\u756a\u74b0\u5883\u3067\u306f\u3001\u30ea\u30d0\u30fc\u30b9\u30d7\u30ed\u30ad\u30b7\u3068Basic\u8a8d\u8a3c\u306e\u7d44\u307f\u5408\u308f\u305b\u304c\u6271\u3044\u3084\u3059\u3044\u69cb\u6210\u3067\u3059\u3002ComfyUI\u672c\u4f53\u306e\u66f4\u65b0\u306b\u8a8d\u8a3c\u6a5f\u80fd\u304c\u5de6\u53f3\u3055\u308c\u305a\u3001Web\u30b5\u30fc\u30d0\u30fc\u5074\u3067\u7d30\u304b\u304f\u5236\u5fa1\u3067\u304d\u308b\u305f\u3081\u3067\u3059\u3002<\/p>\n<h3>API Node\u3092\u4f7f\u3046\u5834\u5408\u306eAPI Key\u6e21\u3057\u65b9<\/h3>\n<p>2025\u5e74\u4ee5\u964d\u3001ComfyUI\u516c\u5f0f\u306eAPI Node\uff08BFL\u3084OpenAI\u7b49\u306e\u5916\u90e8API\u9023\u643a\u30ce\u30fc\u30c9\uff09\u3092\u4f7f\u3046\u5834\u9762\u3067\u306f\u3001ComfyUI Account API Key\u306e\u6307\u5b9a\u304c\u5fc5\u9808\u306b\u306a\u308a\u307e\u3057\u305f\u3002API\u304b\u3089API Node\u3092\u547c\u3073\u51fa\u3059\u5834\u5408\u3001POST\u30dc\u30c7\u30a3\u306e <code>extra_data.api_key_comfy_org<\/code> \u30d5\u30a3\u30fc\u30eb\u30c9\u306bAPI Key\u3092\u57cb\u3081\u8fbc\u3080\u65b9\u5f0f\u304c\u516c\u5f0f\u4ed5\u69d8\u3067\u3059\uff082026\u5e744\u6708\u73fe\u5728\uff09\u3002<\/p>\n<pre><code class=\"language-json\">{\n  &quot;prompt&quot;: { ... },\n  &quot;client_id&quot;: &quot;UUID&quot;,\n  &quot;extra_data&quot;: {\n    &quot;api_key_comfy_org&quot;: &quot;YOUR_API_KEY&quot;\n  }\n}\n<\/code><\/pre>\n<p>API Key\u306f <a href=\"https:\/\/platform.comfy.org\/\">platform.comfy.org<\/a> \u3067\u30ed\u30b0\u30a4\u30f3\u5f8c\u306b\u767a\u884c\u3067\u304d\u307e\u3059\uff082026\u5e744\u6708\u73fe\u5728\uff09\u3002\u30d8\u30c3\u30c9\u30ec\u30b9\u904b\u7528\u3067API Node\u3092\u4f7f\u3046\u5834\u5408\u3001\u3053\u306e\u65b9\u5f0f\u304c\u552f\u4e00\u306e\u516c\u5f0f\u30b5\u30dd\u30fc\u30c8\u3067\u3059\u3002\u65e7\u6765\u306e\u300cAPI Node\u306f\u30d5\u30ed\u30f3\u30c8\u30a8\u30f3\u30c9\u7d4c\u7531\u306e\u307f\u300d\u3068\u3044\u3046\u5236\u9650\u306f\u64a4\u5ec3\u3055\u308c\u307e\u3057\u305f\u3002<\/p>\n<h2>\u307e\u3068\u3081<\/h2>\n<p>ComfyUI API\u306f <code>\/prompt<\/code> \u30a8\u30f3\u30c9\u30dd\u30a4\u30f3\u30c8\u3092\u8ef8\u306b\u3001\u30d7\u30ed\u30b0\u30e9\u30e0\u304b\u3089\u306e\u753b\u50cf\u751f\u6210\u3092\u52b9\u7387\u5316\u3067\u304d\u307e\u3059\u3002<\/p>\n<p>\u8981\u70b9\u3092\u6574\u7406\u3057\u307e\u3059\u3002<\/p>\n<ul>\n<li><code>\/prompt<\/code> \u306bAPI\u5f62\u5f0f\u306e\u30ef\u30fc\u30af\u30d5\u30ed\u30fcJSON\u3092POST\u3057\u3001\u30b8\u30e7\u30d6\u3092\u30ad\u30e5\u30fc\u306b\u6295\u5165\u3059\u308b<\/li>\n<li>WebSocket\u63a5\u7d9a\u3067 <code>status<\/code>\u30fb<code>executing<\/code>\u30fb<code>progress<\/code>\u30fb<code>executed<\/code> \u306e4\u7a2e\u30e1\u30c3\u30bb\u30fc\u30b8\u3092\u76e3\u8996\u3057\u3001<code>\/history<\/code> \u3067\u7d50\u679c\u3092\u53d6\u5f97\u3059\u308b<\/li>\n<li>\u30ef\u30fc\u30af\u30d5\u30ed\u30fcJSON\u306f\u300cSave (API Format)\u300d\u3067\u30a8\u30af\u30b9\u30dd\u30fc\u30c8\u3057\u3001\u30c6\u30f3\u30d7\u30ec\u30fc\u30c8\u3068\u3057\u3066\u518d\u5229\u7528\u3059\u308b<\/li>\n<li>img2img\u3084ControlNet\u306f <code>\/upload\/image<\/code> \u3067\u5165\u529b\u753b\u50cf\u3092\u5148\u9001\u308a\u3057\u3066\u304b\u3089POST\u3059\u308b<\/li>\n<li>\u516c\u958b\u6642\u306f <code>security_level<\/code> \u306e\u6bb5\u968e\u9078\u5b9a\u3068\u3001\u30ea\u30d0\u30fc\u30b9\u30d7\u30ed\u30ad\u30b7\u30fbAPI Key\u8a8d\u8a3c\u306e\u7d44\u307f\u5408\u308f\u305b\u3067\u5b88\u308b<\/li>\n<\/ul>\n<p>1\u679a\u305a\u3064GUI\u3067\u751f\u6210\u3057\u3066\u3044\u305f\u4f5c\u696d\u3092\u3001API\u3067\u81ea\u52d5\u5316\u3059\u308c\u3070\u5927\u5e45\u306a\u6642\u9593\u77ed\u7e2e\u306b\u3064\u306a\u304c\u308a\u307e\u3059\u3002\u307e\u305a\u306f\u30ef\u30fc\u30af\u30d5\u30ed\u30fc\u3092API\u5f62\u5f0f\u3067\u66f8\u304d\u51fa\u3057\u3001Python\u30b9\u30af\u30ea\u30d7\u30c8\u304b\u30891\u679a\u751f\u6210\u3059\u308b\u3068\u3053\u308d\u304b\u3089\u8a66\u3057\u3066\u307f\u3066\u304f\u3060\u3055\u3044\u3002<\/p>\n<h3>\u3042\u308f\u305b\u3066\u8aad\u307f\u305f\u3044<\/h3>\n<ul>\n<li><a href=\"https:\/\/persc.jp\/blog\/comfyui-automation-guide\/\">ComfyUI\u81ea\u52d5\u5316\u30ac\u30a4\u30c9<\/a> \u2014 API\u4ee5\u5916\u306e\u30d0\u30c3\u30c1\u51e6\u7406\u3084CLI\u5b9f\u884c\u3082\u542b\u3080\u81ea\u52d5\u5316\u624b\u6cd5\u306e\u5168\u4f53\u50cf\u3092\u62bc\u3055\u3048\u305f\u3044\u65b9\u5411\u3051<\/li>\n<li><a href=\"https:\/\/persc.jp\/blog\/comfyui-headless-cli\/\">ComfyUI\u30d8\u30c3\u30c9\u30ec\u30b9\u30fbCLI\u5b9f\u884c\u30ac\u30a4\u30c9<\/a> \u2014 GUI\u3092\u4f7f\u308f\u305a\u30b3\u30de\u30f3\u30c9\u30e9\u30a4\u30f3\u304b\u3089\u5b9f\u884c\u3059\u308b\u65b9\u6cd5\u3068\u672c\u8a18\u4e8b\u306e\u4f7f\u3044\u5206\u3051\u3092\u78ba\u8a8d\u3057\u305f\u3044\u65b9\u5411\u3051<\/li>\n<li><a href=\"https:\/\/persc.jp\/blog\/comfyui-folder-watch\/\">ComfyUI\u30d5\u30a9\u30eb\u30c0\u76e3\u8996\u3067\u81ea\u52d5\u5b9f\u884c\u3059\u308b\u65b9\u6cd5<\/a> \u2014 \u30d5\u30a1\u30a4\u30eb\u30c9\u30ed\u30c3\u30d7\u3092\u30c8\u30ea\u30ac\u30fc\u306b\u81ea\u52d5\u5b9f\u884c\u3059\u308b\u4ed5\u7d44\u307f\u3092\u5b66\u3073\u305f\u3044\u65b9\u5411\u3051<\/li>\n<li><a href=\"https:\/\/persc.jp\/blog\/comfyui-docker-cloud-gpu\/\">ComfyUI Docker\u30fb\u30af\u30e9\u30a6\u30c9GPU\u6d3b\u7528\u30ac\u30a4\u30c9<\/a> \u2014 API\u5b9f\u884c\u74b0\u5883\u3092Docker\u3067\u69cb\u7bc9\u3057\u30af\u30e9\u30a6\u30c9GPU\u306b\u30c7\u30d7\u30ed\u30a4\u3057\u305f\u3044\u65b9\u5411\u3051<\/li>\n<\/ul>\n","protected":false},"excerpt":{"rendered":"<p>ComfyUI\uff08\u30ce\u30fc\u30c9\u3092\u3064\u306a\u3044\u3067\u753b\u50cf\u751f\u6210AI\u3092\u52d5\u304b\u3059\u30c4\u30fc\u30eb\uff09\u3092GUI\u3060\u3051\u3067\u64cd\u4f5c\u3057\u3066\u3044\u308b\u3068\u3001\u5927\u91cf\u306e\u753b\u50cf\u751f\u6210\u306b\u6642\u9593\u304c\u304b\u304b\u308a\u307e\u3059\u3002\u30d7\u30ed\u30b0\u30e9\u30e0\u304b\u3089ComfyUI API\u3092\u547c\u3073\u51fa\u305b\u3070\u3001\u6570\u767e\u679a\u30fb\u6570\u5343\u679a\u306e\u753b\u50cf\u3092\u30d0\u30c3\u30c1\u51e6\u7406\u3067\u81ea\u52d5\u751f\u6210\u3067\u304d [&hellip;]<\/p>\n","protected":false},"author":2,"featured_media":0,"comment_status":"open","ping_status":"open","sticky":false,"template":"","format":"standard","meta":{"_acf_changed":false,"inline_featured_image":false,"swell_btn_cv_data":"","footnotes":""},"categories":[112,114,113],"tags":[],"class_list":["post-3667","post","type-post","status-publish","format-standard","hentry","category-ai-architect","category-comfyui-ai-architect","category-service-ai-architect"],"acf":[],"_links":{"self":[{"href":"https:\/\/persc.jp\/blog\/wp-json\/wp\/v2\/posts\/3667","targetHints":{"allow":["GET"]}}],"collection":[{"href":"https:\/\/persc.jp\/blog\/wp-json\/wp\/v2\/posts"}],"about":[{"href":"https:\/\/persc.jp\/blog\/wp-json\/wp\/v2\/types\/post"}],"author":[{"embeddable":true,"href":"https:\/\/persc.jp\/blog\/wp-json\/wp\/v2\/users\/2"}],"replies":[{"embeddable":true,"href":"https:\/\/persc.jp\/blog\/wp-json\/wp\/v2\/comments?post=3667"}],"version-history":[{"count":2,"href":"https:\/\/persc.jp\/blog\/wp-json\/wp\/v2\/posts\/3667\/revisions"}],"predecessor-version":[{"id":4564,"href":"https:\/\/persc.jp\/blog\/wp-json\/wp\/v2\/posts\/3667\/revisions\/4564"}],"wp:attachment":[{"href":"https:\/\/persc.jp\/blog\/wp-json\/wp\/v2\/media?parent=3667"}],"wp:term":[{"taxonomy":"category","embeddable":true,"href":"https:\/\/persc.jp\/blog\/wp-json\/wp\/v2\/categories?post=3667"},{"taxonomy":"post_tag","embeddable":true,"href":"https:\/\/persc.jp\/blog\/wp-json\/wp\/v2\/tags?post=3667"}],"curies":[{"name":"wp","href":"https:\/\/api.w.org\/{rel}","templated":true}]}}