±à¼ÍƼö: |
±¾ÎÄÀ´×ÔÓÚ¼òÊ飬±¾ÎÄÊÇһƪ»ù´¡ÎÄÕ£¬Ïêϸ½éÉÜÁËSolrÊÇʲô£¬¼°Éæ¼°µ½µÄ²ãÃæ¡£
|
|
Ò» »ù±¾ËµÃ÷
¼òµ¥À´ËµSolrÊÇ»ùÓÚLuceneµÄ¸ßÐÔÄܵģ¬¿ªÔ´µÄJavaÆóÒµËÑË÷·þÎñÆ÷¡£Solr¿ÉÒÔ¿´×÷Ò»¸öWeb
app£¬ÔËÐÐÔÚtomcat»òJettyÕâÀàHTTP·þÎñÆ÷ÉÏ£¬
µ×²ãÊÇÒ»¸ö»ùÓÚLuceneµÄËÑË÷ÒýÇæ£¬»¹¸½¼ÓÒ»¸öSolrµÄ»ù±¾¹ÜÀí½çÃæ¡£SolrÌṩHTTP·þÎñ£¬Í¨¹ýGet·½·¨½øÐвéѯ,ͨ¹ýPost·½·¨½øÐÐË÷ÒýµÄÌí¼Ó/ɾ³ý¹ÜÀí¡£
Ò»°ãÀ´ËµSolrµÄ²éѯʱͨ¹ýGet·½·¨ÇëÇóµ½HTTP·þÎñÆ÷µÄsolrÕâ¸öappϵÄ/select¶ÔÓ¦µÄservletÉÏÈ¥£¬¶øÌí¼ÓµÈ²Ù×÷ʱͨ¹ýPOST·½·¨µ½HTTP·þÎñÆ÷µÄ
SolrÕâ¸öappϵÄ/update¶ÔÓ¦µÄservlet·½·¨ÉÏÈ¥¡£
Solr×÷ΪËÑË÷ÒýÇæ£¬Ìṩ»ùÓÚÇÐÃæ/¸ßÁÁ/¶àÖÖÊä³ö¸ñʽ/¸´ÔÓµÄÓï·¨ËÑË÷¹æÔòµÈ¹¦ÄÜ¡£
ÓëLuceneµÄÇø±ðÊÇ£ºLuceneÊÇһЩÀàAPIÊǸö¹¤¾ß°ü£¬Í¨¹ýÕâЩAPIÎÒÃÇ¿ÉÒÔ´´½¨Ë÷Òý/ͨ¹ýË÷Òý²éѯ£»¶øSolrÊÇÔÚ´Ë»ù´¡Éϵķâ×°£¬Í¨¹ý¼òµ¥µÄÅäÖÃ
¾Í¿ÉÒÔÖ±½ÓʹÓõĿªÔ´ËÑË÷·þÎñÆ÷¡£
¶þ »ù±¾¸ÅÄî
ÔÚSolrѧϰһÖÐÁ˽⵽ËÑË÷ÒýÇæµÄºËÐÄÊǽ¨Á¢Ë÷Òý£¬È»ºóÀûÓÃË÷Òý½øÐÐËÑË÷¡£
ÔÚSolrÖÐË÷ÒýÉæ¼°µ½µÄ¸ÅÄîÓУº
1 ¡¢Core£º ÔÚSolrµÄµ¥½Úµã²¿Êð»òÕßMaster-Salve·½Ê½²¿Êðϱêʾһ¸öÍêÕûË÷Òý¡£Core¶¼ÊÇÓɶà¸öÎļþ×é³É£¬½¨Á¢Ë÷ÒýµÄʱºòÊÇÏȷֶΣ¬È»ºóÔٺϲ¢µÄ·½Ê½¡£
Ò»¸öSolr¿ÉÒÔ°üº¬Ò»¸ö»ò¶à¸öCore£¬Ã¿¸öCoreµÄÅäÖÿÉÒÔ²»Í¬£»ÔÚSolrCoud²¿ÊðϱêʾË÷ÒýµÄÒ»²¿·Ö¡£
2¡¢Collection£º ÔÚSolrCould²¿ÊðģʽÏ£¬Ö¸µÄÊÇÒ»¸öË÷ÒýµÄÂß¼¸ÅÄî¡£¿ÉÒÔ°ÑSolrÖеÄCore»òCollection¿´×öÒ»¸öOracleµÄʵÀý¡£Ò»¸öSolrCould¿ÉÒÔ°üº¬¶à¸öCollection¡£
Ò»¸öCollection¿ÉÒÔÇзֳɶà¸öShard£¬ÇзֵÄÊýÁ¿´óСºÍ»úÆ÷½ÚµãÊýºÍ¸±±¾ÊýÓйØÏµ£¬ÒªÇóshardÊýÁ¿*¸±±¾Êý<½ÚµãÊý*numShards?¡£×¢ÒâÒ»¸ö½Úµã±êʾÆô¶¯Ò»¸öHTTP·þÎñÆ÷£¬
һ̨»úÆ÷¿ÉÒÔÆð¶à¸öSolr½Úµã£¨ÕâÖÖÇé¿ö±ØÐëÉèÖò»Í¬µÄ¶Ë¿Ú£©£¬Ò»¸öCollectionµÄÄÚÈÝÊÇÓÉÿ¸öshardÖеÄÐÅÏ¢×é³É¡£Ò»¸öshardµÄÐÅÏ¢¶ÔÓ¦×é³ÉËüµÄÒ»¸ö¸±±¾µÄÐÅÏ¢¡£
3¡¢Shard£º ±êʾÇÐÆ¬£¬ÔÚSolrColud ²¿ÊðģʽÏ£¬½«Ò»¸öÂß¼Ë÷ÒýCollectionÇиî³É¶à¸ö·ÖƬ£¬
ÿ¸öShardÊÇÓɶà¸ö¸±±¾Replica×é³É¡£
4¡¢Replica£º ¸±±¾¡£¶à¸ö¸±±¾×é³ÉÒ»¸öShard¡¢×¢ÒâÒ»¸öShardÖеÄreplica °üº¬µÄÄÚÈÝÂß¼ÉÏÓ¦¸ÃÊÇÒ»ÑùµÄ£¬ShardµÄÊý¾ÝÖ»ÊÇÆäÖÐÒ»·ÝReplica£¬²»ÊÇÕâЩ¸±±¾µÄ×éºÏ¡£
ÕâЩ¸±±¾ÖÐÓÐÒ»¸ö¸±±¾»á±»Ñ¡ÔñΪLeader£¬¸ºÔðдË÷Òý¡£
5¡¢Zookeeper£ºÁíÍâÒ»¸ö¿ªÔ´µÄÈí¼þ£¬ÔÚsolrCloud²¿ÊðģʽÏÂÊDZØÐëµÄ£¬Ö÷Òª×÷ÓÃÊÇ£º
1£©ÅäÖõÄͳһ´æ´¢ºÍ·Ö·¢£»2£©shardÖи±±¾µÄLeaderµÄѡȡ£»3£©¸ºÔð¼à¿Ø¼¯Èº×´Ì¬£¬·¢Éú¸Ä±äʱºò֪ͨÏà¹ØµÄ¼àÌýÆ÷£¬±ÈÈç¹ÒÁËһ̨»úÆ÷£¬Õą̂»úÆ÷ÉÏÈç¹ûÓÐshardµÄleader½Úµã£¬Ê£ÓàµÄͬһ¸öshardµÄÆäËû¸±±¾»á¾ºÑ¡Leader£¬ÇÒsolrColud»áÖªµÀÕą̂»úÆ÷¹Òµô£¬ÔÚ´¦ÀíÇëÇóµÄʱºò¾Í²»·¢ÇëÇó¸øÕą̂»úÆ÷¡£
6¡¢Config Set:ÅäÖÃ×飬´æ´¢ÅäÖÃÐÅÏ¢£¬Ã¿¸öCollection¶¼ÓУ¬ÖÁÉÙ°üº¬solrconfig.xmlÕâ¸öÊÇÅäÖÃÕâ¸öcollection»ù±¾ÅäÖ㬱ÈÈçʹÓõÄLuceneµÄ°æ±¾¡¢Ê¹ÓõIJéѯ×é¼þ¡¢»º´æÏà¹ØÐÅÏ¢µÈ£»»¹±ØÐë°üº¬Schema.Xml
Õâ¸öÅäÖÃÎļþÅäÖõÄÊÇCollection´æÔÚµÄÎĵµµÄ×ֶΣ¬°üÀ¨×ֶεÄÀàÐÍ£¬ÊÇ·ñÐèÒª´æ´¢£¬ÊÇ·ñÐèÒª·Ö´ÊµÈ¡£
7¡¢Îĵµ£º ÔÚSolrÖн¨Á¢Ë÷ÒýÊÇͨ¹ýÎĵµÌí¼ÓµÄ·½Ê½½øÐУ¬Èç¹û½«Ë÷Òý¿´³ÉÒ»ÕÅ±í£¬ÄÇôÎĵµ¿ÉÒÔ¿´³ÉÊÇÒ»Ìõ¼Ç¼£¬ÄÇôSchema.xml¿ÉÒÔ¿´³ÉÕâ¸ö±íµÄ¶¨Òå¡£
Ò»¸öÎĵµÓɶà¸ö×ֶζ¨Ò壬ÕâЩÊÇÔÚSchema.xmlÖж¨ÒåµÄ£¬²»ÊÇËùÓж¨ÒåµÄ×Ö¶ÎÎĵµÖж¼±ØÐëÓУ¬µ«ÊÇ·´¹ýÀ´ÎĵµÖÐÓеÄ×ֶαØÐëÔÚSchema.xmlÖж¨Ò壬
±ÈÈ磺 ±êʾ¶¨ÒåÒ»¸ö×Ö¶ÎΪstringÀàÐÍ£¬Ãû³ÆÎª£ºsubAcctName
ÊDZ»Ë÷ÒýµÄ£¬¶øÇÒÊÇ´æ´¢µÄ¡£µ±È»Ò²¿ÉÒÔͨ¹ýÒ»Öֽж¯Ì¬¶¨ÒåµÄ·½·¨½øÐÐ×ֶεÄÄ£ºýÆ¥Å䣬±ÈÈç?¾Í±íʾËùÓÐÒÔ_i½áβµÄ×ֶζ¼µ±³ÉintÀ´´¦Àí¡£
×¢ÒâÕâÀïÃæµÄÀàÐͲ»Í¬ÓÚjavaµÄÀàÐÍ£¬Ö»ÊÇÏàËÆ£¬¶ÔÓÚÿ¸öÀàÐÍ£¬solr»á¶¨ÒåÆäÏà¹ØµÄ´¦Àí¹æÔòµÈ¡£±ÈÈ磺
±êʾstringÀàÐÍ£¬¶ÔÓ¦µÄÀàΪStrFieldÀ࣬Èç¹ûȱʧÕâ¸ö×ֶΣ¬Ä¬ÈÏÔÚËÑË÷µÄʱºòÊÇÅÅÔÚ×îºóµÄ¡£
Schema.xml ÔÚ¶¨ÒåÎĵµµÄ×Ö¶Îʱºò»á¶¨ÒåÒ»¸öΨһֵ×ֶΣ¬ËÆÓÚ±íµÄÖ÷¼ü£¬ÐÎÈ磺?id£¬×÷ÓÃÊÇÓÃÓÚÔÚsolrCloud
ģʽϽøÐзÓÉ£¬Solrͨ¹ýÒ»¶¨µÄËã·¨¶Ôÿ¸öÎĵµµÄID½øÐмÆË㣬µÃµ½µÄÒ»¸öHashÖµ£¬È»ºó¿´ÏÂÕâ¸öHashÖµÊÇÊôÓÚÄĸöshard£¬¾Í°ÑÎĵµ·¢µ½ÄĸöshardÉÏÈ¥¡£
ͨ¹ýÕâ¸öËã·¨¿ÉÒÔ±£Ö¤shardÖ®¼äÊýÁ¿µÄ¾ùºâ£¬ÔÚ½¨Ë÷Òý¿ÉÒÔÆðµ½¸ºÔؾùºâµÄ×÷Óá£
Èç¹ûÄãÒªÖÆ¶¨Îĵµ´æ´¢µÄshard£¬ÓÐÈý¸ö°ì·¨£º
1£©Í¨¹ýÌØÊâµÄID£¬Õâ¸öID±ØÐëÓÐÁ½²¿·Ö×é³É£¬Á½²¿·ÖÖ®¼äÓ㡺ŷָô£¬solrÔÚ¼ÆËãhashµÄʱºò£¬»áÀûÓã¡Ç°ÃæµÄ16bit×öhash£¬²¢ÇÒÀûÓúóÃæ16¸öbit×öhash£¬
È»ºó°ÑËü×éºÏÆðÀ´£¬ÕâÑù¿ÉÒÔ±£Ö¤ÕâÀàÎĵµ¶¼·¢µ½Ìض¨µÄshardÉÏ£¬×¢ÒâÕâ¸öÌØ¶¨µÄshardÉÏ£¬¶ø²»ÖªµÀÊǾßÌåÊÇÄÄÒ»¸öshardÉÏ¡£
2£©Í¨¹ý_shard_×Ö¶ÎÀ´Ö¸¶¨¾ßÌåµÄshardÉÏ£¬Õâ¸ö×Ö¶ÎÉèÖÃΪshard1¡¢shard2µÈ¡£
3£© ÔÚ½¨collectionµÄʱºò·ÓÉÆ÷ÉèÖÃΪ£ºimplicit·½Ê½£¬ÔÚ½¨Ë÷ÒýµÄʱºò£¬ÎĵµÌí¼ÓÒ»¸ö_route_×ֶΣ¬ÖµÎª£ºshard1¡¢shard2µÈ¡£
¾ßÌåµÄÓï¾ä¾ÙÀý£º?http://x.x.x.x:xxx/solr -5.0.0-web/admin/collections?action =CREATE&name =testimplicit&router.name =implicit&shards= shard1,shard2,shard3
ÎĵµÔÚÌí¼Óʱºò£¬Èç¹ûÒÔxml¸ñʽÌí¼Ó£¬ÄÚÈÝÀàËÆ£º
05991
Peter Parker
Spider-Man
superhero
agility
spider-sense
8¡¢Óò£¨Field£©£ºÀàËÆÓÚÊý¾Ý¿â±íµÄ×ֶΣ¬ÓÐÀàÐÍ£¬Óд¦Àí·½Ê½¡£×¢ÒâÎÒÔÚSolrѧϰ֮һ½²µÄµ¹ÅÅË÷ÒýÖеĴʵäÖеĴʲ»Í¬ÓÚ×ֶΡ£
ÓòÖ»ÓÐÖ¸Ã÷±»Ë÷Òýºó£¬È»ºó±»·Ö´ÊÆ÷½øÐзִʣ¨ÔÚsolrÖÐstringµÈ»ù±¾ÀàÐÍÊDz»»á±»·Ö´ÊµÄ£¬textÀàÐͱêʾ¸´ÔÓÀàÐÍ£¬ÐèÒª·Ö´Ê£©£¬Ö®ºó²Å»á´æ´¢ÔڴʵäÖÐ
ÓòÓм¸¸ö·Ç³£ÖØÒªµÄÊôÐÔ£º
indexed£º ±êʾÊÇ·ñ±»Ë÷Òý£¬¼òµ¥À´Ëµ£¬Ö»Óб»Ë÷ÒýµÄ×ֶΣ¬ÔÚ²éѯʱºò²Å¿ÉÒÔͨ¹ýÕâ¸ö×ֶεÄÖµ½øÐÐÆ¥Åä²éѯ¡£
stored£º ? Èç¹ûÕâ¸öÉèÖÃΪtrue±êʾÔÚË÷ÒýÖÐÒ²´æ´¢Õâ¸ö×Ö¶ÎÐÅÏ¢£»Èç¹û²»´æÔÚÕâ¸öÐÅÏ¢£¬Õâ²éѯµÄ½á¹ûÖв»»áÏÔʾ£¬ÕâÊÊÓÃÓÚÄÚÈݷdz£¶àµÄ³¡¾°£¬
ÎÒÃÇͨ¹ý²éѯµ½µÄID£¬ÔÙµ½ÆäËû´æ´¢ÖУ¬±ÈÈçÊý¾Ý¿âÖаѶÔÓ¦µÄÕâ¸ö×Ö¶ÎÐÅÏ¢ÔÙ³é³öÀ´¡£
ÓòÖÐÓиöÌØÊâµÄÓò½Ð¿½±´Óò£¬ËüµÄ×÷ÓÃÊÇ£¬¿ÉÒÔ½«ÆäËûÓòµÄÖµ¿½±´µ½Õâ¸öÓòÖУ¬ËÑË÷µÄʱºòÖ»ÒªËÑË÷Õâ¸öÓò¾Í¿ÉÒÔÁË¡£½«ÓòtitleºÍcontentÄÚÈÝ¿½±´µ½textÓòÀïÃæ¡£
9¡¢¶Î£¨Segment£©
¶à¸ö¶Î×é³ÉË÷Òý£¬Ò»¸ö¶ÎÓɶà¸öÎļþ×é³É£¬ÐÂÌí¼ÓµÄÎĵµ¿ÉÒÔÉú²úеĶΣ¬²»Í¬µÄ¶ÎÖ®¼ä¿ÉÒԺϲ¢¡£
ÔÚindexĿ¼ÏÂÒÔÏàͬÊý×ÖµÄÎļþ¿ªÍ·µÄÊôÓÚÒ»¸ö¶Î.
segments.genºÍsegments_* ÊôÓڶεÄÔªÊý¾ÝÐÅÏ¢£¬±£´æ¶ÎµÄ»ù±¾ÊôÐÔ¡£
10¡¢´Ê(Term)
µÚÒ»²¿·Ö½éÉÜ×é³É´ÊµäµÄ²¿·Ö£¬ÊÇ´Ê·¨·ÖÎöÓï·¨·ÖÎöºóµÃµ½µÄ×Ö·û´®¡£
termÓÉÒ»¶ÔÖµ×é³É£ºfield name(string)ºÍfield value(bytes)£¬Í¬Ò»¸övalueÔÚ²»Í¬µÄfieldÖÐÓв»Í¬µÄº¬Òå¡£
Îĵµ¡¢Ë÷Òý¡¢×ֶΡ¢´ÊÖ®¼äµÄ¹ØÏµ¿ÉÒÔÓÃÏÂͼÃèÊö£º

¡¶ÍøÉϽèÀ´µÄͼ¡·
Ò»¸öË÷ÒýÊÇÓɶà¸ö¶Î×é³É£¬ÔÚʵ¼ÊÖжÎÊÇһЩÁÐÎļþ£¬Ò»¸ö¶ÎÓÖÊÇÓɶà¸öÎĵµ×é³ÉµÄ£¬Ò»¸öÎĵµÓÖÊÇÓɶà¸ö×Ö¶Î×é³É¡£
¶Î¶ÀÁ¢´æÔÚ£¬×÷Ϊһ¸ö×ÓË÷Òý£¬¿ÉÒÔ±»µ¥¶ÀËÑË÷¡£
Ò»¸ö×Ö¶ÎÖеÄÄÚÈݾ¹ý·Ö´Ê±ä³ÉTeam ´æ´¢ÔÚµ¹ÅÅË÷ÒýÖС£
Lucene±£´æµÄË÷ÒýÐÅÏ¢£¬¼È°üÀ¨ÕýÏòÐÅÏ¢ÓÖ°üº¬·´ÏòÐÅÏ¢¡£
ÕýÏòÐÅÏ¢£º°´ÕÕ´ÓÊô¹ØÏµ£ºË÷Òý(Index) ¨C> ¶Î(segment) ¨C> Îĵµ(Document)
¨C> Óò(Field) ¨C> ´Ê(Term)
Ò»°ãÉϲ㲻¹â°üº¬×Ô¼ºµÄÐÅÏ¢»¹°üº¬²¿·ÖµÄϲãÐÅÏ¢¡£
±£´æÕýÏòÐÅÏ¢µÄÎļþÓÐ:
segments_N |
±£´æÁË´ËË÷Òý°üº¬¶àÉÙ¸ö¶Î£¬Ã¿¸ö¶Î°üº¬¶àÉÙÆªÎĵµ¡£ |
XXX.fnm |
±£´æÁ˴˶ΰüº¬Á˶àÉÙ¸öÓò£¬Ã¿¸öÓòµÄÃû³Æ¼°Ë÷Òý·½Ê½¡£ |
XXX.fdx£¬XXX.fdt |
±£´æÁ˴˶ΰüº¬µÄËùÓÐÎĵµ£¬Ã¿ÆªÎĵµ°üº¬Á˶àÉÙÓò£¬Ã¿¸öÓò±£´æÁËÄÇЩÐÅÏ¢¡£ |
XXX.tvx£¬XXX.tvd£¬XXX.tvf ±£´æÁ˴˶ΰüº¬¶àÉÙÎĵµ£¬Ã¿ÆªÎĵµ°üº¬Á˶àÉÙÓò£¬Ã¿¸öÓò°üº¬Á˶àÉÙ´Ê£¬Ã¿¸ö´ÊµÄ×Ö·û´®£¬Î»ÖõÈÐÅÏ¢¡£
·´ÏòÐÅÏ¢£º
´Êµäµ½Ë÷ÒýµÄÓ³É䣬Ҳ¼´ÎÒÃÇ˵µÄµ¹ÅÅË÷Òý¡£
XXX.tis£¬XXX.tii |
±£´æÁ˴ʵä(Term Dictionary)£¬Ò²¼´´Ë¶Î°üº¬µÄËùÓеĴʰ´×Öµä˳ÐòµÄÅÅÐò¡£ |
XXX.frq |
±£´æÁ˵¹ÅÅ±í£¬Ò²¼´°üº¬Ã¿¸ö´ÊµÄÎĵµIDÁÐ±í¡£ |
XXX.prx |
±£´æÁ˵¹ÅűíÖÐÿ¸ö´ÊÔÚ°üº¬´Ë´ÊµÄÎĵµÖеÄλÖᣠ|
|