linux 下安装sphinx

一定要安装mysql,否则不会成功的。

wget http://www.sphinxsearch.com/downloads/sphinx-0.9.8-rc2.tar.gz

tar-xvzfsphinx-0.9.8-rc2.tar.gz

cdsphinx-0.9.8-rc2

./configure--prefix=/usr/local/sphinx--with-mysql=/usr/local/mysql

make

make install

安装完毕后查看一下/usr/local/sphinx下是否有 三个目录 bin etc var,如有,则安装无误!

运行测试

$cd/usr/local/sphinx/etc

$cpsphinx.conf.distsphinx.conf

$visphinx.conf

这里,sphinx提供了一个简单的例子,基本步骤是先将/sphinx/etc下面的sphinx.conf.dist重命名为sphinx.conf,然后修改sphinx.conf其中的配置,主要是修改你服务器上面的mysql的用户名、密码、使用的数据库等。修改的位置是sphinx.conf的sourcesrc1下面几行。

$mysql-utest</usr/local/sphinx/etc/example.sql

这里是导入sphinx准备的测试数据,我们把数据导入到mysql的test数据库中。当然,这里的数据库要和你上面的配置文件(sphinx.conf)中指定的sql_db值相同。注意,运行这个命令的话,如果你的mysql命令没有加入到环境变量中,就需要用完整路径,同时可能需要输入密码。比如你的mysql安装在/usr/local/mysql目录中,root账户的密码是xxxxxx,那么命令应该调整为:

$ /usr/local/mysql/bin/mysql -uroot -pxxxxxx test < /usr/local/sphinx/etc/example.sql

$cd/usr/local/sphinx/etc

$/usr/local/sphinx/bin/indexer--all

这个命令是建立索引,当然数据基础是刚刚导入的example.sql的数据,如果这里出错,最大的可能是你的sphinx.conf中的数据库配置错了,你需要回去检查并修正。但是,还有可能出现sphinx必须的库文件无法找到,例如出现以下两种错误:

/usr/local/sphinx/bin/indexer:errorwhileloadingsharedlibraries:libmysqlclient.so.15:cannotopensharedobjectfile:Nosuchfileordirectory

/usr/local/sphinx/bin/indexer:errorwhileloadingsharedlibraries:libiconv.so.2:cannotopensharedobjectfile:Nosuchfileordirectory

这主要是因为你安装了一些库后,没有能够配置相应的环境变量。你可以通过建立连接的方式修正这个问题,运行如下命令:

ln-s/usr/local/mysql/lib/libmysqlclient.so.15/usr/lib64/libmysqlclient.so.15

ln-s/usr/local/lib/libiconv.so.2/usr/lib64/libiconv.so.2

这里我假设你相应的软件包安装在/usr/local/xxx目录下,如果你不是安装在相应目录下,你就需要使用你自己的路径。如果你没有安装libiconv软件包,则需要安装下,这个安装比较简单,就不多说了。

如果还出现类似错误,照上面的方法修正。

$cd/usr/local/sphinx/etc

$/usr/local/sphinx/bin/searchtest

上面的命令是搜索测试,测试的关键词就是test了,如果成功的话,你应该看到搜到的结果,出现字串“index'test1':query'test':returned3matchesof3totalin0.000sec”,后面跟的是结果表示成功了。

$cd/usr/local/sphinx/etc

$/usr/local/sphinx/bin/searchd

运行上面的命令,你就启动了sphinx进程了,如果没什么错误,可以通过ps-aux找到sphinx进程了。哈哈,大功告成!

相关推荐