Apache Solr + PHP 进行全文查询

简介:

 

环境:

JDK 1.6

apache-solr-1.2.0 [http://lucene.apache.org/solr]

tomcat 5.5.17

wamp 2.0

SolrPhpClient 开发包 [https://issues.apache.org/jira/browse/SOLR-341]

 

1.         安装solr

a)         下载apache-solr-1.2.0.zip,解压。将apache-solr-1.2.0\dist 下的apache-solr-1.2.0.war 改名为solr.war并拷贝到tomcat目录下的webapps目录中。

b)        apache-solr-1.2.0\example\ 下的 solr 目录拷贝到任意位置,如:E:\solr

c)         tomcat目录下的conf\Catalina\localhost 目录中(如果没有则手工创建该目录)创建solr.xml文件,文件内容如下:
<Context docBase="D:/tomcat/webapps/solr.war" debug="0" crossContext="true" >

1.         <Environment name="solr/home" type="java.lang.String" value="E:/solr" override="true" />

</Context>

d)        修改tomcatserver.xml文件,找到<Connector port="8080" … 项(假设tomcat监听8080端口),添加编码方式,修改后如下<Connector port="8080"  URIEncoding="UTF-8" …

e)         启动tomcat。在浏览器中输入http://localhost:8080/solr/,出现“Welcom to Solr”页面,说明安装成功。

 

2.         建立自定义索引模式

a)         打开E:\solr\conf\schema.xml 文件 找到
<fields>
……
<fields>
替换为
<fields>

1.         <field name="id" type="string" indexed="true" stored="true" required="true" />

2.         <field name="name" type=" string " indexed="true" stored="true" required="true" />

3.         <field name="address" type="text" indexed="true" stored="true" multiValued="true" required="true" />            

</fields>

<defaultSearchField>text</defaultSearchField>
替换为

<defaultSearchField>name</defaultSearchField>

删除所有< copyField …> 

3.         建立PHP客户端
wampwww目录下建立solr目录。
SolrPhpClient.zip解压,并将其中的Apache目录拷贝到www/solr目录下。

创建index.php文件,内容如下:
<!DOCTYPE html PUBLIC "-//W3C//DTD XHTML 1.0 Transitional//EN" "http://www.w3.org/TR/xhtml1/DTD/xhtml1-transitional.dtd"><html xmlns="http://www.w3.org/1999/xhtml" xml:lang="zh-CN" lang="zh-CN">

<head>

<meta content="text/html; charset=UTF-8" http-equiv="Content-Type"/>

<title></title>

</head>

<body>

<?php

  require_once( 'Apache/Solr/Service.php' );

 

  // 连接solr服务器

  $solr = new Apache_Solr_Service( '127.0.0.1', '8080', '/solr' );

  //测试是否联通

  if ( ! $solr->ping() ) {

    echo 'Solr service not responding.';

    exit;

  }

 

  //

  // 创建两条记录nuby  zhangyan

  //

 

 

  $parts = array(

    'nuby' => array(

      'id' => 1,

      'name' => '张岩',

      'address' => array( '天安门', '北京天安门' ),

    ),

    'zhangyan' => array(

      'partno' => 2,

      'name' => '张岩',

      'model' => '北京五道口',

    )

  );

   

  $documents = array();

 

  foreach ( $parts as $item => $fields ) {

    $part = new Apache_Solr_Document();

   

    foreach ( $fields as $key => $value ) {

      if ( is_array( $value ) ) {

        foreach ( $value as $datum ) {

          $part->setMultiValue( $key, $datum );

        }

      }

      else {

        $part->$key = $value;

      }

    }

   

    $documents[] = $part;

  }

   

  //

  // 创建索引

  //

  try {

    $solr->addDocuments( $documents );

    $solr->commit();

    $solr->optimize();

  }

  catch ( Exception $e ) {

    echo $e->getMessage();

  }

 

  //

  // 查询

  //

  $offset = 0;

  $limit = 10;

 

  $queries = array(

    'id: 1 OR id: 2',

    'name: 张岩',

    'name: 天安门'

  );

 

  foreach ( $queries as $query ) {

    $response = $solr->search( $query, $offset, $limit );

   

    if ( $response->getHttpStatus() == 200 ) {

      if ( $response->response->numFound > 0 ) {

        foreach ( $response->response->docs as $doc ) {

          echo "$doc->partno $doc->name <br />";

        }

        echo '<br />';

      }

    }

    else {

      echo $response->getHttpStatusMessage();

    }

  }

?>

</body>

</html>


本文转自holy2009 51CTO博客,原文链接:http://blog.51cto.com/holy2010/326747

