热门标签 | HotTags
当前位置:  开发笔记 > 编程语言 > 正文

使用Solr构建企业级的全文检索(一)---------开篇

换了个工作单位,也就换了从事的项目的业务类型。新的项目中要需要使用全文检索功能,由于项目是基于SQLserver的应用,所以旧的设计也就使用了SQLserver的Full-textSearch

换了个工作单位,也就换了从事的项目的业务类型。新的项目中要需要使用全文检索功能,由于项目是基于SQL server的应用,所以旧的设计也就使用了SQL server的Full-text Search Engine来实现全文检索功能。在使用SQL server 的全文检索功能的过程中,发现有很多的问题不能很好的解决,比如Cache,一般来说,对于SQL server的缓存也就是执行计划的缓存和查询结果的页面缓存,远远不够,而且也很难根据自己的业务需要去调整缓存的参数。另外对于多语言的分词算法问题,SQL server虽然内置了50多种语言的支持,但是都不够完美,如果自己想要进行替换,应该是很困难的。还不支持Highlighting,还有现在应用很广泛的Faceting以及Field Collapsing。客户推荐我们使用一下Solr来改进全文检索功能,所以我就花了些时间来研究了下Solr,并打算写一些文章总结一下Solr的使用,也希望对各位同学有帮助吧。

    唧唧歪歪说了一堆,现在就进入正题吧 。

首先介绍一下Solr是什么。要说Solr,先说说Lucene。Lucene是Apache基金会一个全文检索库类库的项目,这个项目的开源的,这个类库是使用Java开发的,功能非常强大,如果大家感兴趣可以去看看http://lucene.apache.org/.当然这个类库也有几个其它语言的实现,比如Python,也有.net的叫做lucene.net,不过因为社区活跃度不高,Apache基金会已经不再赞助这个子项目了。 如果哪位同学希望把全文检索的功能集成在自己的系统里面,或者扩展luence的全文检索功能,那应该好好学学Lucene。如果你只想使用全文检索,对底层的算法和逻辑既不想研究也不想干预,那么Solr可能是一个更好的选择。简单的说,Solr就是使用Lucene库实现的一个http服务,当然他也做了很多的扩展。你可以将Solr部署在任何一个Java Serverlet容器里,比如Tomcat,Jetty。你可以通过RESTful的url就可以和Solr进行通信,进行文档的indexing和检索。这样一来,易用性就得到大大的提升,因为不管你的项目是基于什么操作系统平台的,使用什么语言开发的,只要你能和http服务器进行通信,就能非常简单快捷的在你的项目中实现全文检索功能。如果要更加详细的谅解Solr的相关信息,请访问:http://lucene.apache.org/solr/

接下来我们需要下载和部署Solr。从 http://mirror.bjtu.edu.cn/apache//lucene/solr/这个页面里选择下载最新的版本,目前是3.5.0,刚刚出炉的。在安装前有几个准备工作要做。Solr是用Java实现的,所以毫无疑问Java的虚拟机是要的,不管你是在Window上安装,还是在Linux上安装,点击这里下载JDK,安装完JDK别忘了检查JAVA_HOME环境变量是否设置了。另外,如果你打算使用Tomcat的话,那就得先安装Tomcat,点击这里了下载。其实在实践和练习的时候是用Jetty是比较方便的。如果你在windows上使用Solr,那么把刚才下载的Solr文件包加开,使用dos 命令行控制台进入example目录,输入java -jar start.jar,然后回车,如果没有什么异常信息,Solr就启动起来了。现在你打开浏览器,输入http://localhost:8983/solr/admin/,就可以进入Solr的管理控制台了,如下图

简单的安装已经完成,可以进行文档索引和查询了。

今天的开篇就到这里吧,算是准备了一个环境。后续我会写一系列文章来介绍Solr的使用。

在提供一些对大家准备环境有帮助的信息:

Solr client for .Net --google code上的项目,项目的负责人很积极,如果你提交了Issue或者Defect,他会持续的关注和反馈。

 

         

 


