Solr的使用 — 部署和数据推送

原文:https://www.fanhaobai.com/2017/08/solr-install-push.html

来到 ziroom 后,我使用 Solr 支持业务也有段时间了,大多数情况下 Solr 满足业务需求,但由于 Solr 随着数据量急剧上升后检索性能和更新索引效率衰退较快,同时一些历史遗留原因导致字段较多不易维护,现架构上已将搜索引擎迁移到了 ES。在这里整理记录自己使用 Solr 的点滴,供后续学习和使用时参考。

Solr的使用 系列的重点应是 Solr 的检索,如果需要可以直接传送到 Sorl检索 部分。

部署

由于该 Solr 平台只供学习使用,所以直接采用 Docker 方式部署,这样能避免一些复杂的依赖环境导致的问题。

下载

Hub 拉取 Solr 官方镜像 到本地,这里只选择 5.5 版本:

$ docker pull solr:5.5

安装

Docker 需要通过挂载宿主机目录的方式持久化数据,先创建供挂载目录(注意目录读写权限):

$ mkdir -p /home/docker/solr

启动 容器,挂载数据目录,隐射监听端口:

$ docker --name solr -p 127.0.0.1:8983:8983 -v /home/docker/solr:/opt/solr/server/solr -d solr:5.5

我们往往需要修改容器的一些默认参数(Solr 的配置),需要我们登入容器:

$ docker exec -it solr /bin/bash

