вторник, декабря 21, 2010

Установка Sphinx 1.10-beta в Fedora 13

Shpinx 0.9.9-1 есть в репозиториях, поэтому для установки этой версии достаточно yum install sphinx

Для установки Sphinx 1.10-beta выкачиваем здесь, или из svn. Смотрим мануал по установке
Будем ставить по максимуму, то есть w/MySQL+PgSQL+libstemmer+id64 support. Что должно быть:
yum install mysql-server mysql-devel postgresql postgresql-devel gcc-c++
Далее 4 простых шага:
1. Выкачиваем sphinx-1.10-beta.tar.gz, распаковываем
wget http://sphinxsearch.com/downloads/sphinx-1.10-beta.tar.gz
tar xzvf sphinx-1.10-beta.tar.gz
cd sphinx-1.10-beta
2. Выкачиваем libstemmer_c.tgz, распаковываем в папку libstemmer_c внутри sphinx-1.10-beta
wget http://snowball.tartarus.org/dist/libstemmer_c.tgz
tar xzvf libstemmer_c.tgz
3. Конфигурируем по максимуму
./configure --prefix=/usr/local/sphinx --with-mysql --with-mysql-includes=/usr/include/mysql --with-mysql-libs=/usr/lib/mysql --with-pgsql --with-pgsql-includes=/usr/include --with-pgsql-libs=/usr/lib/pgsql --enable-id64 --with-libstemmer
4. make
5. make install

6. Создаем /etc/init.d/searchd или берем уже установленный от 0.9.9-1 и корректируем путь к конфигу
#!/bin/sh
#
# sphinx searchd Free open-source SQL full-text search engine
#
# chkconfig:   - 20 80
# description: Starts and stops the sphinx searchd daemon that handles \
#        all search requests.

### BEGIN INIT INFO
# Provides: searchd
# Required-Start: $local_fs $network
# Required-Stop: $local_fs $network
# Should-Start: $remote_fs
# Should-Stop: $remote_fs
# Default-Start: 
# Default-Stop: 0 1 2 3 4 5 6
# Short-Description: start and stop sphinx searchd daemon
# Description: Sphinx is a free open-source SQL full-text search engine     
### END INIT INFO

# Source function library.
. /etc/rc.d/init.d/functions

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

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 --user=$username $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 $?



Все, осталось переименовать и поправить конфиг в /usr/local/sphinx/etc/sphinx.conf
проиндексировать
indexer --all
и запустить сервис
service searchd start

PS: к сожалению, обнаружил неприятную багу (симптомы аналогичны, кажется проявляется только для type = pgsql) с индексатором в sphinx-1.10-beta и в текущей версии. При этом indexer из 0.9.9 работает как надо. Приходится searchd использовать из sphinx-1.10-beta (Server version: 1.10-id64-beta (r2420)) или текущей development версии (Server version: 1.11-id64-dev (r2617)), а indexer из 0.9.9.
Другая проблема - работа sphinx на протоколе mysql41 с mysql jdbc-драйвером. В текущей development версии (Server version: 1.11-id64-dev (r2617)) он просто виснет на DriverManager.getConnection. При этом в версии sphinx-1.10-beta (Server version: 1.10-id64-beta (r2420)) все нормально.

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

Мой список блогов