相关文章
|
6月前
|
Ubuntu Apache PHP
解决Ubuntu下Apache不解析PHP问题
解决Ubuntu下Apache不解析PHP问题
|
1天前
|
数据库连接 PHP Apache
PHP在Apache中如何运行?
PHP在Apache中如何运行?
8 5
|
5月前
|
存储 SQL BI
毫秒级查询性能优化实践!基于阿里云数据库 SelectDB 版内核:Apache Doris 在极越汽车数字化运营和营销方向的解决方案
毫秒级查询性能优化实践!基于阿里云数据库 SelectDB 版内核:Apache Doris 在极越汽车数字化运营和营销方向的解决方案
毫秒级查询性能优化实践!基于阿里云数据库 SelectDB 版内核:Apache Doris 在极越汽车数字化运营和营销方向的解决方案
|
2月前
|
存储 JSON 物联网
查询性能提升 10 倍、存储空间节省 65%,Apache Doris 半结构化数据分析方案及典型场景
本文我们将聚焦企业最普遍使用的 JSON 数据,分别介绍业界传统方案以及 Apache Doris 半结构化数据存储分析的三种方案,并通过图表直观展示这些方案的优势与不足。同时,结合具体应用场景,分享不同需求场景下的使用方式,帮助用户快速选择最合适的 JSON 数据存储及分析方案。
查询性能提升 10 倍、存储空间节省 65%,Apache Doris 半结构化数据分析方案及典型场景
|
3月前
|
存储 消息中间件 人工智能
AI大模型独角兽 MiniMax 基于阿里云数据库 SelectDB 版内核 Apache Doris 升级日志系统,PB 数据秒级查询响应
早期 MiniMax 基于 Grafana Loki 构建了日志系统,在资源消耗、写入性能及系统稳定性上都面临巨大的挑战。为此 MiniMax 开始寻找全新的日志系统方案,并基于阿里云数据库 SelectDB 版内核 Apache Doris 升级了日志系统,新系统已接入 MiniMax 内部所有业务线日志数据,数据规模为 PB 级, 整体可用性达到 99.9% 以上,10 亿级日志数据的检索速度可实现秒级响应。
AI大模型独角兽 MiniMax 基于阿里云数据库 SelectDB 版内核 Apache Doris 升级日志系统,PB 数据秒级查询响应
|
3月前
|
关系型数据库 MySQL 应用服务中间件
win7系统搭建PHP+Mysql+Apache环境+部署ecshop项目
这篇文章介绍了如何在Windows 7系统上搭建PHP、MySQL和Apache环境,并部署ECShop项目,包括安装配置步骤、解决常见问题以及使用XAMPP集成环境的替代方案。
54 1
win7系统搭建PHP+Mysql+Apache环境+部署ecshop项目
|
3月前
|
前端开发 关系型数据库 MySQL
最新黑名单查询录入系统PHP网站源码
最新黑名单查询录入系统PHP网站源码 前端html 后端layui 操作部分都采用API接口的方式实线 集结了layui表格的多数据操作,添加,批量删除,分页,单项删除 后台数据修改采用绑定参数的形式来进行修改可以很好的预防数据库注入,当然如果你想要测试这个防注入的你也可以尝试一下 PHP版本70+ 数据库Mysql 5.6 上传程序访问 http://你的域名/install 安装
93 0
|
3月前
|
关系型数据库 Linux 网络安全
"Linux系统实战:从零开始部署Apache+PHP Web项目,轻松搭建您的在线应用"
【8月更文挑战第9天】Linux作为服务器操作系统,凭借其稳定性和安全性成为部署Web项目的优选平台。本文以Apache Web服务器和PHP项目为例,介绍部署流程。首先,通过包管理器安装Apache与PHP;接着创建项目目录,并上传项目文件至该目录;根据需要配置Apache虚拟主机;最后重启Apache服务并测试项目。确保防火墙允许HTTP流量,正确配置数据库连接,并定期更新系统以维持安全。随着项目复杂度提升,进一步学习高级配置将变得必要。
318 0
|
5月前
|
JavaScript 前端开发 PHP
PHP在线生成查询产品防伪证书系统源码
PHP在线生成查询产品防伪证书系统源码,源码自带90套授权证书模板,带PSD公章模板,证书PSD源文件。 环境要求:PHP+MYSQL,PHP 版本请使用PHP5.1 ~5.3。
166 3
|
5月前
|
缓存 监控 负载均衡
使用Apache Solr进行搜索优化的技术探索
【6月更文挑战第6天】探索Apache Solr搜索优化,通过字段选择、分析器优化、索引压缩提升索引效率;优化查询分析、缓存、分组排序以增强查询性能;硬件升级、分布式部署及监控调优保证系统稳定性。实战案例展示如何在电商平台上应用这些策略,实现快速准确的搜索服务。Solr在大数据时代展现出广阔的应用潜力。

推荐镜像

更多
下一篇
无影云桌面