發現elasticsearch集群的狀態是red,unassign的分片數很多,看了下都是些舊的日期的索引(應該是定時任務刪除失敗導致的)。
curl -XGET ip:port/_cat/shards | grep UNASSIGNED
數量有幾百個,寫個腳本處理下,先恢復成green。red狀態好像會影響索引創建和數據遷移
先把需要刪除的索引導出到文件
curl -XGET ip:port/_cat/shards | grep UNASSIGNED >> needDelIndex.txt
確認下要刪除的索引列表。沒問題就執行下面刪除shell(es的ip和端口需要修改下)
#!/bin/bashecho "$1"esUrl=${esip}:${esport}indexfile=needDelIndex.txt#cp -f /dev/null ${indexfile}#curl -XGET ip:port/_cat/shards | grep UNASSIGNED >> needDelIndex.txtif [ ! -f ./${indexfile} ]; then  echo $indexfile not exists  exit 0filogfile=esindex_del.`date +"%m-%d"`.logcp -f /dev/null ${logfile}lastIndexName="test"for item in `cat ${indexfile} | awk '{print $1}'`do  if [ "$item" = "error" ]  then    continue  fi  if [ "$item" != "$lastIndexName" ]  then    curl -XDELETE ${esUrl}/${item} >> ${logfile}    echo ---------${item} `date` >> ${logfile}    sleep 5  fi  lastIndexName=${item}done因為我們的索引是按天創建的,索引名前綴是yyyy-MM-dd, 保留一段時間后需要批量刪除。shell的第一個參數為yyyy-MM-dd,將刪除該天及以前的舊索引
#!/bin/bashesUrl=${esip}:${esport}echo "$1"if [ $# -ge 1 ]then  deleteDate=$1else  echo "please inpust detete esindex's date(yyyy-MM-dd)"  exit 0fiindexfile=esindex.infocp -f /dev/null ${indexfile}curl '${esUrl}/_cat/indices' >> ${indexfile}logfile=esindex_del.`date +"%m-%d"`.outcp -f /dev/null ${logfile}for item in `cat ${indexfile} | awk '{print $3}'`do  if [ "$item" = "error" ]  then    continue  fi  parameter=${esUrl}/${item}  indexdate=${item:0:10}  if [ "$indexdate" = "$deleteDate" ]  then    curl -XDELETE ${parameter} >> ${logfile}    echo ---------${item} >> ${logfile}    sleep 5  elif [[ "$indexdate" < "$deleteDate" ]]  then    curl -XDELETE ${parameter} >> ${logfile}    echo ---------${item} >> ${logfile}    sleep 5  fidone總結
以上就是這篇文章的全部內容了,希望本文的內容對大家的學習或者工作具有一定的參考學習價值,謝謝大家對武林站長站的支持。如果你想了解更多相關內容請查看下面相關鏈接
新聞熱點
疑難解答