• linux安装sphinx


    1、去sphinx下载相应的包:sphinx-0.9.8.1.tar.gz(建议安装文档版本)

    解压sphinx源码包:

    $ tar xzvf sphinx-0.9.8.1.tar.gz
    $ cd sphinx

    2、运行configure配置程序:

    • $ ./configure [options]

      有一些参数可以在配置的时候指定,主要如下:

        --prefix, 指定sphinx安装到系统的那个位置; 例如 --prefix=/usr/local/sphinx

    如下:./configure --prefix=/usr/local/sphinx --with-mysql=/usr/local/mysql

    3、编译:

              $ make

              在这个步骤,可能遇到一个问题,就是报 sphinx undefined reference to 'libiconv' 的错误,解决办法是修改 /src/MakeFile(注意是src下的Makefile不是csft下的Makefile),编辑LIBS = -lm -lexpat 后面添加-liconv,即将该行该为:
              LIBS = -lm -lexpat -liconv -L/usr/local/lib

     4. 安装
      
             
    $ make install

             
    如果编译中没有产生错误,这个步骤应该不会遇到问题。如果完成后未正确安装,就要回去找make过程中遇到的错误了。
             其实这里可以把3和4一起运行,make & make install
         5. 运行测试
             
             
    $ cd /usr/local/sphinx/etc
              $ cp sphinx.conf.dist sphinx.conf
              $ vi sphinx.conf


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

              $ mysql -u test < /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
    (这里我在运行的时候总是报example.sql有语法错误,看了文件没有发现什么错误,mysql用的是root权限。后来没得办法只有复制一条条的语句执行,发现有些地方的空格复制到命令行下面,会有些过滤掉。
    )
              $ cd /usr/local/sphinx/etc
              $ /usr/local/sphinx/bin/indexer --all
             (这里一定要用全部路径来运行,除非你在环境中配置了,要不会报错。说indexer不存在)
             
    这个命令是建立索引,当然数据基础是刚刚导入的example.sql的数据,如果这里出错,最大的可能是你的sphinx.conf中的数据库配置错了,你需要回去检查并修正。但是,还有可能出现sphinx必须的库文件无法找到,例如出现以下两种错误:
              /usr/local/sphinx/bin/indexer: error while loading shared libraries: libmysqlclient.so.15: cannot open shared object file: No such file or directory
              /usr/local/sphinx/bin/indexer: error while loading shared libraries: libiconv.so.2: cannot open shared object file: No such file or directory
              这主要是因为你安装了一些库后,没有能够配置相应的环境变量。你可以通过建立连接的方式修正这个问题,运行如下命令:
              ln -s /usr/local/mysql/lib/libmysqlclient.so.15 /usr/lib/libmysqlclient.so.15(这里是so.15还是so.16自己要到安装的mysql/bin/mysql下面看看)
             
    ln -s /usr/local/lib/libiconv.so.2 /usr/lib/libiconv.so.2
              这里我假设你相应的软件包安装在/usr/local/xxx 目录下,如果你不是安装在相应目录下,你就需要使用你自己的路径。如果你没有安装libiconv软件包,则需要安装下,这个安装比较简单,就不多说了。
              如果还出现类似错误,照上面的方法修正。

              $ cd /usr/local/sphinx/etc
              $ /usr/local/sphinx/bin/search test

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

              $ cd /usr/local/sphinx/etc
              $ /usr/local/sphinx/bin/searchd


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

  • 相关阅读:
    libZPlay 音频编码解码器库
    C# PropertyGrid控件
    .netGDI+(转)
    (转)JITComplier、NGen.exe及.NET Native
    c# 特性/属性(Attribute) 以及使用反射查看自定义特性
    Fluent NHibernate系列文章
    Hibernate工作原理
    Orchard核心机制
    NHibernate和 FluentNHibernate
    极限编程之TDD
  • 原文地址:https://www.cnblogs.com/myphoebe/p/2144948.html
Copyright © 2020-2023  润新知