来自:http://www.xunsearch.com/doc/php/guide/start.installation
Xunsearch PHP-SDK 是与xunsearch后端服务协同工作的,所以后先必须先在您的服务器 上安装服务端,服务器操作系统要求必须是Linux、BSD或其它类UNIX系统,同时安装了gcc、make等基础编译环境。
Tip:即便您之前已经安装过xunsearch,您也可以安装放心的使用该教程进行覆盖安装,会自动 完成升级操作,而不用担心会删除任何已存在的数据。我们制作的安装脚本包含了智能检测功能。
此外xunsearch的安装和运行都不需要root权限,强烈推荐单独设置一个系统用户用于安装 执行相关指令。
Xunsearch 全部开源,理论上也可以从官方提供的git 仓库获 取源码自行构建,但是 这要求必须有较多的技术基础,在此不打算赘述,有这方面需求的技术人员可以到论坛去交流。 为方便用户安装,我们提供了一个包含安装所需求的全部组件的完整安装包(含xapian/libevent/scws), 您只要下载并安装此完整安装包即可,具体操作步骤如下:
- wget http://www.xunsearch.com/download/xunsearch-full-latest.tar.bz2
- tar -xjf xunsearch-full-latest.tar.bz2
- cd xunsearch-full-1.3.1/
- sh setup.sh
注:(提示安装路径为/usr/local/xunsearch/,如不更改回车即可) -
启动/重新启动xunsearch的后台服务
/usr/local/xunsearch/bin/xs-ctl.sh start本次安装未使用默认启动使用以下方式:/usr/local/xunsearch/bin/xs-ctl.sh -b inet start -
强烈建议您将此命令添加到开机启动脚本中,以便每次服务器重启后能自动启动搜索服务程序, 在Linux系统中您可以将脚本指令写进/etc/rc.local即可(做好端口访问限制,如果只本机使用可以绑定127.0.0.1)。
-
有必要指出的是,关于搜索项目的数据目录规划。搜索系统将所有数据保存在$prefix/data目录中。 如果您希望数据目录另行安排或转移至其它分区,请将$prefix/data作为软链接指向真实目录。
Info:出于性能和多数需求考虑xunsearch服务端和 SDK API 通讯时没有加密和验证处理, 并且默认情况xs-ctl.sh启动的服务程序是绑定并监听在127.0.0.1上。
如 果您的 SDK 调用和xunsearch服务端不在同一服务器,请使用 -b inet 方式启动脚本, 并注意借助类似iptables的防火墙来控制xunsearch的8383/8384两个端口的访问权限。 启动脚本用法举例如下,以下均为合法使用方式(将脚本指令写进/etc/rc.local):
bin/xs-ctl.sh -b local start // 监听在本地回环地址127.0.0.1 上
bin/xs-ctl.sh -b inet start// 监听在所有本地 IP 地址上
bin/xs-ctl.sh -b a.b.c.d start // 监听在指定 IP 上
bin/xs-ctl.sh -b unix start // 分别监听在 tmp/indexd.sock 和 tmp/searchd.sock2.
安装 PHP-SDK
PHP-SDK 的代码不需要另行下载,已经包含在xunsearch的安装结果中了,在此假设您将xunsearch安装在$prefix目录,那么$prefix/sdk/php即是 PHP-SDK 的代码目录。目录结构及功能逻列如下:
_ |- doc/ 离线 HTML 版相关文档 |- app/ 用于存放搜索项目的 ini 文件 |- lib/XS.php 入口文件,所有搜索功能必须且只需包含此文件 \- util/ 辅助工具程序目录 |- RequireCheck.php 用于检测您的 PHP 环境是否符合运行条件 |- IniWizzaard.php 用于帮助您编写 xunsearch 项目配置文件 |- Quest.php 搜索测试工具 \- Indexer.php 索引管理工具如果您的搜索应用程序和xunsearch在同一台服务器,则无需复制任何代码,在开发的时候直接包含 入口文件$prefix/sdk/php/lib/XS.php即可。代码如下:
require_once'$prefix/sdk/php/lib/XS.php';如果您在其它服务器部署前端搜索代码,请将 SDK 代码整个目录复制到相应的服务器上,但并不要求放到 web 可访问目录,考虑安全性也不推荐这么做。
Note:对于前端和后端分离的用户来说,当xunsearch升级安装后必须重新复制安装后的 SDK 代码 去覆盖,否则可能造成版本不匹配导致错误。
3. 检测 PHP-SDK 的运行条件从现在开始的文档及示范代码中我们都假定您将xunsearch安装在$prefix目录中,而不再另行说明。
基 础运行条件要求 PHP 最低版本为 5.2.0,随着功能需求的不同可能还会用到一些其它扩展,具体请在 命令行环境里运行我们提供的检测脚本。如果您的php可执行文件不在默认搜索路径中,假设是安装在/path/to/bin/php请使用第二种方式运 行。运行方式如下:
1.$prefix/sdk/php/util/RequiredCheck.php2./path/to/bin/php $prefix/sdk/php/util/RequiredCheck.php
3.$prefix/sdk/php/util/RequiredCheck.php-c gbk
运行结果输出的中文编码默认为UTF-8,如果您使用GBK环境请在运行命令最后加上-c GBK。 运行结果会给出一个可视化的表格说明检测结果,并在最终给出检测结论,告诉您是否符合运行的基础要求。
至此,安装和准备工作已经完成了,您可以开始使用Xunsearch PHP-SDK开发自己的搜索应用了。
4. 完全删除 Xunsearch首先欢迎对xunsearch提出各种修改、改进建议,我们都会认真对待和处理。如果有一天您真的不再需要xunsearch了,那么只要停止运行后端服务,然后完全删除它的安装目录$prefix即可,整个软件包 所有涉及的文件均在该目录下。
Note:如果您的安装目录没有单独设置,而是使用公共目录(如:/usr/local),请勿直接删除整个目录。
$prefix/bin/xs-ctl.sh faststop rm -fr $prefix5. 从 Git 源码仓库安装Note:在开始安装前,无论如何请先安装一次最新发布的完整版本,以便将所有的运行依赖库安装到位。
我们的源代码托管在 github 上。您可以直接浏览代码仓库,也可以通过以下方式之一取得源代码:
git clone git://github.com/hightman/xunsearch.git git clone https://github.com/hightman/xunsearch.git如果要编译安装这份源代码,您还必须在主机环境上安装相关的 autoconf, automake 工具,然后运行 下面指令完成准备工作。
cd xunsearch/ chmod +x acprep ./acprep在完成上述的准备工作后,接下来编译安装 xunsearch 就和常见的开源软件类似,假设您的安装目录为$prefix,然后按以下步骤操作即可:
./configure --prefix=$prefix make make install$Id$==========================================================================================
评论
Freebsd9.0 下安装 xunsearch-full-1.3.1 出现以下错误: checking for scws_new in -lscws... no configure: error: scws_new() NOT found in libscws, please check it first.
找到解决方法了 cd $prefix/lib; ln -s libuuid.so.1.0 libuuid.so; ln -s libscws.so.2.0 libscws.so;
这个目录不正确,现在加压出来是带版本号的cd xunsearch-full/sh setup.sh