Solr

solr简介

Solr是Apache下的一个顶级开源项目,采用Java开发,它是基于Lucene的全文搜索服务器。Solr提供了比Lucene更为丰富的查询语言,同时实现了可配置、可扩展,并对索引、搜索性能进行了优化

solr安装

  • 官网下载安装包,最新的版本是7.5,点击下载地址进行下载,并解压文件,进入所解压的安装目录(window同理)
~$ ls solr*
solr-7.5.0.zip

~$ unzip -q solr-7.5.0.zip

~$ cd solr-7.5.0/

  • 启动solr
    Unix or MacOS:
    ~$ bin/solr start -e cloud
    
    windows:
    bin\solr.cmd start -e cloud
    
      solr-7.5.0:$ ./bin/solr start -e cloud
      Welcome to the SolrCloud example!
    
      This interactive session will help you launch a SolrCloud cluster on your local workstation.
      To begin, how many Solr nodes would you like to run in your local cluster? (specify 1-4 nodes) [2]:
    
    输入本地集群启动安装的节点数量,默认为2
    Ok, let's start up 2 Solr nodes for your example SolrCloud cluster.
    Please enter the port for node1 [8983]:
    
    输入第一个节点的服务端口号,默认8983
    Please enter the port for node2 [7574]: 
    
    输入第二个节点的端口号,默认7574
      Starting up 2 Solr nodes for your example SolrCloud cluster.
    
      Creating Solr home directory /solr-7.5.0/example/cloud/node1/solr
      Cloning /solr-7.5.0/example/cloud/node1 into
      /solr-7.5.0/example/cloud/node2
    
      Starting up Solr on port 8983 using command:
      "bin/solr" start -cloud -p 8983 -s "example/cloud/node1/solr"
    
      Waiting up to 180 seconds to see Solr running on port 8983 [\]
      Started Solr server on port 8983 (pid=34942). Happy searching!
    
    
      Starting up Solr on port 7574 using command:
      "bin/solr" start -cloud -p 7574 -s "example/cloud/node2/solr" -z localhost:9983
    
      Waiting up to 180 seconds to see Solr running on port 7574 [\]
      Started Solr server on port 7574 (pid=35036). Happy searching!
    
      INFO  - 2017-07-27 12:28:02.835; org.apache.solr.client.solrj.impl.ZkClientClusterStateProvider; Cluster at localhost:9983 ready
    

创建collection(索引的逻辑概念)

这个时候,一个两个节点的solr集群就已经启动完成,solr依靠zookeeper协调管理各个节点,solr会默认启动一个嵌套的zookeeper,启动完成后,会提示你创建集合,熟悉lucene的可以理解为创建document,用来创建数据的索引

 Now let's create a new collection for indexing documents in your 2-node cluster.
  Please provide a name for your new collection: [gettingstarted]

我这里输入techproducts,和官网一致

How many shards would you like to split techproducts into? [2]

这里默认值为2,为了让索引均匀的分布再每个节点上

 How many replicas per shard would you like to create? [2]

这里输入所以备份数量

Please choose a configuration for the techproducts collection, available options are:
_default or sample_techproducts_configs [_default]  

输入配置文件夹名称,主要的配置文件有schema.xml和solrconfig.xml,并在solr-7.5.0\server\solr\configsets文件夹下创建相应的文件夹

Uploading /solr-7.5.0/server/solr/configsets/_default/conf for config techproducts to ZooKeeper at localhost:9983

  Connecting to ZooKeeper at localhost:9983 ...
  INFO  - 2017-07-27 12:48:59.289; org.apache.solr.client.solrj.impl.ZkClientClusterStateProvider; Cluster at localhost:9983 ready
  Uploading /solr-7.5.0/server/solr/configsets/sample_techproducts_configs/conf for config techproducts to ZooKeeper at localhost:9983

  Creating new collection 'techproducts' using command:
  http://localhost:8983/solr/admin/collections?action=CREATE&name=techproducts&numShards=2&replicationFactor=2&maxShardsPerNode=2&collection.configName=techproducts

  {
  "responseHeader":{
      "status":0,
      "QTime":5460},
  "success":{
      "192.168.0.110:7574_solr":{
      "responseHeader":{
          "status":0,
          "QTime":4056},
      "core":"techproducts_shard1_replica_n1"},
      "192.168.0.110:8983_solr":{
      "responseHeader":{
          "status":0,
          "QTime":4056},
      "core":"techproducts_shard2_replica_n2"}}}

  Enabling auto soft-commits with maxTime 3 secs using the Config API

  POSTing request to Config API: http://localhost:8983/solr/techproducts/config
  {"set-property":{"updateHandler.autoSoftCommit.maxTime":"3000"}}
  Successfully set-property updateHandler.autoSoftCommit.maxTime to 3000

 SolrCloud example running, please visit: http://localhost:8983/solr