推荐阅读
  • 本文旨在解决 MySQL 无法连接到 localhost 的常见问题,并提供详细的步骤来确保 MySQL 服务正确启动和配置。 ... [详细]
  • vue引入echarts地图的四种方式
    一、vue中引入echart1、安装echarts:npminstallecharts--save2、在main.js文件中引入echarts实例:  Vue.prototype.$echartsecharts3、在需要用到echart图形的vue文件中引入:   importechartsfrom"echarts";4、如果用到map(地图),还 ... [详细]
  • Ubuntu 22.04 安装搜狗输入法详细指南及常见问题解决方案
    本文将详细介绍如何在 Ubuntu 22.04 上安装搜狗输入法,并提供常见问题的解决方法。包括下载安装包、更新源、安装依赖项等步骤。 ... [详细]
  • 直播带货系统中的推流技术详解
    本文介绍了RTMP(实时消息传输协议)及其在直播带货系统中的应用,并详细探讨了带货直播系统的连麦方案,包括服务端合流和客户端合流的优势与劣势。 ... [详细]
  • 如何配置VisualSVN以确保提交时必须填写日志信息
    在软件开发团队中,成员们有时会忘记在提交代码时添加必要的备注信息。为了规范这一流程,可以通过配置VisualSVN来强制要求团队成员在提交文件时填写日志信息。本文将详细介绍如何设置这一功能。 ... [详细]
  • 本文介绍了 Go 语言中的高性能、可扩展、轻量级 Web 框架 Echo。Echo 框架简单易用,仅需几行代码即可启动一个高性能 HTTP 服务。 ... [详细]
  • Docker 环境下 MySQL 双主同步配置指南
    本文介绍了如何在 Docker 环境中配置 MySQL 的双主同步,包括目录结构的创建、配置文件的编写、容器的创建与设置以及最终的验证步骤。 ... [详细]
  • MySQL Server 8.0.28 升级至 8.0.30 的详细步骤
    为了修复安全漏洞,本文档提供了从 MySQL Server 8.0.28 升级到 8.0.30 的详细步骤,包括备份数据库、停止和删除旧服务、安装新版本以及配置相关环境变量。 ... [详细]
  • 华为捐赠欧拉操作系统,承诺不推商用版
    华为近日宣布将欧拉开源操作系统捐赠给开放原子开源基金会,并承诺不会推出欧拉的商用发行版。此举旨在推动欧拉和鸿蒙操作系统的全场景融合与生态发展。 ... [详细]
  • 包含phppdoerrorcode的词条 ... [详细]
  • 一、Tomcat安装后本身提供了一个server,端口配置默认是8080,对应目录为:..\Tomcat8.0\webapps二、Tomcat8.0配置多个端口,其实也就是给T ... [详细]
  • 在 CentOS 7 环境中使用 MySQL 5.6 镜像启动数据库时遇到权限问题,本文将详细探讨并提供解决方案。 ... [详细]
  • HTTP(HyperTextTransferProtocol)是超文本传输协议的缩写,它用于传送www方式的数据。HTTP协议采用了请求响应模型。客服端向服务器发送一 ... [详细]
  • 本文介绍了如何使用Flume从Linux文件系统收集日志并存储到HDFS,然后通过MapReduce清洗数据,使用Hive进行数据分析,并最终通过Sqoop将结果导出到MySQL数据库。 ... [详细]
  • 基于iSCSI的SQL Server 2012群集测试(一)SQL群集安装
    一、测试需求介绍与准备公司计划服务器迁移过程计划同时上线SQLServer2012,引入SQLServer2012群集提高高可用性,需要对SQLServ ... [详细]
author-avatar
溪边莎草
这个家伙很懒,什么也没留下!
PHP1.CN | 中国最专业的PHP中文社区 | DevBox开发工具箱 | json解析格式化 |PHP资讯 | PHP教程 | 数据库技术 | 服务器技术 | 前端开发技术 | PHP框架 | 开发工具 | 在线工具
Copyright © 1998 - 2020 PHP1.CN. All Rights Reserved | 京公网安备 11010802041100号 | 京ICP备19059560号-4 | PHP1.CN 第一PHP社区 版权所有