StarRocks MCP Server
ทางการโต้ตอบกับ StarRocks
เอกสาร
เซิร์ฟเวอร์ MCP อย่างเป็นทางการของ StarRocks
เซิร์ฟเวอร์ StarRocks MCP ทำหน้าที่เป็นสะพานเชื่อมระหว่างผู้ช่วย AI และฐานข้อมูล StarRocks ช่วยให้สามารถดำเนินการ SQL โดยตรง สำรวจฐานข้อมูล แสดงภาพข้อมูลผ่านแผนภูมิ และเรียกดูภาพรวมของ schema/ข้อมูลโดยละเอียด โดยไม่ต้องตั้งค่าฝั่งไคลเอ็นต์ที่ซับซ้อน
คุณสมบัติ
- การดำเนินการ SQL โดยตรง: รันคำสั่ง
SELECT(read_query) และคำสั่ง DDL/DML (write_query) - การสำรวจฐานข้อมูล: แสดงรายการฐานข้อมูลและตาราง เรียกดู schema ของตาราง (ทรัพยากร
starrocks://) - ข้อมูลระบบ: เข้าถึงเมตริกและสถานะภายในของ StarRocks ผ่านเส้นทางทรัพยากร
proc:// - ภาพรวมโดยละเอียด: รับสรุปที่ครอบคลุมของตาราง (
table_overview) หรือฐานข้อมูลทั้งหมด (db_overview) รวมถึงคำจำกัดความของคอลัมน์ จำนวนแถว และข้อมูลตัวอย่าง - การแสดงภาพข้อมูล: ดำเนินการคิวรีและสร้างแผนภูมิ Plotly โดยตรงจากผลลัพธ์ (
query_and_plotly_chart) - แคชอัจฉริยะ: ภาพรวมของตารางและฐานข้อมูลถูกแคชในหน่วยความจำเพื่อเพิ่มความเร็วในการร้องขอซ้ำ สามารถข้ามแคชได้เมื่อจำเป็น
- การกำหนดค่าที่ยืดหยุ่น: ตั้งค่ารายละเอียดการเชื่อมต่อและพฤติกรรมผ่านตัวแปรสภาพแวดล้อม
ข้อกำหนดเบื้องต้น
- Python 3.11 หรือใหม่กว่า
- คลัสเตอร์ StarRocks ที่เข้าถึงได้ (บริการ FE) โดยค่าเริ่มต้นเซิร์ฟเวอร์จะเชื่อมต่อกับ
localhost:9030ผ่านโปรโตคอล MySQL uv— เครื่องมือจัดการแพ็คเกจและโปรเจกต์ Python ที่รวดเร็ว (ตัวแทนสมัยใหม่ของpip+virtualenv) จาก Astral โปรเจกต์นี้ใช้uvเพื่อแก้ไขการพึ่งพา สร้างสภาพแวดล้อมเสมือน และเปิดใช้เซิร์ฟเวอร์ คำสั่งuv runตลอด README นี้จะสร้างสภาพแวดล้อมแบบแยกและติดตั้งการพึ่งพาที่จำเป็นโดยอัตโนมัติเมื่อใช้งานครั้งแรก ดังนั้นจึงไม่จำเป็นต้องมีขั้นตอนpip installด้วยตนเอง
การติดตั้ง uv
# macOS / Linux
curl -LsSf https://astral.sh/uv/install.sh | sh
# Windows (PowerShell)
powershell -ExecutionPolicy ByPass -c "irm https://astral.sh/uv/install.ps1 | iex"
# Or via Homebrew / pipx / pip
brew install uv
# pipx install uv
# pip install uv
ดู คู่มือการติดตั้ง uv อย่างเป็นทางการ สำหรับตัวเลือกอื่นๆ หลังจากติดตั้งแล้ว ตรวจสอบว่าอยู่ใน PATH ของคุณ:
uv --version
การติดตั้ง
โดยทั่วไปคุณไม่จำเป็นต้องติดตั้งแพ็คเกจด้วยตนเอง — โฮสต์ MCP จะเปิดใช้ผ่าน uv (ดู การกำหนดค่า ด้านล่าง) uv จะดึงแพ็คเกจและการพึ่งพาตามต้องการ
หากต้องการรันโดยตรงเพื่อการทดสอบหรือพัฒนา:
# Run the published package in a throwaway environment
uv run --with mcp-server-starrocks mcp-server-starrocks --help
# Or, from a local checkout of this repository
git clone https://github.com/starrocks/mcp-server-starrocks.git
cd mcp-server-starrocks
uv sync # create the virtual environment and install dependencies
uv run mcp-server-starrocks --help
การกำหนดค่า
โดยทั่วไปเซิร์ฟเวอร์ MCP จะทำงานผ่านโฮสต์ MCP การกำหนดค่าจะถูกส่งไปยังโฮสต์ โดยระบุวิธีการเปิดใช้กระบวนการเซิร์ฟเวอร์ StarRocks MCP
การใช้ Streamable HTTP (แนะนำ):
เพื่อเริ่มเซิร์ฟเวอร์ในโหมด Streamable HTTP:
ขั้นแรกทดสอบว่าการเชื่อมต่อกับ StarRocks ใช้ได้ (9030 คือพอร์ตโปรโตคอล MySQL ของ StarRocks ไม่ใช่พอร์ตเซิร์ฟเวอร์ HTTP):
$ STARROCKS_URL=root:@localhost:9030 uv run mcp-server-starrocks --test
เริ่มเซิร์ฟเวอร์:
uv run mcp-server-starrocks --mode streamable-http --port 8000
จากนั้นกำหนดค่า MCP ดังนี้:
{
"mcpServers": {
"mcp-server-starrocks": {
"url": "http://localhost:8000/mcp"
}
}
}
การใช้ uv กับแพ็คเกจที่ติดตั้ง (ตัวแปรสภาพแวดล้อมแยก):
{
"mcpServers": {
"mcp-server-starrocks": {
"command": "uv",
"args": ["run", "--with", "mcp-server-starrocks", "mcp-server-starrocks"],
"env": {
"STARROCKS_HOST": "default localhost",
"STARROCKS_PORT": "default 9030",
"STARROCKS_USER": "default root",
"STARROCKS_PASSWORD": "default empty",
"STARROCKS_DB": "default empty"
}
}
}
}
การใช้ uv กับแพ็คเกจที่ติดตั้ง (URL การเชื่อมต่อ):
{
"mcpServers": {
"mcp-server-starrocks": {
"command": "uv",
"args": ["run", "--with", "mcp-server-starrocks", "mcp-server-starrocks"],
"env": {
"STARROCKS_URL": "root:password@localhost:9030/my_database"
}
}
}
}
การใช้ uv กับไดเรกทอรีในเครื่อง (สำหรับการพัฒนา):
{
"mcpServers": {
"mcp-server-starrocks": {
"command": "uv",
"args": [
"--directory",
"path/to/mcp-server-starrocks", // <-- Update this path
"run",
"mcp-server-starrocks"
],
"env": {
"STARROCKS_HOST": "default localhost",
"STARROCKS_PORT": "default 9030",
"STARROCKS_USER": "default root",
"STARROCKS_PASSWORD": "default empty",
"STARROCKS_DB": "default empty"
}
}
}
}
การใช้ uv กับไดเรกทอรีในเครื่องและ URL การเชื่อมต่อ:
{
"mcpServers": {
"mcp-server-starrocks": {
"command": "uv",
"args": [
"--directory",
"path/to/mcp-server-starrocks", // <-- Update this path
"run",
"mcp-server-starrocks"
],
"env": {
"STARROCKS_URL": "root:password@localhost:9030/my_database"
}
}
}
}
อาร์กิวเมนต์บรรทัดคำสั่ง:
เซิร์ฟเวอร์รองรับอาร์กิวเมนต์บรรทัดคำสั่งต่อไปนี้:
uv run mcp-server-starrocks --help
--mode {stdio,sse,http,streamable-http}: โหมดการขนส่ง (ค่าเริ่มต้น: stdio หรือตัวแปรสภาพแวดล้อม MCP_TRANSPORT_MODE)--host HOST: โฮสต์เซิร์ฟเวอร์สำหรับโหมด HTTP (ค่าเริ่มต้น: localhost)--port PORT: พอร์ตเซิร์ฟเวอร์สำหรับโหมด HTTP--test: รันในโหมดทดสอบเพื่อตรวจสอบฟังก์ชันการทำงาน
ตัวอย่าง:
# Start in streamable HTTP mode on custom host/port
uv run mcp-server-starrocks --mode streamable-http --host 0.0.0.0 --port 8080
# Start in stdio mode (default)
uv run mcp-server-starrocks --mode stdio
# Run test mode
uv run mcp-server-starrocks --test
- ฟิลด์
urlควรชี้ไปยังปลายทาง Streamable HTTP ของเซิร์ฟเวอร์ MCP ของคุณ (ปรับโฮสต์/พอร์ตตามความจำเป็น) - ด้วยการกำหนดค่านี้ ไคลเอ็นต์สามารถโต้ตอบกับเซิร์ฟเวอร์โดยใช้ JSON มาตรฐานผ่านคำขอ HTTP POST ไม่จำเป็นต้องใช้ SDK พิเศษ
- API เครื่องมือทั้งหมดรับและส่งคืน JSON มาตรฐานตามที่อธิบายไว้ข้างต้น
หมายเหตุ: โหมด
sse(Server-Sent Events) เลิกใช้แล้วและไม่ได้รับการดูแลอีกต่อไป โปรดใช้โหมด Streamable HTTP สำหรับการผสานรวมใหม่ทั้งหมด
ตัวแปรสภาพแวดล้อม:
การกำหนดค่าการเชื่อมต่อ
คุณสามารถกำหนดค่าการเชื่อมต่อ StarRocks โดยใช้ตัวแปรสภาพแวดล้อมแยกหรือ URL การเชื่อมต่อเดียว:
ตัวเลือกที่ 1: ตัวแปรสภาพแวดล้อมแยก
STARROCKS_HOST: (ไม่บังคับ) ชื่อโฮสต์หรือที่อยู่ IP ของบริการ StarRocks FE ค่าเริ่มต้นคือlocalhostSTARROCKS_PORT: (ไม่บังคับ) พอร์ตโปรโตคอล MySQL ของบริการ StarRocks FE ค่าเริ่มต้นคือ9030STARROCKS_USER: (ไม่บังคับ) ชื่อผู้ใช้ StarRocks ค่าเริ่มต้นคือrootSTARROCKS_PASSWORD: (ไม่บังคับ) รหัสผ่าน StarRocks ค่าเริ่มต้นคือสตริงว่างSTARROCKS_PASSWORD_KEYCHAIN_SERVICE: (ไม่บังคับ, macOS เท่านั้น) ชื่อบริการรหัสผ่านทั่วไปที่จะใช้เมื่ออ่านรหัสผ่านจาก Keychain จะใช้เฉพาะเมื่อไม่มีรหัสผ่านที่ชัดเจนผ่านSTARROCKS_PASSWORDหรือSTARROCKS_URLSTARROCKS_PASSWORD_KEYCHAIN_ACCOUNT: (ไม่บังคับ, macOS เท่านั้น) ชื่อบัญชีรหัสผ่านทั่วไปที่จะใช้เมื่ออ่านรหัสผ่านจาก Keychain ค่าเริ่มต้นคือผู้ใช้ StarRocks ที่แก้ไขแล้วSTARROCKS_DB: (ไม่บังคับ) ฐานข้อมูลเริ่มต้นที่จะใช้หากไม่ได้ระบุในอาร์กิวเมนต์เครื่องมือหรือ URI ทรัพยากร หากตั้งค่า การเชื่อมต่อจะพยายามUSEฐานข้อมูลนี้ เครื่องมือเช่นtable_overviewและdb_overviewจะใช้สิ่งนี้หากส่วนฐานข้อมูลถูกละไว้ในอาร์กิวเมนต์ ค่าเริ่มต้นคือว่างเปล่า (ไม่มีฐานข้อมูลเริ่มต้น)
ตัวเลือกที่ 2: URL การเชื่อมต่อ (มีความสำคัญเหนือกว่าตัวแปรแยก)
-
STARROCKS_URL: (ไม่บังคับ) สตริง URL การเชื่อมต่อที่มีพารามิเตอร์การเชื่อมต่อทั้งหมดในตัวแปรเดียว รูปแบบ:[<schema>://]user:password@host:port/databaseส่วน schema เป็นตัวเลือก เมื่อตั้งค่าตัวแปรนี้ จะมีความสำคัญเหนือกว่าตัวแปรSTARROCKS_HOST,STARROCKS_PORT,STARROCKS_USER,STARROCKS_PASSWORDและSTARROCKS_DBแต่ละตัวตัวอย่าง:
root:mypass@localhost:9030/test_dbmysql://admin:[email protected]:9030/productionstarrocks://user:[email protected]:9030/analytics
ลำดับความสำคัญของรหัสผ่าน:
- รหัสผ่านที่ฝังใน
STARROCKS_URLจะชนะ รวมถึงรหัสผ่านว่างที่ชัดเจนเช่นuser:@host:9030/db - หาก
STARROCKS_URLละเว้นรหัสผ่านSTARROCKS_PASSWORDจะถูกใช้เมื่อตั้งค่า - หากไม่มีการตั้งค่าแหล่งรหัสผ่านที่ชัดเจนและกำหนดค่า
STARROCKS_PASSWORD_KEYCHAIN_SERVICEรหัสผ่านจะถูกอ่านจาก macOS Keychain
ตัวอย่าง macOS Keychain
จัดเก็บรหัสผ่าน:
security add-generic-password -U -a root -s mcp-server-starrocks -w 'secret'
ตรวจสอบรหัสผ่านที่จัดเก็บ:
security find-generic-password -a root -s mcp-server-starrocks -w
ใช้กับเซิร์ฟเวอร์นี้:
export STARROCKS_URL=root@localhost:9030/test_db
export STARROCKS_PASSWORD_KEYCHAIN_SERVICE=mcp-server-starrocks
export STARROCKS_PASSWORD_KEYCHAIN_ACCOUNT=root
การกำหนดค่าเพิ่มเติม
-
STARROCKS_FE_ARROW_FLIGHT_SQL_PORT: (ไม่บังคับ) พอร์ต Arrow Flight SQL ของบริการ StarRocks FE เมื่อตั้งค่า เซิร์ฟเวอร์จะเชื่อมต่อโดยใช้โปรโตคอล Arrow Flight SQL ประสิทธิภาพสูง (ผ่านไดรเวอร์ ADBC) แทนโปรโตคอล MySQL มาตรฐาน ปล่อยว่างไว้เพื่อใช้การเชื่อมต่อ MySQL เริ่มต้น โฮสต์ ผู้ใช้ และรหัสผ่านนำมาจากการตั้งค่าการเชื่อมต่อเดียวกันที่อธิบายไว้ข้างต้น -
STARROCKS_OVERVIEW_LIMIT: (ไม่บังคับ) ขีดจำกัดอักขระ_โดยประมาณ_ สำหรับข้อความ_ทั้งหมด_ที่สร้างโดยเครื่องมือภาพรวม (table_overview,db_overview) เมื่อดึงข้อมูลเพื่อเติมแคช สิ่งนี้ช่วยป้องกันการใช้หน่วยความจำมากเกินไปสำหรับ schema ขนาดใหญ่มากหรือตารางจำนวนมาก ค่าเริ่มต้นคือ20000 -
STARROCKS_MCP_OUTPUT_DIR: (ไม่บังคับ) ไดเรกทอรีที่ใช้โดยread_queryเมื่ออาร์กิวเมนต์output_fileเป็นเส้นทางสัมพัทธ์ ค่าเริ่มต้นคือ~/.mcp-server-starrocks/output/ไดเรกทอรีจะถูกสร้างขึ้นตามต้องการ เส้นทางสัมบูรณ์ที่ส่งไปยังoutput_file(รวมถึงเส้นทางที่ขึ้นต้นด้วย~) จะข้ามการตั้งค่านี้ หมายเหตุ: ไฟล์จะถูกเขียนบนเครื่องที่เซิร์ฟเวอร์ MCP ทำงาน สำหรับ Claude Code / Claude Desktop เซิร์ฟเวอร์จะทำงานในเครื่อง ดังนั้นไฟล์จะอยู่บนแล็ปท็อปของคุณ สำหรับการปรับใช้ระยะไกล/http ไฟล์จะอยู่บนเซิร์ฟเวอร์ ไม่ใช่ไคลเอ็นต์ -
STARROCKS_MYSQL_AUTH_PLUGIN: (ไม่บังคับ) ระบุปลั๊กอินการตรวจสอบสิทธิ์ที่จะใช้เมื่อเชื่อมต่อกับบริการ StarRocks FE ตัวอย่างเช่น ตั้งค่าเป็นmysql_clear_passwordหากการปรับใช้ StarRocks ของคุณต้องการการตรวจสอบสิทธิ์รหัสผ่านแบบข้อความชัดเจน (เช่น เมื่อใช้ LDAP หรือการตั้งค่าการตรวจสอบสิทธิ์ภายนอกบางอย่าง) ตั้งค่านี้เฉพาะเมื่อสภาพแวดล้อมของคุณต้องการโดยเฉพาะ มิฉะนั้น จะใช้ auth_plugin เริ่มต้น -
MCP_TRANSPORT_MODE: (ไม่บังคับ) โหมดการสื่อสารที่ระบุวิธีที่เซิร์ฟเวอร์ MCP เปิดเผยบริการ ตัวเลือกที่มี:stdio(ค่าเริ่มต้น): สื่อสารผ่านอินพุต/เอาต์พุตมาตรฐาน เหมาะสำหรับการโฮสต์ MCP Hoststreamable-http(Streamable HTTP): เริ่มต้นเป็นเซิร์ฟเวอร์ Streamable HTTP รองรับการเรียก API แบบ RESTfulsse: (เลิกใช้แล้ว ไม่แนะนำ) เริ่มต้นในโหมดสตรีมมิ่ง Server-Sent Events (SSE) เหมาะสำหรับสถานการณ์ที่ต้องการการตอบสนองแบบสตรีมมิ่ง หมายเหตุ: โหมด SSE ไม่ได้รับการดูแลอีกต่อไป ขอแนะนำให้ใช้โหมด Streamable HTTP อย่างสม่ำเสมอ
ส่วนประกอบ
เครื่องมือ
-
read_query- คำอธิบาย: ดำเนินการคิวรี SELECT หรือคำสั่งอื่นๆ ที่ส่งคืน ResultSet (เช่น
SHOW,DESCRIBE) สามารถเขียนผลลัพธ์ทั้งหมดไปยังไฟล์ในเครื่องแทนที่จะส่งคืนแบบอินไลน์ — มีประโยชน์สำหรับผลลัพธ์ที่ใหญ่เกินกว่าจะพอดีกับบริบทของโมเดล - อินพุต:
{ "query": "SQL query string", "db": "database name (optional, uses default database if not specified)", "output_file": "optional path; if set, writes the full result to disk and returns only a summary + small preview. Relative paths resolve against STARROCKS_MCP_OUTPUT_DIR (default: ~/.mcp-server-starrocks/output/); absolute paths and ~ are used as-is", "output_format": "optional: csv | tsv | json | jsonl. If omitted, inferred from output_file extension (.csv/.tsv/.json/.jsonl/.ndjson); defaults to csv" } - เอาต์พุต: หากไม่มี
output_fileเนื้อหาข้อความที่มีผลลัพธ์คิวรีในรูปแบบคล้าย CSV พร้อมแถวหัวข้อและสรุปจำนวนแถว หากมีoutput_fileสรุปสั้นๆ รวมถึงเส้นทางสัมบูรณ์ที่แก้ไขแล้ว จำนวนไบต์ และจำนวนแถว พร้อมตัวอย่างเล็กน้อย ส่งคืนข้อความแสดงข้อผิดพลาดเมื่อล้มเหลว
- คำอธิบาย: ดำเนินการคิวรี SELECT หรือคำสั่งอื่นๆ ที่ส่งคืน ResultSet (เช่น
-
write_query- คำอธิบาย: ดำเนินการคำสั่ง DDL (
CREATE,ALTER,DROP), DML (INSERT,UPDATE,DELETE) หรือคำสั่ง StarRocks อื่นๆ ที่ไม่ส่งคืน ResultSet - อินพุต:
{ "query": "SQL command string", "db": "database name (optional, uses default database if not specified)" } - เอาต์พุต: เนื้อหาข้อความยืนยันความสำเร็จ (เช่น "Query OK, X rows affected") หรือรายงานข้อผิดพลาด การเปลี่ยนแปลงจะถูกคอมมิตโดยอัตโนมัติเมื่อสำเร็จ
- คำอธิบาย: ดำเนินการคำสั่ง DDL (
-
analyze_query- คำอธิบาย: วิเคราะห์คิวรีและรับผลการวิเคราะห์โดยใช้ query profile หรือ explain analyze
- อินพุต:
{ "uuid": "Query ID, a string composed of 32 hexadecimal digits formatted as 8-4-4-4-12", "sql": "Query SQL to analyze", "db": "database name (optional, uses default database if not specified)" } - เอาต์พุต: เนื้อหาข้อความที่มีผลการวิเคราะห์คิวรี ใช้
ANALYZE PROFILE FROMหากระบุ uuid มิฉะนั้นจะใช้EXPLAIN ANALYZEหากระบุ sql
-
query_and_plotly_chart- คำอธิบาย: ดำเนินการคิวรี SQL โหลดผลลัพธ์ลงใน Pandas DataFrame และสร้างแผนภูมิ Plotly โดยใช้นิพจน์ Python ที่ให้มา ออกแบบมาสำหรับการแสดงภาพใน UI ที่รองรับ
- อินพุต:
{ "query": "SQL query to fetch data", "plotly_expr": "Python expression string using 'px' (Plotly Express) and 'df' (DataFrame). Example: 'px.scatter(df, x=\"col1\", y=\"col2\")'", "db": "database name (optional, uses default database if not specified)" } - เอาต์พุต: รายการที่ประกอบด้วย:
TextContent: การแสดงข้อความของ DataFrame และหมายเหตุว่าแผนภูมิมีไว้สำหรับแสดงผล UIImageContent: แผนภูมิ Plotly ที่สร้างขึ้นซึ่งเข้ารหัสเป็นรูปภาพ PNG base64 (image/png) ส่งคืนข้อความแสดงข้อผิดพลาดเมื่อล้มเหลวหรือหากคิวรีไม่มีข้อมูล
-
table_overview- คำอธิบาย: รับภาพรวมของตารางเฉพาะ: คอลัมน์ (จาก
DESCRIBE), จำนวนแถวทั้งหมด และแถวตัวอย่าง (LIMIT 3) ใช้แคชในหน่วยความจำเว้นแต่refreshเป็นจริง - อินพุต:
{ "table": "Table name, optionally prefixed with database name (e.g., 'db_name.table_name' or 'table_name'). If database is omitted, uses STARROCKS_DB environment variable if set.", "refresh": false // Optional, boolean. Set to true to bypass the cache. Defaults to false. } - เอาต์พุต: เนื้อหาข้อความที่มีภาพรวมที่จัดรูปแบบแล้ว (คอลัมน์, จำนวนแถว, ข้อมูลตัวอย่าง) หรือข้อความแสดงข้อผิดพลาด ผลลัพธ์ที่แคชรวมถึงข้อผิดพลาดก่อนหน้าหากมี
- คำอธิบาย: รับภาพรวมของตารางเฉพาะ: คอลัมน์ (จาก
-
db_overview- คำอธิบาย: รับภาพรวม (คอลัมน์, จำนวนแถว, แถวตัวอย่าง) สำหรับตาราง_ทั้งหมด_ภายในฐานข้อมูลที่ระบุ ใช้แคชระดับตารางสำหรับแต่ละตารางเว้นแต่
refreshเป็นจริง - อินพุต:
{ "db": "database_name", // Optional if default database is set. "refresh": false // Optional, boolean. Set to true to bypass the cache for all tables in the DB. Defaults to false. } - เอาต์พุต: เนื้อหาข้อความที่มีภาพรวมที่ต่อกันสำหรับตารางทั้งหมดที่พบในฐานข้อมูล คั่นด้วยส่วนหัว ส่งคืนข้อความแสดงข้อผิดพลาดหากไม่สามารถเข้าถึงฐานข้อมูลหรือไม่มีตาราง
- คำอธิบาย: รับภาพรวม (คอลัมน์, จำนวนแถว, แถวตัวอย่าง) สำหรับตาราง_ทั้งหมด_ภายในฐานข้อมูลที่ระบุ ใช้แคชระดับตารางสำหรับแต่ละตารางเว้นแต่
ทรัพยากร
ทรัพยากรโดยตรง
starrocks:///databases- คำอธิบาย: แสดงรายการฐานข้อมูลทั้งหมดที่ผู้ใช้ที่กำหนดค่าไว้สามารถเข้าถึงได้
- คิวรีที่เทียบเท่า:
SHOW DATABASES - ประเภท MIME:
text/plain
เทมเพลตทรัพยากร
-
starrocks:///{db}/{table}/schema -
คำอธิบาย: รับนิยามสคีมาของตารางที่ระบุ
- คิวรีที่เทียบเท่า:
SHOW CREATE TABLE {db}.{table} - ประเภท MIME:
text/plain
- คิวรีที่เทียบเท่า:
-
starrocks:///{db}/tables- คำอธิบาย: แสดงรายการตารางทั้งหมดภายในฐานข้อมูลที่ระบุ
- คิวรีที่เทียบเท่า:
SHOW TABLES FROM {db} - ประเภท MIME:
text/plain
-
proc:///{+path}- คำอธิบาย: เข้าถึงข้อมูลระบบภายในของ StarRocks คล้ายกับ
/procของ Linux พารามิเตอร์pathระบุโหนดข้อมูลที่ต้องการ - คิวรีที่เทียบเท่า:
SHOW PROC '/{path}' - ประเภท MIME:
text/plain - พาธทั่วไป:
/frontends- ข้อมูลเกี่ยวกับโหนด FE/backends- ข้อมูลเกี่ยวกับโหนด BE (สำหรับการปรับใช้ที่ไม่ใช่คลาวด์เนทีฟ)/compute_nodes- ข้อมูลเกี่ยวกับโหนด CN (สำหรับการปรับใช้แบบคลาวด์เนทีฟ)/dbs- ข้อมูลเกี่ยวกับฐานข้อมูล/dbs/<DB_ID>- ข้อมูลเกี่ยวกับฐานข้อมูลที่ระบุตาม ID/dbs/<DB_ID>/<TABLE_ID>- ข้อมูลเกี่ยวกับตารางที่ระบุตาม ID/dbs/<DB_ID>/<TABLE_ID>/partitions- ข้อมูลพาร์ติชันสำหรับตาราง/transactions- ข้อมูลธุรกรรมที่จัดกลุ่มตามฐานข้อมูล/transactions/<DB_ID>- ข้อมูลธุรกรรมสำหรับ ID ฐานข้อมูลที่ระบุ/transactions/<DB_ID>/running- ธุรกรรมที่กำลังทำงานสำหรับ ID ฐานข้อมูล/transactions/<DB_ID>/finished- ธุรกรรมที่เสร็จสิ้นแล้วสำหรับ ID ฐานข้อมูล/jobs- ข้อมูลเกี่ยวกับงานอะซิงโครนัส (Schema Change, Rollup ฯลฯ)/statistic- สถิติสำหรับแต่ละฐานข้อมูล/tasks- ข้อมูลเกี่ยวกับงานของเอเจนต์/cluster_balance- ข้อมูลสถานะการโหลดบาลานซ์/routine_loads- ข้อมูลเกี่ยวกับงาน Routine Load/colocation_group- ข้อมูลเกี่ยวกับกลุ่ม Colocation Join/catalog- ข้อมูลเกี่ยวกับแค็ตตาล็อกที่กำหนดค่าไว้ (เช่น Hive, Iceberg)
- คำอธิบาย: เข้าถึงข้อมูลระบบภายในของ StarRocks คล้ายกับ
พรอมต์
ไม่มีการกำหนดโดยเซิร์ฟเวอร์นี้
พฤติกรรมการแคช
- เครื่องมือ
table_overviewและdb_overviewใช้แคชในหน่วยความจำเพื่อจัดเก็บข้อความภาพรวมที่สร้างขึ้น - คีย์แคชคือทูเพิลของ
(database_name, table_name) - เมื่อเรียก
table_overviewจะตรวจสอบแคชก่อน หากมีผลลัพธ์อยู่และพารามิเตอร์refreshเป็นfalse(ค่าเริ่มต้น) ผลลัพธ์ที่แคชไว้จะถูกส่งคืนทันที มิฉะนั้น จะดึงข้อมูลจาก StarRocks จัดเก็บในแคช แล้วจึงส่งคืน - เมื่อเรียก
db_overviewจะแสดงรายการตารางทั้งหมดในฐานข้อมูล จากนั้นพยายามดึงภาพรวมสำหรับ แต่ละตาราง โดยใช้ตรรกะการแคชเดียวกับtable_overview(ตรวจสอบแคชก่อน ดึงข้อมูลหากจำเป็นและrefreshเป็นfalseหรือแคชพลาด) หากrefreshเป็นtrueสำหรับdb_overviewจะบังคับให้รีเฟรชสำหรับ ทุก ตารางในฐานข้อมูลนั้น - ตัวแปรสภาพแวดล้อม
STARROCKS_OVERVIEW_LIMITให้ เป้าหมายแบบนุ่มนวล สำหรับความยาวสูงสุดของสตริงภาพรวมที่สร้างขึ้น ต่อตาราง เมื่อเติมข้อมูลในแคช ช่วยจัดการการใช้หน่วยความจำ - ผลลัพธ์ที่แคชไว้ รวมถึงข้อความแสดงข้อผิดพลาดใดๆ ที่พบระหว่างการดึงข้อมูลครั้งแรก จะถูกจัดเก็บและส่งคืนเมื่อแคชถูกใช้งานในครั้งต่อๆ ไป
การดีบัก
หลังจากเริ่มต้นเซิร์ฟเวอร์ mcp คุณสามารถใช้อินสเปกเตอร์เพื่อดีบัก:
npx @modelcontextprotocol/inspector
การสาธิต