至此,solr创建techproduct已经完成,可以访问solr的管理界面http://localhost:8983/solr,接下来可以向solr添加需要搜索的数据

Linux/Mac:

solr-7.5.0:$ bin/post -c techproducts example/exampledocs/*

windows:

 C:\solr-7.5.0> java -jar -Dc=techproducts -Dauto example\exampledocs\post.jar example\exampledocs\*

example\exampledocs下的文件是solr提供测试演示的文档,正式使用的时候可以是我们自己的所需要分析的数据

  SimplePostTool version 5.0.0
  Posting files to [base] url http://localhost:8983/solr/techproducts/update...
  Entering auto mode. File endings considered are xml,json,jsonl,csv,pdf,doc,docx,ppt,pptx,xls,xlsx,odt,odp,ods,ott,otp,ots,rtf,htm,html,txt,log
  POSTing file books.csv (text/csv) to [base]
  POSTing file books.json (application/json) to [base]/json/docs
  POSTing file gb18030-example.xml (application/xml) to [base]
  POSTing file hd.xml (application/xml) to [base]
  POSTing file ipod_other.xml (application/xml) to [base]
  POSTing file ipod_video.xml (application/xml) to [base]
  POSTing file manufacturers.xml (application/xml) to [base]
  POSTing file mem.xml (application/xml) to [base]
  POSTing file money.xml (application/xml) to [base]
  POSTing file monitor.xml (application/xml) to [base]
  POSTing file monitor2.xml (application/xml) to [base]
  POSTing file more_books.jsonl (application/json) to [base]/json/docs
  POSTing file mp500.xml (application/xml) to [base]
  POSTing file post.jar (application/octet-stream) to [base]/extract
  POSTing file sample.html (text/html) to [base]/extract
  POSTing file sd500.xml (application/xml) to [base]
  POSTing file solr-word.pdf (application/pdf) to [base]/extract
  POSTing file solr.xml (application/xml) to [base]
  POSTing file test_utf8.sh (application/octet-stream) to [base]/extract
  POSTing file utf8-example.xml (application/xml) to [base]
  POSTing file vidcard.xml (application/xml) to [base]
  21 files indexed.
  COMMITting Solr index changes to http://localhost:8983/solr/techproducts/update...
  Time spent: 0:00:00.822

到这里,我们的solr加入了分析的数据,并且solr会根据文件的特性,生成默认的field

小试牛刀

solr提供界面进行搜索,操作简单,同事提供接口对外进行搜索,这里展示接口的方式搜索

  • Search for a Single Term
    根据关键字foundation进行搜索

     curl "http://localhost:8983/solr/techproducts/select?q=foundation"
    
  • Field Searches
    搜索字段cat并等于electronics的文件

     curl "http://localhost:8983/solr/techproducts/select?q=cat:electronics"
    
  • Phrase Search
    搜索包含CAS latency的文件

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

推荐阅读更多精彩内容

  • Solr的两种部署模式 Solr程序包安装好后,可以以两种模式来启动solr服务器: Standalone Ser...
    WinnXUDONG阅读 998评论 0 0
  • solr script solr如何启动: bin/solr start 需注意新版本的solr需要jdk1.8 ...
    扣鼻屎的猪阅读 1,064评论 0 1
  • 1:下载solr的安装包,目前最新版本是6.6.0 要求jdk1.8+ 百度网盘 2: 解压 tar -zxvf ...
    哈德丝阅读 419评论 0 1
  • 两年前用过solr5.1版本的,当时只是简单入个门,拿来在项目里建个全文索引,然后再query,其他什么也没做,还...
    Coselding阅读 3,097评论 3 22
  • 1. Solr 官网 搜索引擎是指一个庞大的互联网资源数据库,如网页,新闻组,程序,图像等。它有助于在万维网上定位...
    _凌浩雨阅读 2,197评论 0 4