среда, 17 августа 2011 г.

Установка Sphinx 0.9.9 на CentOS 5.6

Понадобилось прикрутить к сайту поисковый движок Sphinx. Казалось бы,
yum install sphinx - и все в шоколаде.
Ан нет, почему-то последней версией в репозиториях был 0.9.8, а разработчики сайта строго сказали, что нужен именно 0.9.9, потому что только он как надо работает с нашей версией MySQL.

Ну что ж.
Сперва убеждаемся, что стоят все нужные пакеты:

yum install mysql-server mysql-devel gcc-c++ 

Качаем с официального сайта нужную версию:

wget http://sphinxsearch.com/files/sphinx-0.9.9.tar.gz

Распаковываем, идем в папочку:

tar xzvf sphinx-0.9.9.tar.gz
cd sphinx-0.9.9
 ./configure --prefix=/usr/local/sphinx --with-mysql --with-mysql-includes=/usr/include/mysql/ --with-mysql-libs=/usr/lib64/mysql/ --enable-id64
 (постгре мне не нужен, поэтому опций про него я не ставил)

make
make install

Далее создаем скрипт запуска:

nano /etc/init.d/searchd

Текст:

#!/bin/sh

. /etc/rc.d/init.d/functions

exec="/usr/local/sphinx/bin/searchd"
prog="searchd"
config="/usr/local/sphinx/etc/sphinx.conf"

lockfile=/var/lock/subsys/searchd
start() {
[ -x $exec ] || exit 5
[ -f $config ] || exit 6
echo -n $"Starting $prog: "
# if not running, start it up here, usually something like "daemon $exec"
daemon $exec --config $config
retval=$?
echo
[ $retval -eq 0 ] && touch $lockfile
return $retval
}
stop() {
echo -n $"Stopping $prog: "
# stop it here, often "killproc $prog"
killproc $prog
retval=$?
  echo 
[ $retval -eq 0 ] && rm -f $lockfile
return $retval
}
restart() {
stop
start
}
reload() {
restart
}
force_reload() {
restart
}
rh_status() {
# run checks to determine if the service is running or use generic status
status $prog
}
rh_status_q() {
rh_status >/dev/null 2>&1
}
case "$1" in
start)
rh_status_q && exit 0
$1
;;
stop)
rh_status_q || exit 0
$1
;;
restart)
$1
;;
reload)
rh_status_q || exit 7
$1
;;
force-reload)
force_reload
;;
status)
rh_status
;;
condrestart|try-restart)
rh_status_q || exit 0
restart
;;
*)
echo $"Usage: $0 {start|stop|status|restart|condrestart|try-restart|reload|force-reload}"
exit 2
esac
exit $?

И добавляем сфинкса в автозагрузку

chkconfig searchd on

Весь sphinx.conf приводить не буду, там вроде все понятно (его с комментариями кстати можно посмотреть, например тут).Единственное, что у меня вызвало затык, так это сообщение:

ERROR: index 'тратата': sql_connect: Can't connect to local MySQL server through socket '/var/run/mysqld/mysqld.sock 

Однако, выполнив

ps -ef | grep mysql

увиделось, что  сокет-то лежит не там, а тут: /var/lib/mysql/mysql.sock, что я собственно и указал в конфиге. Далее:


/usr/local/sphinx/bin/indexer --all
/etc/init.d/searchd start 

И о чудо! Все неожиданно заработало. Теперь остается только добавить в крон периодическую переиндексацию. Разработчики сайта велели делать это каждый час:

crontab -e

И добавляем:

30 * * * * /usr/local/sphinx/bin/indexer --all --rotate

Таким образом, переиндексация будет проводиться в середине каждого часа. Ура. 

Комментариев нет:

Отправить комментарий