Elasticsearch - คลัสเตอร์ API
คลัสเตอร์ API ใช้สำหรับรับข้อมูลเกี่ยวกับคลัสเตอร์และโหนดและทำการเปลี่ยนแปลงในคลัสเตอร์ ในการเรียก API นี้เราต้องระบุชื่อโหนดที่อยู่หรือ _local
GET /_nodes/_local
ในการรันโค้ดด้านบนเราจะได้รับคำตอบตามที่แสดงด้านล่าง -
………………………………………………
cluster_name" : "elasticsearch",
"nodes" : {
"FKH-5blYTJmff2rJ_lQOCg" : {
"name" : "ubuntu",
"transport_address" : "127.0.0.1:9300",
"host" : "127.0.0.1",
"ip" : "127.0.0.1",
"version" : "7.0.0",
"build_flavor" : "default",
"build_type" : "tar",
"build_hash" : "b7e28a7",
"total_indexing_buffer" : 106502553,
"roles" : [
"master",
"data",
"ingest"
],
"attributes" : {
………………………………………………
สุขภาพคลัสเตอร์
API นี้ใช้เพื่อรับสถานะความสมบูรณ์ของคลัสเตอร์โดยการต่อท้ายคีย์เวิร์ด 'health'
GET /_cluster/health
ในการรันโค้ดด้านบนเราจะได้รับคำตอบตามที่แสดงด้านล่าง -
{
"cluster_name" : "elasticsearch",
"status" : "yellow",
"timed_out" : false,
"number_of_nodes" : 1,
"number_of_data_nodes" : 1,
"active_primary_shards" : 7,
"active_shards" : 7,
"relocating_shards" : 0,
"initializing_shards" : 0,
"unassigned_shards" : 4,
"delayed_unassigned_shards" : 0,
"number_of_pending_tasks" : 0,
"number_of_in_flight_fetch" : 0,
"task_max_waiting_in_queue_millis" : 0,
"active_shards_percent_as_number" : 63.63636363636363
}
สถานะคลัสเตอร์
API นี้ใช้เพื่อรับข้อมูลสถานะเกี่ยวกับคลัสเตอร์โดยการต่อท้าย URL คำหลัก 'state' ข้อมูลสถานะประกอบด้วยเวอร์ชันโหนดหลักโหนดอื่น ๆ ตารางเส้นทางข้อมูลเมตาและบล็อก
GET /_cluster/state
ในการรันโค้ดด้านบนเราจะได้รับคำตอบตามที่แสดงด้านล่าง -
………………………………………………
{
"cluster_name" : "elasticsearch",
"cluster_uuid" : "IzKu0OoVTQ6LxqONJnN2eQ",
"version" : 89,
"state_uuid" : "y3BlwvspR1eUQBTo0aBjig",
"master_node" : "FKH-5blYTJmff2rJ_lQOCg",
"blocks" : { },
"nodes" : {
"FKH-5blYTJmff2rJ_lQOCg" : {
"name" : "ubuntu",
"ephemeral_id" : "426kTGpITGixhEzaM-5Qyg",
"transport
}
………………………………………………
สถิติคลัสเตอร์
API นี้ช่วยในการดึงข้อมูลสถิติเกี่ยวกับคลัสเตอร์โดยใช้คีย์เวิร์ด "stats" API นี้ส่งคืนหมายเลขชาร์ดขนาดที่จัดเก็บการใช้หน่วยความจำจำนวนโหนดบทบาท OS และระบบไฟล์
GET /_cluster/stats
ในการรันโค้ดด้านบนเราจะได้รับคำตอบตามที่แสดงด้านล่าง -
………………………………………….
"cluster_name" : "elasticsearch",
"cluster_uuid" : "IzKu0OoVTQ6LxqONJnN2eQ",
"timestamp" : 1556435464704,
"status" : "yellow",
"indices" : {
"count" : 7,
"shards" : {
"total" : 7,
"primaries" : 7,
"replication" : 0.0,
"index" : {
"shards" : {
"min" : 1,
"max" : 1,
"avg" : 1.0
},
"primaries" : {
"min" : 1,
"max" : 1,
"avg" : 1.0
},
"replication" : {
"min" : 0.0,
"max" : 0.0,
"avg" : 0.0
}
………………………………………….
การตั้งค่าการอัปเดตคลัสเตอร์
API นี้ช่วยให้คุณสามารถอัปเดตการตั้งค่าของคลัสเตอร์ได้โดยใช้คีย์เวิร์ด "settings" การตั้งค่ามีสองประเภทคือแบบถาวร (ใช้กับการรีสตาร์ท) และชั่วคราว (ไม่สามารถรีสตาร์ทคลัสเตอร์ทั้งหมดได้)
Node Stats
API นี้ใช้เพื่อดึงข้อมูลสถิติของอีกหนึ่งโหนดของคลัสเตอร์ สถิติโหนดเกือบจะเหมือนกับคลัสเตอร์
GET /_nodes/stats
ในการรันโค้ดด้านบนเราจะได้รับคำตอบตามที่แสดงด้านล่าง -
{
"_nodes" : {
"total" : 1,
"successful" : 1,
"failed" : 0
},
"cluster_name" : "elasticsearch",
"nodes" : {
"FKH-5blYTJmff2rJ_lQOCg" : {
"timestamp" : 1556437348653,
"name" : "ubuntu",
"transport_address" : "127.0.0.1:9300",
"host" : "127.0.0.1",
"ip" : "127.0.0.1:9300",
"roles" : [
"master",
"data",
"ingest"
],
"attributes" : {
"ml.machine_memory" : "4112797696",
"xpack.installed" : "true",
"ml.max_open_jobs" : "20"
},
………………………………………………………….
โหนด hot_threads
API นี้ช่วยให้คุณดึงข้อมูลเกี่ยวกับเธรดฮอตปัจจุบันบนแต่ละโหนดในคลัสเตอร์
GET /_nodes/hot_threads
ในการรันโค้ดด้านบนเราจะได้รับคำตอบตามที่แสดงด้านล่าง -
:::{ubuntu}{FKH-5blYTJmff2rJ_lQOCg}{426kTGpITGixhEzaM5Qyg}{127.0.0.1}{127.0.0.1:9300}{ml.machine_memory=4112797696,
xpack.installed=true, ml.max_open_jobs=20}
Hot threads at 2019-04-28T07:43:58.265Z, interval=500ms, busiestThreads=3,
ignoreIdleThreads=true: