程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 編程語言 >> 網頁編程 >> PHP編程 >> PHP綜合 >> sphinx增量索引的一個問題

sphinx增量索引的一個問題

編輯:PHP綜合
但最近發現增量的總是搜索不到,今天看了下運行日志,有如下提示:

[Sun Apr 17 19:30:01.876 2011] [ 3400] WARNING: rotating index 'news_delta': cur to old rename failed: rename /dev/shm/sphinx/data/news_delta.spa to /dev/shm/sphinx/data/news_delta.old.spa failed: No such file or directory

[Sun Apr 17 19:30:01.881 2011] [ 3400] WARNING: rotating index 'article_delta': cur to old rename failed: rename /dev/shm/sphinx/data/article_delta.spa to /dev/shm/sphinx/data/article_delta.old.spa failed: No such file or directory

為提高增量索引速度,我將增量索引存放在/dev/shm中,看了下/dev/shm/sphinx/data/目錄下的內容:
-rw-r--r-- 1 root root 385762 Apr 17 19:21 article_delta.new.spd
-rw-r--r-- 1 root root 3713 Apr 17 19:21 article_delta.new.sph
-rw-r--r-- 1 root root 46260 Apr 17 19:21 article_delta.new.spi
-rw-r--r-- 1 root root 0 Apr 17 19:21 article_delta.new.spk
-rw-r--r-- 1 root root 0 Apr 17 19:21 article_delta.new.spm
-rw-r--r-- 1 root root 261402 Apr 17 19:21 article_delta.new.spp

奇怪,應該要有article_delta.spd等文件,不應該是.new的文件。
增量索引時是使用--rotate參數的,
復制代碼 代碼如下:
bin/indexer --rotate news_delta
bin/indexer --rotate article_delta

在rotate時,需要將原article_delta.spa重命名為article_delta.old.spa,然後將article_delta.new.spa重命名為article_delta.spa,再通知searchd重啟完成rotate。

想起應該是前幾天凌晨重啟過機器,原文件都丟了,導致無法rotate:(

解決方法:
運行:bin/indexer article_delta
創建了article_delta.spd,sph等文件。

再運行:bin/indexer article_delta --rotate
運行日志提示:rotating index 'article_delta': success
正常了!

把要做增量索引的命令寫了個腳本,放在rc.local中,這樣重啟過機器就不會再出現這種問題了。
復制代碼 代碼如下:
echo "start:" $(date +"%y-%m-%d %H:%M:%S")
cd /usr/local/coreseek/bin
./indexer news_delta
./indexer article_delta
echo "end:" $(date +"%y-%m-%d %H:%M:%S")
  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved