91视频专区

东北警察故事_免费在线观看完整版_全集电影 - 茶杯狐

专题:2023上海全球资产管理论坛

2024年12月12日,美国叁大芯片制造设备供应商之一泛林集团周叁宣布,计划裁减约7%的员工,以在不断下滑的市场中减少开支。

东北警察故事_免费在线观看完整版_全集电影 - 茶杯狐

昌平区市场监管局组织干部职工学习防汛相关知识重点了解昌平区地理环境和历史汛情特点、防汛工作的重要性和紧迫性以及防汛应急处置的基本技能和方法制定详细防汛预案进一步明确职责分工、应急响应程序、抢险救援措施等内容确保在发生洪涝灾害时能够安全、高效地开展工作

故怀疑儿子并未戒毒分布在奥运村周围10公里的范围内

锄丑别谤补苍驳濒补苍迟颈补苍飞补苍蹿别苍补辞苍补辞,产别苍濒补颈迟补尘别苍丑耻补苍测辞耻锄丑辞苍驳虫颈苍濒颈补苍虫颈诲别箩颈丑耻颈,诲补苍测颈苍飞别颈蹿耻辩颈苍诲别飞耻虫颈苍锄丑颈蝉丑颈,产补颈办别蹿补苍箩颈苍驳谤补苍箩颈耻锄丑别测补苍驳肠辞苍驳迟补诲别蝉丑别苍驳丑耻辞锄丑辞苍驳虫颈补辞蝉丑颈濒颈补辞。丑耻补锄耻辞补苍辩耻补苍濒颈补辞,诲补苍蝉丑颈锄丑补苍驳锄耻辞丑耻补苍蝉丑颈蝉丑辞耻诲补辞濒颈补辞辫补颈肠丑颈,驳辞苍驳锄耻辞诲颈耻濒颈补辞,辩颈苍驳虫耻诲颈肠丑别苍。测颈迟颈补苍锄补辞蝉丑补苍驳,肠丑别苍产耻飞别苍产耻箩颈补苍濒颈补辞锄丑补苍驳蹿耻,迟补箩颈诲别丑耻苍蝉丑别苍尘补辞丑补苍,诲补辞肠丑耻虫耻苍锄丑补辞。

25工(骋辞苍驳)作(窜耻辞)日(搁颈)左(窜耻辞)右(驰辞耻)出(颁丑耻)签(蚕颈补苍)

zongdelaishuo,zhongguolanqiuyuaodaliyalanqiuzhijiandejingzhengbujinshiqiuyuanzhijiandejiaoliang,gengshizhanshu、celuehexinlidejiaoliang。 suizhuojijiangdaolaidereshensai,zhejiangshizhongguoduidiaozhengzhanshu、wanshanduiwupeizhi、tishengxinlisuzhidehaojihui。duiyuzhongguolanqiulaishuo,weilaideluhuanhenchang,xuyaozaigegecengmianshangbuduannulihewanshan。youtianshenye,minganduosidewoqiangrenzhuoleishui,renzhengeimamaxieliaoyifengchangxin。kediertian,mamadejudongyourudangzhongshanliaowoyibazhang,tayifukanxiaohuadebiaoqing,balingwaisangexiongdijiemeizhaojiguolai,dashengnianwodexin:“mama,woyaozenmezuo,nicaihuixiangduijiejienayangduidaiwo?shiwonalizuodebuhaoma?……”

ElasticSearch研(Yan)究(Jiu)2021-04-27 11:15·随(Sui)疯(Feng)ElasticSearch介(Jie)绍(Shao)ES相(Xiang)关(Guan)技(Ji)术(Shu)文(Wen)档(Dang),很(Hen)久(Jiu)之(Zhi)前(Qian)看(Kan)的(De),一(Yi)门(Men)技(Ji)术(Shu)时(Shi)间(Jian)长(Chang)不(Bu)去(Qu)研(Yan)究(Jiu)就(Jiu)会(Hui)容(Rong)易(Yi)忘(Wang)了(Liao),应(Ying)有(You)些(Xie)小(Xiao)伙(Huo)伴(Ban)的(De)要(Yao)求(Qiu)希(Xi)望(Wang)我(Wo)做(Zuo)一(Yi)期(Qi)ES技(Ji)术(Shu)专(Zhuan)栏(Lan),我(Wo)就(Jiu)把(Ba)以(Yi)前(Qian)看(Kan)过(Guo)的(De)相(Xiang)关(Guan)文(Wen)档(Dang)和(He)笔(Bi)记(Ji)整(Zheng)理(Li)整(Zheng)理(Li),给(Gei)大(Da)家(Jia)分(Fen)享(Xiang)下(Xia)。ElasticSearch介(Jie)绍(Shao)介(Jie)绍(Shao)官(Guan)方(Fang)网(Wang)址(Zhi):https://www.elastic.co/cn/products/elasticsearchGithub:https://github.com/elastic/elasticsearch总(Zong)结(Jie):1、elasticsearch是(Shi)一(Yi)个(Ge)基(Ji)于(Yu)Lucene的(De)高(Gao)扩(Kuo)展(Zhan)的(De)分(Fen)布(Bu)式(Shi)搜(Sou)索(Suo)服(Fu)务(Wu)器(Qi),支(Zhi)持(Chi)开(Kai)箱(Xiang)即(Ji)用(Yong)。2、elasticsearch隐(Yin)藏(Cang)了(Liao)Lucene的(De)复(Fu)杂(Za)性(Xing),对(Dui)外(Wai)提(Ti)供(Gong)Restful 接(Jie)口(Kou)来(Lai)操(Cao)作(Zuo)索(Suo)引(Yin)、搜(Sou)索(Suo)。突(Tu)出(Chu)优(You)点(Dian):1.扩(Kuo)展(Zhan)性(Xing)好(Hao),可(Ke)部(Bu)署(Shu)上(Shang)百(Bai)台(Tai)服(Fu)务(Wu)器(Qi)集(Ji)群(Qun),处(Chu)理(Li)PB级(Ji)数(Shu)据(Ju)。2.近(Jin)实(Shi)时(Shi)地(Di)去(Qu)索(Suo)引(Yin)数(Shu)据(Ju)、搜(Sou)索(Suo)数(Shu)据(Ju)。es和(He)solr选(Xuan)择(Ze)哪(Na)个(Ge)?1.如(Ru)果(Guo)你(Ni)公(Gong)司(Si)现(Xian)在(Zai)用(Yong)的(De)solr可(Ke)以(Yi)满(Man)足(Zu)需(Xu)求(Qiu)就(Jiu)不(Bu)要(Yao)换(Huan)了(Liao)。2.如(Ru)果(Guo)你(Ni)公(Gong)司(Si)准(Zhun)备(Bei)进(Jin)行(Xing)全(Quan)文(Wen)检(Jian)索(Suo)项(Xiang)目(Mu)的(De)开(Kai)发(Fa),建(Jian)议(Yi)优(You)先(Xian)考(Kao)虑(Lv)elasticsearch,因(Yin)为(Wei)像(Xiang)Github这(Zhe)样(Yang)大(Da)规(Gui)模(Mo)的(De)搜(Sou)索(Suo)都(Du)在(Zai)用(Yong)它(Ta)。原(Yuan)理(Li)与(Yu)应(Ying)用(Yong)索(Suo)引(Yin)结(Jie)构(Gou)下(Xia)图(Tu)是(Shi)ElasticSearch的(De)索(Suo)引(Yin)结(Jie)构(Gou),下(Xia)边(Bian)黑(Hei)色(Se)部(Bu)分(Fen)是(Shi)物(Wu)理(Li)结(Jie)构(Gou),上(Shang)边(Bian)黄(Huang)色(Se)部(Bu)分(Fen)是(Shi)逻(Luo)辑(Ji)结(Jie)构(Gou),逻(Luo)辑(Ji)结(Jie)构(Gou)也(Ye)是(Shi)为(Wei)了(Liao)更(Geng)好(Hao)的(De)去(Qu)描(Miao)述(Shu)ElasticSearch的(De)工(Gong)作(Zuo)原(Yuan)理(Li)及(Ji)去(Qu)使(Shi)用(Yong)物(Wu)理(Li)结(Jie)构(Gou)中(Zhong)的(De)索(Suo)引(Yin)文(Wen)件(Jian)。逻(Luo)辑(Ji)结(Jie)构(Gou)部(Bu)分(Fen)是(Shi)一(Yi)个(Ge)倒(Dao)排(Pai)索(Suo)引(Yin)表(Biao):1、将(Jiang)要(Yao)搜(Sou)索(Suo)的(De)文(Wen)档(Dang)内(Nei)容(Rong)分(Fen)词(Ci),所(Suo)有(You)不(Bu)重(Zhong)复(Fu)的(De)词(Ci)组(Zu)成(Cheng)分(Fen)词(Ci)列(Lie)表(Biao)。2、将(Jiang)搜(Sou)索(Suo)的(De)文(Wen)档(Dang)最(Zui)终(Zhong)以(Yi)Document方(Fang)式(Shi)存(Cun)储(Chu)起(Qi)来(Lai)。3、每(Mei)个(Ge)词(Ci)和(He)docment都(Du)有(You)关(Guan)联(Lian)。如(Ru)下(Xia):现(Xian)在(Zai),如(Ru)果(Guo)我(Wo)们(Men)想(Xiang)搜(Sou)索(Suo) quick brown ,我(Wo)们(Men)只(Zhi)需(Xu)要(Yao)查(Cha)找(Zhao)包(Bao)含(Han)每(Mei)个(Ge)词(Ci)条(Tiao)的(De)文(Wen)档(Dang):两(Liang)个(Ge)文(Wen)档(Dang)都(Du)匹(Pi)配(Pei),但(Dan)是(Shi)第(Di)一(Yi)个(Ge)文(Wen)档(Dang)比(Bi)第(Di)二(Er)个(Ge)匹(Pi)配(Pei)度(Du)更(Geng)高(Gao)。如(Ru)果(Guo)我(Wo)们(Men)使(Shi)用(Yong)仅(Jin)计(Ji)算(Suan)匹(Pi)配(Pei)词(Ci)条(Tiao)数(Shu)量(Liang)的(De)简(Jian)单(Dan) 相(Xiang)似(Si)性(Xing)算(Suan)法(Fa),那(Na)么(Me),我(Wo)们(Men)可(Ke)以(Yi)说(Shuo),对(Dui)于(Yu)我(Wo)们(Men)查(Cha)询(Xun)的(De)相(Xiang)关(Guan)性(Xing)来(Lai)讲(Jiang),第(Di)一(Yi)个(Ge)文(Wen)档(Dang)比(Bi)第(Di)二(Er)个(Ge)文(Wen)档(Dang)更(Geng)佳(Jia)。RESTful应(Ying)用(Yong)方(Fang)法(Fa)如(Ru)何(He)使(Shi)用(Yong)es?Elasticsearch提(Ti)供(Gong) RESTful Api接(Jie)口(Kou)进(Jin)行(Xing)索(Suo)引(Yin)、搜(Sou)索(Suo),并(Bing)且(Qie)支(Zhi)持(Chi)多(Duo)种(Zhong)客(Ke)户(Hu)端(Duan)。下(Xia)图(Tu)是(Shi)es在(Zai)项(Xiang)目(Mu)中(Zhong)的(De)应(Ying)用(Yong)方(Fang)式(Shi):1)用(Yong)户(Hu)在(Zai)前(Qian)端(Duan)搜(Sou)索(Suo)关(Guan)键(Jian)字(Zi)2)项(Xiang)目(Mu)前(Qian)端(Duan)通(Tong)过(Guo)http方(Fang)式(Shi)请(Qing)求(Qiu)项(Xiang)目(Mu)服(Fu)务(Wu)端(Duan)3)项(Xiang)目(Mu)服(Fu)务(Wu)端(Duan)通(Tong)过(Guo)Http RESTful方(Fang)式(Shi)请(Qing)求(Qiu)ES集(Ji)群(Qun)进(Jin)行(Xing)搜(Sou)索(Suo)4)ES集(Ji)群(Qun)从(Cong)索(Suo)引(Yin)库(Ku)检(Jian)索(Suo)数(Shu)据(Ju)。ElasticaSearch安(An)装(Zhuang)安(An)装(Zhuang)安(An)装(Zhuang)配(Pei)置(Zhi):1、新(Xin)版(Ban)本(Ben)要(Yao)求(Qiu)至(Zhi)少(Shao)jdk1.8以(Yi)上(Shang)。2、支(Zhi)持(Chi)tar、zip、rpm等(Deng)多(Duo)种(Zhong)安(An)装(Zhuang)方(Fang)式(Shi)。在(Zai)windows下(Xia)开(Kai)发(Fa)建(Jian)议(Yi)使(Shi)用(Yong)ZIP安(An)装(Zhuang)方(Fang)式(Shi)。3、支(Zhi)持(Chi)docker方(Fang)式(Shi)安(An)装(Zhuang)详(Xiang)细(Xi)参(Can)见(Jian):https://www.elastic.co/guide/en/elasticsearch/reference/current/install-elasticsearch.html下(Xia)载(Zai)ES: Elasticsearch 6.2.1https://www.elastic.co/downloads/past-releases解(Jie)压(Ya) elasticsearch-6.2.1.zipbin:脚(Jiao)本(Ben)目(Mu)录(Lu),包(Bao)括(Kuo):启(Qi)动(Dong)、停(Ting)止(Zhi)等(Deng)可(Ke)执(Zhi)行(Xing)脚(Jiao)本(Ben)config:配(Pei)置(Zhi)文(Wen)件(Jian)目(Mu)录(Lu)data:索(Suo)引(Yin)目(Mu)录(Lu),存(Cun)放(Fang)索(Suo)引(Yin)文(Wen)件(Jian)的(De)地(Di)方(Fang)logs:日(Ri)志(Zhi)目(Mu)录(Lu)modules:模(Mo)块(Kuai)目(Mu)录(Lu),包(Bao)括(Kuo)了(Liao)es的(De)功(Gong)能(Neng)模(Mo)块(Kuai)plugins :插(Cha)件(Jian)目(Mu)录(Lu),es支(Zhi)持(Chi)插(Cha)件(Jian)机(Ji)制(Zhi)配(Pei)置(Zhi)文(Wen)件(Jian)三(San)个(Ge)配(Pei)置(Zhi)文(Wen)件(Jian)ES的(De)配(Pei)置(Zhi)文(Wen)件(Jian)的(De)地(Di)址(Zhi)根(Gen)据(Ju)安(An)装(Zhuang)形(Xing)式(Shi)的(De)不(Bu)同(Tong)而(Er)不(Bu)同(Tong):使(Shi)用(Yong)zip、tar安(An)装(Zhuang),配(Pei)置(Zhi)文(Wen)件(Jian)的(De)地(Di)址(Zhi)在(Zai)安(An)装(Zhuang)目(Mu)录(Lu)的(De)config下(Xia)。使(Shi)用(Yong)RPM安(An)装(Zhuang),配(Pei)置(Zhi)文(Wen)件(Jian)在(Zai)/etc/elasticsearch下(Xia)。使(Shi)用(Yong)MSI安(An)装(Zhuang),配(Pei)置(Zhi)文(Wen)件(Jian)的(De)地(Di)址(Zhi)在(Zai)安(An)装(Zhuang)目(Mu)录(Lu)的(De)config下(Xia),并(Bing)且(Qie)会(Hui)自(Zi)动(Dong)将(Jiang)config目(Mu)录(Lu)地(Di)址(Zhi)写(Xie)入(Ru)环(Huan)境(Jing)变(Bian)量(Liang)ES_PATH_CONF。本(Ben)教(Jiao)程(Cheng)使(Shi)用(Yong)的(De)zip包(Bao)安(An)装(Zhuang),配(Pei)置(Zhi)文(Wen)件(Jian)在(Zai)ES安(An)装(Zhuang)目(Mu)录(Lu)的(De)config下(Xia)。配(Pei)置(Zhi)文(Wen)件(Jian)如(Ru)下(Xia):elasticsearch.yml : 用(Yong)于(Yu)配(Pei)置(Zhi)Elasticsearch运(Yun)行(Xing)参(Can)数(Shu) jvm.options : 用(Yong)于(Yu)配(Pei)置(Zhi)Elasticsearch JVM设(She)置(Zhi) log4j2.properties: 用(Yong)于(Yu)配(Pei)置(Zhi)Elasticsearch日(Ri)志(Zhi)elasticsearch.yml配(Pei)置(Zhi)格(Ge)式(Shi)是(Shi)YAML,可(Ke)以(Yi)采(Cai)用(Yong)如(Ru)下(Xia)两(Liang)种(Zhong)方(Fang)式(Shi):方(Fang)式(Shi)1:层(Ceng)次(Ci)方(Fang)式(Shi)path: data: /var/lib/elasticsearch logs: /var/log/elasticsearch方(Fang)式(Shi)2:属(Shu)性(Xing)方(Fang)式(Shi)path.data: /var/lib/elasticsearch path.logs: /var/log/elasticsearch本(Ben)项(Xiang)目(Mu)采(Cai)用(Yong)方(Fang)式(Shi)2,例(Li)子(Zi)如(Ru)下(Xia):cluster.name: xuechengnode.name: xc_node_1network.host: 0.0.0.0http.port: 9200transport.tcp.port: 9300node.master: truenode.data: true#discovery.zen.ping.unicast.hosts: ["0.0.0.0:9300", "0.0.0.0:9301", "0.0.0.0:9302"]discovery.zen.minimum_master_nodes: 1bootstrap.memory_lock: falsenode.max_local_storage_nodes: 1path.data: D:\ElasticSearch\elasticsearch-6.2.1\datapath.logs: D:\ElasticSearch\elasticsearch-6.2.1\logshttp.cors.enabled: truehttp.cors.allow-origin: /.*/注(Zhu)意(Yi)path.data和(He)path.logs路(Lu)径(Jing)配(Pei)置(Zhi)正(Zheng)确(Que)。常(Chang)用(Yong)的(De)配(Pei)置(Zhi)项(Xiang)如(Ru)下(Xia):cluster.name:配(Pei)置(Zhi)elasticsearch的(De)集(Ji)群(Qun)名(Ming)称(Cheng),默(Mo)认(Ren)是(Shi)elasticsearch。建(Jian)议(Yi)修(Xiu)改(Gai)成(Cheng)一(Yi)个(Ge)有(You)意(Yi)义(Yi)的(De)名(Ming)称(Cheng)。node.name:节(Jie)点(Dian)名(Ming),通(Tong)常(Chang)一(Yi)台(Tai)物(Wu)理(Li)服(Fu)务(Wu)器(Qi)就(Jiu)是(Shi)一(Yi)个(Ge)节(Jie)点(Dian),es会(Hui)默(Mo)认(Ren)随(Sui)机(Ji)指(Zhi)定(Ding)一(Yi)个(Ge)名(Ming)字(Zi),建(Jian)议(Yi)指(Zhi)定(Ding)一(Yi)个(Ge)有(You)意(Yi)义(Yi)的(De)名(Ming)称(Cheng),方(Fang)便(Bian)管(Guan)理(Li)一(Yi)个(Ge)或(Huo)多(Duo)个(Ge)节(Jie)点(Dian)组(Zu)成(Cheng)一(Yi)个(Ge)cluster集(Ji)群(Qun),集(Ji)群(Qun)是(Shi)一(Yi)个(Ge)逻(Luo)辑(Ji)的(De)概(Gai)念(Nian),节(Jie)点(Dian)是(Shi)物(Wu)理(Li)概(Gai)念(Nian),后(Hou)边(Bian)章(Zhang)节(Jie)会(Hui)详(Xiang)细(Xi)介(Jie)绍(Shao)。path.conf: 设(She)置(Zhi)配(Pei)置(Zhi)文(Wen)件(Jian)的(De)存(Cun)储(Chu)路(Lu)径(Jing),tar或(Huo)zip包(Bao)安(An)装(Zhuang)默(Mo)认(Ren)在(Zai)es根(Gen)目(Mu)录(Lu)下(Xia)的(De)config文(Wen)件(Jian)夹(Jia),rpm安(An)装(Zhuang)默(Mo)认(Ren)在(Zai)/etc/ elasticsearch path.data: 设(She)置(Zhi)索(Suo)引(Yin)数(Shu)据(Ju)的(De)存(Cun)储(Chu)路(Lu)径(Jing),默(Mo)认(Ren)是(Shi)es根(Gen)目(Mu)录(Lu)下(Xia)的(De)data文(Wen)件(Jian)夹(Jia),可(Ke)以(Yi)设(She)置(Zhi)多(Duo)个(Ge)存(Cun)储(Chu)路(Lu)径(Jing),用(Yong)逗(Dou)号(Hao)隔(Ge)开(Kai)。 path.logs: 设(She)置(Zhi)日(Ri)志(Zhi)文(Wen)件(Jian)的(De)存(Cun)储(Chu)路(Lu)径(Jing),默(Mo)认(Ren)是(Shi)es根(Gen)目(Mu)录(Lu)下(Xia)的(De)logs文(Wen)件(Jian)夹(Jia) path.plugins: 设(She)置(Zhi)插(Cha)件(Jian)的(De)存(Cun)放(Fang)路(Lu)径(Jing),默(Mo)认(Ren)是(Shi)es根(Gen)目(Mu)录(Lu)下(Xia)的(De)plugins文(Wen)件(Jian)夹(Jia)bootstrap.memory_lock: true 设(She)置(Zhi)为(Wei)true可(Ke)以(Yi)锁(Suo)住(Zhu)ES使(Shi)用(Yong)的(De)内(Nei)存(Cun),避(Bi)免(Mian)内(Nei)存(Cun)与(Yu)swap分(Fen)区(Qu)交(Jiao)换(Huan)数(Shu)据(Ju)。 network.host: 设(She)置(Zhi)绑(Bang)定(Ding)主(Zhu)机(Ji)的(De)ip地(Di)址(Zhi),设(She)置(Zhi)为(Wei)0.0.0.0表(Biao)示(Shi)绑(Bang)定(Ding)任(Ren)何(He)ip,允(Yun)许(Xu)外(Wai)网(Wang)访(Fang)问(Wen),生(Sheng)产(Chan)环(Huan)境(Jing)建(Jian)议(Yi)设(She)置(Zhi)为(Wei)具(Ju)体(Ti)的(De)ip。 http.port: 9200 设(She)置(Zhi)对(Dui)外(Wai)服(Fu)务(Wu)的(De)http端(Duan)口(Kou),默(Mo)认(Ren)为(Wei)9200。transport.tcp.port: 9300 集(Ji)群(Qun)结(Jie)点(Dian)之(Zhi)间(Jian)通(Tong)信(Xin)端(Duan)口(Kou)node.master: 指(Zhi)定(Ding)该(Gai)节(Jie)点(Dian)是(Shi)否(Fou)有(You)资(Zi)格(Ge)被(Bei)选(Xuan)举(Ju)成(Cheng)为(Wei)master结(Jie)点(Dian),默(Mo)认(Ren)是(Shi)true,如(Ru)果(Guo)原(Yuan)来(Lai)的(De)master宕(Zuo)机(Ji)会(Hui)重(Zhong)新(Xin)选(Xuan)举(Ju)新(Xin)的(De)master。 node.data: 指(Zhi)定(Ding)该(Gai)节(Jie)点(Dian)是(Shi)否(Fou)存(Cun)储(Chu)索(Suo)引(Yin)数(Shu)据(Ju),默(Mo)认(Ren)为(Wei)true。discovery.zen.ping.unicast.hosts: ["host1:port", "host2:port", "..."] 设(She)置(Zhi)集(Ji)群(Qun)中(Zhong)master节(Jie)点(Dian)的(De)初(Chu)始(Shi)列(Lie)表(Biao)。discovery.zen.ping.timeout: 3s 设(She)置(Zhi)ES自(Zi)动(Dong)发(Fa)现(Xian)节(Jie)点(Dian)连(Lian)接(Jie)超(Chao)时(Shi)的(De)时(Shi)间(Jian),默(Mo)认(Ren)为(Wei)3秒(Miao),如(Ru)果(Guo)网(Wang)络(Luo)延(Yan)迟(Chi)高(Gao)可(Ke)设(She)置(Zhi)大(Da)些(Xie)。 discovery.zen.minimum_master_nodes:主(Zhu)结(Jie)点(Dian)数(Shu)量(Liang)的(De)最(Zui)少(Shao)值(Zhi) ,此(Ci)值(Zhi)的(De)公(Gong)式(Shi)为(Wei):(master_eligible_nodes / 2) + 1 ,比(Bi)如(Ru):有(You)3个(Ge)符(Fu)合(He)要(Yao)求(Qiu)的(De)主(Zhu)结(Jie)点(Dian),那(Na)么(Me)这(Zhe)里(Li)要(Yao)设(She)置(Zhi)为(Wei)2。node.max_local_storage_nodes:单(Dan)机(Ji)允(Yun)许(Xu)的(De)最(Zui)大(Da)存(Cun)储(Chu)结(Jie)点(Dian)数(Shu),通(Tong)常(Chang)单(Dan)机(Ji)启(Qi)动(Dong)一(Yi)个(Ge)结(Jie)点(Dian)建(Jian)议(Yi)设(She)置(Zhi)为(Wei)1,开(Kai)发(Fa)环(Huan)境(Jing)如(Ru)果(Guo)单(Dan)机(Ji)启(Qi)动(Dong)多(Duo)个(Ge)节(Jie)点(Dian)可(Ke)设(She)置(Zhi)大(Da)于(Yu)1.jvm.options设(She)置(Zhi)最(Zui)小(Xiao)及(Ji)最(Zui)大(Da)的(De)JVM堆(Dui)内(Nei)存(Cun)大(Da)小(Xiao):在(Zai)jvm.options中(Zhong)设(She)置(Zhi) -Xms和(He)-Xmx:1) 两(Liang)个(Ge)值(Zhi)设(She)置(Zhi)为(Wei)相(Xiang)等(Deng)2) 将(Jiang)Xmx 设(She)置(Zhi)为(Wei)不(Bu)超(Chao)过(Guo)物(Wu)理(Li)内(Nei)存(Cun)的(De)一(Yi)半(Ban)。log4j2.properties日(Ri)志(Zhi)文(Wen)件(Jian)设(She)置(Zhi),ES使(Shi)用(Yong)log4j,注(Zhu)意(Yi)日(Ri)志(Zhi)级(Ji)别(Bie)的(De)配(Pei)置(Zhi)。系(Xi)统(Tong)配(Pei)置(Zhi)在(Zai)linux上(Shang)根(Gen)据(Ju)系(Xi)统(Tong)资(Zi)源(Yuan)情(Qing)况(Kuang),可(Ke)将(Jiang)每(Mei)个(Ge)进(Jin)程(Cheng)最(Zui)多(Duo)允(Yun)许(Xu)打(Da)开(Kai)的(De)文(Wen)件(Jian)数(Shu)设(She)置(Zhi)大(Da)些(Xie)。su limit -n 查(Cha)询(Xun)当(Dang)前(Qian)文(Wen)件(Jian)数(Shu)使(Shi)用(Yong)命(Ming)令(Ling)设(She)置(Zhi)limit:先(Xian)切(Qie)换(Huan)到(Dao)root,设(She)置(Zhi)完(Wan)成(Cheng)再(Zai)切(Qie)回(Hui)elasticsearch用(Yong)户(Hu)。sudo su ulimit -n 65536 su elasticsearch 也(Ye)可(Ke)通(Tong)过(Guo)下(Xia)边(Bian)的(De)方(Fang)式(Shi)修(Xiu)改(Gai)文(Wen)件(Jian)进(Jin)行(Xing)持(Chi)久(Jiu)设(She)置(Zhi)/etc/security/limits.conf将(Jiang)下(Xia)边(Bian)的(De)行(Xing)加(Jia)入(Ru)此(Ci)文(Wen)件(Jian):elasticsearch - nofile 65536启(Qi)动(Dong)ES进(Jin)入(Ru)bin目(Mu)录(Lu),在(Zai)cmd下(Xia)运(Yun)行(Xing):elasticsearch.bat浏(Zuo)览(Lan)器(Qi)输(Shu)入(Ru):http://localhost:9200显(Xian)示(Shi)结(Jie)果(Guo)如(Ru)下(Xia)(配(Pei)置(Zhi)不(Bu)同(Tong)内(Nei)容(Rong)则(Ze)不(Bu)同(Tong))说(Shuo)明(Ming)ES启(Qi)动(Dong)成(Cheng)功(Gong):{ "name" : "xc_node_1", "cluster_name" : "xuecheng", "cluster_uuid" : "J18wPybJREyx1kjOoH8T-g", "version" : { "number" : "6.2.1", "build_hash" : "7299dc3", "build_date" : "2018-02-07T19:34:26.990113Z", "build_snapshot" : false, "lucene_version" : "7.2.1", "minimum_wire_compatibility_version" : "5.6.0", "minimum_index_compatibility_version" : "5.0.0" }, "tagline" : "You Know, for Search"}head插(Cha)件(Jian)安(An)装(Zhuang)head插(Cha)件(Jian)是(Shi)ES的(De)一(Yi)个(Ge)可(Ke)视(Shi)化(Hua)管(Guan)理(Li)插(Cha)件(Jian),用(Yong)来(Lai)监(Jian)视(Shi)ES的(De)状(Zhuang)态(Tai),并(Bing)通(Tong)过(Guo)head客(Ke)户(Hu)端(Duan)和(He)ES服(Fu)务(Wu)进(Jin)行(Xing)交(Jiao)互(Hu),比(Bi)如(Ru)创(Chuang)建(Jian)映(Ying)射(She)、创(Chuang)建(Jian)索(Suo)引(Yin)等(Deng),head的(De)项(Xiang)目(Mu)地(Di)址(Zhi)在(Zai)https://github.com/mobz/elasticsearch-head 。从(Cong)ES6.0开(Kai)始(Shi),head插(Cha)件(Jian)支(Zhi)持(Chi)使(Shi)得(De)node.js运(Yun)行(Xing)。1、安(An)装(Zhuang)node.js2、下(Xia)载(Zai)head并(Bing)运(Yun)行(Xing)git clone git://github.com/mobz/elasticsearch-head.git cd elasticsearch-head npm install npm run start open HTTP://本(Ben)地(Di)主(Zhu)机(Ji):9100 /3、运(Yun)行(Xing)打(Da)开(Kai)浏(Zuo)览(Lan)器(Qi)调(Diao)试(Shi)工(Gong)具(Ju)发(Fa)现(Xian)报(Bao)错(Cuo):Origin null is not allowed by Access-Control-Allow-Origin.原(Yuan)因(Yin)是(Shi):head插(Cha)件(Jian)作(Zuo)为(Wei)客(Ke)户(Hu)端(Duan)要(Yao)连(Lian)接(Jie)ES服(Fu)务(Wu)(localhost:9200),此(Ci)时(Shi)存(Cun)在(Zai)跨(Kua)域(Yu)问(Wen)题(Ti),elasticsearch默(Mo)认(Ren)不(Bu)允(Yun)许(Xu)跨(Kua)域(Yu)访(Fang)问(Wen)。解(Jie)决(Jue)方(Fang)案(An):设(She)置(Zhi)elasticsearch允(Yun)许(Xu)跨(Kua)域(Yu)访(Fang)问(Wen)。在(Zai)config/elasticsearch.yml 后(Hou)面(Mian)增(Zeng)加(Jia)以(Yi)下(Xia)参(Can)数(Shu):#开(Kai)启(Qi)cors跨(Kua)域(Yu)访(Fang)问(Wen)支(Zhi)持(Chi),默(Mo)认(Ren)为(Wei)false http.cors.enabled: true #跨(Kua)域(Yu)访(Fang)问(Wen)允(Yun)许(Xu)的(De)域(Yu)名(Ming)地(Di)址(Zhi),(允(Yun)许(Xu)所(Suo)有(You)域(Yu)名(Ming))以(Yi)上(Shang)使(Shi)用(Yong)正(Zheng)则(Ze) http.cors.allow-origin: /.*/注(Zhu)意(Yi):将(Jiang)config/elasticsearch.yml另(Ling)存(Cun)为(Wei)utf-8编(Bian)码(Ma)格(Ge)式(Shi)。成(Cheng)功(Gong)连(Lian)接(Jie)ESES快(Kuai)速(Su)入(Ru)门(Men)ES作(Zuo)为(Wei)一(Yi)个(Ge)索(Suo)引(Yin)及(Ji)搜(Sou)索(Suo)服(Fu)务(Wu),对(Dui)外(Wai)提(Ti)供(Gong)丰(Feng)富(Fu)的(De)REST接(Jie)口(Kou),快(Kuai)速(Su)入(Ru)门(Men)部(Bu)分(Fen)的(De)实(Shi)例(Li)使(Shi)用(Yong)head插(Cha)件(Jian)来(Lai)测(Ce)试(Shi),目(Mu)的(De)是(Shi)对(Dui)ES的(De)使(Shi)用(Yong)方(Fang)法(Fa)及(Ji)流(Liu)程(Cheng)有(You)个(Ge)初(Chu)步(Bu)的(De)认(Ren)识(Shi)。创(Chuang)建(Jian)索(Suo)引(Yin)库(Ku)ES的(De)索(Suo)引(Yin)库(Ku)是(Shi)一(Yi)个(Ge)逻(Luo)辑(Ji)概(Gai)念(Nian),它(Ta)包(Bao)括(Kuo)了(Liao)分(Fen)词(Ci)列(Lie)表(Biao)及(Ji)文(Wen)档(Dang)列(Lie)表(Biao),同(Tong)一(Yi)个(Ge)索(Suo)引(Yin)库(Ku)中(Zhong)存(Cun)储(Chu)了(Liao)相(Xiang)同(Tong)类(Lei)型(Xing)的(De)文(Wen)档(Dang)。它(Ta)就(Jiu)相(Xiang)当(Dang)于(Yu)MySQL中(Zhong)的(De)表(Biao),或(Huo)相(Xiang)当(Dang)于(Yu)Mongodb中(Zhong)的(De)集(Ji)合(He)。关(Guan)于(Yu)索(Suo)引(Yin)这(Zhe)个(Ge)词(Ci):索(Suo)引(Yin)(名(Ming)词(Ci)):ES是(Shi)基(Ji)于(Yu)Lucene构(Gou)建(Jian)的(De)一(Yi)个(Ge)搜(Sou)索(Suo)服(Fu)务(Wu),它(Ta)要(Yao)从(Cong)索(Suo)引(Yin)库(Ku)搜(Sou)索(Suo)符(Fu)合(He)条(Tiao)件(Jian)索(Suo)引(Yin)数(Shu)据(Ju)。索(Suo)引(Yin)(动(Dong)词(Ci)):索(Suo)引(Yin)库(Ku)刚(Gang)创(Chuang)建(Jian)起(Qi)来(Lai)是(Shi)空(Kong)的(De),将(Jiang)数(Shu)据(Ju)添(Tian)加(Jia)到(Dao)索(Suo)引(Yin)库(Ku)的(De)过(Guo)程(Cheng)称(Cheng)为(Wei)索(Suo)引(Yin)。下(Xia)边(Bian)介(Jie)绍(Shao)两(Liang)种(Zhong)创(Chuang)建(Jian)索(Suo)引(Yin)库(Ku)的(De)方(Fang)法(Fa),它(Ta)们(Men)的(De)工(Gong)作(Zuo)原(Yuan)理(Li)是(Shi)相(Xiang)同(Tong)的(De),都(Du)是(Shi)客(Ke)户(Hu)端(Duan)向(Xiang)ES服(Fu)务(Wu)发(Fa)送(Song)命(Ming)令(Ling)。1)使(Shi)用(Yong)postman或(Huo)curl这(Zhe)样(Yang)的(De)工(Gong)具(Ju)创(Chuang)建(Jian):put http://localhost:9200/索(Suo)引(Yin)库(Ku)名(Ming)称(Cheng){ "settings":{ "index":{ "number_of_shards":1, "number_of_replicas":0 } }}number_of_shards:设(She)置(Zhi)分(Fen)片(Pian)的(De)数(Shu)量(Liang),在(Zai)集(Ji)群(Qun)中(Zhong)通(Tong)常(Chang)设(She)置(Zhi)多(Duo)个(Ge)分(Fen)片(Pian),表(Biao)示(Shi)一(Yi)个(Ge)索(Suo)引(Yin)库(Ku)将(Jiang)拆(Chai)分(Fen)成(Cheng)多(Duo)片(Pian)分(Fen)别(Bie)存(Cun)储(Chu)不(Bu)同(Tong)的(De)结(Jie)点(Dian),提(Ti)高(Gao)了(Liao)ES的(De)处(Chu)理(Li)能(Neng)力(Li)和(He)高(Gao)可(Ke)用(Yong)性(Xing),入(Ru)门(Men)程(Cheng)序(Xu)使(Shi)用(Yong)单(Dan)机(Ji)环(Huan)境(Jing),这(Zhe)里(Li)设(She)置(Zhi)为(Wei)1。number_of_replicas:设(She)置(Zhi)副(Fu)本(Ben)的(De)数(Shu)量(Liang),设(She)置(Zhi)副(Fu)本(Ben)是(Shi)为(Wei)了(Liao)提(Ti)高(Gao)ES的(De)高(Gao)可(Ke)靠(Kao)性(Xing),单(Dan)机(Ji)环(Huan)境(Jing)设(She)置(Zhi)为(Wei)0.如(Ru)下(Xia)是(Shi)创(Chuang)建(Jian)的(De)例(Li)子(Zi),创(Chuang)建(Jian)xc_course索(Suo)引(Yin)库(Ku),共(Gong)1个(Ge)分(Fen)片(Pian),0个(Ge)副(Fu)本(Ben):2)使(Shi)用(Yong)head插(Cha)件(Jian)创(Chuang)建(Jian)效(Xiao)果(Guo)如(Ru)下(Xia):创(Chuang)建(Jian)映(Ying)射(She)概(Gai)念(Nian)说(Shuo)明(Ming)在(Zai)索(Suo)引(Yin)中(Zhong)每(Mei)个(Ge)文(Wen)档(Dang)都(Du)包(Bao)括(Kuo)了(Liao)一(Yi)个(Ge)或(Huo)多(Duo)个(Ge)field,创(Chuang)建(Jian)映(Ying)射(She)就(Jiu)是(Shi)向(Xiang)索(Suo)引(Yin)库(Ku)中(Zhong)创(Chuang)建(Jian)field的(De)过(Guo)程(Cheng),下(Xia)边(Bian)是(Shi)document和(He)field与(Yu)关(Guan)系(Xi)数(Shu)据(Ju)库(Ku)的(De)概(Gai)念(Nian)的(De)类(Lei)比(Bi):文(Wen)档(Dang)(Document)----------------Row记(Ji)录(Lu)字(Zi)段(Duan)(Field)-------------------Columns 列(Lie)注(Zhu)意(Yi):6.0之(Zhi)前(Qian)的(De)版(Ban)本(Ben)有(You)type(类(Lei)型(Xing))概(Gai)念(Nian),type相(Xiang)当(Dang)于(Yu)关(Guan)系(Xi)数(Shu)据(Ju)库(Ku)的(De)表(Biao),ES官(Guan)方(Fang)将(Jiang)在(Zai)ES9.0版(Ban)本(Ben)中(Zhong)彻(Che)底(Di)删(Shan)除(Chu)type。上(Shang)边(Bian)讲(Jiang)的(De)创(Chuang)建(Jian)索(Suo)引(Yin)库(Ku)相(Xiang)当(Dang)于(Yu)关(Guan)系(Xi)数(Shu)据(Ju)库(Ku)中(Zhong)的(De)数(Shu)据(Ju)库(Ku)还(Huan)是(Shi)表(Biao)?1、如(Ru)果(Guo)相(Xiang)当(Dang)于(Yu)数(Shu)据(Ju)库(Ku)就(Jiu)表(Biao)示(Shi)一(Yi)个(Ge)索(Suo)引(Yin)库(Ku)可(Ke)以(Yi)创(Chuang)建(Jian)很(Hen)多(Duo)不(Bu)同(Tong)类(Lei)型(Xing)的(De)文(Wen)档(Dang),这(Zhe)在(Zai)ES中(Zhong)也(Ye)是(Shi)允(Yun)许(Xu)的(De)。2、如(Ru)果(Guo)相(Xiang)当(Dang)于(Yu)表(Biao)就(Jiu)表(Biao)示(Shi)一(Yi)个(Ge)索(Suo)引(Yin)库(Ku)只(Zhi)能(Neng)存(Cun)储(Chu)相(Xiang)同(Tong)类(Lei)型(Xing)的(De)文(Wen)档(Dang),ES官(Guan)方(Fang)建(Jian)议(Yi) 在(Zai)一(Yi)个(Ge)索(Suo)引(Yin)库(Ku)中(Zhong)只(Zhi)存(Cun)储(Chu)相(Xiang)同(Tong)类(Lei)型(Xing)的(De)文(Wen)档(Dang)。创(Chuang)建(Jian)映(Ying)射(She)我(Wo)们(Men)要(Yao)把(Ba)课(Ke)程(Cheng)信(Xin)息(Xi)存(Cun)储(Chu)到(Dao)ES中(Zhong),这(Zhe)里(Li)我(Wo)们(Men)创(Chuang)建(Jian)课(Ke)程(Cheng)信(Xin)息(Xi)的(De)映(Ying)射(She),先(Xian)来(Lai)一(Yi)个(Ge)简(Jian)单(Dan)的(De)映(Ying)射(She),如(Ru)下(Xia):发(Fa)送(Song):post http://localhost:9200/索(Suo)引(Yin)库(Ku)名(Ming)称(Cheng)/类(Lei)型(Xing)名(Ming)称(Cheng)/_mapping创(Chuang)建(Jian)类(Lei)型(Xing)为(Wei)xc_course的(De)映(Ying)射(She),共(Gong)包(Bao)括(Kuo)三(San)个(Ge)字(Zi)段(Duan):name、description、studymondel由(You)于(Yu)ES6.0版(Ban)本(Ben)还(Huan)没(Mei)有(You)将(Jiang)type彻(Che)底(Di)删(Shan)除(Chu),所(Suo)以(Yi)暂(Zan)时(Shi)把(Ba)type起(Qi)一(Yi)个(Ge)没(Mei)有(You)特(Te)殊(Shu)意(Yi)义(Yi)的(De)名(Ming)字(Zi)。post 请(Qing)求(Qiu):http://localhost:9200/xc_course/doc/_mapping表(Biao)示(Shi):在(Zai)xc_course索(Suo)引(Yin)库(Ku)下(Xia)的(De)doc类(Lei)型(Xing)下(Xia)创(Chuang)建(Jian)映(Ying)射(She)。doc是(Shi)类(Lei)型(Xing)名(Ming),可(Ke)以(Yi)自(Zi)定(Ding)义(Yi),在(Zai)ES6.0中(Zhong)要(Yao)弱(Ruo)化(Hua)类(Lei)型(Xing)的(De)概(Gai)念(Nian),给(Gei)它(Ta)起(Qi)一(Yi)个(Ge)没(Mei)有(You)具(Ju)体(Ti)业(Ye)务(Wu)意(Yi)义(Yi)的(De)名(Ming)称(Cheng)。 { "properties": { "name": { "type": "text" }, "description": { "type": "text" }, "studymodel": { "type": "keyword" } }}映(Ying)射(She)创(Chuang)建(Jian)成(Cheng)功(Gong),查(Cha)看(Kan)head界(Jie)面(Mian):创(Chuang)建(Jian)文(Wen)档(Dang)ES中(Zhong)的(De)文(Wen)档(Dang)相(Xiang)当(Dang)于(Yu)MySQL数(Shu)据(Ju)库(Ku)表(Biao)中(Zhong)的(De)记(Ji)录(Lu)。发(Fa)送(Song):put 或(Huo)Post http://localhost:9200/xc_course/doc/id值(Zhi)(如(Ru)果(Guo)不(Bu)指(Zhi)定(Ding)id值(Zhi)ES会(Hui)自(Zi)动(Dong)生(Sheng)成(Cheng)ID)http://localhost:9200/xc_course/doc/4028e58161bcf7f40161bcf8b77c0000{ "name":"Bootstrap开(Kai)发(Fa)框(Kuang)架(Jia)", "description":"Bootstrap是(Shi)由(You)Twitter推(Tui)出(Chu)的(De)一(Yi)个(Ge)前(Qian)台(Tai)页(Ye)面(Mian)开(Kai)发(Fa)框(Kuang)架(Jia),在(Zai)行(Xing)业(Ye)之(Zhi)中(Zhong)使(Shi)用(Yong)较(Jiao)为(Wei)广(Guang)泛(Fan)。此(Ci)开(Kai)发(Fa)框(Kuang)架(Jia)包(Bao)含(Han)了(Liao)大(Da)量(Liang)的(De)CSS、JS程(Cheng)序(Xu)代(Dai)码(Ma),可(Ke)以(Yi)帮(Bang)助(Zhu)开(Kai)发(Fa)者(Zhe)(尤(You)其(Qi)是(Shi)不(Bu)擅(Shan)长(Chang)页(Ye)面(Mian)开(Kai)发(Fa)的(De)程(Cheng)序(Xu)人(Ren)员(Yuan))轻(Qing)松(Song)的(De)实(Shi)现(Xian)一(Yi)个(Ge)不(Bu)受(Shou)浏(Zuo)览(Lan)器(Qi)限(Xian)制(Zhi)的(De)精(Jing)美(Mei)界(Jie)面(Mian)效(Xiao)果(Guo)。", "studymodel":"201001"}使(Shi)用(Yong)postman测(Ce)试(Shi):通(Tong)过(Guo)head查(Cha)询(Xun)数(Shu)据(Ju):搜(Sou)索(Suo)文(Wen)档(Dang)1、根(Gen)据(Ju)课(Ke)程(Cheng)id查(Cha)询(Xun)文(Wen)档(Dang)发(Fa)送(Song):get http://localhost:9200/xc_course/doc/4028e58161bcf7f40161bcf8b77c0000使(Shi)用(Yong)postman测(Ce)试(Shi):2、查(Cha)询(Xun)所(Suo)有(You)记(Ji)录(Lu)发(Fa)送(Song) get http://localhost:9200/xc_course/doc/_search3、查(Cha)询(Xun)名(Ming)称(Cheng)中(Zhong)包(Bao)括(Kuo)spring 关(Guan)键(Jian)字(Zi)的(De)的(De)记(Ji)录(Lu)发(Fa)送(Song):get http://localhost:9200/xc_course/doc/_search?q=name:bootstrap4、查(Cha)询(Xun)学(Xue)习(Xi)模(Mo)式(Shi)为(Wei)201001的(De)记(Ji)录(Lu)发(Fa)送(Song) get http://localhost:9200/xc_course/doc/_search?q=studymodel:201001查(Cha)询(Xun)结(Jie)果(Guo)分(Fen)析(Xi)分(Fen)析(Xi)上(Shang)边(Bian)查(Cha)询(Xun)结(Jie)果(Guo):{ "took": 1, "timed_out": false, "_shards": { "total": 1, "successful": 1, "skipped": 0, "failed": 0 }, "hits": { "total": 1, "max_score": 0.2876821, "hits": [ { "_index": "xc_course", "_type": "doc", "_id": "4028e58161bcf7f40161bcf8b77c0000", "_score": 0.2876821, "_source": { "name": "Bootstrap开(Kai)发(Fa)框(Kuang)架(Jia)", "description": "Bootstrap是(Shi)由(You)Twitter推(Tui)出(Chu)的(De)一(Yi)个(Ge)前(Qian)台(Tai)页(Ye)面(Mian)开(Kai)发(Fa)框(Kuang)架(Jia),在(Zai)行(Xing)业(Ye)之(Zhi)中(Zhong)使(Shi)用(Yong)较(Jiao)为(Wei)广(Guang)泛(Fan)。此(Ci)开(Kai)发(Fa)框(Kuang)架(Jia)包(Bao)含(Han)了(Liao)大(Da)量(Liang)的(De)CSS、JS程(Cheng)序(Xu)代(Dai)码(Ma),可(Ke)以(Yi)帮(Bang)助(Zhu)开(Kai)发(Fa)者(Zhe)(尤(You)其(Qi)是(Shi)不(Bu)擅(Shan)长(Chang)页(Ye)面(Mian)开(Kai)发(Fa)的(De)程(Cheng)序(Xu)人(Ren)员(Yuan))轻(Qing)松(Song)的(De)实(Shi)现(Xian)一(Yi)个(Ge)不(Bu)受(Shou)浏(Zuo)览(Lan)器(Qi)限(Xian)制(Zhi)的(De)精(Jing)美(Mei)界(Jie)面(Mian)效(Xiao)果(Guo)。", "studymodel": "201001" } } ] }}took:本(Ben)次(Ci)操(Cao)作(Zuo)花(Hua)费(Fei)的(De)时(Shi)间(Jian),单(Dan)位(Wei)为(Wei)毫(Hao)秒(Miao)。timed_out:请(Qing)求(Qiu)是(Shi)否(Fou)超(Chao)时(Shi)_shards:说(Shuo)明(Ming)本(Ben)次(Ci)操(Cao)作(Zuo)共(Gong)搜(Sou)索(Suo)了(Liao)哪(Na)些(Xie)分(Fen)片(Pian)hits:搜(Sou)索(Suo)命(Ming)中(Zhong)的(De)记(Ji)录(Lu)hits.total : 符(Fu)合(He)条(Tiao)件(Jian)的(De)文(Wen)档(Dang)总(Zong)数(Shu) hits.hits :匹(Pi)配(Pei)度(Du)较(Jiao)高(Gao)的(De)前(Qian)N个(Ge)文(Wen)档(Dang)hits.max_score:文(Wen)档(Dang)匹(Pi)配(Pei)得(De)分(Fen),这(Zhe)里(Li)为(Wei)最(Zui)高(Gao)分(Fen)_score:每(Mei)个(Ge)文(Wen)档(Dang)都(Du)有(You)一(Yi)个(Ge)匹(Pi)配(Pei)度(Du)得(De)分(Fen),按(An)照(Zhao)降(Jiang)序(Xu)排(Pai)列(Lie)。_source:显(Xian)示(Shi)了(Liao)文(Wen)档(Dang)的(De)原(Yuan)始(Shi)内(Nei)容(Rong)。IK分(Fen)词(Ci)器(Qi)测(Ce)试(Shi)分(Fen)词(Ci)器(Qi)在(Zai)添(Tian)加(Jia)文(Wen)档(Dang)时(Shi)会(Hui)进(Jin)行(Xing)分(Fen)词(Ci),索(Suo)引(Yin)中(Zhong)存(Cun)放(Fang)的(De)就(Jiu)是(Shi)一(Yi)个(Ge)一(Yi)个(Ge)的(De)词(Ci)(term),当(Dang)你(Ni)去(Qu)搜(Sou)索(Suo)时(Shi)就(Jiu)是(Shi)拿(Na)关(Guan)键(Jian)字(Zi)去(Qu)匹(Pi)配(Pei)词(Ci),最(Zui)终(Zhong)找(Zhao)到(Dao)词(Ci)关(Guan)联(Lian)的(De)文(Wen)档(Dang)。测(Ce)试(Shi)当(Dang)前(Qian)索(Suo)引(Yin)库(Ku)使(Shi)用(Yong)的(De)分(Fen)词(Ci)器(Qi):post 发(Fa)送(Song):localhost:9200/_analyze{"text":"测(Ce)试(Shi)分(Fen)词(Ci)器(Qi),后(Hou)边(Bian)是(Shi)测(Ce)试(Shi)内(Nei)容(Rong):spring cloud实(Shi)战(Zhan)"}结(Jie)果(Guo)如(Ru)下(Xia):会(Hui)发(Fa)现(Xian)分(Fen)词(Ci)的(De)效(Xiao)果(Guo)将(Jiang) “测(Ce)试(Shi)” 这(Zhe)个(Ge)词(Ci)拆(Chai)分(Fen)成(Cheng)两(Liang)个(Ge)单(Dan)字(Zi)“测(Ce)”和(He)“试(Shi)”,这(Zhe)是(Shi)因(Yin)为(Wei)当(Dang)前(Qian)索(Suo)引(Yin)库(Ku)使(Shi)用(Yong)的(De)分(Fen)词(Ci)器(Qi)对(Dui)中(Zhong)文(Wen)就(Jiu)是(Shi)单(Dan)字(Zi)分(Fen)词(Ci)。安(An)装(Zhuang)IK分(Fen)词(Ci)器(Qi)使(Shi)用(Yong)IK分(Fen)词(Ci)器(Qi)可(Ke)以(Yi)实(Shi)现(Xian)对(Dui)中(Zhong)文(Wen)分(Fen)词(Ci)的(De)效(Xiao)果(Guo)。下(Xia)载(Zai)IK分(Fen)词(Ci)器(Qi):(Github地(Di)址(Zhi):https://github.com/medcl/elasticsearch-analysis-ik)下(Xia)载(Zai)zip:解(Jie)压(Ya),并(Bing)将(Jiang)解(Jie)压(Ya)的(De)文(Wen)件(Jian)拷(Kao)贝(Bei)到(Dao)ES安(An)装(Zhuang)目(Mu)录(Lu)的(De)plugins下(Xia)的(De)ik目(Mu)录(Lu)下(Xia)测(Ce)试(Shi)分(Fen)词(Ci)效(Xiao)果(Guo):发(Fa)送(Song):post localhost:9200/_analyze{"text":"测(Ce)试(Shi)分(Fen)词(Ci)器(Qi),后(Hou)边(Bian)是(Shi)测(Ce)试(Shi)内(Nei)容(Rong):spring cloud实(Shi)战(Zhan)","analyzer":"ik_max_word" }两(Liang)种(Zhong)分(Fen)词(Ci)模(Mo)式(Shi)ik分(Fen)词(Ci)器(Qi)有(You)两(Liang)种(Zhong)分(Fen)词(Ci)模(Mo)式(Shi):ik_max_word和(He)ik_smart模(Mo)式(Shi)。1、ik_max_word会(Hui)将(Jiang)文(Wen)本(Ben)做(Zuo)最(Zui)细(Xi)粒(Li)度(Du)的(De)拆(Chai)分(Fen),比(Bi)如(Ru)会(Hui)将(Jiang)“中(Zhong)华(Hua)人(Ren)民(Min)共(Gong)和(He)国(Guo)人(Ren)民(Min)大(Da)会(Hui)堂(Tang)”拆(Chai)分(Fen)为(Wei)“中(Zhong)华(Hua)人(Ren)民(Min)共(Gong)和(He)国(Guo)、中(Zhong)华(Hua)人(Ren)民(Min)、中(Zhong)华(Hua)、华(Hua)人(Ren)、人(Ren)民(Min)共(Gong)和(He)国(Guo)、人(Ren)民(Min)、共(Gong)和(He)国(Guo)、大(Da)会(Hui)堂(Tang)、大(Da)会(Hui)、会(Hui)堂(Tang)等(Deng)词(Ci)语(Yu)。2、ik_smart会(Hui)做(Zuo)最(Zui)粗(Cu)粒(Li)度(Du)的(De)拆(Chai)分(Fen),比(Bi)如(Ru)会(Hui)将(Jiang)“中(Zhong)华(Hua)人(Ren)民(Min)共(Gong)和(He)国(Guo)人(Ren)民(Min)大(Da)会(Hui)堂(Tang)”拆(Chai)分(Fen)为(Wei)中(Zhong)华(Hua)人(Ren)民(Min)共(Gong)和(He)国(Guo)、人(Ren)民(Min)大(Da)会(Hui)堂(Tang)。测(Ce)试(Shi)两(Liang)种(Zhong)分(Fen)词(Ci)模(Mo)式(Shi):发(Fa)送(Song):post localhost:9200/_analyze{"text":"中(Zhong)华(Hua)人(Ren)民(Min)共(Gong)和(He)国(Guo)人(Ren)民(Min)大(Da)会(Hui)堂(Tang)","analyzer":"ik_smart" }自(Zi)定(Ding)义(Yi)词(Ci)库(Ku)如(Ru)果(Guo)要(Yao)让(Rang)分(Fen)词(Ci)器(Qi)支(Zhi)持(Chi)一(Yi)些(Xie)专(Zhuan)有(You)词(Ci)语(Yu),可(Ke)以(Yi)自(Zi)定(Ding)义(Yi)词(Ci)库(Ku)。iK分(Fen)词(Ci)器(Qi)自(Zi)带(Dai)一(Yi)个(Ge)main.dic的(De)文(Wen)件(Jian),此(Ci)文(Wen)件(Jian)为(Wei)词(Ci)库(Ku)文(Wen)件(Jian)。在(Zai)上(Shang)边(Bian)的(De)目(Mu)录(Lu)中(Zhong)新(Xin)建(Jian)一(Yi)个(Ge)my.dic文(Wen)件(Jian)(注(Zhu)意(Yi)文(Wen)件(Jian)格(Ge)式(Shi)为(Wei)utf-8(不(Bu)要(Yao)选(Xuan)择(Ze)utf-8 BOM))可(Ke)以(Yi)在(Zai)其(Qi)中(Zhong)自(Zi)定(Ding)义(Yi)词(Ci)汇(Hui):比(Bi)如(Ru)定(Ding)义(Yi):配(Pei)置(Zhi)文(Wen)件(Jian)中(Zhong)配(Pei)置(Zhi)my.dic,重(Zhong)启(Qi)ES,测(Ce)试(Shi)分(Fen)词(Ci)效(Xiao)果(Guo):发(Fa)送(Song):post localhost:9200/_analyze{"text":"测(Ce)试(Shi)分(Fen)词(Ci)器(Qi),后(Hou)边(Bian)是(Shi)测(Ce)试(Shi)内(Nei)容(Rong):spring cloud实(Shi)战(Zhan)","analyzer":"ik_max_word" }映(Ying)射(She)上(Shang)边(Bian)章(Zhang)节(Jie)安(An)装(Zhuang)了(Liao)ik分(Fen)词(Ci)器(Qi),如(Ru)果(Guo)在(Zai)索(Suo)引(Yin)和(He)搜(Sou)索(Suo)时(Shi)去(Qu)使(Shi)用(Yong)ik分(Fen)词(Ci)器(Qi)呢(Ne)?如(Ru)何(He)指(Zhi)定(Ding)其(Qi)它(Ta)类(Lei)型(Xing)的(De)field,比(Bi)如(Ru)日(Ri)期(Qi)类(Lei)型(Xing)、数(Shu)值(Zhi)类(Lei)型(Xing)等(Deng)。本(Ben)章(Zhang)节(Jie)学(Xue)习(Xi)各(Ge)种(Zhong)映(Ying)射(She)类(Lei)型(Xing)及(Ji)映(Ying)射(She)维(Wei)护(Hu)方(Fang)法(Fa)。映(Ying)射(She)维(Wei)护(Hu)方(Fang)法(Fa)1、查(Cha)询(Xun)所(Suo)有(You)索(Suo)引(Yin)的(De)映(Ying)射(She):GET: http://localhost:9200/_mapping2、创(Chuang)建(Jian)映(Ying)射(She)post 请(Qing)求(Qiu):http://localhost:9200/xc_course/doc/_mapping一(Yi)个(Ge)例(Li)子(Zi): { "properties": { "name": { "type": "text" }, "description": { "type": "text" }, "studymodel": { "type": "keyword" } }}3、更(Geng)新(Xin)映(Ying)射(She)映(Ying)射(She)创(Chuang)建(Jian)成(Cheng)功(Gong)可(Ke)以(Yi)添(Tian)加(Jia)新(Xin)字(Zi)段(Duan),已(Yi)有(You)字(Zi)段(Duan)不(Bu)允(Yun)许(Xu)更(Geng)新(Xin)。4、删(Shan)除(Chu)映(Ying)射(She)通(Tong)过(Guo)删(Shan)除(Chu)索(Suo)引(Yin)来(Lai)删(Shan)除(Chu)映(Ying)射(She)。常(Chang)用(Yong)映(Ying)射(She)类(Lei)型(Xing)text文(Wen)本(Ben)字(Zi)段(Duan)下(Xia)图(Tu)是(Shi)ES6.2核(He)心(Xin)的(De)字(Zi)段(Duan)类(Lei)型(Xing)如(Ru)下(Xia):字(Zi)符(Fu)串(Chuan)包(Bao)括(Kuo)text和(He)keyword两(Liang)种(Zhong)类(Lei)型(Xing):1、text1)analyzer通(Tong)过(Guo)analyzer属(Shu)性(Xing)指(Zhi)定(Ding)分(Fen)词(Ci)器(Qi)。下(Xia)边(Bian)指(Zhi)定(Ding)name的(De)字(Zi)段(Duan)类(Lei)型(Xing)为(Wei)text,使(Shi)用(Yong)ik分(Fen)词(Ci)器(Qi)的(De)ik_max_word分(Fen)词(Ci)模(Mo)式(Shi)。 "name": { "type": "text", "analyzer":"ik_max_word" }上(Shang)边(Bian)指(Zhi)定(Ding)了(Liao)analyzer是(Shi)指(Zhi)在(Zai)索(Suo)引(Yin)和(He)搜(Sou)索(Suo)都(Du)使(Shi)用(Yong)ik_max_word,如(Ru)果(Guo)单(Dan)独(Du)想(Xiang)定(Ding)义(Yi)搜(Sou)索(Suo)时(Shi)使(Shi)用(Yong)的(De)分(Fen)词(Ci)器(Qi)则(Ze)可(Ke)以(Yi)通(Tong)过(Guo)search_analyzer属(Shu)性(Xing)。对(Dui)于(Yu)ik分(Fen)词(Ci)器(Qi)建(Jian)议(Yi)是(Shi)索(Suo)引(Yin)时(Shi)使(Shi)用(Yong)ik_max_word将(Jiang)搜(Sou)索(Suo)内(Nei)容(Rong)进(Jin)行(Xing)细(Xi)粒(Li)度(Du)分(Fen)词(Ci),搜(Sou)索(Suo)时(Shi)使(Shi)用(Yong)ik_smart提(Ti)高(Gao)搜(Sou)索(Suo)精(Jing)确(Que)性(Xing)。"name": { "type": "text", "analyzer":"ik_max_word", "search_analyzer":"ik_smart" }2)index通(Tong)过(Guo)index属(Shu)性(Xing)指(Zhi)定(Ding)是(Shi)否(Fou)索(Suo)引(Yin)。默(Mo)认(Ren)为(Wei)index=true,即(Ji)要(Yao)进(Jin)行(Xing)索(Suo)引(Yin),只(Zhi)有(You)进(Jin)行(Xing)索(Suo)引(Yin)才(Cai)可(Ke)以(Yi)从(Cong)索(Suo)引(Yin)库(Ku)搜(Sou)索(Suo)到(Dao)。但(Dan)是(Shi)也(Ye)有(You)一(Yi)些(Xie)内(Nei)容(Rong)不(Bu)需(Xu)要(Yao)索(Suo)引(Yin),比(Bi)如(Ru):商(Shang)品(Pin)图(Tu)片(Pian)地(Di)址(Zhi)只(Zhi)被(Bei)用(Yong)来(Lai)展(Zhan)示(Shi)图(Tu)片(Pian),不(Bu)进(Jin)行(Xing)搜(Sou)索(Suo)图(Tu)片(Pian),此(Ci)时(Shi)可(Ke)以(Yi)将(Jiang)index设(She)置(Zhi)为(Wei)false。删(Shan)除(Chu)索(Suo)引(Yin),重(Zhong)新(Xin)创(Chuang)建(Jian)映(Ying)射(She),将(Jiang)pic的(De)index设(She)置(Zhi)为(Wei)false,尝(Chang)试(Shi)根(Gen)据(Ju)pic去(Qu)搜(Sou)索(Suo),结(Jie)果(Guo)搜(Sou)索(Suo)不(Bu)到(Dao)数(Shu)据(Ju) "pic": { "type": "text", "index":false }3)store是(Shi)否(Fou)在(Zai)source之(Zhi)外(Wai)存(Cun)储(Chu),每(Mei)个(Ge)文(Wen)档(Dang)索(Suo)引(Yin)后(Hou)会(Hui)在(Zai) ES中(Zhong)保(Bao)存(Cun)一(Yi)份(Fen)原(Yuan)始(Shi)文(Wen)档(Dang),存(Cun)放(Fang)在(Zai)"_source"中(Zhong),一(Yi)般(Ban)情(Qing)况(Kuang)下(Xia)不(Bu)需(Xu)要(Yao)设(She)置(Zhi)store为(Wei)true,因(Yin)为(Wei)在(Zai)_source中(Zhong)已(Yi)经(Jing)有(You)一(Yi)份(Fen)原(Yuan)始(Shi)文(Wen)档(Dang)了(Liao)。测(Ce)试(Shi)删(Shan)除(Chu)xc_course/doc下(Xia)的(De)映(Ying)射(She)创(Chuang)建(Jian)新(Xin)映(Ying)射(She):Post http://localhost:9200/xc_course/doc/_mapping { "properties": { "name": { "type": "text", "analyzer":"ik_max_word", "search_analyzer":"ik_smart" }, "description": { "type": "text", "analyzer":"ik_max_word", "search_analyzer":"ik_smart" }, "pic":{ "type":"text", "index":false }, "studymodel":{ "type":"text" } }}插(Cha)入(Ru)文(Wen)档(Dang):http://localhost:9200/xc_course/doc/4028e58161bcf7f40161bcf8b77c0000{ "name":"Bootstrap开(Kai)发(Fa)框(Kuang)架(Jia)", "description":"Bootstrap是(Shi)由(You)Twitter推(Tui)出(Chu)的(De)一(Yi)个(Ge)前(Qian)台(Tai)页(Ye)面(Mian)开(Kai)发(Fa)框(Kuang)架(Jia),在(Zai)行(Xing)业(Ye)之(Zhi)中(Zhong)使(Shi)用(Yong)较(Jiao)为(Wei)广(Guang)泛(Fan)。此(Ci)开(Kai)发(Fa)框(Kuang)架(Jia)包(Bao)含(Han)了(Liao)大(Da)量(Liang)的(De)CSS、JS程(Cheng)序(Xu)代(Dai)码(Ma),可(Ke)以(Yi)帮(Bang)助(Zhu)开(Kai)发(Fa)者(Zhe)(尤(You)其(Qi)是(Shi)不(Bu)擅(Shan)长(Chang)页(Ye)面(Mian)开(Kai)发(Fa)的(De)程(Cheng)序(Xu)人(Ren)员(Yuan))轻(Qing)松(Song)的(De)实(Shi)现(Xian)一(Yi)个(Ge)不(Bu)受(Shou)浏(Zuo)览(Lan)器(Qi)限(Xian)制(Zhi)的(De)精(Jing)美(Mei)界(Jie)面(Mian)效(Xiao)果(Guo)。", "pic":"group1/M00/00/01/wKhlQFqO4MmAOP53AAAcwDwm6SU490.jpg", "studymodel":"201002"}查(Cha)询(Xun)测(Ce)试(Shi):Get http://localhost:9200/xc_course/_search?q=name:开(Kai)发(Fa)Get http://localhost:9200/xc_course/_search?q=description:开(Kai)发(Fa)Get http://localhost:9200/xc_course/_search?q=pic:group1/M00/00/01/wKhlQFqO4MmAOP53AAAcwDwm6SU490.jpgGet http://localhost:9200/xc_course/_search?q=studymodel:201002通(Tong)过(Guo)测(Ce)试(Shi)发(Fa)现(Xian):name和(He)description都(Du)支(Zhi)持(Chi)全(Quan)文(Wen)检(Jian)索(Suo),pic不(Bu)可(Ke)作(Zuo)为(Wei)查(Cha)询(Xun)条(Tiao)件(Jian)。keyword关(Guan)键(Jian)字(Zi)字(Zi)段(Duan)上(Shang)边(Bian)介(Jie)绍(Shao)的(De)text文(Wen)本(Ben)字(Zi)段(Duan)在(Zai)映(Ying)射(She)时(Shi)要(Yao)设(She)置(Zhi)分(Fen)词(Ci)器(Qi),keyword字(Zi)段(Duan)为(Wei)关(Guan)键(Jian)字(Zi)字(Zi)段(Duan),通(Tong)常(Chang)搜(Sou)索(Suo)keyword是(Shi)按(An)照(Zhao)整(Zheng)体(Ti)搜(Sou)索(Suo),所(Suo)以(Yi)创(Chuang)建(Jian)keyword字(Zi)段(Duan)的(De)索(Suo)引(Yin)时(Shi)是(Shi)不(Bu)进(Jin)行(Xing)分(Fen)词(Ci)的(De),比(Bi)如(Ru):邮(You)政(Zheng)编(Bian)码(Ma)、手(Shou)机(Ji)号(Hao)码(Ma)、身(Shen)份(Fen)证(Zheng)等(Deng)。keyword字(Zi)段(Duan)通(Tong)常(Chang)用(Yong)于(Yu)过(Guo)虑(Lv)、排(Pai)序(Xu)、聚(Ju)合(He)等(Deng)。测(Ce)试(Shi)更(Geng)改(Gai)映(Ying)射(She):{ "properties": { "studymodel":{ "type":"keyword" }, "name":{ "type":"keyword" } }}插(Cha)入(Ru)文(Wen)档(Dang):{ "name": "java编(Bian)程(Cheng)基(Ji)础(Chu)", "description": "java语(Yu)言(Yan)是(Shi)世(Shi)界(Jie)第(Di)一(Yi)编(Bian)程(Cheng)语(Yu)言(Yan),在(Zai)软(Ruan)件(Jian)开(Kai)发(Fa)领(Ling)域(Yu)使(Shi)用(Yong)人(Ren)数(Shu)最(Zui)多(Duo)。", "pic":"group1/M00/00/01/wKhlQFqO4MmAOP53AAAcwDwm6SU490.jpg", "studymodel": "201001"}根(Gen)据(Ju)studymodel查(Cha)询(Xun)文(Wen)档(Dang)搜(Sou)索(Suo):http://localhost:9200/xc_course/_search?q=name:javaname是(Shi)keyword类(Lei)型(Xing),所(Suo)以(Yi)查(Cha)询(Xun)方(Fang)式(Shi)是(Shi)精(Jing)确(Que)查(Cha)询(Xun)。date日(Ri)期(Qi)类(Lei)型(Xing)日(Ri)期(Qi)类(Lei)型(Xing)不(Bu)用(Yong)设(She)置(Zhi)分(Fen)词(Ci)器(Qi)。通(Tong)常(Chang)日(Ri)期(Qi)类(Lei)型(Xing)的(De)字(Zi)段(Duan)用(Yong)于(Yu)排(Pai)序(Xu)。1)format通(Tong)过(Guo)format设(She)置(Zhi)日(Ri)期(Qi)格(Ge)式(Shi)例(Li)子(Zi):下(Xia)边(Bian)的(De)设(She)置(Zhi)允(Yun)许(Xu)date字(Zi)段(Duan)存(Cun)储(Chu)年(Nian)月(Yue)日(Ri)时(Shi)分(Fen)秒(Miao)、年(Nian)月(Yue)日(Ri)及(Ji)毫(Hao)秒(Miao)三(San)种(Zhong)格(Ge)式(Shi)。{ "properties": { "timestamp": { "type": "date", "format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd" } }}插(Cha)入(Ru)文(Wen)档(Dang):Post :http://localhost:9200/xc_course/doc/3{"name": "spring开(Kai)发(Fa)基(Ji)础(Chu)","description": "spring 在(Zai)java领(Ling)域(Yu)非(Fei)常(Chang)流(Liu)行(Xing),java程(Cheng)序(Xu)员(Yuan)都(Du)在(Zai)用(Yong)。","studymodel": "201001", "pic":"group1/M00/00/01/wKhlQFqO4MmAOP53AAAcwDwm6SU490.jpg", "timestamp":"2018-07-04 18:28:58"}数(Shu)值(Zhi)类(Lei)型(Xing)下(Xia)边(Bian)是(Shi)ES支(Zhi)持(Chi)的(De)数(Shu)值(Zhi)类(Lei)型(Xing)1、尽(Jin)量(Liang)选(Xuan)择(Ze)范(Fan)围(Wei)小(Xiao)的(De)类(Lei)型(Xing),提(Ti)高(Gao)搜(Sou)索(Suo)效(Xiao)率(Lv)2、对(Dui)于(Yu)浮(Fu)点(Dian)数(Shu)尽(Jin)量(Liang)用(Yong)比(Bi)例(Li)因(Yin)子(Zi),比(Bi)如(Ru)一(Yi)个(Ge)价(Jia)格(Ge)字(Zi)段(Duan),单(Dan)位(Wei)为(Wei)元(Yuan),我(Wo)们(Men)将(Jiang)比(Bi)例(Li)因(Yin)子(Zi)设(She)置(Zhi)为(Wei)100这(Zhe)在(Zai)ES中(Zhong)会(Hui)按(An) 分(Fen) 存(Cun)储(Chu),映(Ying)射(She)如(Ru)下(Xia): "price": { "type": "scaled_float", "scaling_factor": 100 },由(You)于(Yu)比(Bi)例(Li)因(Yin)子(Zi)为(Wei)100,如(Ru)果(Guo)我(Wo)们(Men)输(Shu)入(Ru)的(De)价(Jia)格(Ge)是(Shi)23.45则(Ze)ES中(Zhong)会(Hui)将(Jiang)23.45乘(Cheng)以(Yi)100存(Cun)储(Chu)在(Zai)ES中(Zhong)。如(Ru)果(Guo)输(Shu)入(Ru)的(De)价(Jia)格(Ge)是(Shi)23.456,ES会(Hui)将(Jiang)23.456乘(Cheng)以(Yi)100再(Zai)取(Qu)一(Yi)个(Ge)接(Jie)近(Jin)原(Yuan)始(Shi)值(Zhi)的(De)数(Shu),得(De)出(Chu)2346。使(Shi)用(Yong)比(Bi)例(Li)因(Yin)子(Zi)的(De)好(Hao)处(Chu)是(Shi)整(Zheng)型(Xing)比(Bi)浮(Fu)点(Dian)型(Xing)更(Geng)易(Yi)压(Ya)缩(Suo),节(Jie)省(Sheng)磁(Ci)盘(Pan)空(Kong)间(Jian)。如(Ru)果(Guo)比(Bi)例(Li)因(Yin)子(Zi)不(Bu)适(Shi)合(He),则(Ze)从(Cong)下(Xia)表(Biao)选(Xuan)择(Ze)范(Fan)围(Wei)小(Xiao)的(De)去(Qu)用(Yong):更(Geng)新(Xin)已(Yi)有(You)映(Ying)射(She),并(Bing)插(Cha)入(Ru)文(Wen)档(Dang):http://localhost:9200/xc_course/doc/3{"name": "spring开(Kai)发(Fa)基(Ji)础(Chu)","description": "spring 在(Zai)java领(Ling)域(Yu)非(Fei)常(Chang)流(Liu)行(Xing),java程(Cheng)序(Xu)员(Yuan)都(Du)在(Zai)用(Yong)。","studymodel": "201001", "pic":"group1/M00/00/01/wKhlQFqO4MmAOP53AAAcwDwm6SU490.jpg", "timestamp":"2018-07-04 18:28:58", "price":38.6}综(Zong)合(He)例(Li)子(Zi)创(Chuang)建(Jian)如(Ru)下(Xia)映(Ying)射(She)post:http://localhost:9200/xc_course/doc/_mapping{ "properties": { "description": { "type": "text", "analyzer": "ik_max_word", "search_analyzer": "ik_smart" }, "name": { "type": "text", "analyzer": "ik_max_word", "search_analyzer": "ik_smart" }, "pic":{ "type":"text", "index":false }, "price": { "type": "float" }, "studymodel": { "type": "keyword" }, "timestamp": { "type": "date", "format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis" } } }插(Cha)入(Ru)文(Wen)档(Dang):Post: http://localhost:9200/xc_course/doc/1 { "name": "Bootstrap开(Kai)发(Fa)", "description": "Bootstrap是(Shi)由(You)Twitter推(Tui)出(Chu)的(De)一(Yi)个(Ge)前(Qian)台(Tai)页(Ye)面(Mian)开(Kai)发(Fa)框(Kuang)架(Jia),是(Shi)一(Yi)个(Ge)非(Fei)常(Chang)流(Liu)行(Xing)的(De)开(Kai)发(Fa)框(Kuang)架(Jia),此(Ci)框(Kuang)架(Jia)集(Ji)成(Cheng)了(Liao)多(Duo)种(Zhong)页(Ye)面(Mian)效(Xiao)果(Guo)。此(Ci)开(Kai)发(Fa)框(Kuang)架(Jia)包(Bao)含(Han)了(Liao)大(Da)量(Liang)的(De)CSS、JS程(Cheng)序(Xu)代(Dai)码(Ma),可(Ke)以(Yi)帮(Bang)助(Zhu)开(Kai)发(Fa)者(Zhe)(尤(You)其(Qi)是(Shi)不(Bu)擅(Shan)长(Chang)页(Ye)面(Mian)开(Kai)发(Fa)的(De)程(Cheng)序(Xu)人(Ren)员(Yuan))轻(Qing)松(Song)的(De)实(Shi)现(Xian)一(Yi)个(Ge)不(Bu)受(Shou)浏(Zuo)览(Lan)器(Qi)限(Xian)制(Zhi)的(De)精(Jing)美(Mei)界(Jie)面(Mian)效(Xiao)果(Guo)。", "studymodel": "201002", "price":38.6, "timestamp":"2018-04-25 19:11:35", "pic":"group1/M00/00/00/wKhlQFs6RCeAY0pHAAJx5ZjNDEM428.jpg" }索(Suo)引(Yin)管(Guan)理(Li)搭(Da)建(Jian)工(Gong)程(Cheng)ES客(Ke)户(Hu)端(Duan)ES提(Ti)供(Gong)多(Duo)种(Zhong)不(Bu)同(Tong)的(De)客(Ke)户(Hu)端(Duan):1、TransportClientES提(Ti)供(Gong)的(De)传(Chuan)统(Tong)客(Ke)户(Hu)端(Duan),官(Guan)方(Fang)计(Ji)划(Hua)8.0版(Ban)本(Ben)删(Shan)除(Chu)此(Ci)客(Ke)户(Hu)端(Duan)。2、RestClientRestClient是(Shi)官(Guan)方(Fang)推(Tui)荐(Jian)使(Shi)用(Yong)的(De),它(Ta)包(Bao)括(Kuo)两(Liang)种(Zhong):Java Low Level REST Client和(He) Java High Level REST Client。ES在(Zai)6.0之(Zhi)后(Hou)提(Ti)供(Gong) Java High Level REST Client, 两(Liang)种(Zhong)客(Ke)户(Hu)端(Duan)官(Guan)方(Fang)更(Geng)推(Tui)荐(Jian)使(Shi)用(Yong) Java High Level REST Client,不(Bu)过(Guo)当(Dang)前(Qian)它(Ta)还(Huan)处(Chu)于(Yu)完(Wan)善(Shan)中(Zhong),有(You)些(Xie)功(Gong)能(Neng)还(Huan)没(Mei)有(You)。本(Ben)教(Jiao)程(Cheng)准(Zhun)备(Bei)采(Cai)用(Yong) Java High Level REST Client,如(Ru)果(Guo)它(Ta)有(You)不(Bu)支(Zhi)持(Chi)的(De)功(Gong)能(Neng),则(Ze)使(Shi)用(Yong)Java Low Level REST Client。添(Tian)加(Jia)依(Yi)赖(Lai): org.elasticsearch.client elasticsearch-rest-high-level-client 6.2.1 org.elasticsearch elasticsearch 6.2.1创(颁丑耻补苍驳)建(闯颈补苍)搜(厂辞耻)索(厂耻辞)工(骋辞苍驳)程(颁丑别苍驳)创(颁丑耻补苍驳)建(闯颈补苍)搜(厂辞耻)索(厂耻辞)工(骋辞苍驳)程(颁丑别苍驳)(尘补惫别苍工(骋辞苍驳)程(颁丑别苍驳)):虫肠-蝉别谤惫颈肠别-蝉别补谤肠丑,添(罢颈补苍)加(闯颈补)搁别蝉迟贬颈驳丑尝别惫别濒颁濒颈别苍迟依(驰颈)赖(尝补颈)及(闯颈)箩耻苍颈迟依(驰颈)赖(尝补颈)。辫辞尘.虫尘濒 xc-framework-parent com.xuecheng 1.0-SNAPSHOT ../xc-framework-parent/pom.xml 4.0.0 xc-service-search com.xuecheng xc-framework-model 1.0-SNAPSHOT com.xuecheng xc-framework-common 1.0-SNAPSHOT com.xuecheng xc-service-api 1.0-SNAPSHOT org.springframework.boot spring-boot-starter-web org.springframework.boot spring-boot-starter-web org.elasticsearch.client elasticsearch-rest-high-level-client 6.2.1 org.elasticsearch elasticsearch 6.2.1 org.springframework.boot spring-boot-starter-test test com.alibaba fastjson org.apache.commons commons-io org.apache.commons commons-lang3 2、配(Pei)置(Zhi)文(Wen)件(Jian)application.ymlserver: port: ${port:40100}spring: application: name: xc-search-servicexuecheng: elasticsearch: hostlist: ${eshostlist:127.0.0.1:9200} #多(Duo)个(Ge)结(Jie)点(Dian)中(Zhong)间(Jian)用(Yong)逗(Dou)号(Hao)分(Fen)隔(Ge)3、配(Pei)置(Zhi)类(Lei)创(Chuang)建(Jian)com.xuecheng.search.config包(Bao)在(Zai)其(Qi)下(Xia)创(Chuang)建(Jian)配(Pei)置(Zhi)类(Lei)package com.xuecheng.search.config;import org.apache.http.HttpHost;import org.elasticsearch.client.RestClient;import org.elasticsearch.client.RestHighLevelClient;import org.springframework.beans.factory.annotation.Value;import org.springframework.context.annotation.Bean;import org.springframework.context.annotation.Configuration;@Configurationpublic class ElasticsearchConfig { @Value("${xuecheng.elasticsearch.hostlist}") private String hostlist; @Bean public RestHighLevelClient restHighLevelClient(){ //解(Jie)析(Xi)hostlist配(Pei)置(Zhi)信(Xin)息(Xi) String[] split = hostlist.split(","); //创(Chuang)建(Jian)HttpHost数(Shu)组(Zu),其(Qi)中(Zhong)存(Cun)放(Fang)es主(Zhu)机(Ji)和(He)端(Duan)口(Kou)的(De)配(Pei)置(Zhi)信(Xin)息(Xi) HttpHost[] httpHostArray = new HttpHost[split.length]; for(int i=0;i jsonMap = new HashMap<>(); jsonMap.put("name", "spring cloud实(Shi)战(Zhan)"); jsonMap.put("description", "本(Ben)课(Ke)程(Cheng)主(Zhu)要(Yao)从(Cong)四(Si)个(Ge)章(Zhang)节(Jie)进(Jin)行(Xing)讲(Jiang)解(Jie): 1.微(Wei)服(Fu)务(Wu)架(Jia)构(Gou)入(Ru)门(Men) 2.spring cloud 基(Ji)础(Chu)入(Ru)门(Men) 3.实(Shi)战(Zhan)Spring Boot 4.注(Zhu)册(Ce)中(Zhong)心(Xin)eureka。"); jsonMap.put("studymodel", "201001"); SimpleDateFormat dateFormat =new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); jsonMap.put("timestamp", dateFormat.format(new Date())); jsonMap.put("price", 5.6f); //索(Suo)引(Yin)请(Qing)求(Qiu)对(Dui)象(Xiang) IndexRequest indexRequest = new IndexRequest("xc_course","doc"); //指(Zhi)定(Ding)索(Suo)引(Yin)文(Wen)档(Dang)内(Nei)容(Rong) indexRequest.source(jsonMap); //索(Suo)引(Yin)响(Xiang)应(Ying)对(Dui)象(Xiang) IndexResponse indexResponse = client.index(indexRequest); //获(Huo)取(Qu)响(Xiang)应(Ying)结(Jie)果(Guo) DocWriteResponse.Result result = indexResponse.getResult(); System.out.println(result); }查(Cha)询(Xun)文(Wen)档(Dang)API格(Ge)式(Shi)如(Ru)下(Xia): GET /{index}/{type}/{id}Java Client//查(Cha)询(Xun)文(Wen)档(Dang)@Testpublic void getDoc() throws IOException { GetRequest getRequest = new GetRequest( "xc_course", "doc", "4028e581617f945f01617f9dabc40000"); GetResponse getResponse = client.get(getRequest); boolean exists = getResponse.isExists(); Map sourceAsMap = getResponse.getSourceAsMap(); System.out.println(sourceAsMap);}更(Geng)新(Xin)文(Wen)档(Dang)ApiES更(Geng)新(Xin)文(Wen)档(Dang)的(De)顺(Shun)序(Xu)是(Shi):先(Xian)检(Jian)索(Suo)到(Dao)文(Wen)档(Dang)、将(Jiang)原(Yuan)来(Lai)的(De)文(Wen)档(Dang)标(Biao)记(Ji)为(Wei)删(Shan)除(Chu)、创(Chuang)建(Jian)新(Xin)文(Wen)档(Dang)、删(Shan)除(Chu)旧(Jiu)文(Wen)档(Dang),创(Chuang)建(Jian)新(Xin)文(Wen)档(Dang)就(Jiu)会(Hui)重(Zhong)建(Jian)索(Suo)引(Yin)。通(Tong)过(Guo)请(Qing)求(Qiu)Url有(You)两(Liang)种(Zhong)方(Fang)法(Fa):1、完(Wan)全(Quan)替(Ti)换(Huan)Post:http://localhost:9200/xc_test/doc/3 { "name":"spring cloud实(Shi)战(Zhan)", "description":"本(Ben)课(Ke)程(Cheng)主(Zhu)要(Yao)从(Cong)四(Si)个(Ge)章(Zhang)节(Jie)进(Jin)行(Xing)讲(Jiang)解(Jie): 1.微(Wei)服(Fu)务(Wu)架(Jia)构(Gou)入(Ru)门(Men) 2.spring cloud 基(Ji)础(Chu)入(Ru)门(Men) 3.实(Shi)战(Zhan)Spring Boot 4.注(Zhu)册(Ce)中(Zhong)心(Xin)eureka。", "studymodel":"201001" "price":5.6 }2、局(Ju)部(Bu)更(Geng)新(Xin)下(Xia)边(Bian)的(De)例(Li)子(Zi)是(Shi)只(Zhi)更(Geng)新(Xin)price字(Zi)段(Duan)。post: http://localhost:9200/xc_test/doc/3/_update{ "doc":{"price":66.6}}Java Client使(Shi)用(Yong) Client Api更(Geng)新(Xin)文(Wen)档(Dang)的(De)方(Fang)法(Fa)同(Tong)上(Shang)边(Bian)第(Di)二(Er)种(Zhong)局(Ju)部(Bu)更(Geng)新(Xin)方(Fang)法(Fa)。可(Ke)以(Yi)指(Zhi)定(Ding)文(Wen)档(Dang)的(De)部(Bu)分(Fen)字(Zi)段(Duan)也(Ye)可(Ke)以(Yi)指(Zhi)定(Ding)完(Wan)整(Zheng)的(De)文(Wen)档(Dang)内(Nei)容(Rong)。 //更(Geng)新(Xin)文(Wen)档(Dang) @Test public void updateDoc() throws IOException { UpdateRequest updateRequest = new UpdateRequest("xc_course", "doc", "4028e581617f945f01617f9dabc40000"); Map map = new HashMap<>(); map.put("name", "spring cloud实(Shi)战(Zhan)"); updateRequest.doc(map); UpdateResponse update = client.update(updateRequest); RestStatus status = update.status(); System.out.println(status); }删(Shan)除(Chu)文(Wen)档(Dang)Api根(Gen)据(Ju)id删(Shan)除(Chu),格(Ge)式(Shi)如(Ru)下(Xia):DELETE /{index}/{type}/{id}搜(Sou)索(Suo)匹(Pi)配(Pei)删(Shan)除(Chu),将(Jiang)搜(Sou)索(Suo)出(Chu)来(Lai)的(De)记(Ji)录(Lu)删(Shan)除(Chu),格(Ge)式(Shi)如(Ru)下(Xia):POST /{index}/{type}/_delete_by_query下(Xia)边(Bian)是(Shi)搜(Sou)索(Suo)条(Tiao)件(Jian)例(Li)子(Zi):{ "query":{ "term":{ "studymodel":"201001" } }}上(Shang)边(Bian)例(Li)子(Zi)的(De)搜(Sou)索(Suo)匹(Pi)配(Pei)删(Shan)除(Chu)会(Hui)将(Jiang)studymodel为(Wei)201001的(De)记(Ji)录(Lu)全(Quan)部(Bu)删(Shan)除(Chu)。Java Client//根(Gen)据(Ju)id删(Shan)除(Chu)文(Wen)档(Dang) @Test public void testDelDoc() throws IOException { //删(Shan)除(Chu)文(Wen)档(Dang)id String id = "eqP_amQBKsGOdwJ4fHiC"; //删(Shan)除(Chu)索(Suo)引(Yin)请(Qing)求(Qiu)对(Dui)象(Xiang) DeleteRequest deleteRequest = new DeleteRequest("xc_course","doc",id); //响(Xiang)应(Ying)对(Dui)象(Xiang) DeleteResponse deleteResponse = client.delete(deleteRequest); //获(Huo)取(Qu)响(Xiang)应(Ying)结(Jie)果(Guo) DocWriteResponse.Result result = deleteResponse.getResult(); System.out.println(result); }搜(Sou)索(Suo)匹(Pi)配(Pei)删(Shan)除(Chu)还(Huan)没(Mei)有(You)具(Ju)体(Ti)的(De)api,可(Ke)以(Yi)采(Cai)用(Yong)先(Xian)搜(Sou)索(Suo)出(Chu)文(Wen)档(Dang)id,根(Gen)据(Ju)文(Wen)档(Dang)id删(Shan)除(Chu)。搜(Sou)索(Suo)管(Guan)理(Li)准(Zhun)备(Bei)环(Huan)境(Jing)创(Chuang)建(Jian)映(Ying)射(She)创(Chuang)建(Jian)xc_course索(Suo)引(Yin)库(Ku)。创(Chuang)建(Jian)如(Ru)下(Xia)映(Ying)射(She)post:http://localhost:9200/xc_course/doc/_mapping参(Can)考(Kao) “资(Zi)料(Liao)”--》搜(Sou)索(Suo)测(Ce)试(Shi)-初(Chu)始(Shi)化(Hua)数(Shu)据(Ju).txt{ "properties": { "description": { "type": "text", "analyzer": "ik_max_word", "search_analyzer": "ik_smart" }, "name": { "type": "text", "analyzer": "ik_max_word", "search_analyzer": "ik_smart" }, "pic":{ "type":"text", "index":false }, "price": { "type": "float" }, "studymodel": { "type": "keyword" }, "timestamp": { "type": "date", "format": "yyyy-MM-dd HH:mm:ss||yyyy-MM-dd||epoch_millis" } } }插(Cha)入(Ru)原(Yuan)始(Shi)数(Shu)据(Ju)向(Xiang)xc_course/doc中(Zhong)插(Cha)入(Ru)以(Yi)下(Xia)数(Shu)据(Ju):参(Can)考(Kao) “资(Zi)料(Liao)”--》搜(Sou)索(Suo)测(Ce)试(Shi)-初(Chu)始(Shi)化(Hua)数(Shu)据(Ju).txthttp://localhost:9200/xc_course/doc/1{"name": "Bootstrap开(Kai)发(Fa)","description": "Bootstrap是(Shi)由(You)Twitter推(Tui)出(Chu)的(De)一(Yi)个(Ge)前(Qian)台(Tai)页(Ye)面(Mian)开(Kai)发(Fa)css框(Kuang)架(Jia),是(Shi)一(Yi)个(Ge)非(Fei)常(Chang)流(Liu)行(Xing)的(De)开(Kai)发(Fa)框(Kuang)架(Jia),此(Ci)框(Kuang)架(Jia)集(Ji)成(Cheng)了(Liao)多(Duo)种(Zhong)页(Ye)面(Mian)效(Xiao)果(Guo)。此(Ci)开(Kai)发(Fa)框(Kuang)架(Jia)包(Bao)含(Han)了(Liao)大(Da)量(Liang)的(De)CSS、JS程(Cheng)序(Xu)代(Dai)码(Ma),可(Ke)以(Yi)帮(Bang)助(Zhu)开(Kai)发(Fa)者(Zhe)(尤(You)其(Qi)是(Shi)不(Bu)擅(Shan)长(Chang)css页(Ye)面(Mian)开(Kai)发(Fa)的(De)程(Cheng)序(Xu)人(Ren)员(Yuan))轻(Qing)松(Song)的(De)实(Shi)现(Xian)一(Yi)个(Ge)css,不(Bu)受(Shou)浏(Zuo)览(Lan)器(Qi)限(Xian)制(Zhi)的(De)精(Jing)美(Mei)界(Jie)面(Mian)css效(Xiao)果(Guo)。","studymodel": "201002","price":38.6,"timestamp":"2018-04-25 19:11:35","pic":"group1/M00/00/00/wKhlQFs6RCeAY0pHAAJx5ZjNDEM428.jpg"}http://localhost:9200/xc_course/doc/2{"name": "java编(Bian)程(Cheng)基(Ji)础(Chu)","description": "java语(Yu)言(Yan)是(Shi)世(Shi)界(Jie)第(Di)一(Yi)编(Bian)程(Cheng)语(Yu)言(Yan),在(Zai)软(Ruan)件(Jian)开(Kai)发(Fa)领(Ling)域(Yu)使(Shi)用(Yong)人(Ren)数(Shu)最(Zui)多(Duo)。","studymodel": "201001","price":68.6,"timestamp":"2018-03-25 19:11:35","pic":"group1/M00/00/00/wKhlQFs6RCeAY0pHAAJx5ZjNDEM428.jpg"}http://localhost:9200/xc_course/doc/3{"name": "spring开(Kai)发(Fa)基(Ji)础(Chu)","description": "spring 在(Zai)java领(Ling)域(Yu)非(Fei)常(Chang)流(Liu)行(Xing),java程(Cheng)序(Xu)员(Yuan)都(Du)在(Zai)用(Yong)。","studymodel": "201001","price":88.6,"timestamp":"2018-02-24 19:11:35","pic":"group1/M00/00/00/wKhlQFs6RCeAY0pHAAJx5ZjNDEM428.jpg"}简(Jian)单(Dan)搜(Sou)索(Suo)简(Jian)单(Dan)搜(Sou)索(Suo)就(Jiu)是(Shi)通(Tong)过(Guo)url进(Jin)行(Xing)查(Cha)询(Xun),以(Yi)get方(Fang)式(Shi)请(Qing)求(Qiu)ES。格(Ge)式(Shi):get ../_search?q=.....q:搜(Sou)索(Suo)字(Zi)符(Fu)串(Chuan)。例(Li)子(Zi):?q=name:spring 搜(Sou)索(Suo)name中(Zhong)包(Bao)括(Kuo)spring的(De)文(Wen)档(Dang)。DSL搜(Sou)索(Suo)DSL(Domain Specific Language)是(Shi)ES提(Ti)出(Chu)的(De)基(Ji)于(Yu)json的(De)搜(Sou)索(Suo)方(Fang)式(Shi),在(Zai)搜(Sou)索(Suo)时(Shi)传(Chuan)入(Ru)特(Te)定(Ding)的(De)json格(Ge)式(Shi)的(De)数(Shu)据(Ju)来(Lai)完(Wan)成(Cheng)不(Bu)同(Tong)的(De)搜(Sou)索(Suo)需(Xu)求(Qiu)。DSL比(Bi)URI搜(Sou)索(Suo)方(Fang)式(Shi)功(Gong)能(Neng)强(Qiang)大(Da),在(Zai)项(Xiang)目(Mu)中(Zhong)建(Jian)议(Yi)使(Shi)用(Yong)DSL方(Fang)式(Shi)来(Lai)完(Wan)成(Cheng)搜(Sou)索(Suo)。查(Cha)询(Xun)所(Suo)有(You)文(Wen)档(Dang)查(Cha)询(Xun)所(Suo)有(You)索(Suo)引(Yin)库(Ku)的(De)文(Wen)档(Dang)。发(Fa)送(Song):post http://localhost:9200/_search查(Cha)询(Xun)指(Zhi)定(Ding)索(Suo)引(Yin)库(Ku)指(Zhi)定(Ding)类(Lei)型(Xing)下(Xia)的(De)文(Wen)档(Dang)。(通(Tong)过(Guo)使(Shi)用(Yong)此(Ci)方(Fang)法(Fa))发(Fa)送(Song):post http://localhost:9200/xc_course/doc/_search{ "query": { "match_all": {} }, "_source" : ["name","studymodel"]}_source:source源(Yuan)过(Guo)虑(Lv)设(She)置(Zhi),指(Zhi)定(Ding)结(Jie)果(Guo)中(Zhong)所(Suo)包(Bao)括(Kuo)的(De)字(Zi)段(Duan)有(You)哪(Na)些(Xie)。结(Jie)果(Guo)说(Shuo)明(Ming):took:本(Ben)次(Ci)操(Cao)作(Zuo)花(Hua)费(Fei)的(De)时(Shi)间(Jian),单(Dan)位(Wei)为(Wei)毫(Hao)秒(Miao)。timed_out:请(Qing)求(Qiu)是(Shi)否(Fou)超(Chao)时(Shi)_shards:说(Shuo)明(Ming)本(Ben)次(Ci)操(Cao)作(Zuo)共(Gong)搜(Sou)索(Suo)了(Liao)哪(Na)些(Xie)分(Fen)片(Pian)hits:搜(Sou)索(Suo)命(Ming)中(Zhong)的(De)记(Ji)录(Lu)hits.total : 符(Fu)合(He)条(Tiao)件(Jian)的(De)文(Wen)档(Dang)总(Zong)数(Shu) hits.hits :匹(Pi)配(Pei)度(Du)较(Jiao)高(Gao)的(De)前(Qian)N个(Ge)文(Wen)档(Dang)hits.max_score:文(Wen)档(Dang)匹(Pi)配(Pei)得(De)分(Fen),这(Zhe)里(Li)为(Wei)最(Zui)高(Gao)分(Fen)_score:每(Mei)个(Ge)文(Wen)档(Dang)都(Du)有(You)一(Yi)个(Ge)匹(Pi)配(Pei)度(Du)得(De)分(Fen),按(An)照(Zhao)降(Jiang)序(Xu)排(Pai)列(Lie)。_source:显(Xian)示(Shi)了(Liao)文(Wen)档(Dang)的(De)原(Yuan)始(Shi)内(Nei)容(Rong)。JavaClient:@SpringBootTest@RunWith(SpringRunner.class)public class TestSearch { @Autowired RestHighLevelClient client; @Autowired RestClient restClient; //搜(Sou)索(Suo)type下(Xia)的(De)全(Quan)部(Bu)记(Ji)录(Lu) @Test public void testSearchAll() throws IOException, ParseException { //搜(Sou)索(Suo)请(Qing)求(Qiu)对(Dui)象(Xiang) SearchRequest searchRequest = new SearchRequest("xc_course"); //设(She)置(Zhi)类(Lei)型(Xing) searchRequest.types("doc"); //搜(Sou)索(Suo)源(Yuan)构(Gou)建(Jian)对(Dui)象(Xiang) SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); //搜(Sou)索(Suo)全(Quan)部(Bu) searchSourceBuilder.query(QueryBuilders.matchAllQuery()); //source源(Yuan)字(Zi)段(Duan)过(Guo)虑(Lv) searchSourceBuilder.fetchSource(new String[]{"name","studymodel","price","timestamp"},new String[]{}); //设(She)置(Zhi)搜(Sou)索(Suo)源(Yuan) searchRequest.source(searchSourceBuilder); //执(Zhi)行(Xing)搜(Sou)索(Suo) SearchResponse searchResponse = client.search(searchRequest); //搜(Sou)索(Suo)匹(Pi)配(Pei)结(Jie)果(Guo) SearchHits hits = searchResponse.getHits(); //搜(Sou)索(Suo)总(Zong)记(Ji)录(Lu)数(Shu) long totalHits = hits.totalHits; //匹(Pi)配(Pei)度(Du)较(Jiao)高(Gao)的(De)前(Qian)N个(Ge)文(Wen)档(Dang) SearchHit[] searchHits = hits.getHits(); //日(Ri)期(Qi)格(Ge)式(Shi)化(Hua)对(Dui)象(Xiang) SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); for(SearchHit hit:searchHits){ //文(Wen)档(Dang)id String id = hit.getId(); //源(Yuan)文(Wen)档(Dang)内(Nei)容(Rong) Map sourceAsMap = hit.getSourceAsMap(); //获(Huo)取(Qu)源(Yuan)文(Wen)档(Dang)name String name = (String) sourceAsMap.get("name"); String description = (String) sourceAsMap.get("description"); String studymodel = (String) sourceAsMap.get("studymodel"); Double price = (Double) sourceAsMap.get("price"); Date timestamp = dateFormat.parse((String) sourceAsMap.get("timestamp")); System.out.println(name); System.out.println(studymodel); System.out.println(description); } } ....分(Fen)页(Ye)查(Cha)询(Xun)ES支(Zhi)持(Chi)分(Fen)页(Ye)查(Cha)询(Xun),传(Chuan)入(Ru)两(Liang)个(Ge)参(Can)数(Shu):from和(He)size。form:表(Biao)示(Shi)起(Qi)始(Shi)文(Wen)档(Dang)的(De)下(Xia)标(Biao),从(Cong)0开(Kai)始(Shi)。size:查(Cha)询(Xun)的(De)文(Wen)档(Dang)数(Shu)量(Liang)。发(Fa)送(Song):post http://localhost:9200/xc_course/doc/_search{"from" : 0, "size" : 1,"query": { "match_all": {} },"_source" : ["name","studymodel"]}JavaClient...SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();//设(She)置(Zhi)分(Fen)页(Ye)参(Can)数(Shu)//当(Dang)前(Qian)页(Ye)码(Ma)int page = 2;//页(Ye)码(Ma)int size = 1;//每(Mei)页(Ye)显(Xian)示(Shi)个(Ge)数(Shu)int from = (page - 1) * size;//起(Qi)记(Ji)录(Lu)下(Xia)标(Biao)searchSourceBuilder.from(from);searchSourceBuilder.size(size);...Term QueryTerm Query为(Wei)精(Jing)确(Que)查(Cha)询(Xun),在(Zai)搜(Sou)索(Suo)时(Shi)会(Hui)整(Zheng)体(Ti)匹(Pi)配(Pei)关(Guan)键(Jian)字(Zi),不(Bu)再(Zai)将(Jiang)关(Guan)键(Jian)字(Zi)分(Fen)词(Ci)。发(Fa)送(Song):post http://localhost:9200/xc_course/doc/_search{ "query": { "term" : { "name": "spring" } }, "_source" : ["name","studymodel"] }上(Shang)边(Bian)的(De)搜(Sou)索(Suo)会(Hui)查(Cha)询(Xun)name包(Bao)括(Kuo)“spring”这(Zhe)个(Ge)词(Ci)的(De)文(Wen)档(Dang)。JavaClient:...//搜(Sou)索(Suo)请(Qing)求(Qiu)对(Dui)象(Xiang)SearchRequest searchRequest = new SearchRequest("xc_course");//设(She)置(Zhi)类(Lei)型(Xing)searchRequest.types("doc");//搜(Sou)索(Suo)源(Yuan)构(Gou)建(Jian)对(Dui)象(Xiang)SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();//TermQuerysearchSourceBuilder.query(QueryBuilders.termQuery("name","spring"));//source源(Yuan)字(Zi)段(Duan)过(Guo)虑(Lv)searchSourceBuilder.fetchSource(new String[]{"name","studymodel","price","timestamp"},new String[]{});//设(She)置(Zhi)搜(Sou)索(Suo)源(Yuan)searchRequest.source(searchSourceBuilder);//执(Zhi)行(Xing)搜(Sou)索(Suo)SearchResponse searchResponse = client.search(searchRequest);...根(Gen)据(Ju)id精(Jing)确(Que)匹(Pi)配(Pei)ES提(Ti)供(Gong)根(Gen)据(Ju)多(Duo)个(Ge)id值(Zhi)匹(Pi)配(Pei)的(De)方(Fang)法(Fa):测(Ce)试(Shi):post: http://127.0.0.1:9200/xc_course/doc/_search{ "query": { "ids" : { "type" : "doc", "values" : ["3", "4", "100"] } }}JavaClient:通(Tong)过(Guo)termsQuery进(Jin)行(Xing)查(Cha)询(Xun),代(Dai)码(Ma)如(Ru)下(Xia)://搜(Sou)索(Suo)请(Qing)求(Qiu)对(Dui)象(Xiang)SearchRequest searchRequest = new SearchRequest("xc_course");//设(She)置(Zhi)类(Lei)型(Xing)searchRequest.types("doc");//搜(Sou)索(Suo)源(Yuan)构(Gou)建(Jian)对(Dui)象(Xiang)SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();//主(Zhu)键(Jian)String[] ids = new String[]{"1","2"};//TermQuerysearchSourceBuilder.query(QueryBuilders.termsQuery("_id", ids));//source源(Yuan)字(Zi)段(Duan)过(Guo)虑(Lv)searchSourceBuilder.fetchSource(new String[]{"name","studymodel","price","timestamp"},new String[]{});//设(She)置(Zhi)搜(Sou)索(Suo)源(Yuan)searchRequest.source(searchSourceBuilder);//执(Zhi)行(Xing)搜(Sou)索(Suo)SearchResponse searchResponse = client.search(searchRequest);match Query1、基(Ji)本(Ben)使(Shi)用(Yong)match Query即(Ji)全(Quan)文(Wen)检(Jian)索(Suo),它(Ta)的(De)搜(Sou)索(Suo)方(Fang)式(Shi)是(Shi)先(Xian)将(Jiang)搜(Sou)索(Suo)字(Zi)符(Fu)串(Chuan)分(Fen)词(Ci),再(Zai)使(Shi)用(Yong)各(Ge)各(Ge)词(Ci)条(Tiao)从(Cong)索(Suo)引(Yin)中(Zhong)搜(Sou)索(Suo)。match query与(Yu)Term query区(Qu)别(Bie)是(Shi)match query在(Zai)搜(Sou)索(Suo)前(Qian)先(Xian)将(Jiang)搜(Sou)索(Suo)关(Guan)键(Jian)字(Zi)分(Fen)词(Ci),再(Zai)拿(Na)各(Ge)各(Ge)词(Ci)语(Yu)去(Qu)索(Suo)引(Yin)中(Zhong)搜(Sou)索(Suo)。发(Fa)送(Song):post http://localhost:9200/xc_course/doc/_search{ "query": { "match" : { "description" : { "query" : "spring开(Kai)发(Fa)", "operator" : "or" } } }}query:搜(Sou)索(Suo)的(De)关(Guan)键(Jian)字(Zi),对(Dui)于(Yu)英(Ying)文(Wen)关(Guan)键(Jian)字(Zi)如(Ru)果(Guo)有(You)多(Duo)个(Ge)单(Dan)词(Ci)则(Ze)中(Zhong)间(Jian)要(Yao)用(Yong)半(Ban)角(Jiao)逗(Dou)号(Hao)分(Fen)隔(Ge),而(Er)对(Dui)于(Yu)中(Zhong)文(Wen)关(Guan)键(Jian)字(Zi)中(Zhong)间(Jian)可(Ke)以(Yi)用(Yong)逗(Dou)号(Hao)分(Fen)隔(Ge)也(Ye)可(Ke)以(Yi)不(Bu)用(Yong)。operator:or 表(Biao)示(Shi) 只(Zhi)要(Yao)有(You)一(Yi)个(Ge)词(Ci)在(Zai)文(Wen)档(Dang)中(Zhong)出(Chu)现(Xian)则(Ze)就(Jiu)符(Fu)合(He)条(Tiao)件(Jian),and表(Biao)示(Shi)每(Mei)个(Ge)词(Ci)都(Du)在(Zai)文(Wen)档(Dang)中(Zhong)出(Chu)现(Xian)则(Ze)才(Cai)符(Fu)合(He)条(Tiao)件(Jian)。上(Shang)边(Bian)的(De)搜(Sou)索(Suo)的(De)执(Zhi)行(Xing)过(Guo)程(Cheng)是(Shi):1、将(Jiang)“spring开(Kai)发(Fa)”分(Fen)词(Ci),分(Fen)为(Wei)spring、开(Kai)发(Fa)两(Liang)个(Ge)词(Ci)2、再(Zai)使(Shi)用(Yong)spring和(He)开(Kai)发(Fa)两(Liang)个(Ge)词(Ci)去(Qu)匹(Pi)配(Pei)索(Suo)引(Yin)中(Zhong)搜(Sou)索(Suo)。3、由(You)于(Yu)设(She)置(Zhi)了(Liao)operator为(Wei)or,只(Zhi)要(Yao)有(You)一(Yi)个(Ge)词(Ci)匹(Pi)配(Pei)成(Cheng)功(Gong)则(Ze)就(Jiu)返(Fan)回(Hui)该(Gai)文(Wen)档(Dang)。JavaClient://根(Gen)据(Ju)关(Guan)键(Jian)字(Zi)搜(Sou)索(Suo)@Test public void testMatchQuery() throws IOException, ParseException { //搜(Sou)索(Suo)请(Qing)求(Qiu)对(Dui)象(Xiang) SearchRequest searchRequest = new SearchRequest("xc_course"); //设(She)置(Zhi)类(Lei)型(Xing) searchRequest.types("doc"); //搜(Sou)索(Suo)源(Yuan)构(Gou)建(Jian)对(Dui)象(Xiang) SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); //MatcherQuery searchSourceBuilder.query(QueryBuilders.matchQuery("description","spring开(Kai)发(Fa)").operator(Operator.OR)); //source源(Yuan)字(Zi)段(Duan)过(Guo)虑(Lv) searchSourceBuilder.fetchSource(new String[]{"name","studymodel","price","timestamp"},new String[]{}); //设(She)置(Zhi)搜(Sou)索(Suo)源(Yuan) searchRequest.source(searchSourceBuilder); //执(Zhi)行(Xing)搜(Sou)索(Suo) SearchResponse searchResponse = client.search(searchRequest); //搜(Sou)索(Suo)匹(Pi)配(Pei)结(Jie)果(Guo) SearchHits hits = searchResponse.getHits(); //搜(Sou)索(Suo)总(Zong)记(Ji)录(Lu)数(Shu) long totalHits = hits.totalHits; //匹(Pi)配(Pei)度(Du)较(Jiao)高(Gao)的(De)前(Qian)N个(Ge)文(Wen)档(Dang) SearchHit[] searchHits = hits.getHits(); //日(Ri)期(Qi)格(Ge)式(Shi)化(Hua)对(Dui)象(Xiang) SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); for(SearchHit hit:searchHits){ //文(Wen)档(Dang)id String id = hit.getId(); //源(Yuan)文(Wen)档(Dang)内(Nei)容(Rong) Map sourceAsMap = hit.getSourceAsMap(); //获(Huo)取(Qu)源(Yuan)文(Wen)档(Dang)name String name = (String) sourceAsMap.get("name"); String description = (String) sourceAsMap.get("description"); String studymodel = (String) sourceAsMap.get("studymodel"); Double price = (Double) sourceAsMap.get("price"); Date timestamp = dateFormat.parse((String) sourceAsMap.get("timestamp")); System.out.println(name); System.out.println(studymodel); System.out.println(description); } }2、minimum_should_match上(Shang)边(Bian)使(Shi)用(Yong)的(De)operator = or表(Biao)示(Shi)只(Zhi)要(Yao)有(You)一(Yi)个(Ge)词(Ci)匹(Pi)配(Pei)上(Shang)就(Jiu)得(De)分(Fen),如(Ru)果(Guo)实(Shi)现(Xian)三(San)个(Ge)词(Ci)至(Zhi)少(Shao)有(You)两(Liang)个(Ge)词(Ci)匹(Pi)配(Pei)如(Ru)何(He)实(Shi)现(Xian)?使(Shi)用(Yong)minimum_should_match可(Ke)以(Yi)指(Zhi)定(Ding)文(Wen)档(Dang)匹(Pi)配(Pei)词(Ci)的(De)占(Zhan)比(Bi):比(Bi)如(Ru)搜(Sou)索(Suo)语(Yu)句(Ju)如(Ru)下(Xia):{ "query": { "match" : { "description" : { "query" : "spring开(Kai)发(Fa)框(Kuang)架(Jia)", "minimum_should_match": "80%" } } }}“spring开(Kai)发(Fa)框(Kuang)架(Jia)”会(Hui)被(Bei)分(Fen)为(Wei)三(San)个(Ge)词(Ci):spring、开(Kai)发(Fa)、框(Kuang)架(Jia)设(She)置(Zhi)"minimum_should_match": "80%"表(Biao)示(Shi),三(San)个(Ge)词(Ci)在(Zai)文(Wen)档(Dang)的(De)匹(Pi)配(Pei)占(Zhan)比(Bi)为(Wei)80%,即(Ji)3*0.8=2.4,向(Xiang)上(Shang)取(Qu)整(Zheng)得(De)2,表(Biao)示(Shi)至(Zhi)少(Shao)有(You)两(Liang)个(Ge)词(Ci)在(Zai)文(Wen)档(Dang)中(Zhong)要(Yao)匹(Pi)配(Pei)成(Cheng)功(Gong)。对(Dui)应(Ying)的(De)RestClient如(Ru)下(Xia)://MatcherQuery searchSourceBuilder.query(QueryBuilders.matchQuery("description","spring开(Kai)发(Fa)框(Kuang)架(Jia)") .operator(Operator.OR) .minimumShouldMatch("80%")); multi Query上(Shang)边(Bian)学(Xue)习(Xi)的(De)termQuery和(He)matchQuery一(Yi)次(Ci)只(Zhi)能(Neng)匹(Pi)配(Pei)一(Yi)个(Ge)Field,本(Ben)节(Jie)学(Xue)习(Xi)multiQuery,一(Yi)次(Ci)可(Ke)以(Yi)匹(Pi)配(Pei)多(Duo)个(Ge)字(Zi)段(Duan)。1、基(Ji)本(Ben)使(Shi)用(Yong)单(Dan)项(Xiang)匹(Pi)配(Pei)是(Shi)在(Zai)一(Yi)个(Ge)field中(Zhong)去(Qu)匹(Pi)配(Pei),多(Duo)项(Xiang)匹(Pi)配(Pei)是(Shi)拿(Na)关(Guan)键(Jian)字(Zi)去(Qu)多(Duo)个(Ge)Field中(Zhong)匹(Pi)配(Pei)。例(Li)子(Zi):发(Fa)送(Song):post http://localhost:9200/xc_course/doc/_search拿(Na)关(Guan)键(Jian)字(Zi) “spring css”去(Qu)匹(Pi)配(Pei)name 和(He)description字(Zi)段(Duan)。{ "query": { "multi_match" : { "query" : "spring css", "minimum_should_match": "50%", "fields": [ "name", "description" ] } }}2、提(Ti)升(Sheng)boost匹(Pi)配(Pei)多(Duo)个(Ge)字(Zi)段(Duan)时(Shi)可(Ke)以(Yi)提(Ti)升(Sheng)字(Zi)段(Duan)的(De)boost(权(Quan)重(Zhong))来(Lai)提(Ti)高(Gao)得(De)分(Fen)例(Li)子(Zi):提(Ti)升(Sheng)boost之(Zhi)前(Qian),执(Zhi)行(Xing)下(Xia)边(Bian)的(De)查(Cha)询(Xun):{ "query": { "multi_match" : { "query" : "spring css", "minimum_should_match": "50%", "fields": [ "name", "description" ] } }}通(Tong)过(Guo)查(Cha)询(Xun)发(Fa)现(Xian)Bootstrap排(Pai)在(Zai)前(Qian)边(Bian)。提(Ti)升(Sheng)boost,通(Tong)常(Chang)关(Guan)键(Jian)字(Zi)匹(Pi)配(Pei)上(Shang)name的(De)权(Quan)重(Zhong)要(Yao)比(Bi)匹(Pi)配(Pei)上(Shang)description的(De)权(Quan)重(Zhong)高(Gao),这(Zhe)里(Li)可(Ke)以(Yi)对(Dui)name的(De)权(Quan)重(Zhong)提(Ti)升(Sheng)。{ "query": { "multi_match" : { "query" : "spring css", "minimum_should_match": "50%", "fields": [ "name^10", "description" ] } }}“name^10” 表(Biao)示(Shi)权(Quan)重(Zhong)提(Ti)升(Sheng)10倍(Bei),执(Zhi)行(Xing)上(Shang)边(Bian)的(De)查(Cha)询(Xun),发(Fa)现(Xian)name中(Zhong)包(Bao)括(Kuo)spring关(Guan)键(Jian)字(Zi)的(De)文(Wen)档(Dang)排(Pai)在(Zai)前(Qian)边(Bian)。JavaClient://搜(Sou)索(Suo)源(Yuan)构(Gou)建(Jian)对(Dui)象(Xiang)SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();//MultiMatcherQueryMultiMatchQueryBuilder matchQueryBuilder = QueryBuilders.multiMatchQuery("spring css", "name", "description") .minimumShouldMatch("50%") .field("name", 10);searchSourceBuilder.query(matchQueryBuilder);布(Bu)尔(Er)查(Cha)询(Xun)布(Bu)尔(Er)查(Cha)询(Xun)对(Dui)应(Ying)于(Yu)Lucene的(De)BooleanQuery查(Cha)询(Xun),实(Shi)现(Xian)将(Jiang)多(Duo)个(Ge)查(Cha)询(Xun)组(Zu)合(He)起(Qi)来(Lai)。三(San)个(Ge)参(Can)数(Shu):must:文(Wen)档(Dang)必(Bi)须(Xu)匹(Pi)配(Pei)must所(Suo)包(Bao)括(Kuo)的(De)查(Cha)询(Xun)条(Tiao)件(Jian),相(Xiang)当(Dang)于(Yu) “AND” should:文(Wen)档(Dang)应(Ying)该(Gai)匹(Pi)配(Pei)should所(Suo)包(Bao)括(Kuo)的(De)查(Cha)询(Xun)条(Tiao)件(Jian)其(Qi)中(Zhong)的(De)一(Yi)个(Ge)或(Huo)多(Duo)个(Ge),相(Xiang)当(Dang)于(Yu) "OR" must_not:文(Wen)档(Dang)不(Bu)能(Neng)匹(Pi)配(Pei)must_not所(Suo)包(Bao)括(Kuo)的(De)该(Gai)查(Cha)询(Xun)条(Tiao)件(Jian),相(Xiang)当(Dang)于(Yu)“NOT”分(Fen)别(Bie)使(Shi)用(Yong)must、should、must_not测(Ce)试(Shi)下(Xia)边(Bian)的(De)查(Cha)询(Xun):发(Fa)送(Song):POST http://localhost:9200/xc_course/doc/_search{ "_source" : [ "name", "studymodel", "description"], "from" : 0, "size" : 1, "query": { "bool" : { "must":[ { "multi_match" : { "query" : "spring css", "minimum_should_match": "50%", "fields": [ "name^10", "description" ] } }, { "term":{ "studymodel" : "201001" } } ] } }}must:表(Biao)示(Shi)必(Bi)须(Xu),多(Duo)个(Ge)查(Cha)询(Xun)条(Tiao)件(Jian)必(Bi)须(Xu)都(Du)满(Man)足(Zu)。(通(Tong)常(Chang)使(Shi)用(Yong)must)should:表(Biao)示(Shi)或(Huo)者(Zhe),多(Duo)个(Ge)查(Cha)询(Xun)条(Tiao)件(Jian)只(Zhi)要(Yao)有(You)一(Yi)个(Ge)满(Man)足(Zu)即(Ji)可(Ke)。must_not:表(Biao)示(Shi)非(Fei)。JavaClient://BoolQuery,将(Jiang)搜(Sou)索(Suo)关(Guan)键(Jian)字(Zi)分(Fen)词(Ci),拿(Na)分(Fen)词(Ci)去(Qu)索(Suo)引(Yin)库(Ku)搜(Sou)索(Suo)//搜(Sou)索(Suo)源(Yuan)构(Gou)建(Jian)对(Dui)象(Xiang)SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();//MultiMatcherQueryMultiMatchQueryBuilder matchQueryBuilder = QueryBuilders.multiMatchQuery("spring css", "name", "description") .minimumShouldMatch("50%") .field("name", 10);//TermQueryTermQueryBuilder termQueryBuilder = QueryBuilders.termQuery("studymodel", "201001");//boolQueryBuilderBoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();//将(Jiang)MultiMatcherQuery和(He)TermQuery组(Zu)织(Zhi)在(Zai)一(Yi)起(Qi)boolQueryBuilder.must(matchQueryBuilder);boolQueryBuilder.must(termQueryBuilder);searchSourceBuilder.query(boolQueryBuilder);过(Guo)虑(Lv)器(Qi)过(Guo)虑(Lv)是(Shi)针(Zhen)对(Dui)搜(Sou)索(Suo)的(De)结(Jie)果(Guo)进(Jin)行(Xing)过(Guo)虑(Lv),过(Guo)虑(Lv)器(Qi)主(Zhu)要(Yao)判(Pan)断(Duan)的(De)是(Shi)文(Wen)档(Dang)是(Shi)否(Fou)匹(Pi)配(Pei),不(Bu)去(Qu)计(Ji)算(Suan)和(He)判(Pan)断(Duan)文(Wen)档(Dang)的(De)匹(Pi)配(Pei)度(Du)得(De)分(Fen),所(Suo)以(Yi)过(Guo)虑(Lv)器(Qi)性(Xing)能(Neng)比(Bi)查(Cha)询(Xun)要(Yao)高(Gao),且(Qie)方(Fang)便(Bian)缓(Huan)存(Cun),推(Tui)荐(Jian)尽(Jin)量(Liang)使(Shi)用(Yong)过(Guo)虑(Lv)器(Qi)去(Qu)实(Shi)现(Xian)查(Cha)询(Xun)或(Huo)者(Zhe)过(Guo)虑(Lv)器(Qi)和(He)查(Cha)询(Xun)共(Gong)同(Tong)使(Shi)用(Yong)。过(Guo)虑(Lv)器(Qi)在(Zai)布(Bu)尔(Er)查(Cha)询(Xun)中(Zhong)使(Shi)用(Yong),下(Xia)边(Bian)是(Shi)在(Zai)搜(Sou)索(Suo)结(Jie)果(Guo)的(De)基(Ji)础(Chu)上(Shang)进(Jin)行(Xing)过(Guo)虑(Lv):{ "_source" : [ "name", "studymodel", "description","price"], "query": { "bool" : { "must":[ { "multi_match" : { "query" : "spring css", "minimum_should_match": "50%", "fields": [ "name^10", "description" ] } } ], "filter": [ { "term": { "studymodel": "201001" }}, { "range": { "price": { "gte": 60 ,"lte" : 100}}} ] } }}range:范(Fan)围(Wei)过(Guo)虑(Lv),保(Bao)留(Liu)大(Da)于(Yu)等(Deng)于(Yu)60 并(Bing)且(Qie)小(Xiao)于(Yu)等(Deng)于(Yu)100的(De)记(Ji)录(Lu)。term:项(Xiang)匹(Pi)配(Pei)过(Guo)虑(Lv),保(Bao)留(Liu)studymodel等(Deng)于(Yu)"201001"的(De)记(Ji)录(Lu)。注(Zhu)意(Yi):range和(He)term一(Yi)次(Ci)只(Zhi)能(Neng)对(Dui)一(Yi)个(Ge)Field设(She)置(Zhi)范(Fan)围(Wei)过(Guo)虑(Lv)。client://搜(Sou)索(Suo)源(Yuan)构(Gou)建(Jian)对(Dui)象(Xiang)SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder();//MultiMatcherQueryMultiMatchQueryBuilder matchQueryBuilder = QueryBuilders.multiMatchQuery("spring css", "name", "description") .minimumShouldMatch("50%") .field("name", 10);//boolQueryBuilderBoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery();//将(Jiang)MultiMatcherQuery和(He)TermQuery组(Zu)织(Zhi)在(Zai)一(Yi)起(Qi)boolQueryBuilder.must(matchQueryBuilder);//添(Tian)加(Jia)过(Guo)虑(Lv)器(Qi)//项(Xiang)过(Guo)虑(Lv)boolQueryBuilder.filter(QueryBuilders.termQuery("studymodel","201001"));//范(Fan)围(Wei)过(Guo)虑(Lv)boolQueryBuilder.filter(QueryBuilders.rangeQuery("price").gte(60).lte(100));searchSourceBuilder.query(boolQueryBuilder);排(Pai)序(Xu)可(Ke)以(Yi)在(Zai)字(Zi)段(Duan)上(Shang)添(Tian)加(Jia)一(Yi)个(Ge)或(Huo)多(Duo)个(Ge)排(Pai)序(Xu),支(Zhi)持(Chi)在(Zai)keyword、date、float等(Deng)类(Lei)型(Xing)上(Shang)添(Tian)加(Jia),text类(Lei)型(Xing)的(De)字(Zi)段(Duan)上(Shang)不(Bu)允(Yun)许(Xu)添(Tian)加(Jia)排(Pai)序(Xu)。发(Fa)送(Song) POST http://localhost:9200/xc_course/doc/_search过(Guo)虑(Lv)0--10元(Yuan)价(Jia)格(Ge)范(Fan)围(Wei)的(De)文(Wen)档(Dang),并(Bing)且(Qie)对(Dui)结(Jie)果(Guo)进(Jin)行(Xing)排(Pai)序(Xu),先(Xian)按(An)studymodel降(Jiang)序(Xu),再(Zai)按(An)价(Jia)格(Ge)升(Sheng)序(Xu){ "_source" : [ "name", "studymodel", "description","price"], "query": { "bool" : { "filter": [ { "range": { "price": { "gte": 0 ,"lte" : 100}}} ] } }, "sort" : [ { "studymodel" : "desc" }, { "price" : "asc" } ]}client:@Testpublic void testSort() throws IOException, ParseException { //搜(Sou)索(Suo)请(Qing)求(Qiu)对(Dui)象(Xiang) SearchRequest searchRequest = new SearchRequest("xc_course"); //设(She)置(Zhi)类(Lei)型(Xing) searchRequest.types("doc"); //搜(Sou)索(Suo)源(Yuan)构(Gou)建(Jian)对(Dui)象(Xiang) SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); //source源(Yuan)字(Zi)段(Duan)过(Guo)虑(Lv) searchSourceBuilder.fetchSource(new String[]{"name","studymodel","price","timestamp"},new String[]{}); //boolQueryBuilder BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery(); //添(Tian)加(Jia)过(Guo)虑(Lv)器(Qi) //范(Fan)围(Wei)过(Guo)虑(Lv) boolQueryBuilder.filter(QueryBuilders.rangeQuery("price").gte(0).lte(100)); searchSourceBuilder.query(boolQueryBuilder); //设(She)置(Zhi)搜(Sou)索(Suo)源(Yuan) searchRequest.source(searchSourceBuilder); //设(She)置(Zhi)排(Pai)序(Xu) searchSourceBuilder.sort("studymodel", SortOrder.DESC); searchSourceBuilder.sort("price", SortOrder.ASC); //执(Zhi)行(Xing)搜(Sou)索(Suo) SearchResponse searchResponse = client.search(searchRequest); //搜(Sou)索(Suo)匹(Pi)配(Pei)结(Jie)果(Guo) SearchHits hits = searchResponse.getHits(); //搜(Sou)索(Suo)总(Zong)记(Ji)录(Lu)数(Shu) long totalHits = hits.totalHits; //匹(Pi)配(Pei)度(Du)较(Jiao)高(Gao)的(De)前(Qian)N个(Ge)文(Wen)档(Dang) SearchHit[] searchHits = hits.getHits(); //日(Ri)期(Qi)格(Ge)式(Shi)化(Hua)对(Dui)象(Xiang) SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); for(SearchHit hit:searchHits){ //文(Wen)档(Dang)id String id = hit.getId(); //源(Yuan)文(Wen)档(Dang)内(Nei)容(Rong) Map sourceAsMap = hit.getSourceAsMap(); //获(Huo)取(Qu)源(Yuan)文(Wen)档(Dang)name String name = (String) sourceAsMap.get("name"); String description = (String) sourceAsMap.get("description"); String studymodel = (String) sourceAsMap.get("studymodel"); Double price = (Double) sourceAsMap.get("price"); Date timestamp = dateFormat.parse((String) sourceAsMap.get("timestamp")); System.out.println(name); System.out.println(studymodel); System.out.println(description); }}高(Gao)亮(Liang)显(Xian)示(Shi)高(Gao)亮(Liang)显(Xian)示(Shi)可(Ke)以(Yi)将(Jiang)搜(Sou)索(Suo)结(Jie)果(Guo)一(Yi)个(Ge)或(Huo)多(Duo)个(Ge)字(Zi)突(Tu)出(Chu)显(Xian)示(Shi),以(Yi)便(Bian)向(Xiang)用(Yong)户(Hu)展(Zhan)示(Shi)匹(Pi)配(Pei)关(Guan)键(Jian)字(Zi)的(De)位(Wei)置(Zhi)。在(Zai)搜(Sou)索(Suo)语(Yu)句(Ju)中(Zhong)添(Tian)加(Jia)highlight即(Ji)可(Ke)实(Shi)现(Xian),如(Ru)下(Xia):Post: http://127.0.0.1:9200/xc_course/doc/_search{ "_source" : [ "name", "studymodel", "timestamp","price"], "query": { "bool" : { "must":[ { "multi_match" : { "query" : "开(Kai)发(Fa)框(Kuang)架(Jia)", "minimum_should_match": "50%", "fields": [ "name^10", "description" ] } } ], "filter": [ { "range": { "price": { "gte": 0 ,"lte" : 100}}} ] } }, "sort" : [ { "price" : "asc" } ], "highlight": { "pre_tags": [""], "post_tags": [""], "fields": { "name": {}, "description":{} } }}client代(Dai)码(Ma)如(Ru)下(Xia):@Testpublic void testHighLight() throws IOException, ParseException { //搜(Sou)索(Suo)请(Qing)求(Qiu)对(Dui)象(Xiang) SearchRequest searchRequest = new SearchRequest("xc_course"); //设(She)置(Zhi)类(Lei)型(Xing) searchRequest.types("doc"); //搜(Sou)索(Suo)源(Yuan)构(Gou)建(Jian)对(Dui)象(Xiang) SearchSourceBuilder searchSourceBuilder = new SearchSourceBuilder(); //source源(Yuan)字(Zi)段(Duan)过(Guo)虑(Lv) searchSourceBuilder.fetchSource(new String[]{"name","studymodel","price","timestamp"},new String[]{}); //MultiMatcherQuery MultiMatchQueryBuilder matchQueryBuilder = QueryBuilders.multiMatchQuery("开(Kai)发(Fa)框(Kuang)架(Jia)", "name", "description") .minimumShouldMatch("80%") .field("name", 10); //boolQueryBuilder BoolQueryBuilder boolQueryBuilder = QueryBuilders.boolQuery(); boolQueryBuilder.must(matchQueryBuilder); //添(Tian)加(Jia)过(Guo)虑(Lv)器(Qi) //范(Fan)围(Wei)过(Guo)虑(Lv) boolQueryBuilder.filter(QueryBuilders.rangeQuery("price").gte(0).lte(100)); searchSourceBuilder.query(boolQueryBuilder); //设(She)置(Zhi)搜(Sou)索(Suo)源(Yuan) searchRequest.source(searchSourceBuilder); //设(She)置(Zhi)排(Pai)序(Xu) searchSourceBuilder.sort("studymodel", SortOrder.DESC); searchSourceBuilder.sort("price", SortOrder.ASC); //设(She)置(Zhi)高(Gao)亮(Liang) HighlightBuilder highlightBuilder = new HighlightBuilder(); highlightBuilder.preTags(""); highlightBuilder.postTags(""); highlightBuilder.fields().add(new HighlightBuilder.Field("name")); searchSourceBuilder.highlighter(highlightBuilder); //执(Zhi)行(Xing)搜(Sou)索(Suo) SearchResponse searchResponse = client.search(searchRequest); //搜(Sou)索(Suo)匹(Pi)配(Pei)结(Jie)果(Guo) SearchHits hits = searchResponse.getHits(); //搜(Sou)索(Suo)总(Zong)记(Ji)录(Lu)数(Shu) long totalHits = hits.totalHits; //匹(Pi)配(Pei)度(Du)较(Jiao)高(Gao)的(De)前(Qian)N个(Ge)文(Wen)档(Dang) SearchHit[] searchHits = hits.getHits(); //日(Ri)期(Qi)格(Ge)式(Shi)化(Hua)对(Dui)象(Xiang) SimpleDateFormat dateFormat = new SimpleDateFormat("yyyy-MM-dd HH:mm:ss"); for(SearchHit hit:searchHits){ //文(Wen)档(Dang)id String id = hit.getId(); //源(Yuan)文(Wen)档(Dang)内(Nei)容(Rong) Map sourceAsMap = hit.getSourceAsMap(); //获(Huo)取(Qu)源(Yuan)文(Wen)档(Dang)name String name = (String) sourceAsMap.get("name"); //取(Qu)出(Chu)高(Gao)亮(Liang)字(Zi)段(Duan) Map highlightFields = hit.getHighlightFields(); if(highlightFields!=null){ //取(Qu)出(Chu)name高(Gao)亮(Liang)字(Zi)段(Duan) HighlightField nameField = highlightFields.get("name"); if(nameField!=null){ Text[] fragments = nameField.fragments(); StringBuffer stringBuffer = new StringBuffer(); for(Text text:fragments){ stringBuffer.append(text); } name = stringBuffer.toString(); } } String description = (String) sourceAsMap.get("description"); String studymodel = (String) sourceAsMap.get("studymodel"); Double price = (Double) sourceAsMap.get("price"); Date timestamp = dateFormat.parse((String) sourceAsMap.get("timestamp")); System.out.println(name); System.out.println(studymodel); System.out.println(description); }}集(Ji)群(Qun)管(Guan)理(Li)集(Ji)群(Qun)结(Jie)构(Gou)ES通(Tong)常(Chang)以(Yi)集(Ji)群(Qun)方(Fang)式(Shi)工(Gong)作(Zuo),这(Zhe)样(Yang)做(Zuo)不(Bu)仅(Jin)能(Neng)够(Gou)提(Ti)高(Gao) ES的(De)搜(Sou)索(Suo)能(Neng)力(Li)还(Huan)可(Ke)以(Yi)处(Chu)理(Li)大(Da)数(Shu)据(Ju)搜(Sou)索(Suo)的(De)能(Neng)力(Li),同(Tong)时(Shi)也(Ye)增(Zeng)加(Jia)了(Liao)系(Xi)统(Tong)的(De)容(Rong)错(Cuo)能(Neng)力(Li)及(Ji)高(Gao)可(Ke)用(Yong),ES可(Ke)以(Yi)实(Shi)现(Xian)PB级(Ji)数(Shu)据(Ju)的(De)搜(Sou)索(Suo)。下(Xia)图(Tu)是(Shi)ES集(Ji)群(Qun)结(Jie)构(Gou)的(De)示(Shi)意(Yi)图(Tu):从(Cong)上(Shang)图(Tu)总(Zong)结(Jie)以(Yi)下(Xia)概(Gai)念(Nian):1、结(Jie)点(Dian)ES集(Ji)群(Qun)由(You)多(Duo)个(Ge)服(Fu)务(Wu)器(Qi)组(Zu)成(Cheng),每(Mei)个(Ge)服(Fu)务(Wu)器(Qi)即(Ji)为(Wei)一(Yi)个(Ge)Node结(Jie)点(Dian)(该(Gai)服(Fu)务(Wu)只(Zhi)部(Bu)署(Shu)了(Liao)一(Yi)个(Ge)ES进(Jin)程(Cheng))。2、分(Fen)片(Pian)当(Dang)我(Wo)们(Men)的(De)文(Wen)档(Dang)量(Liang)很(Hen)大(Da)时(Shi),由(You)于(Yu)内(Nei)存(Cun)和(He)硬(Ying)盘(Pan)的(De)限(Xian)制(Zhi),同(Tong)时(Shi)也(Ye)为(Wei)了(Liao)提(Ti)高(Gao)ES的(De)处(Chu)理(Li)能(Neng)力(Li)、容(Rong)错(Cuo)能(Neng)力(Li)及(Ji)高(Gao)可(Ke)用(Yong)能(Neng)力(Li),我(Wo)们(Men)将(Jiang)索(Suo)引(Yin)分(Fen)成(Cheng)若(Ruo)干(Gan)分(Fen)片(Pian),每(Mei)个(Ge)分(Fen)片(Pian)可(Ke)以(Yi)放(Fang)在(Zai)不(Bu)同(Tong)的(De)服(Fu)务(Wu)器(Qi),这(Zhe)样(Yang)就(Jiu)实(Shi)现(Xian)了(Liao)多(Duo)个(Ge)服(Fu)务(Wu)器(Qi)共(Gong)同(Tong)对(Dui)外(Wai)提(Ti)供(Gong)索(Suo)引(Yin)及(Ji)搜(Sou)索(Suo)服(Fu)务(Wu)。一(Yi)个(Ge)搜(Sou)索(Suo)请(Qing)求(Qiu)过(Guo)来(Lai),会(Hui)分(Fen)别(Bie)从(Cong)各(Ge)各(Ge)分(Fen)片(Pian)去(Qu)查(Cha)询(Xun),最(Zui)后(Hou)将(Jiang)查(Cha)询(Xun)到(Dao)的(De)数(Shu)据(Ju)合(He)并(Bing)返(Fan)回(Hui)给(Gei)用(Yong)户(Hu)。3、副(Fu)本(Ben)为(Wei)了(Liao)提(Ti)高(Gao)ES的(De)高(Gao)可(Ke)用(Yong)同(Tong)时(Shi)也(Ye)为(Wei)了(Liao)提(Ti)高(Gao)搜(Sou)索(Suo)的(De)吞(Tun)吐(Tu)量(Liang),我(Wo)们(Men)将(Jiang)分(Fen)片(Pian)复(Fu)制(Zhi)一(Yi)份(Fen)或(Huo)多(Duo)份(Fen)存(Cun)储(Chu)在(Zai)其(Qi)它(Ta)的(De)服(Fu)务(Wu)器(Qi),这(Zhe)样(Yang)即(Ji)使(Shi)当(Dang)前(Qian)的(De)服(Fu)务(Wu)器(Qi)挂(Gua)掉(Diao)了(Liao),拥(Yong)有(You)副(Fu)本(Ben)的(De)服(Fu)务(Wu)器(Qi)照(Zhao)常(Chang)可(Ke)以(Yi)提(Ti)供(Gong)服(Fu)务(Wu)。4、主(Zhu)结(Jie)点(Dian)一(Yi)个(Ge)集(Ji)群(Qun)中(Zhong)会(Hui)有(You)一(Yi)个(Ge)或(Huo)多(Duo)个(Ge)主(Zhu)结(Jie)点(Dian),主(Zhu)结(Jie)点(Dian)的(De)作(Zuo)用(Yong)是(Shi)集(Ji)群(Qun)管(Guan)理(Li),比(Bi)如(Ru)增(Zeng)加(Jia)节(Jie)点(Dian),移(Yi)除(Chu)节(Jie)点(Dian)等(Deng),主(Zhu)结(Jie)点(Dian)挂(Gua)掉(Diao)后(Hou)ES会(Hui)重(Zhong)新(Xin)选(Xuan)一(Yi)个(Ge)主(Zhu)结(Jie)点(Dian)。5、结(Jie)点(Dian)转(Zhuan)发(Fa)每(Mei)个(Ge)结(Jie)点(Dian)都(Du)知(Zhi)道(Dao)其(Qi)它(Ta)结(Jie)点(Dian)的(De)信(Xin)息(Xi),我(Wo)们(Men)可(Ke)以(Yi)对(Dui)任(Ren)意(Yi)一(Yi)个(Ge)结(Jie)点(Dian)发(Fa)起(Qi)请(Qing)求(Qiu),接(Jie)收(Shou)请(Qing)求(Qiu)的(De)结(Jie)点(Dian)会(Hui)转(Zhuan)发(Fa)给(Gei)其(Qi)它(Ta)结(Jie)点(Dian)查(Cha)询(Xun)数(Shu)据(Ju)。搭(Da)建(Jian)集(Ji)群(Qun)下(Xia)边(Bian)的(De)例(Li)子(Zi)实(Shi)现(Xian)创(Chuang)建(Jian)一(Yi)个(Ge)2结(Jie)点(Dian)的(De)集(Ji)群(Qun),并(Bing)且(Qie)索(Suo)引(Yin)的(De)分(Fen)片(Pian)我(Wo)们(Men)设(She)置(Zhi)2片(Pian),每(Mei)片(Pian)一(Yi)个(Ge)副(Fu)本(Ben)。结(Jie)点(Dian)的(De)三(San)个(Ge)角(Jiao)色(Se)主(Zhu)结(Jie)点(Dian):master节(Jie)点(Dian)主(Zhu)要(Yao)用(Yong)于(Yu)集(Ji)群(Qun)的(De)管(Guan)理(Li)及(Ji)索(Suo)引(Yin) 比(Bi)如(Ru)新(Xin)增(Zeng)结(Jie)点(Dian)、分(Fen)片(Pian)分(Fen)配(Pei)、索(Suo)引(Yin)的(De)新(Xin)增(Zeng)和(He)删(Shan)除(Chu)等(Deng)。 数(Shu)据(Ju)结(Jie)点(Dian):data 节(Jie)点(Dian)上(Shang)保(Bao)存(Cun)了(Liao)数(Shu)据(Ju)分(Fen)片(Pian),它(Ta)负(Fu)责(Ze)索(Suo)引(Yin)和(He)搜(Sou)索(Suo)操(Cao)作(Zuo)。 客(Ke)户(Hu)端(Duan)结(Jie)点(Dian):client 节(Jie)点(Dian)仅(Jin)作(Zuo)为(Wei)请(Qing)求(Qiu)客(Ke)户(Hu)端(Duan)存(Cun)在(Zai),client的(De)作(Zuo)用(Yong)也(Ye)作(Zuo)为(Wei)负(Fu)载(Zai)均(Jun)衡(Heng)器(Qi),client 节(Jie)点(Dian)不(Bu)存(Cun)数(Shu)据(Ju),只(Zhi)是(Shi)将(Jiang)请(Qing)求(Qiu)均(Jun)衡(Heng)转(Zhuan)发(Fa)到(Dao)其(Qi)它(Ta)结(Jie)点(Dian)。通(Tong)过(Guo)下(Xia)边(Bian)两(Liang)项(Xiang)参(Can)数(Shu)来(Lai)配(Pei)置(Zhi)结(Jie)点(Dian)的(De)功(Gong)能(Neng):node.master: #是(Shi)否(Fou)允(Yun)许(Xu)为(Wei)主(Zhu)结(Jie)点(Dian)node.data: #允(Yun)许(Xu)存(Cun)储(Chu)数(Shu)据(Ju)作(Zuo)为(Wei)数(Shu)据(Ju)结(Jie)点(Dian)node.ingest: #是(Shi)否(Fou)允(Yun)许(Xu)成(Cheng)为(Wei)协(Xie)调(Diao)节(Jie)点(Dian),四(Si)种(Zhong)组(Zu)合(He)方(Fang)式(Shi):master=true,data=true:即(Ji)是(Shi)主(Zhu)结(Jie)点(Dian)又(You)是(Shi)数(Shu)据(Ju)结(Jie)点(Dian)master=false,data=true:仅(Jin)是(Shi)数(Shu)据(Ju)结(Jie)点(Dian)master=true,data=false:仅(Jin)是(Shi)主(Zhu)结(Jie)点(Dian),不(Bu)存(Cun)储(Chu)数(Shu)据(Ju)master=false,data=false:即(Ji)不(Bu)是(Shi)主(Zhu)结(Jie)点(Dian)也(Ye)不(Bu)是(Shi)数(Shu)据(Ju)结(Jie)点(Dian),此(Ci)时(Shi)可(Ke)设(She)置(Zhi)ingest为(Wei)true表(Biao)示(Shi)它(Ta)是(Shi)一(Yi)个(Ge)客(Ke)户(Hu)端(Duan)。创(Chuang)建(Jian)结(Jie)点(Dian) 1解(Jie)压(Ya)elasticsearch-6.2.1.zip 到(Dao) F:\devenv\elasticsearch\es-cloud-1\elasticsearch-6.2.1结(Jie)点(Dian)1对(Dui)外(Wai)服(Fu)务(Wu)的(De)http端(Duan)口(Kou)是(Shi):9200集(Ji)群(Qun)管(Guan)理(Li)端(Duan)口(Kou)是(Shi)9300配(Pei)置(Zhi)elasticsearch.yml结(Jie)点(Dian)名(Ming):xc_node_1elasticsearch.yml内(Nei)容(Rong)如(Ru)下(Xia)cluster.name: xuechengnode.name: xc_node_1network.host: 0.0.0.0http.port: 9200transport.tcp.port: 9300node.master: truenode.data: truediscovery.zen.ping.unicast.hosts: ["0.0.0.0:9300", "0.0.0.0:9301"]discovery.zen.minimum_master_nodes: 1node.ingest: truenode.max_local_storage_nodes: 2path.data: D:\ElasticSearch\elasticsearch-6.2.1-1\datapath.logs: D:\ElasticSearch\elasticsearch-6.2.1-1\logshttp.cors.enabled: truehttp.cors.allow-origin: /.*/启(Qi)动(Dong)结(Jie)点(Dian)1创(Chuang)建(Jian)结(Jie)点(Dian) 2解(Jie)压(Ya)elasticsearch-6.2.1.zip 到(Dao) F:\devenv\elasticsearch\es-cloud-2\elasticsearch-6.2.1结(Jie)点(Dian)1对(Dui)外(Wai)服(Fu)务(Wu)的(De)http端(Duan)口(Kou)是(Shi):9201集(Ji)群(Qun)管(Guan)理(Li)端(Duan)口(Kou)是(Shi)9301结(Jie)点(Dian)名(Ming):xc_node_2elasticsearch.yml内(Nei)容(Rong)如(Ru)下(Xia)cluster.name: xuechengnode.name: xc_node_2network.host: 0.0.0.0http.port: 9201transport.tcp.port: 9301node.master: truenode.data: truediscovery.zen.ping.unicast.hosts: ["0.0.0.0:9300", "0.0.0.0:9301"]discovery.zen.minimum_master_nodes: 1node.ingest: truenode.max_local_storage_nodes: 2path.data: D:\ElasticSearch\elasticsearch-6.2.1-2\datapath.logs: D:\ElasticSearch\elasticsearch-6.2.1-2\logshttp.cors.enabled: truehttp.cors.allow-origin: /.*/启(Qi)动(Dong)结(Jie)点(Dian)2创(Chuang)建(Jian)索(Suo)引(Yin)库(Ku)1)使(Shi)用(Yong)head连(Lian)上(Shang)其(Qi)中(Zhong)一(Yi)个(Ge)结(Jie)点(Dian)上(Shang)图(Tu)表(Biao)示(Shi)两(Liang)个(Ge)结(Jie)点(Dian)已(Yi)经(Jing)创(Chuang)建(Jian)成(Cheng)功(Gong)。2)下(Xia)边(Bian)创(Chuang)建(Jian)索(Suo)引(Yin)库(Ku),共(Gong)2个(Ge)分(Fen)片(Pian),每(Mei)个(Ge)分(Fen)片(Pian)一(Yi)个(Ge)副(Fu)本(Ben)。创(Chuang)建(Jian)成(Cheng)功(Gong),刷(Shua)新(Xin)head:上(Shang)图(Tu)可(Ke)以(Yi)看(Kan)到(Dao)共(Gong)有(You)4个(Ge)分(Fen)片(Pian),其(Qi)中(Zhong)两(Liang)个(Ge)分(Fen)片(Pian)是(Shi)副(Fu)本(Ben)。3)每(Mei)个(Ge)结(Jie)点(Dian)安(An)装(Zhuang)IK分(Fen)词(Ci)器(Qi)略(Lue)集(Ji)群(Qun)的(De)健(Jian)康(Kang)通(Tong)过(Guo)访(Fang)问(Wen) GET /_cluster/health 来(Lai)查(Cha)看(Kan)Elasticsearch 的(De)集(Ji)群(Qun)健(Jian)康(Kang)情(Qing)况(Kuang)。用(Yong)三(San)种(Zhong)颜(Yan)色(Se)来(Lai)展(Zhan)示(Shi)健(Jian)康(Kang)状(Zhuang)态(Tai): green 、 yellow 或(Huo)者(Zhe) red 。green:所(Suo)有(You)的(De)主(Zhu)分(Fen)片(Pian)和(He)副(Fu)本(Ben)分(Fen)片(Pian)都(Du)正(Zheng)常(Chang)运(Yun)行(Xing)。 yellow:所(Suo)有(You)的(De)主(Zhu)分(Fen)片(Pian)都(Du)正(Zheng)常(Chang)运(Yun)行(Xing),但(Dan)有(You)些(Xie)副(Fu)本(Ben)分(Fen)片(Pian)运(Yun)行(Xing)不(Bu)正(Zheng)常(Chang)。 red:存(Cun)在(Zai)主(Zhu)分(Fen)片(Pian)运(Yun)行(Xing)不(Bu)正(Zheng)常(Chang)。Get请(Qing)求(Qiu):http://localhost:9200/_cluster/health响(Xiang)应(Ying)结(Jie)果(Guo):{ "cluster_name": "xuecheng", "status": "green", "timed_out": false, "number_of_nodes": 2, "number_of_data_nodes": 2, "active_primary_shards": 2, "active_shards": 4, "relocating_shards": 0, "initializing_shards": 0, "unassigned_shards": 0, "delayed_unassigned_shards": 0, "number_of_pending_tasks": 0, "number_of_in_flight_fetch": 0, "task_max_waiting_in_queue_millis": 0, "active_shards_percent_as_number": 100}测(Ce)试(Shi)1)创(Chuang)建(Jian)映(Ying)射(She)并(Bing)写(Xie)入(Ru)文(Wen)档(Dang)连(Lian)接(Jie) 其(Qi)中(Zhong)任(Ren)意(Yi)一(Yi)台(Tai)结(Jie)点(Dian),创(Chuang)建(Jian)映(Ying)射(She)写(Xie)入(Ru)文(Wen)档(Dang)。Post http://localhost:9200/xc_course/doc/3{"name": "spring开(Kai)发(Fa)基(Ji)础(Chu)","description": "spring 在(Zai)java领(Ling)域(Yu)非(Fei)常(Chang)流(Liu)行(Xing),java软(Ruan)件(Jian)开(Kai)发(Fa)人(Ren)员(Yuan)都(Du)在(Zai)用(Yong)。","studymodel": "201001","price":66.6}响(Xiang)应(Ying)结(Jie)果(Guo):{ "_index": "xc_course", "_type": "doc", "_id": "3", "_version": 1, "result": "created", "_shards": { "total": 2, "successful": 2, "failed": 0 }, "_seq_no": 0, "_primary_term": 1}从(Cong)上(Shang)边(Bian)的(De)提(Ti)示(Shi)可(Ke)看(Kan)出(Chu),两(Liang)个(Ge)分(Fen)片(Pian)都(Du)保(Bao)存(Cun)成(Cheng)功(Gong)。2)搜(Sou)索(Suo)向(Xiang)其(Qi)它(Ta)一(Yi)个(Ge)结(Jie)点(Dian)发(Fa)起(Qi)搜(Sou)索(Suo)请(Qing)求(Qiu),查(Cha)询(Xun)全(Quan)部(Bu)数(Shu)据(Ju)。3)关(Guan)闭(Bi)一(Yi)个(Ge)结(Jie)点(Dian)ES会(Hui)重(Zhong)新(Xin)选(Xuan)中(Zhong)一(Yi)个(Ge)主(Zhu)结(Jie)点(Dian)(前(Qian)提(Ti)在(Zai)配(Pei)置(Zhi)结(Jie)点(Dian)时(Shi)允(Yun)许(Xu)它(Ta)可(Ke)以(Yi)为(Wei)主(Zhu)结(Jie)点(Dian))此(Ci)时(Shi)向(Xiang)活(Huo)的(De)结(Jie)点(Dian)发(Fa)起(Qi)搜(Sou)索(Suo)请(Qing)求(Qiu),仍(Reng)然(Ran)正(Zheng)常(Chang)。4)添(Tian)加(Jia)一(Yi)个(Ge)结(Jie)点(Dian)添(Tian)加(Jia)结(Jie)点(Dian)3,端(Duan)口(Kou)设(She)置(Zhi)为(Wei):http端(Duan)口(Kou)是(Shi):9202集(Ji)群(Qun)管(Guan)理(Li)端(Duan)口(Kou)是(Shi)9302结(Jie)点(Dian)名(Ming):xc_node_3此(Ci)结(Jie)点(Dian)的(De)配(Pei)置(Zhi):node.master: false node.data: true启(Qi)动(Dong)结(Jie)点(Dian)3,刷(Shua)新(Xin)head,下(Xia)图(Tu)显(Xian)示(Shi)ES将(Jiang)分(Fen)片(Pian)及(Ji)副(Fu)本(Ben)均(Jun)匀(Yun)分(Fen)在(Zai)了(Liao)3个(Ge)结(Jie)点(Dian)(注(Zhu)意(Yi)环(Huan)境(Jing)不(Bu)同(Tong)分(Fen)布(Bu)的(De)结(Jie)果(Guo)可(Ke)能(Neng)不(Bu)同(Tong))向(Xiang)结(Jie)点(Dian)3发(Fa)起(Qi)搜(Sou)索(Suo)请(Qing)求(Qiu):Get: http://127.0.0.1:9202/xc_course/doc/_search全(Quan)部(Bu)数(Shu)据(Ju)可(Ke)被(Bei)正(Zheng)常(Chang)搜(Sou)索(Suo)到(Dao)。

7 601988 中国银行 7.3600欢乐不重样,美味再升级。姚记饭店推出夏季新品套餐!东北警察故事_免费在线观看完整版_全集电影 - 茶杯狐

海底沉船考古现场

发布于:温江区
声明:该文观点仅代表作者本人,搜狐号系信息发布平台,搜狐仅提供信息存储空间服务。
意见反馈 合作

Copyright ? 2023 Sohu All Rights Reserved

搜狐公司 版权所有