注:由于容器中 /opt/solr/server/solr 会默认存在一些 Solr 启动的必须配置文件,直接将空目录挂载到该目录,会导致容器启动失败。可以先将目录挂载到 /opt/solr/mydata 目录,启动容器后cp /opt/solr/server/solr/* /opt/solr/mydata/,获得这些配置文件后,重新以上述地址挂载启动容器即可。

配置Web服务

Solr 容器启动成功后,配置 Web 服务器到 8983 端口,访问后看到 Solr Admin 页面,就表示安装成功了。

向 Solr 里推送数据,需要先建立 Core(核),然后在 Core 上创建或更新 Document(文档)。

新建Core

Core 默认路径为/opt/solr/server/solr。有两种方式新建 Core,方式一 是使用命令:

$ bin/solr create_core -c books
Creating new core 'books'
{
  "responseHeader":{
    "status":0,
    "QTime":1140},
  "core":"books"}

#删除核使用delete

方式二:在 Admin 面板点击 “Core Admin >> Add Core”,填写 name、instanceDir、dataDir、config、schema(文档的字段类型描述) 信息即可。由于 config 和 schema 配置可由模板生成,所以我偏向于使用命令方式创建。

注:方式一和方式二,其实都是通过/solr/admin/cores?action=CREATE这个 API 来完成创建任务。

新建 Core 后,可选中 books 核,点击 “Files”,这里列举出后面需要使用的 2 个配置文件:

$ pwd
/opt/solr/server/solr/bools/conf
#使用命令创建后自动生成,后续新建文档的字段类型描述需加入其中
managed-schema
solrconfig.xml

新建Document(s)

Document 存放着数据记录,新建 Document 后就可以使用 Solr 检索了。这里需存入 book 的数据格式(例如 json)如下:

{
    "id" : "978-0641723445",
    "cat" : ["book", "hardcover"],
    "name" : "The Lightning Thief",
    "author" : "Rick Riordan",
    "price" : 12.50
}

配置字段类型

如果没有配置字段映射类型推送数据时,Solr 会自动根据字段值设置字段的映射类型,并保存在core-name/conf/managed-schema文件,但是有时结果并不是我们想要的,所以配置文档的字段类型描述很有必要。

从上述 book 的数据可得,各个 Document 的字段类型关系:

字段名 类型 是否只被索引
id string
cat strings
name string
author strings
price tdouble

字段类型通过文件schema.xml描述,需放置于 Core 的 conf 目录,文档格式可以参考managed-schema文件,基本要素大致为:

<?xml version="1.0" encoding="UTF-8"?>
<!-- ![需更改]schema.name需要同core名一致 -->
<schema name="books" version="1.6">
    <!-- ![需更改]唯一键,重复时记录会覆盖 -->
    <uniqueKey>id</uniqueKey>
    <!-- ![无需更改]fieldType定义字段值类型,这里只列举了部分 -->
    <fieldType name="boolean" class="solr.BoolField" sortMissingLast="true"/><!-- as: true -->
    <fieldType name="booleans" class="solr.BoolField" sortMissingLast="true" multiValued="true"/><!-- as: [true,false,true] -->
    <fieldType name="int" class="solr.TrieIntField" positionIncrementGap="0" precisionStep="0"/>
    ... ...
    <!-- ![需更改]field定义各字段类型,type为fieldType.name定义值,indexed=false使用只用于返回而无需进行搜索的字段,stored=false适用只需要搜索而无需返回的字段,required=true字段值必须存在 -->
    <field name="_version_" type="long" indexed="true" stored="true"/>
    <field name="author" type="strings"/>
    <field name="cat" type="strings"/>
    <field name="id" type="string" indexed="true" required="true" stored="true"/>
    <field name="name" type="string"/>
    <field name="price" type="tdouble"/>
    ... ...
    <!-- ![无需更改]dynamicField -->
    <dynamicField name="*_s" type="string" indexed="true" stored="true"/>
    ... ...
    <copyField source="*" dest="_text_"/>
</schema>

注:如果后续更新 schema.xml 配置后,需要对 Core 进行 Reload 操作,否则检索时字段类型可能未变更。可以点击 “Core Admin >> Reload” 操作。

推送数据

Solr 支持的数据源类型较多,为 xml、json、csv 等格式。

方式一:使用 post 命令:

#post工具
$ bin/post -c books server/solr/data/books.json

books.json是以 json 格式描述的一些 book,可以批量推送数据。

方式二:在 Admin 面板点击 “books >> Documents”,在 Document(s) 一栏中输入一个 book 信息,并点击 “ Submit Document” 即可。成功右侧会返回:

Status: success
Response:
{
  "responseHeader": {
    "status": 0,
    "QTime": 12
  }
}

也可以通过 检索,可以查看数据推送是否成功,检索结果为:

"docs": [
{
    "id": "978-0641723445",
    "cat": [
        "book",
        "hardcover"
    ],
    "name": "The Lightning Thief",
    "author": [
        "Rick Riordan"
    ],
    "price": 12.5,
    "_version_": 1575546976608452600
}]

注:方式一和二其实是殊途同归,都是 POST 请求solr/books/update?wt=json这个 API。

删除Document(s)

删除 Document 其实也是 update 操作,同样有两种方式。

先使用 xml 格式构建需要删除 Document 的条件描述del-book.xml,如删除 id 为 978-0641723445 的 book 信息:

<delete>
    <!-- 要删除文档的query条件 -->
    <query>id:978-0641723445</query>
</delete>
<!-- commit一定要,否则不会提交修改到索引 -->
<commit/>

方式一:同样使用 post 命令:

$ bin/post -c books server/solr/data/del-book.xml
#这里会自动提交commit,所以del-book.xml中无commit也可以
COMMITting Solr index changes to http://localhost:8983/solr/books/update..

方式二:在 Admin 面板点击 “books >> Documents”,Document Type 项选择 xml,然后在 Document(s) 一栏中输入需要删除 book 的条件描述(del-book.xml 内容),并点击 “ Submit Document” 即可。

重新检索,可以发现 id 为 978-0641723445 的 book 信息已经被成功删除。

注:方式一和二都是 POST 请求solr/books/update?wt=json这个 API。

总结

本文仅仅叙述了 Solr 的 Docker 单节点部署和简单的数据推送实现,由于个人能力和时间限制,并未涉及到其生成环境的应用环节。后续的一篇文章将会记录 Solr 的检索语法和 PHP 作为客户端调用 Solr 服务的一种方案。

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 214,922评论 6 497
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 91,591评论 3 389
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 160,546评论 0 350
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 57,467评论 1 288
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 66,553评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 50,580评论 1 293
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,588评论 3 414
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,334评论 0 270
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,780评论 1 307
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,092评论 2 330
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,270评论 1 344
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,925评论 5 338
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,573评论 3 322
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,194评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,437评论 1 268
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,154评论 2 366
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,127评论 2 352

推荐阅读更多精彩内容