Понадобилось прикрутить к сайту поисковый движок 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
Таким образом, переиндексация будет проводиться в середине каждого часа. Ура.
Комментариев нет:
Отправить комментарий