| 12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667686970717273747576777879808182838485868788899091929394959697989910010110210310410510610710810911011111211311411511611711811912012112212312412512612712812913013113213313413513613713813914014114214314414514614714814915015115215315415515615715815916016116216316416516616716816917017117217317417517617717817918018118218318418518618718818919019119219319419519619719819920020120220320420520620720820921021121221321421521621721821922022122222322422522622722822923023123223323423523623723823924024124224324424524624724824925025125225325425525625725825926026126226326426526626726826927027127227327427527627727827928028128228328428528628728828929029129229329429529629729829930030130230330430530630730830931031131231331431531631731831932032132232332432532632732832933033133233333433533633733833934034134234334434534634734834935035135235335435535635735835936036136236336436536636736836937037137237337437537637737837938038138238338438538638738838939039139239339439539639739839940040140240340440540640740840941041141241341441541641741841942042142242342442542642742842943043143243343443543643743843944044144244344444544644744844945045145245345445545645745845946046146246346446546646746846947047147247347447547647747847948048148248348448548648748848949049149249349449549649749849950050150250350450550650750850951051151251351451551651751851952052152252352452552652752852953053153253353453553653753853954054154254354454554654754854955055155255355455555655755855956056156256356456556656756856957057157257357457557657757857958058158258358458558658758858959059159259359459559659759859960060160260360460560660760860961061161261361461561661761861962062162262362462562662762862963063163263363463563663763863964064164264364464564664764864965065165265365465565665765865966066166266366466566666766866967067167267367467567667767867968068168268368468568668768868969069169269369469569669769869970070170270370470570670770870971071171271371471571671771871972072172272372472572672772872973073173273373473573673773873974074174274374474574674774874975075175275375475575675775875976076176276376476576676776876977077177277377477577677777877978078178278378478578678778878979079179279379479579679779879980080180280380480580680780880981081181281381481581681781881982082182282382482582682782882983083183283383483583683783883984084184284384484584684784884985085185285385485585685785885986086186286386486586686786886987087187287387487587687787887988088188288388488588688788888989089189289389489589689789889990090190290390490590690790890991091191291391491591691791891992092192292392492592692792892993093193293393493593693793893994094194294394494594694794894995095195295395495595695795895996096196296396496596696796896997097197297397497597697797897998098198298398498598698798898999099199299399499599699799899910001001100210031004100510061007100810091010101110121013101410151016101710181019102010211022102310241025102610271028102910301031103210331034103510361037103810391040104110421043104410451046104710481049105010511052105310541055105610571058105910601061106210631064106510661067106810691070107110721073107410751076107710781079108010811082108310841085108610871088108910901091109210931094109510961097109810991100110111021103110411051106110711081109111011111112111311141115111611171118111911201121112211231124112511261127112811291130113111321133113411351136113711381139114011411142114311441145114611471148114911501151115211531154115511561157115811591160116111621163116411651166116711681169117011711172117311741175117611771178117911801181118211831184118511861187118811891190119111921193119411951196119711981199120012011202120312041205120612071208120912101211121212131214121512161217121812191220122112221223122412251226122712281229123012311232123312341235123612371238123912401241124212431244124512461247124812491250125112521253125412551256125712581259126012611262126312641265126612671268126912701271127212731274127512761277127812791280128112821283128412851286128712881289129012911292129312941295129612971298129913001301130213031304130513061307130813091310131113121313131413151316131713181319132013211322132313241325132613271328132913301331133213331334133513361337133813391340134113421343134413451346134713481349135013511352135313541355135613571358135913601361136213631364136513661367136813691370137113721373137413751376137713781379138013811382138313841385138613871388138913901391139213931394139513961397139813991400140114021403140414051406140714081409141014111412141314141415141614171418141914201421142214231424142514261427142814291430143114321433143414351436143714381439144014411442144314441445144614471448144914501451145214531454145514561457145814591460146114621463146414651466146714681469147014711472147314741475147614771478147914801481148214831484148514861487148814891490149114921493149414951496149714981499150015011502150315041505150615071508150915101511151215131514151515161517151815191520152115221523152415251526152715281529153015311532153315341535153615371538153915401541154215431544154515461547154815491550155115521553155415551556155715581559156015611562156315641565156615671568156915701571157215731574157515761577157815791580158115821583158415851586158715881589159015911592159315941595159615971598159916001601160216031604160516061607160816091610161116121613161416151616161716181619162016211622162316241625162616271628162916301631163216331634163516361637163816391640164116421643164416451646164716481649165016511652165316541655165616571658165916601661166216631664166516661667166816691670167116721673167416751676167716781679168016811682168316841685168616871688168916901691169216931694169516961697169816991700170117021703170417051706170717081709171017111712171317141715171617171718171917201721172217231724172517261727172817291730173117321733173417351736173717381739174017411742174317441745174617471748174917501751175217531754175517561757175817591760176117621763176417651766176717681769177017711772177317741775177617771778177917801781178217831784178517861787178817891790179117921793179417951796179717981799180018011802180318041805180618071808180918101811181218131814181518161817181818191820182118221823182418251826182718281829183018311832183318341835183618371838183918401841184218431844184518461847184818491850185118521853185418551856185718581859186018611862186318641865186618671868186918701871187218731874187518761877187818791880188118821883188418851886188718881889189018911892189318941895189618971898189919001901190219031904190519061907190819091910191119121913191419151916191719181919192019211922192319241925192619271928192919301931193219331934193519361937193819391940194119421943194419451946194719481949195019511952195319541955195619571958195919601961196219631964196519661967196819691970197119721973197419751976197719781979198019811982198319841985198619871988198919901991199219931994199519961997199819992000200120022003200420052006200720082009201020112012201320142015201620172018201920202021202220232024202520262027202820292030203120322033203420352036203720382039204020412042204320442045204620472048204920502051205220532054205520562057205820592060206120622063206420652066206720682069207020712072207320742075207620772078207920802081208220832084208520862087208820892090209120922093209420952096209720982099210021012102210321042105210621072108210921102111211221132114211521162117211821192120212121222123212421252126212721282129213021312132213321342135213621372138213921402141214221432144214521462147214821492150215121522153215421552156215721582159216021612162216321642165216621672168216921702171217221732174217521762177217821792180218121822183218421852186218721882189219021912192219321942195219621972198219922002201220222032204220522062207220822092210221122122213221422152216221722182219222022212222222322242225222622272228222922302231223222332234223522362237223822392240224122422243224422452246224722482249225022512252225322542255225622572258225922602261226222632264226522662267226822692270227122722273227422752276227722782279228022812282228322842285228622872288228922902291229222932294229522962297229822992300230123022303230423052306230723082309231023112312231323142315231623172318231923202321232223232324232523262327232823292330233123322333233423352336233723382339234023412342234323442345234623472348234923502351235223532354235523562357235823592360236123622363236423652366236723682369237023712372237323742375237623772378237923802381238223832384238523862387238823892390239123922393239423952396239723982399240024012402240324042405240624072408240924102411241224132414241524162417241824192420242124222423242424252426242724282429243024312432243324342435243624372438243924402441244224432444244524462447244824492450245124522453245424552456245724582459246024612462246324642465246624672468246924702471247224732474247524762477247824792480248124822483248424852486248724882489249024912492249324942495249624972498249925002501250225032504250525062507250825092510251125122513251425152516251725182519252025212522252325242525252625272528252925302531253225332534253525362537253825392540254125422543254425452546254725482549255025512552255325542555255625572558255925602561256225632564256525662567256825692570257125722573257425752576257725782579258025812582258325842585258625872588258925902591259225932594259525962597259825992600260126022603260426052606260726082609261026112612261326142615261626172618261926202621262226232624262526262627262826292630263126322633263426352636263726382639264026412642264326442645264626472648264926502651265226532654265526562657265826592660266126622663266426652666266726682669267026712672267326742675267626772678267926802681268226832684268526862687268826892690269126922693269426952696269726982699270027012702270327042705270627072708270927102711271227132714271527162717271827192720272127222723272427252726272727282729273027312732273327342735273627372738273927402741274227432744274527462747274827492750275127522753275427552756275727582759276027612762276327642765276627672768276927702771277227732774277527762777277827792780278127822783278427852786278727882789279027912792279327942795279627972798279928002801280228032804280528062807280828092810281128122813281428152816281728182819282028212822282328242825282628272828282928302831283228332834283528362837283828392840284128422843284428452846284728482849285028512852285328542855285628572858285928602861286228632864286528662867286828692870287128722873287428752876287728782879288028812882288328842885288628872888288928902891289228932894289528962897289828992900290129022903290429052906290729082909291029112912291329142915291629172918291929202921292229232924292529262927292829292930293129322933293429352936293729382939294029412942294329442945294629472948294929502951295229532954295529562957295829592960296129622963296429652966296729682969297029712972297329742975297629772978297929802981298229832984298529862987298829892990299129922993299429952996299729982999300030013002300330043005300630073008300930103011301230133014301530163017301830193020302130223023302430253026302730283029303030313032303330343035303630373038303930403041304230433044304530463047304830493050305130523053305430553056305730583059306030613062306330643065306630673068306930703071307230733074307530763077307830793080308130823083308430853086308730883089309030913092309330943095309630973098309931003101310231033104310531063107310831093110311131123113311431153116311731183119312031213122312331243125312631273128312931303131313231333134313531363137313831393140314131423143314431453146314731483149315031513152315331543155315631573158315931603161316231633164316531663167316831693170317131723173317431753176317731783179318031813182318331843185318631873188318931903191319231933194319531963197319831993200320132023203320432053206320732083209321032113212321332143215321632173218321932203221322232233224322532263227322832293230323132323233323432353236323732383239324032413242324332443245324632473248324932503251325232533254325532563257325832593260326132623263326432653266326732683269327032713272327332743275327632773278327932803281328232833284328532863287328832893290329132923293329432953296329732983299330033013302330333043305330633073308330933103311331233133314331533163317331833193320332133223323332433253326332733283329333033313332333333343335333633373338333933403341334233433344334533463347334833493350335133523353335433553356335733583359336033613362336333643365336633673368336933703371337233733374337533763377337833793380338133823383338433853386338733883389339033913392339333943395339633973398339934003401340234033404340534063407340834093410341134123413341434153416341734183419342034213422342334243425342634273428342934303431343234333434343534363437343834393440344134423443344434453446344734483449345034513452345334543455345634573458345934603461346234633464346534663467346834693470347134723473347434753476347734783479348034813482348334843485348634873488348934903491349234933494349534963497349834993500350135023503350435053506350735083509351035113512351335143515351635173518351935203521352235233524352535263527352835293530353135323533353435353536353735383539354035413542354335443545354635473548354935503551355235533554355535563557355835593560356135623563356435653566356735683569357035713572357335743575357635773578357935803581358235833584358535863587358835893590359135923593359435953596359735983599360036013602360336043605360636073608360936103611361236133614361536163617361836193620362136223623362436253626362736283629363036313632363336343635363636373638363936403641364236433644364536463647364836493650365136523653365436553656365736583659366036613662366336643665366636673668366936703671367236733674367536763677367836793680368136823683368436853686368736883689369036913692369336943695369636973698369937003701370237033704370537063707370837093710371137123713371437153716371737183719372037213722372337243725372637273728372937303731373237333734373537363737373837393740374137423743374437453746374737483749375037513752375337543755375637573758375937603761376237633764376537663767376837693770377137723773377437753776377737783779378037813782378337843785378637873788378937903791379237933794379537963797379837993800380138023803380438053806380738083809381038113812381338143815381638173818381938203821382238233824382538263827382838293830383138323833383438353836383738383839384038413842384338443845384638473848384938503851385238533854385538563857385838593860386138623863386438653866386738683869387038713872387338743875387638773878387938803881388238833884388538863887388838893890389138923893389438953896389738983899390039013902390339043905390639073908390939103911391239133914391539163917391839193920392139223923392439253926392739283929393039313932393339343935393639373938393939403941394239433944394539463947394839493950395139523953395439553956395739583959396039613962396339643965396639673968396939703971397239733974397539763977397839793980398139823983398439853986398739883989399039913992399339943995399639973998399940004001400240034004400540064007400840094010401140124013401440154016401740184019402040214022402340244025402640274028402940304031403240334034403540364037403840394040404140424043404440454046404740484049405040514052405340544055405640574058405940604061406240634064406540664067406840694070407140724073407440754076407740784079408040814082408340844085408640874088408940904091409240934094409540964097409840994100410141024103410441054106410741084109411041114112411341144115411641174118411941204121412241234124412541264127412841294130413141324133413441354136413741384139414041414142414341444145414641474148414941504151415241534154415541564157415841594160416141624163416441654166416741684169417041714172417341744175417641774178417941804181418241834184418541864187418841894190419141924193419441954196419741984199420042014202420342044205420642074208420942104211421242134214421542164217421842194220422142224223422442254226422742284229423042314232423342344235423642374238423942404241424242434244424542464247424842494250425142524253425442554256425742584259426042614262426342644265426642674268426942704271427242734274427542764277427842794280428142824283428442854286428742884289429042914292429342944295429642974298429943004301430243034304430543064307430843094310431143124313431443154316431743184319432043214322432343244325432643274328432943304331433243334334433543364337433843394340434143424343434443454346434743484349435043514352435343544355435643574358435943604361436243634364436543664367436843694370437143724373437443754376437743784379438043814382438343844385438643874388438943904391439243934394439543964397439843994400440144024403440444054406440744084409441044114412441344144415441644174418441944204421442244234424442544264427442844294430443144324433443444354436443744384439444044414442444344444445444644474448444944504451445244534454445544564457445844594460446144624463446444654466446744684469447044714472447344744475447644774478447944804481448244834484448544864487448844894490449144924493449444954496449744984499450045014502450345044505450645074508450945104511451245134514451545164517451845194520452145224523452445254526452745284529453045314532453345344535453645374538453945404541454245434544454545464547454845494550455145524553455445554556455745584559456045614562456345644565456645674568456945704571457245734574457545764577457845794580458145824583458445854586458745884589459045914592459345944595459645974598459946004601460246034604460546064607460846094610461146124613461446154616461746184619462046214622462346244625462646274628462946304631463246334634463546364637463846394640464146424643464446454646464746484649465046514652465346544655465646574658465946604661466246634664466546664667466846694670467146724673467446754676467746784679468046814682468346844685468646874688468946904691469246934694469546964697469846994700470147024703470447054706470747084709471047114712471347144715471647174718471947204721472247234724472547264727472847294730473147324733473447354736473747384739474047414742474347444745474647474748474947504751475247534754475547564757475847594760476147624763476447654766476747684769477047714772477347744775477647774778477947804781478247834784478547864787478847894790479147924793479447954796479747984799480048014802480348044805480648074808480948104811481248134814481548164817481848194820482148224823482448254826482748284829483048314832483348344835483648374838483948404841484248434844484548464847484848494850485148524853485448554856485748584859486048614862486348644865486648674868486948704871487248734874487548764877487848794880488148824883488448854886488748884889489048914892489348944895489648974898489949004901490249034904490549064907490849094910491149124913491449154916491749184919492049214922492349244925492649274928492949304931493249334934493549364937493849394940494149424943494449454946494749484949495049514952495349544955495649574958495949604961496249634964496549664967496849694970497149724973497449754976497749784979498049814982498349844985498649874988498949904991499249934994499549964997499849995000500150025003500450055006500750085009501050115012501350145015501650175018501950205021502250235024502550265027502850295030503150325033503450355036503750385039504050415042504350445045504650475048504950505051505250535054505550565057505850595060506150625063506450655066506750685069507050715072507350745075507650775078507950805081508250835084508550865087508850895090509150925093509450955096509750985099510051015102510351045105510651075108510951105111511251135114511551165117511851195120512151225123512451255126512751285129513051315132513351345135513651375138513951405141514251435144514551465147514851495150515151525153515451555156515751585159516051615162516351645165516651675168516951705171517251735174517551765177517851795180518151825183518451855186518751885189519051915192519351945195519651975198519952005201520252035204520552065207520852095210521152125213521452155216521752185219522052215222522352245225522652275228522952305231523252335234523552365237523852395240524152425243524452455246524752485249525052515252525352545255525652575258525952605261526252635264526552665267526852695270527152725273527452755276527752785279528052815282528352845285528652875288528952905291529252935294529552965297529852995300530153025303530453055306530753085309531053115312531353145315531653175318531953205321532253235324532553265327532853295330533153325333533453355336533753385339534053415342534353445345534653475348534953505351535253535354535553565357535853595360536153625363536453655366536753685369537053715372537353745375537653775378537953805381538253835384538553865387538853895390539153925393539453955396539753985399540054015402540354045405540654075408540954105411541254135414541554165417541854195420542154225423542454255426542754285429543054315432543354345435543654375438543954405441544254435444544554465447544854495450545154525453545454555456545754585459546054615462546354645465546654675468546954705471547254735474547554765477547854795480548154825483548454855486548754885489549054915492549354945495549654975498549955005501550255035504550555065507550855095510551155125513551455155516551755185519552055215522552355245525552655275528552955305531553255335534553555365537553855395540554155425543554455455546554755485549555055515552555355545555555655575558555955605561556255635564556555665567556855695570557155725573557455755576557755785579558055815582558355845585558655875588558955905591559255935594559555965597559855995600560156025603560456055606560756085609561056115612561356145615561656175618561956205621562256235624562556265627562856295630563156325633563456355636563756385639564056415642564356445645564656475648564956505651565256535654565556565657565856595660566156625663566456655666566756685669567056715672567356745675567656775678567956805681568256835684568556865687568856895690569156925693569456955696569756985699570057015702570357045705570657075708570957105711571257135714571557165717571857195720572157225723572457255726572757285729573057315732573357345735573657375738573957405741574257435744574557465747574857495750575157525753575457555756575757585759576057615762576357645765576657675768576957705771577257735774577557765777577857795780578157825783578457855786578757885789579057915792579357945795579657975798579958005801580258035804580558065807580858095810581158125813581458155816581758185819582058215822582358245825582658275828582958305831583258335834583558365837583858395840584158425843584458455846584758485849585058515852585358545855585658575858585958605861586258635864586558665867586858695870587158725873587458755876587758785879588058815882588358845885588658875888588958905891589258935894589558965897589858995900590159025903590459055906590759085909591059115912591359145915591659175918591959205921592259235924592559265927592859295930593159325933593459355936593759385939594059415942594359445945594659475948594959505951595259535954595559565957595859595960596159625963596459655966596759685969597059715972597359745975597659775978597959805981598259835984598559865987598859895990599159925993599459955996599759985999600060016002600360046005600660076008600960106011601260136014601560166017601860196020602160226023602460256026602760286029603060316032603360346035603660376038603960406041604260436044604560466047604860496050605160526053605460556056605760586059606060616062606360646065606660676068606960706071607260736074607560766077607860796080608160826083608460856086608760886089609060916092609360946095609660976098609961006101610261036104610561066107610861096110611161126113611461156116611761186119612061216122612361246125612661276128612961306131613261336134613561366137613861396140614161426143614461456146614761486149615061516152615361546155615661576158615961606161616261636164616561666167616861696170617161726173617461756176617761786179618061816182618361846185618661876188618961906191619261936194619561966197619861996200620162026203620462056206620762086209621062116212621362146215621662176218621962206221622262236224622562266227622862296230623162326233623462356236623762386239624062416242624362446245624662476248624962506251625262536254625562566257625862596260626162626263626462656266626762686269627062716272627362746275627662776278627962806281628262836284628562866287628862896290629162926293629462956296629762986299630063016302630363046305630663076308630963106311631263136314631563166317631863196320632163226323632463256326632763286329633063316332633363346335633663376338633963406341634263436344634563466347634863496350635163526353635463556356635763586359636063616362636363646365636663676368636963706371637263736374637563766377637863796380638163826383638463856386638763886389639063916392639363946395639663976398639964006401640264036404640564066407640864096410641164126413641464156416641764186419642064216422642364246425642664276428642964306431643264336434643564366437643864396440644164426443644464456446644764486449645064516452645364546455645664576458645964606461646264636464646564666467646864696470647164726473647464756476647764786479648064816482648364846485648664876488648964906491649264936494649564966497649864996500650165026503650465056506650765086509651065116512651365146515651665176518651965206521652265236524652565266527652865296530653165326533653465356536653765386539654065416542654365446545654665476548654965506551655265536554655565566557655865596560656165626563656465656566656765686569657065716572657365746575657665776578657965806581658265836584658565866587658865896590659165926593659465956596659765986599660066016602660366046605660666076608660966106611661266136614661566166617661866196620662166226623662466256626662766286629663066316632663366346635663666376638663966406641664266436644664566466647664866496650665166526653665466556656665766586659666066616662666366646665666666676668666966706671667266736674667566766677667866796680668166826683668466856686668766886689669066916692669366946695669666976698669967006701670267036704670567066707670867096710671167126713671467156716671767186719672067216722672367246725672667276728672967306731673267336734673567366737673867396740674167426743674467456746674767486749675067516752675367546755675667576758675967606761676267636764676567666767676867696770677167726773677467756776677767786779678067816782678367846785678667876788678967906791679267936794679567966797679867996800680168026803680468056806680768086809681068116812681368146815681668176818681968206821682268236824682568266827682868296830683168326833683468356836683768386839684068416842684368446845684668476848684968506851685268536854685568566857685868596860686168626863686468656866686768686869687068716872687368746875687668776878687968806881688268836884688568866887688868896890689168926893689468956896689768986899690069016902690369046905690669076908690969106911691269136914691569166917691869196920692169226923692469256926692769286929693069316932693369346935693669376938693969406941694269436944694569466947694869496950695169526953695469556956695769586959696069616962696369646965696669676968696969706971697269736974697569766977697869796980698169826983698469856986698769886989699069916992699369946995699669976998699970007001700270037004700570067007700870097010701170127013701470157016701770187019702070217022702370247025702670277028702970307031703270337034703570367037703870397040704170427043704470457046704770487049705070517052705370547055705670577058705970607061706270637064706570667067706870697070707170727073707470757076707770787079708070817082708370847085708670877088708970907091709270937094709570967097709870997100710171027103710471057106710771087109711071117112711371147115711671177118711971207121712271237124712571267127712871297130713171327133713471357136713771387139714071417142714371447145714671477148714971507151715271537154715571567157715871597160716171627163716471657166716771687169717071717172717371747175717671777178717971807181718271837184718571867187718871897190719171927193719471957196719771987199720072017202720372047205720672077208720972107211721272137214721572167217721872197220722172227223722472257226722772287229723072317232723372347235723672377238723972407241724272437244724572467247724872497250725172527253725472557256725772587259726072617262726372647265726672677268726972707271727272737274727572767277727872797280728172827283728472857286728772887289729072917292729372947295729672977298729973007301730273037304730573067307730873097310731173127313731473157316731773187319732073217322732373247325732673277328732973307331733273337334733573367337733873397340734173427343734473457346734773487349735073517352735373547355735673577358735973607361736273637364736573667367736873697370737173727373737473757376737773787379738073817382738373847385738673877388738973907391739273937394739573967397739873997400740174027403740474057406740774087409741074117412741374147415741674177418741974207421742274237424742574267427742874297430743174327433743474357436743774387439744074417442744374447445744674477448744974507451745274537454745574567457745874597460746174627463746474657466746774687469747074717472747374747475747674777478747974807481748274837484748574867487748874897490749174927493749474957496749774987499750075017502750375047505750675077508750975107511751275137514751575167517751875197520752175227523752475257526752775287529753075317532753375347535753675377538753975407541754275437544754575467547754875497550755175527553755475557556755775587559756075617562756375647565756675677568756975707571757275737574757575767577757875797580758175827583758475857586758775887589759075917592759375947595759675977598759976007601760276037604760576067607760876097610761176127613761476157616761776187619762076217622762376247625762676277628762976307631763276337634763576367637763876397640764176427643764476457646764776487649765076517652765376547655765676577658765976607661766276637664766576667667766876697670767176727673767476757676767776787679768076817682768376847685768676877688768976907691769276937694769576967697769876997700770177027703770477057706770777087709771077117712771377147715771677177718771977207721772277237724772577267727772877297730773177327733773477357736773777387739774077417742774377447745774677477748774977507751775277537754775577567757775877597760776177627763776477657766776777687769777077717772777377747775777677777778777977807781778277837784778577867787778877897790779177927793779477957796779777987799780078017802780378047805780678077808780978107811781278137814781578167817781878197820782178227823782478257826782778287829783078317832783378347835783678377838783978407841784278437844784578467847784878497850785178527853785478557856785778587859786078617862786378647865786678677868786978707871787278737874787578767877787878797880788178827883788478857886788778887889789078917892789378947895789678977898789979007901790279037904790579067907790879097910791179127913791479157916791779187919792079217922792379247925792679277928792979307931793279337934793579367937793879397940794179427943794479457946794779487949795079517952795379547955795679577958795979607961796279637964796579667967796879697970797179727973797479757976797779787979798079817982798379847985798679877988798979907991799279937994799579967997799879998000800180028003800480058006800780088009801080118012801380148015801680178018801980208021802280238024802580268027802880298030803180328033803480358036803780388039804080418042804380448045804680478048804980508051805280538054805580568057805880598060806180628063806480658066806780688069807080718072807380748075807680778078807980808081808280838084808580868087808880898090809180928093809480958096809780988099810081018102810381048105810681078108810981108111811281138114811581168117811881198120812181228123812481258126812781288129813081318132813381348135813681378138813981408141814281438144814581468147814881498150815181528153815481558156815781588159816081618162816381648165816681678168816981708171817281738174817581768177817881798180818181828183818481858186818781888189819081918192819381948195819681978198819982008201820282038204820582068207820882098210821182128213821482158216821782188219822082218222822382248225822682278228822982308231823282338234823582368237823882398240824182428243824482458246824782488249825082518252825382548255825682578258825982608261826282638264826582668267826882698270827182728273827482758276827782788279828082818282828382848285828682878288828982908291829282938294829582968297829882998300830183028303830483058306830783088309831083118312831383148315831683178318831983208321832283238324832583268327832883298330833183328333833483358336833783388339834083418342834383448345834683478348834983508351835283538354835583568357835883598360836183628363836483658366836783688369837083718372837383748375837683778378837983808381838283838384838583868387838883898390839183928393839483958396839783988399840084018402840384048405840684078408840984108411841284138414841584168417841884198420842184228423842484258426842784288429843084318432843384348435843684378438843984408441844284438444844584468447844884498450845184528453845484558456845784588459846084618462846384648465846684678468846984708471847284738474847584768477847884798480848184828483848484858486848784888489849084918492849384948495849684978498849985008501850285038504850585068507850885098510851185128513851485158516851785188519852085218522852385248525852685278528852985308531853285338534853585368537853885398540854185428543854485458546854785488549855085518552855385548555855685578558855985608561856285638564856585668567856885698570857185728573857485758576857785788579858085818582858385848585858685878588858985908591859285938594859585968597859885998600860186028603860486058606860786088609861086118612861386148615861686178618861986208621862286238624862586268627862886298630863186328633863486358636863786388639864086418642864386448645864686478648864986508651865286538654865586568657865886598660866186628663866486658666866786688669867086718672867386748675867686778678867986808681868286838684868586868687868886898690869186928693869486958696869786988699870087018702870387048705870687078708870987108711871287138714871587168717871887198720872187228723872487258726872787288729873087318732873387348735873687378738873987408741874287438744874587468747874887498750875187528753875487558756875787588759876087618762876387648765876687678768876987708771877287738774877587768777877887798780878187828783878487858786878787888789879087918792879387948795879687978798879988008801880288038804880588068807880888098810881188128813881488158816881788188819882088218822882388248825882688278828882988308831883288338834883588368837883888398840884188428843884488458846884788488849885088518852885388548855885688578858885988608861886288638864886588668867886888698870887188728873887488758876887788788879888088818882888388848885888688878888888988908891889288938894889588968897889888998900890189028903890489058906890789088909891089118912891389148915891689178918891989208921892289238924892589268927892889298930893189328933893489358936893789388939894089418942894389448945894689478948894989508951895289538954895589568957895889598960896189628963896489658966896789688969897089718972897389748975897689778978897989808981898289838984898589868987898889898990899189928993899489958996899789988999900090019002900390049005900690079008900990109011901290139014901590169017901890199020902190229023902490259026902790289029903090319032903390349035903690379038903990409041904290439044904590469047904890499050905190529053905490559056905790589059906090619062906390649065906690679068906990709071907290739074907590769077907890799080908190829083908490859086908790889089909090919092909390949095909690979098909991009101910291039104910591069107910891099110911191129113911491159116911791189119912091219122912391249125912691279128912991309131913291339134913591369137913891399140914191429143914491459146914791489149915091519152915391549155915691579158915991609161916291639164916591669167916891699170917191729173917491759176917791789179918091819182918391849185918691879188918991909191919291939194919591969197919891999200920192029203920492059206920792089209921092119212921392149215921692179218921992209221922292239224922592269227922892299230923192329233923492359236923792389239924092419242924392449245924692479248924992509251925292539254925592569257925892599260926192629263926492659266926792689269927092719272927392749275927692779278927992809281928292839284928592869287928892899290929192929293929492959296929792989299930093019302930393049305930693079308930993109311931293139314931593169317931893199320932193229323932493259326932793289329933093319332933393349335933693379338933993409341934293439344934593469347934893499350935193529353935493559356935793589359936093619362936393649365936693679368936993709371937293739374937593769377937893799380938193829383938493859386938793889389939093919392939393949395939693979398939994009401940294039404940594069407940894099410941194129413941494159416941794189419942094219422942394249425942694279428942994309431943294339434943594369437943894399440944194429443944494459446944794489449945094519452945394549455945694579458945994609461946294639464946594669467946894699470947194729473947494759476947794789479948094819482948394849485948694879488948994909491949294939494949594969497949894999500950195029503950495059506950795089509951095119512951395149515951695179518951995209521952295239524952595269527952895299530953195329533953495359536953795389539954095419542954395449545954695479548954995509551955295539554955595569557955895599560956195629563956495659566956795689569957095719572957395749575957695779578957995809581958295839584958595869587958895899590959195929593959495959596959795989599960096019602960396049605960696079608960996109611961296139614961596169617961896199620962196229623962496259626962796289629963096319632963396349635963696379638963996409641964296439644964596469647964896499650965196529653965496559656965796589659966096619662966396649665966696679668966996709671967296739674967596769677967896799680968196829683968496859686968796889689969096919692969396949695969696979698969997009701970297039704970597069707970897099710971197129713971497159716971797189719972097219722972397249725972697279728972997309731973297339734973597369737973897399740974197429743974497459746974797489749975097519752975397549755975697579758975997609761976297639764976597669767976897699770977197729773977497759776977797789779978097819782978397849785978697879788978997909791979297939794979597969797979897999800980198029803980498059806980798089809981098119812981398149815981698179818981998209821982298239824982598269827982898299830983198329833983498359836983798389839984098419842984398449845984698479848984998509851985298539854985598569857985898599860986198629863986498659866986798689869987098719872987398749875987698779878987998809881988298839884988598869887988898899890989198929893989498959896989798989899990099019902990399049905990699079908990999109911991299139914991599169917991899199920992199229923992499259926992799289929993099319932993399349935993699379938993999409941994299439944994599469947994899499950995199529953995499559956995799589959996099619962996399649965996699679968996999709971997299739974997599769977997899799980998199829983998499859986998799889989999099919992999399949995999699979998999910000100011000210003100041000510006100071000810009100101001110012100131001410015100161001710018100191002010021100221002310024100251002610027100281002910030100311003210033100341003510036100371003810039100401004110042100431004410045100461004710048100491005010051100521005310054100551005610057100581005910060100611006210063100641006510066100671006810069100701007110072100731007410075100761007710078100791008010081100821008310084100851008610087100881008910090100911009210093100941009510096100971009810099101001010110102101031010410105101061010710108101091011010111101121011310114101151011610117101181011910120101211012210123101241012510126101271012810129101301013110132101331013410135101361013710138101391014010141101421014310144101451014610147101481014910150101511015210153101541015510156101571015810159101601016110162101631016410165101661016710168101691017010171101721017310174101751017610177101781017910180101811018210183101841018510186101871018810189101901019110192101931019410195101961019710198101991020010201102021020310204102051020610207102081020910210102111021210213102141021510216102171021810219102201022110222102231022410225102261022710228102291023010231102321023310234102351023610237102381023910240102411024210243102441024510246102471024810249102501025110252102531025410255102561025710258102591026010261102621026310264102651026610267102681026910270102711027210273102741027510276102771027810279102801028110282102831028410285102861028710288102891029010291102921029310294102951029610297102981029910300103011030210303103041030510306103071030810309103101031110312103131031410315103161031710318103191032010321103221032310324103251032610327103281032910330103311033210333103341033510336103371033810339103401034110342103431034410345103461034710348103491035010351103521035310354103551035610357103581035910360103611036210363103641036510366103671036810369103701037110372103731037410375103761037710378103791038010381103821038310384103851038610387103881038910390103911039210393103941039510396103971039810399104001040110402104031040410405104061040710408104091041010411104121041310414104151041610417104181041910420104211042210423104241042510426104271042810429104301043110432104331043410435104361043710438104391044010441104421044310444104451044610447104481044910450104511045210453104541045510456104571045810459104601046110462104631046410465104661046710468104691047010471104721047310474104751047610477104781047910480104811048210483104841048510486104871048810489104901049110492104931049410495104961049710498104991050010501105021050310504105051050610507105081050910510105111051210513105141051510516105171051810519105201052110522105231052410525105261052710528105291053010531105321053310534105351053610537105381053910540105411054210543105441054510546105471054810549105501055110552105531055410555105561055710558105591056010561105621056310564105651056610567105681056910570105711057210573105741057510576105771057810579105801058110582105831058410585105861058710588105891059010591105921059310594105951059610597105981059910600106011060210603106041060510606106071060810609106101061110612106131061410615106161061710618106191062010621106221062310624106251062610627106281062910630106311063210633106341063510636106371063810639106401064110642106431064410645106461064710648106491065010651106521065310654106551065610657106581065910660106611066210663106641066510666106671066810669106701067110672106731067410675106761067710678106791068010681106821068310684106851068610687106881068910690106911069210693106941069510696106971069810699107001070110702107031070410705107061070710708107091071010711107121071310714107151071610717107181071910720107211072210723107241072510726107271072810729107301073110732107331073410735107361073710738107391074010741107421074310744107451074610747107481074910750107511075210753107541075510756107571075810759107601076110762107631076410765107661076710768107691077010771107721077310774107751077610777107781077910780107811078210783107841078510786107871078810789107901079110792107931079410795107961079710798107991080010801108021080310804108051080610807108081080910810108111081210813108141081510816108171081810819108201082110822108231082410825108261082710828108291083010831108321083310834108351083610837108381083910840108411084210843108441084510846108471084810849108501085110852108531085410855108561085710858108591086010861108621086310864108651086610867108681086910870108711087210873108741087510876108771087810879108801088110882108831088410885108861088710888108891089010891108921089310894108951089610897108981089910900109011090210903109041090510906109071090810909109101091110912109131091410915109161091710918109191092010921109221092310924109251092610927109281092910930109311093210933109341093510936109371093810939109401094110942109431094410945109461094710948109491095010951109521095310954109551095610957109581095910960109611096210963109641096510966109671096810969109701097110972109731097410975109761097710978109791098010981109821098310984109851098610987109881098910990109911099210993109941099510996109971099810999110001100111002110031100411005110061100711008110091101011011110121101311014110151101611017110181101911020110211102211023110241102511026110271102811029110301103111032110331103411035110361103711038110391104011041110421104311044110451104611047110481104911050110511105211053110541105511056110571105811059110601106111062110631106411065110661106711068110691107011071110721107311074110751107611077110781107911080110811108211083110841108511086110871108811089110901109111092110931109411095110961109711098110991110011101111021110311104111051110611107111081110911110111111111211113111141111511116111171111811119111201112111122111231112411125111261112711128111291113011131111321113311134111351113611137111381113911140111411114211143111441114511146111471114811149111501115111152111531115411155111561115711158111591116011161111621116311164111651116611167111681116911170111711117211173111741117511176111771117811179111801118111182111831118411185111861118711188111891119011191111921119311194111951119611197111981119911200112011120211203112041120511206112071120811209112101121111212112131121411215112161121711218112191122011221112221122311224112251122611227112281122911230112311123211233112341123511236112371123811239112401124111242112431124411245112461124711248112491125011251112521125311254112551125611257112581125911260112611126211263112641126511266112671126811269112701127111272112731127411275112761127711278112791128011281112821128311284112851128611287112881128911290112911129211293112941129511296112971129811299113001130111302113031130411305113061130711308113091131011311113121131311314113151131611317113181131911320113211132211323113241132511326113271132811329113301133111332113331133411335113361133711338113391134011341113421134311344113451134611347113481134911350113511135211353113541135511356113571135811359113601136111362113631136411365113661136711368113691137011371113721137311374113751137611377113781137911380113811138211383113841138511386113871138811389113901139111392113931139411395113961139711398113991140011401114021140311404114051140611407114081140911410114111141211413114141141511416114171141811419114201142111422114231142411425114261142711428114291143011431114321143311434114351143611437114381143911440114411144211443114441144511446114471144811449114501145111452114531145411455114561145711458114591146011461114621146311464114651146611467114681146911470114711147211473114741147511476114771147811479114801148111482114831148411485114861148711488114891149011491114921149311494114951149611497114981149911500115011150211503115041150511506115071150811509115101151111512115131151411515115161151711518115191152011521115221152311524115251152611527115281152911530115311153211533115341153511536115371153811539115401154111542115431154411545115461154711548115491155011551115521155311554115551155611557115581155911560115611156211563115641156511566115671156811569115701157111572115731157411575115761157711578115791158011581115821158311584115851158611587115881158911590115911159211593115941159511596115971159811599116001160111602116031160411605116061160711608116091161011611116121161311614116151161611617116181161911620116211162211623116241162511626116271162811629116301163111632116331163411635116361163711638116391164011641116421164311644116451164611647116481164911650116511165211653116541165511656116571165811659116601166111662116631166411665116661166711668116691167011671116721167311674116751167611677116781167911680116811168211683116841168511686116871168811689116901169111692116931169411695116961169711698116991170011701117021170311704117051170611707117081170911710117111171211713117141171511716117171171811719117201172111722117231172411725117261172711728117291173011731117321173311734117351173611737117381173911740117411174211743117441174511746117471174811749117501175111752117531175411755117561175711758117591176011761117621176311764117651176611767117681176911770117711177211773117741177511776117771177811779117801178111782117831178411785117861178711788117891179011791117921179311794117951179611797117981179911800118011180211803118041180511806118071180811809118101181111812118131181411815118161181711818118191182011821118221182311824118251182611827118281182911830118311183211833118341183511836118371183811839118401184111842118431184411845118461184711848118491185011851118521185311854118551185611857118581185911860118611186211863118641186511866118671186811869118701187111872118731187411875118761187711878118791188011881118821188311884118851188611887118881188911890118911189211893118941189511896118971189811899119001190111902119031190411905119061190711908119091191011911119121191311914119151191611917119181191911920119211192211923119241192511926119271192811929119301193111932119331193411935119361193711938119391194011941119421194311944119451194611947119481194911950119511195211953119541195511956119571195811959119601196111962119631196411965119661196711968119691197011971119721197311974119751197611977119781197911980119811198211983119841198511986119871198811989119901199111992119931199411995119961199711998119991200012001120021200312004120051200612007120081200912010120111201212013120141201512016120171201812019120201202112022120231202412025120261202712028120291203012031120321203312034120351203612037120381203912040120411204212043120441204512046120471204812049120501205112052120531205412055120561205712058120591206012061120621206312064120651206612067120681206912070120711207212073120741207512076120771207812079120801208112082120831208412085120861208712088120891209012091120921209312094120951209612097120981209912100121011210212103121041210512106121071210812109121101211112112121131211412115121161211712118121191212012121121221212312124121251212612127121281212912130121311213212133121341213512136121371213812139121401214112142121431214412145121461214712148121491215012151121521215312154121551215612157121581215912160121611216212163121641216512166121671216812169121701217112172121731217412175121761217712178121791218012181121821218312184121851218612187121881218912190121911219212193121941219512196121971219812199122001220112202122031220412205122061220712208122091221012211122121221312214122151221612217122181221912220122211222212223122241222512226122271222812229122301223112232122331223412235122361223712238122391224012241122421224312244122451224612247122481224912250122511225212253122541225512256122571225812259122601226112262122631226412265122661226712268122691227012271122721227312274122751227612277122781227912280122811228212283122841228512286122871228812289122901229112292122931229412295122961229712298122991230012301123021230312304123051230612307123081230912310123111231212313123141231512316123171231812319123201232112322123231232412325123261232712328123291233012331123321233312334123351233612337123381233912340123411234212343123441234512346123471234812349123501235112352123531235412355123561235712358123591236012361123621236312364123651236612367123681236912370123711237212373123741237512376123771237812379123801238112382123831238412385123861238712388123891239012391123921239312394123951239612397123981239912400124011240212403124041240512406124071240812409124101241112412124131241412415124161241712418124191242012421124221242312424124251242612427124281242912430124311243212433124341243512436124371243812439124401244112442124431244412445124461244712448124491245012451124521245312454124551245612457124581245912460124611246212463124641246512466124671246812469124701247112472124731247412475124761247712478124791248012481124821248312484124851248612487124881248912490124911249212493124941249512496124971249812499125001250112502125031250412505125061250712508125091251012511125121251312514125151251612517125181251912520125211252212523125241252512526125271252812529125301253112532125331253412535125361253712538125391254012541125421254312544125451254612547125481254912550125511255212553125541255512556125571255812559125601256112562125631256412565125661256712568125691257012571125721257312574125751257612577125781257912580125811258212583125841258512586125871258812589125901259112592125931259412595125961259712598125991260012601126021260312604126051260612607126081260912610126111261212613126141261512616126171261812619126201262112622126231262412625126261262712628126291263012631126321263312634126351263612637126381263912640126411264212643126441264512646126471264812649126501265112652126531265412655126561265712658126591266012661126621266312664126651266612667126681266912670126711267212673126741267512676126771267812679126801268112682126831268412685126861268712688126891269012691126921269312694126951269612697126981269912700127011270212703127041270512706127071270812709127101271112712127131271412715127161271712718127191272012721127221272312724127251272612727127281272912730127311273212733127341273512736127371273812739127401274112742127431274412745127461274712748127491275012751127521275312754127551275612757127581275912760127611276212763127641276512766127671276812769127701277112772127731277412775127761277712778127791278012781127821278312784127851278612787127881278912790127911279212793127941279512796127971279812799128001280112802128031280412805128061280712808128091281012811128121281312814128151281612817128181281912820128211282212823128241282512826128271282812829128301283112832128331283412835128361283712838128391284012841128421284312844128451284612847128481284912850128511285212853128541285512856128571285812859128601286112862128631286412865128661286712868128691287012871128721287312874128751287612877128781287912880128811288212883128841288512886128871288812889128901289112892128931289412895128961289712898128991290012901129021290312904129051290612907129081290912910129111291212913129141291512916129171291812919129201292112922129231292412925129261292712928129291293012931129321293312934129351293612937129381293912940129411294212943129441294512946129471294812949129501295112952129531295412955129561295712958129591296012961129621296312964129651296612967129681296912970129711297212973129741297512976129771297812979129801298112982129831298412985129861298712988129891299012991129921299312994129951299612997129981299913000130011300213003130041300513006130071300813009130101301113012130131301413015130161301713018130191302013021130221302313024130251302613027130281302913030130311303213033130341303513036130371303813039130401304113042130431304413045130461304713048130491305013051130521305313054130551305613057130581305913060130611306213063130641306513066130671306813069130701307113072130731307413075130761307713078130791308013081130821308313084130851308613087130881308913090130911309213093130941309513096130971309813099131001310113102131031310413105131061310713108131091311013111131121311313114131151311613117131181311913120131211312213123131241312513126131271312813129131301313113132131331313413135131361313713138131391314013141131421314313144131451314613147131481314913150131511315213153131541315513156131571315813159131601316113162131631316413165131661316713168131691317013171131721317313174131751317613177131781317913180131811318213183131841318513186131871318813189131901319113192131931319413195131961319713198131991320013201132021320313204132051320613207132081320913210132111321213213132141321513216132171321813219132201322113222132231322413225132261322713228132291323013231132321323313234132351323613237132381323913240132411324213243132441324513246132471324813249132501325113252132531325413255132561325713258132591326013261132621326313264132651326613267132681326913270132711327213273132741327513276132771327813279132801328113282132831328413285132861328713288132891329013291132921329313294132951329613297132981329913300133011330213303133041330513306133071330813309133101331113312133131331413315133161331713318133191332013321133221332313324133251332613327133281332913330133311333213333133341333513336133371333813339133401334113342133431334413345133461334713348133491335013351133521335313354133551335613357133581335913360133611336213363133641336513366133671336813369133701337113372133731337413375133761337713378133791338013381133821338313384133851338613387133881338913390133911339213393133941339513396133971339813399134001340113402134031340413405134061340713408134091341013411134121341313414134151341613417134181341913420134211342213423134241342513426134271342813429134301343113432134331343413435134361343713438134391344013441134421344313444134451344613447134481344913450134511345213453134541345513456134571345813459134601346113462134631346413465134661346713468134691347013471134721347313474134751347613477134781347913480134811348213483134841348513486134871348813489134901349113492134931349413495134961349713498134991350013501135021350313504135051350613507135081350913510135111351213513135141351513516135171351813519135201352113522135231352413525135261352713528135291353013531135321353313534135351353613537135381353913540135411354213543135441354513546135471354813549135501355113552135531355413555135561355713558135591356013561135621356313564135651356613567135681356913570135711357213573135741357513576135771357813579135801358113582135831358413585135861358713588135891359013591135921359313594135951359613597135981359913600136011360213603136041360513606136071360813609136101361113612136131361413615136161361713618136191362013621136221362313624136251362613627136281362913630136311363213633136341363513636136371363813639136401364113642136431364413645136461364713648136491365013651136521365313654136551365613657136581365913660136611366213663136641366513666136671366813669136701367113672136731367413675136761367713678136791368013681136821368313684136851368613687136881368913690136911369213693136941369513696136971369813699137001370113702137031370413705137061370713708137091371013711137121371313714137151371613717137181371913720137211372213723137241372513726137271372813729137301373113732137331373413735137361373713738137391374013741137421374313744137451374613747137481374913750137511375213753137541375513756137571375813759137601376113762137631376413765137661376713768137691377013771137721377313774137751377613777137781377913780137811378213783137841378513786137871378813789137901379113792137931379413795137961379713798137991380013801138021380313804138051380613807138081380913810138111381213813138141381513816138171381813819138201382113822138231382413825138261382713828138291383013831138321383313834138351383613837138381383913840138411384213843138441384513846138471384813849138501385113852138531385413855138561385713858138591386013861138621386313864138651386613867138681386913870138711387213873138741387513876138771387813879138801388113882138831388413885138861388713888138891389013891138921389313894138951389613897138981389913900139011390213903139041390513906139071390813909139101391113912139131391413915139161391713918139191392013921139221392313924139251392613927139281392913930139311393213933139341393513936139371393813939139401394113942139431394413945139461394713948139491395013951139521395313954139551395613957139581395913960139611396213963139641396513966139671396813969139701397113972139731397413975139761397713978139791398013981139821398313984139851398613987139881398913990139911399213993139941399513996139971399813999140001400114002140031400414005140061400714008140091401014011140121401314014140151401614017140181401914020140211402214023140241402514026140271402814029140301403114032140331403414035140361403714038140391404014041140421404314044140451404614047140481404914050140511405214053140541405514056140571405814059140601406114062140631406414065140661406714068140691407014071140721407314074140751407614077140781407914080140811408214083140841408514086140871408814089140901409114092140931409414095140961409714098140991410014101141021410314104141051410614107141081410914110141111411214113141141411514116141171411814119141201412114122141231412414125141261412714128141291413014131141321413314134141351413614137141381413914140141411414214143141441414514146141471414814149141501415114152141531415414155141561415714158141591416014161141621416314164141651416614167141681416914170141711417214173141741417514176141771417814179141801418114182141831418414185141861418714188141891419014191141921419314194141951419614197141981419914200142011420214203142041420514206142071420814209142101421114212142131421414215142161421714218142191422014221142221422314224142251422614227142281422914230142311423214233142341423514236142371423814239142401424114242142431424414245142461424714248142491425014251142521425314254142551425614257142581425914260142611426214263142641426514266142671426814269142701427114272142731427414275142761427714278142791428014281142821428314284142851428614287142881428914290142911429214293142941429514296142971429814299143001430114302143031430414305143061430714308143091431014311143121431314314143151431614317143181431914320143211432214323143241432514326143271432814329143301433114332143331433414335143361433714338143391434014341143421434314344143451434614347143481434914350143511435214353143541435514356143571435814359143601436114362143631436414365143661436714368143691437014371143721437314374143751437614377143781437914380143811438214383143841438514386143871438814389143901439114392143931439414395143961439714398143991440014401144021440314404144051440614407144081440914410144111441214413144141441514416144171441814419144201442114422144231442414425144261442714428144291443014431144321443314434144351443614437144381443914440144411444214443144441444514446144471444814449144501445114452144531445414455144561445714458144591446014461144621446314464144651446614467144681446914470144711447214473144741447514476144771447814479144801448114482144831448414485144861448714488144891449014491144921449314494144951449614497144981449914500145011450214503145041450514506145071450814509145101451114512145131451414515145161451714518145191452014521145221452314524145251452614527145281452914530145311453214533145341453514536145371453814539145401454114542145431454414545145461454714548145491455014551145521455314554145551455614557145581455914560145611456214563145641456514566145671456814569145701457114572145731457414575145761457714578145791458014581145821458314584145851458614587145881458914590145911459214593145941459514596145971459814599146001460114602146031460414605146061460714608146091461014611146121461314614146151461614617146181461914620146211462214623146241462514626146271462814629146301463114632146331463414635146361463714638146391464014641146421464314644146451464614647146481464914650146511465214653146541465514656146571465814659146601466114662146631466414665146661466714668146691467014671146721467314674146751467614677146781467914680146811468214683146841468514686146871468814689146901469114692146931469414695146961469714698146991470014701147021470314704147051470614707147081470914710147111471214713147141471514716147171471814719147201472114722147231472414725147261472714728147291473014731147321473314734147351473614737147381473914740147411474214743147441474514746147471474814749147501475114752147531475414755147561475714758147591476014761147621476314764147651476614767147681476914770147711477214773147741477514776147771477814779147801478114782147831478414785147861478714788147891479014791147921479314794147951479614797147981479914800148011480214803148041480514806148071480814809148101481114812148131481414815148161481714818148191482014821148221482314824148251482614827148281482914830148311483214833148341483514836148371483814839148401484114842148431484414845148461484714848148491485014851148521485314854148551485614857148581485914860148611486214863148641486514866148671486814869148701487114872148731487414875148761487714878148791488014881148821488314884148851488614887148881488914890148911489214893148941489514896148971489814899149001490114902149031490414905149061490714908149091491014911149121491314914149151491614917149181491914920149211492214923149241492514926149271492814929149301493114932149331493414935149361493714938149391494014941149421494314944149451494614947149481494914950149511495214953149541495514956149571495814959149601496114962149631496414965149661496714968149691497014971149721497314974149751497614977149781497914980149811498214983149841498514986149871498814989149901499114992149931499414995149961499714998149991500015001150021500315004150051500615007150081500915010150111501215013150141501515016150171501815019150201502115022150231502415025150261502715028150291503015031150321503315034150351503615037150381503915040150411504215043150441504515046150471504815049150501505115052150531505415055150561505715058150591506015061150621506315064150651506615067150681506915070150711507215073150741507515076150771507815079150801508115082150831508415085150861508715088150891509015091150921509315094150951509615097150981509915100151011510215103151041510515106151071510815109151101511115112151131511415115151161511715118151191512015121151221512315124151251512615127151281512915130151311513215133151341513515136151371513815139151401514115142151431514415145151461514715148151491515015151151521515315154151551515615157151581515915160151611516215163151641516515166151671516815169151701517115172151731517415175151761517715178151791518015181151821518315184151851518615187151881518915190151911519215193151941519515196151971519815199152001520115202152031520415205152061520715208152091521015211152121521315214152151521615217152181521915220152211522215223152241522515226152271522815229152301523115232152331523415235152361523715238152391524015241152421524315244152451524615247152481524915250152511525215253152541525515256152571525815259152601526115262152631526415265152661526715268152691527015271152721527315274152751527615277152781527915280152811528215283152841528515286152871528815289152901529115292152931529415295152961529715298152991530015301153021530315304153051530615307153081530915310153111531215313153141531515316153171531815319153201532115322153231532415325153261532715328153291533015331153321533315334153351533615337153381533915340153411534215343153441534515346153471534815349153501535115352153531535415355153561535715358153591536015361153621536315364153651536615367153681536915370153711537215373153741537515376153771537815379153801538115382153831538415385153861538715388153891539015391153921539315394153951539615397153981539915400154011540215403154041540515406154071540815409154101541115412154131541415415154161541715418154191542015421154221542315424154251542615427154281542915430154311543215433154341543515436154371543815439154401544115442154431544415445154461544715448154491545015451154521545315454154551545615457154581545915460154611546215463154641546515466154671546815469154701547115472154731547415475154761547715478154791548015481154821548315484154851548615487154881548915490154911549215493154941549515496154971549815499155001550115502155031550415505155061550715508155091551015511155121551315514155151551615517155181551915520155211552215523155241552515526155271552815529155301553115532155331553415535155361553715538155391554015541155421554315544155451554615547155481554915550155511555215553155541555515556155571555815559155601556115562155631556415565155661556715568155691557015571155721557315574155751557615577155781557915580155811558215583155841558515586155871558815589155901559115592155931559415595155961559715598155991560015601156021560315604156051560615607156081560915610156111561215613156141561515616156171561815619156201562115622156231562415625156261562715628156291563015631156321563315634156351563615637156381563915640156411564215643156441564515646156471564815649156501565115652156531565415655156561565715658156591566015661156621566315664156651566615667156681566915670156711567215673156741567515676156771567815679156801568115682156831568415685156861568715688156891569015691156921569315694156951569615697156981569915700157011570215703157041570515706157071570815709157101571115712157131571415715157161571715718157191572015721157221572315724157251572615727157281572915730157311573215733157341573515736157371573815739157401574115742157431574415745157461574715748157491575015751157521575315754157551575615757157581575915760157611576215763157641576515766157671576815769157701577115772157731577415775157761577715778157791578015781157821578315784157851578615787157881578915790157911579215793157941579515796157971579815799158001580115802158031580415805158061580715808158091581015811158121581315814158151581615817158181581915820158211582215823158241582515826158271582815829158301583115832158331583415835158361583715838158391584015841158421584315844158451584615847158481584915850158511585215853158541585515856158571585815859158601586115862158631586415865158661586715868158691587015871158721587315874158751587615877158781587915880158811588215883158841588515886158871588815889158901589115892158931589415895158961589715898158991590015901159021590315904159051590615907159081590915910159111591215913159141591515916159171591815919159201592115922159231592415925159261592715928159291593015931159321593315934159351593615937159381593915940159411594215943159441594515946159471594815949159501595115952159531595415955159561595715958159591596015961159621596315964159651596615967159681596915970159711597215973159741597515976159771597815979159801598115982159831598415985159861598715988159891599015991159921599315994159951599615997159981599916000160011600216003160041600516006160071600816009160101601116012160131601416015160161601716018160191602016021160221602316024160251602616027160281602916030160311603216033160341603516036160371603816039160401604116042160431604416045160461604716048160491605016051160521605316054160551605616057160581605916060160611606216063160641606516066160671606816069160701607116072160731607416075160761607716078160791608016081160821608316084160851608616087160881608916090160911609216093160941609516096160971609816099161001610116102161031610416105161061610716108161091611016111161121611316114161151611616117161181611916120161211612216123161241612516126161271612816129161301613116132161331613416135161361613716138161391614016141161421614316144161451614616147161481614916150161511615216153161541615516156161571615816159161601616116162161631616416165161661616716168161691617016171161721617316174161751617616177161781617916180161811618216183161841618516186161871618816189161901619116192161931619416195161961619716198161991620016201162021620316204162051620616207162081620916210162111621216213162141621516216162171621816219162201622116222162231622416225162261622716228162291623016231162321623316234162351623616237162381623916240162411624216243162441624516246162471624816249162501625116252162531625416255162561625716258162591626016261162621626316264162651626616267162681626916270162711627216273162741627516276162771627816279162801628116282162831628416285162861628716288162891629016291162921629316294162951629616297162981629916300163011630216303163041630516306163071630816309163101631116312163131631416315163161631716318163191632016321163221632316324163251632616327163281632916330163311633216333163341633516336163371633816339163401634116342163431634416345163461634716348163491635016351163521635316354163551635616357163581635916360163611636216363163641636516366163671636816369163701637116372163731637416375163761637716378163791638016381163821638316384163851638616387163881638916390163911639216393163941639516396163971639816399164001640116402164031640416405164061640716408164091641016411164121641316414164151641616417164181641916420164211642216423164241642516426164271642816429164301643116432164331643416435164361643716438164391644016441164421644316444164451644616447164481644916450164511645216453164541645516456164571645816459164601646116462164631646416465164661646716468164691647016471164721647316474164751647616477164781647916480164811648216483164841648516486164871648816489164901649116492164931649416495164961649716498164991650016501165021650316504165051650616507165081650916510165111651216513165141651516516165171651816519165201652116522165231652416525165261652716528165291653016531165321653316534165351653616537165381653916540165411654216543165441654516546165471654816549165501655116552165531655416555165561655716558165591656016561165621656316564165651656616567165681656916570165711657216573165741657516576165771657816579165801658116582165831658416585165861658716588165891659016591165921659316594165951659616597165981659916600166011660216603166041660516606166071660816609166101661116612166131661416615166161661716618166191662016621166221662316624166251662616627166281662916630166311663216633166341663516636166371663816639166401664116642166431664416645166461664716648166491665016651166521665316654166551665616657166581665916660166611666216663166641666516666166671666816669166701667116672166731667416675166761667716678166791668016681166821668316684166851668616687166881668916690166911669216693166941669516696166971669816699167001670116702167031670416705167061670716708167091671016711167121671316714167151671616717167181671916720167211672216723167241672516726167271672816729167301673116732167331673416735167361673716738167391674016741167421674316744167451674616747167481674916750167511675216753167541675516756167571675816759167601676116762167631676416765167661676716768167691677016771167721677316774167751677616777167781677916780167811678216783167841678516786167871678816789167901679116792167931679416795167961679716798167991680016801168021680316804168051680616807168081680916810168111681216813168141681516816168171681816819168201682116822168231682416825168261682716828168291683016831168321683316834168351683616837168381683916840168411684216843168441684516846168471684816849168501685116852168531685416855168561685716858168591686016861168621686316864168651686616867168681686916870168711687216873168741687516876168771687816879168801688116882168831688416885168861688716888168891689016891168921689316894168951689616897168981689916900169011690216903169041690516906169071690816909169101691116912169131691416915169161691716918169191692016921169221692316924169251692616927169281692916930169311693216933169341693516936169371693816939169401694116942169431694416945169461694716948169491695016951169521695316954169551695616957169581695916960169611696216963169641696516966169671696816969169701697116972169731697416975169761697716978169791698016981169821698316984169851698616987169881698916990169911699216993169941699516996169971699816999170001700117002170031700417005170061700717008170091701017011170121701317014170151701617017170181701917020170211702217023170241702517026170271702817029170301703117032170331703417035170361703717038170391704017041170421704317044170451704617047170481704917050170511705217053170541705517056170571705817059170601706117062170631706417065170661706717068170691707017071170721707317074170751707617077170781707917080170811708217083170841708517086170871708817089170901709117092170931709417095170961709717098170991710017101171021710317104171051710617107171081710917110171111711217113171141711517116171171711817119171201712117122171231712417125171261712717128171291713017131171321713317134171351713617137171381713917140171411714217143171441714517146171471714817149171501715117152171531715417155171561715717158171591716017161171621716317164171651716617167171681716917170171711717217173171741717517176171771717817179171801718117182171831718417185171861718717188171891719017191171921719317194171951719617197171981719917200172011720217203172041720517206172071720817209172101721117212172131721417215172161721717218172191722017221172221722317224172251722617227172281722917230172311723217233172341723517236172371723817239172401724117242172431724417245172461724717248172491725017251172521725317254172551725617257172581725917260172611726217263172641726517266172671726817269172701727117272172731727417275172761727717278172791728017281172821728317284172851728617287172881728917290172911729217293172941729517296172971729817299173001730117302173031730417305173061730717308173091731017311173121731317314173151731617317173181731917320173211732217323173241732517326173271732817329173301733117332173331733417335173361733717338173391734017341173421734317344173451734617347173481734917350173511735217353173541735517356173571735817359173601736117362173631736417365173661736717368173691737017371173721737317374173751737617377173781737917380173811738217383173841738517386173871738817389173901739117392173931739417395173961739717398173991740017401174021740317404174051740617407174081740917410174111741217413174141741517416174171741817419174201742117422174231742417425174261742717428174291743017431174321743317434174351743617437174381743917440174411744217443174441744517446174471744817449174501745117452174531745417455174561745717458174591746017461174621746317464174651746617467174681746917470174711747217473174741747517476174771747817479174801748117482174831748417485174861748717488174891749017491174921749317494174951749617497174981749917500175011750217503175041750517506175071750817509175101751117512175131751417515175161751717518175191752017521175221752317524175251752617527175281752917530175311753217533175341753517536175371753817539175401754117542175431754417545175461754717548175491755017551175521755317554175551755617557175581755917560175611756217563175641756517566175671756817569175701757117572175731757417575175761757717578175791758017581175821758317584175851758617587175881758917590175911759217593175941759517596175971759817599176001760117602176031760417605176061760717608176091761017611176121761317614176151761617617176181761917620176211762217623176241762517626176271762817629176301763117632176331763417635176361763717638176391764017641176421764317644176451764617647176481764917650176511765217653176541765517656176571765817659176601766117662176631766417665176661766717668176691767017671176721767317674176751767617677176781767917680176811768217683176841768517686176871768817689176901769117692176931769417695176961769717698176991770017701177021770317704177051770617707177081770917710177111771217713177141771517716177171771817719177201772117722177231772417725177261772717728177291773017731177321773317734177351773617737177381773917740177411774217743177441774517746177471774817749177501775117752177531775417755177561775717758177591776017761177621776317764177651776617767177681776917770177711777217773177741777517776177771777817779177801778117782177831778417785177861778717788177891779017791177921779317794177951779617797177981779917800178011780217803178041780517806178071780817809178101781117812178131781417815178161781717818178191782017821178221782317824178251782617827178281782917830178311783217833178341783517836178371783817839178401784117842178431784417845178461784717848178491785017851178521785317854178551785617857178581785917860178611786217863178641786517866178671786817869178701787117872178731787417875178761787717878178791788017881178821788317884178851788617887178881788917890178911789217893178941789517896178971789817899179001790117902179031790417905179061790717908179091791017911179121791317914179151791617917179181791917920179211792217923179241792517926179271792817929179301793117932179331793417935179361793717938179391794017941179421794317944179451794617947179481794917950179511795217953179541795517956179571795817959179601796117962179631796417965179661796717968179691797017971179721797317974179751797617977179781797917980179811798217983179841798517986179871798817989179901799117992179931799417995179961799717998179991800018001180021800318004180051800618007180081800918010180111801218013180141801518016180171801818019180201802118022180231802418025180261802718028180291803018031180321803318034180351803618037180381803918040180411804218043180441804518046180471804818049180501805118052180531805418055180561805718058180591806018061180621806318064180651806618067180681806918070180711807218073180741807518076180771807818079180801808118082180831808418085180861808718088180891809018091180921809318094180951809618097180981809918100181011810218103181041810518106181071810818109181101811118112181131811418115181161811718118181191812018121181221812318124181251812618127181281812918130181311813218133181341813518136181371813818139181401814118142181431814418145181461814718148181491815018151181521815318154181551815618157181581815918160181611816218163181641816518166181671816818169181701817118172181731817418175181761817718178181791818018181181821818318184181851818618187181881818918190181911819218193181941819518196181971819818199182001820118202182031820418205182061820718208182091821018211182121821318214182151821618217182181821918220182211822218223182241822518226182271822818229182301823118232182331823418235182361823718238182391824018241182421824318244182451824618247182481824918250182511825218253182541825518256182571825818259182601826118262182631826418265182661826718268182691827018271182721827318274182751827618277182781827918280182811828218283182841828518286182871828818289182901829118292182931829418295182961829718298182991830018301183021830318304183051830618307183081830918310183111831218313183141831518316183171831818319183201832118322183231832418325183261832718328183291833018331183321833318334183351833618337183381833918340183411834218343183441834518346183471834818349183501835118352183531835418355183561835718358183591836018361183621836318364183651836618367183681836918370183711837218373183741837518376183771837818379183801838118382183831838418385183861838718388183891839018391183921839318394183951839618397183981839918400184011840218403184041840518406184071840818409184101841118412 |
- Apache Solr Release Notes
- Introduction
- ------------
- Apache Solr is an open source enterprise search server based on the Apache Lucene Java
- search library, with XML/HTTP and JSON APIs, hit highlighting, faceted search,
- caching, replication, and a web administration interface.
- See http://lucene.apache.org/solr for more information.
- Getting Started
- ---------------
- You need a Java 1.8 VM or later installed.
- In this release, there is an example Solr server including a bundled
- servlet container in the directory named "example".
- See the Solr tutorial at https://lucene.apache.org/solr/guide/solr-tutorial.html
- ================== 7.7.2 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.19.1
- Carrot2 3.16.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache ZooKeeper 3.4.14
- Jetty 9.4.14.v20181114
- Upgrade Notes
- ----------------------
- * SOLR-13234: The Prometheus Metric Exporter now collects metrics from Solr at a fixed schedule that is controlled
- by the exporter itself. The default interval is 60s but it can be changed by specifying the --scrape-interval
- command line parameter to the tool. The collected metrics are cached and returned for any requests coming in before
- the next scheduled collection. This can impact the freshness of the metrics if prometheus is configured to query the
- tool more frequently.
- * SOLR-12708: When requesting the status of an async request via REQUESTSTATUS collections API, the response will
- include the list of internal async requests (if any) in the "success" or "failed" keys (in addition
- to them being included outside those keys for backwards compatibility). See SOLR-12708 for more
- details
- Bug fixes
- ----------------------
- * SOLR-13234: Prometheus Metric Exporter not threadsafe. This changes the prometheus exporter to collect metrics
- from Solr on a fixed interval controlled by this tool and prevents concurrent collections. This change also improves
- performance slightly by using the cluster state instead of sending multiple HTTP requests to each node to lookup
- all the cores.
- (Danyal Prout via shalin)
- * SOLR-12708: Async collection actions should not hide internal failures (Mano Kovacs, Varun Thacker, Tomás Fernández Löbbe)
- * SOLR-11876: In-place update fails when resolving from Tlog if schema has a required field (Justin Deoliveira, janhoy,
- Ishan Chattopadhyaya)
- * SOLR-13349: High CPU usage in Solr due to Java 8 bug (Erick Erickson)
- * SOLR-13355: 'all' permission ignored by RuleBasedAuthorizationPlugin in most cases (Jason Gerlowski, janhoy)
- * SOLR-13344: Admin UI inaccessible with RuleBasedAuthorizationPlugin (janhoy, Jason Gerlowski)
- * SOLR-12860: MetricsHistoryHandler now uses PKI Auth for metrics collection in background thread (janhoy, Lorenzo)
- * SOLR-13331: Atomic Update 'remove' operations broken for certain field types in SolrJ (Thomas Wockinger via Jason Gerlowski)
- * SOLR-13285: Updates with enum fields and javabin cause ClassCastException (noble)
- * SOLR-12371: Editing authorization config via REST API now works in standalone mode (janhoy)
- * SOLR-13281: Fixed NPE in DocExpirationUpdateProcessorFactory (Munendra S N, Tomás Fernández Löbbe)
- * SOLR-13409: Disable HTML directory listings in admin interface to prevent possible security issues (Uwe Schindler)
- * SOLR-13126: Query boosts were not being combined correctly for documents where not all boost queries
- matched (Alan Woodward, Mikhail Khludnev)
- * SOLR-13414: SolrSchema - Avoid NPE if Luke returns field with no type defined (Kevin Risden)
- * SOLR-12833: Avoid unnecessary memory cost when DistributedUpdateProcessor timed-out lock is not used. (ab)
- * SOLR-13449: SolrClientNodeStateProvider always retries on requesting metrics from other nodes (Cao Manh Dat)
- * SOLR-13112: Upgrade jackson to 2.9.8 (Kevin Risden)
- * SOLR-13410: Designated overseer wasn't able to rejoin election queue at head upon restart (Ishan Chattopadhyaya,
- Kesharee Nandan Vishwakarma)
- * SOLR-13254: Correct message that is logged in solrj's ConnectionManager when an exception
- occurred while reconnecting to ZooKeeper. (hu xiaodong via Christine Poerschke)
- * SOLR-13252: Fix an NPE when setting a "policy" property for an existing collection (ab)
- * SOLR-13398: Move log line "Processing SSL Credential Provider chain..." from INFO to DEBUG (janhoy)
- * SOLR-13386: OverseerTaskQueue#remove should not throw an exception when no node exists after an exists
- check and the Overseer work loop should not allow free spinning the loop when it hits a KeeperException.
- (Mark Miller, Fernandez-Lobbe, Mike Drob)
- * SOLR-13366: Clarify 'Invalid stage name' warning logging in AutoScalingConfig (Christine Poerschke)
- * SOLR-13352: Remove risk of deadlock/threadleak when shutting down an Overseer(TriggerThread). (hossman)
- * SOLR-13229: Cleanup replicasMetTragicEvent after all types of exception (Tomás Fernández Löbbe)
- Other Changes
- ----------------------
- * SOLR-13363: Upgrade to ZooKeeper 3.4.14 (Erick Erickson)
- ================== 7.7.1 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.19.1
- Carrot2 3.16.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache ZooKeeper 3.4.13
- Jetty 9.4.14.v20181114
- Upgrade Notes
- ----------------------
- * SOLR-13248: The default replica placement strategy used in Solr has been reverted to the 'legacy' policy used by Solr
- 7.4 and previous versions. This is due to multiple bugs in the autoscaling based replica placement strategy that was
- made default in Solr 7.5 which causes multiple replicas of the same shard to be placed on the same node in addition
- to the maxShardsPerNode and createNodeSet parameters being ignored. Although the default has changed, autoscaling
- will continue to be used if a cluster policy or preference is specified or a collection level policy is in use.
- The default replica placement strategy can be changed to use autoscaling again by setting a cluster property:
- curl -X POST -H 'Content-type:application/json' --data-binary '
- {
- "set-obj-property": {
- "defaults" : {
- "cluster": {
- "useLegacyReplicaAssignment":false
- }
- }
- }
- }' http://$SOLR_HOST:$SOLR_PORT/api/cluster
- Bug Fixes
- ----------------------
- * SOLR-13255 : ClasscastException when URPs try to read a String field which returns a ByteArrayUTF8CHarSequence . This is a regression
- in release 7.7 (noble)
- * SOLR-13248: Autoscaling based replica placement is broken out of the box. Solr 7.5 enabled autoscaling based replica
- placement by default but in the absence of default cluster policies, autoscaling can place more than 1 replica of the
- same shard on the same node. Also, the maxShardsPerNode and createNodeSet was not respected. Due to these reasons,
- this issue reverts the default replica placement policy to the 'legacy' assignment policy that was the default until
- Solr 7.4. (Gus Heck, Andrzej Bialecki, Bram Van Dam, shalin)
- * SOLR-13408: Cannot start/stop DaemonStream repeatedly, other API improvements (Erick Erickson)
- ================== 7.7.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.19.1
- Carrot2 3.16.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache ZooKeeper 3.4.13
- Jetty 9.4.14.v20181114
- Upgrade Notes
- ----------------------
- * SOLR-12770: The 'shards' parameter handling logic changes to use a new config element to determine what hosts can be
- requested. Please see Apache Solr Reference Guide chapter "Distributed Requests" for details, as well as SOLR-12770.
- New Features
- ----------------------
- * SOLR-12839: JSON 'terms' Faceting now supports a 'prelim_sort' option to use when initially selecting
- the top ranking buckets, prior to the final 'sort' option used after refinement. (hossman)
- * SOLR-7896: Add a login page to Admin UI, with initial support for Basic Auth (janhoy)
- * SOLR-13116: Add Admin UI login support for Kerberos (janhoy, Jason Gerlowski)
- * SOLR-12770: Make it possible to configure a host whitelist for distributed search
- (Christine Poerschke, janhoy, Erick Erickson, Tomás Fernández Löbbe)
- * SOLR-12373: Add a "tombstoneConfig" option to DocBasedVersionConstraintsProcessor that allows
- users to configure which fields/values to add to tombstone documents. This can be useful to
- make sure tombstone documents include fields that are marked as required in the schema
- (Tomás Fernández Löbbe)
- * SOLR-12984: The search Streaming Expression should properly support and push down paging
- when using the /select handler (Joel Bernstein)
- * SOLR-13088: Add zplot Stream Evaluator to plot math expressions in Apache Zeppelin (Joel Bernstein)
- Bug Fixes
- ----------------------
- * SOLR-12546: CVSResponseWriter omits useDocValuesAsStored=true field when fl=*
- (Munendra S N via Mikhail Khludnev)
- * SOLR-6117: Fix 'status' of ReplicationHandler commands (Shalin Mangar, Jason Gerlowski)
- * SOLR-12933: Fix SolrCloud distributed commit. (Mark Miller)
- * SOLR-13014: URI Too Long with large streaming expressions in SolrJ (janhoy)
- * SOLR-13066: A failure while reloading a SolrCore can result in the SolrCore not being closed. (Mark Miller)
- * SOLR-13058: Fix block that was synchronizing on the wrong collection in OverseerTaskProcessor (Gus Heck)
- * SOLR-11296: Spellcheck parameters not working in new UI (Matt Pearce via janhoy)
- * SOLR-10975: New Admin UI Query does not URL-encode the query produced in the URL box (janhoy)
- * SOLR-13072: Management of markers for nodeLost / nodeAdded events is broken. This bug could have caused
- some events to be lost if they coincided with an Overseer leader crash. (ab)
- * SOLR-13080: The "terms" QParser's "automaton" method semi-required that the input terms/IDs be sorted. This
- query parser now does this. Unclear if this is a perf issue or actual bug. (Daniel Lowe, David Smiley)
- * SOLR-13082: A trigger that creates trigger events more frequently than the cool down period can starve other triggers.
- This is mitigated to some extent by randomly choosing the trigger to resume after cool down. It is recommended that
- scheduled triggers not be used for very frequent operations to avoid this problem.
- (ab, shalin)
- * SOLR-12514: Rule-base Authorization plugin skips authorization if querying node does not have collection replica (noble)
- * SOLR-11853: Solr installer fails on SuSE linux (Markus Mandalka via janhoy)
- * SOLR-12237: Fix incorrect SOLR_SSL_KEYSTORE_TYPE variable in solr start script (janhoy, Joel Bernstein)
- * SOLR-13053: NodeAddedTrigger and NodeLostTrigger do not reserve added/removed time populated by restoreState
- (Cao Manh Dat)
- * SOLR-13137: NPE when /admin/zookeeper/status endpoint hit in standalone mode (janhoy)
- * SOLR-13091: REBALANCELEADERS is broken (Erick Erickson)
- * SOLR-11998: RebalanceLeaders API broken response format with wt=JSON (Erick Erickson)
- * SOLR-9735: Fix v2 API for AutoscalingHistoryHandler. (ab)
- * SOLR-13168: Fixed a bug in TestInjection that caused test only code to be invoked when TLOG replicas
- recieved commits if java assertions were enabled. (hossman)
- Improvements
- ----------------------
- * SOLR-12881: Remove unneeded import statements (Peter Somogyi via Erick Erickson)
- * SOLR-12992: When using binary format, ExportWriter to directly copy BytesRef instead of
- creating new String (noble)
- * SOLR-12898: Replace cluster state polling with ZkStateReader#waitFor. (Mark Miller)
- * SOLR-12897: Introduce AlreadyClosedException to clean up silly close / shutdown logging. (Mark Miller)
- * SOLR-12896: Introduce more checks for shutdown and closed to improve clean close and shutdown. (Mark Miller)
- * SOLR-12804: Remove static modifier from Overseer queue access. (Mark Miller)
- * SOLR-12833: Add configurable timeout to VersionBucket lock. (Jeffery Yuan, Mark Miller)
- * SOLR-12885: BinaryResponseWriter (javabin format) should directly copy from BytesRef to output (noble)
- * SOLR-12973: Admin UI "Nodes" view support for replica* replica names. (Daniel Collins, Christine Poerschke, janhoy)
- * SOLR-13090: All shipped configurations still have `maxBooleanClauses` default to 1024. But if the
- `solr.max.booleanClauses` sysprop is specified, that will override the 1024 default. This enables users to
- update this property across the board more easily. (Jason Gerlowski)
- * SOLR-12983: JavabinLoader should avoid creating String Objects and create UTF8CharSequence fields from byte[] (noble)
- * SOLR-13016: Computing suggestions when policy have "#EQUAL" or "#ALL" rules take too long (noble)
- * SOLR-13029: solr.hdfs.buffer.size can be configured for HdfsBackupRepository for better performance (Tim Owen via Mikhail Khludnev)
- * SOLR-13156: support facet.sort for facet.field={!terms=foo,bar}field. (Konstantin Perikov via Mikhail Khludnev)
- * SOLR-13146: Allow derivatives to be computed for the oscillate Stream Evaluator (Joel Bernstein)
- Other Changes
- ----------------------
- * SOLR-12981: SolrJ's QueryResponse now has a method `getJsonFacetingResponse()`,
- which allows easier access to the response information for the JSON faceting API. (Jason Gerlowski)
- * SOLR-12972: deprecate unused SolrIndexConfig.luceneVersion (Christine Poerschke)
- * SOLR-12801: Make massive improvements to the tests. (Mark Miller)
- * SOLR-12923: The new AutoScaling tests are way too flaky and need special attention. (Mark Miller)
- * SOLR-12932: ant test (without badapples=false) should pass easily for developers. (Mark Miller)
- * SOLR-13036: Fix retry logic in JettySolrRunner (Gus Heck)
- * SOLR-12727: Upgrade ZooKeeper dependency to 3.4.13 (Kevin Risden, Erick Erickson)
- * SOLR-13086: Improve the error message reported by DocumentObjectBinder when a setter is not found (Gus Heck)
- ================== 7.6.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.19.1
- Carrot2 3.16.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache ZooKeeper 3.4.11
- Jetty 9.4.11.v20180605
- Upgrade Notes
- ----------------------
- * SOLR-12767: The min_rf parameter is no longer needed, Solr will always return the achieved replication factor (rf)
- in the response header.
- * SOLR-12827: The cluster wide defaults structure has changed from {collectionDefaults: {nrtReplicas : 2}} to
- {defaults : {collection : {nrtReplicas : 2}}}. The old format continues to be supported and can be read from
- ZK as well as written using the V2 set-obj-property syntax but it is deprecated and will be removed in Solr 9.
- We recommend that users change their API calls to use the new format going forward.
- * SOLR-12739: Autoscaling policy framework is now used as the default strategy to select the nodes on which
- new replicas or replicas of new collections are created. Previously, the maxShardsPerNode parameter was not allowed
- on collections when autoscaling policy was configured. Also if an autoscaling policy was configured then the default
- was to set an unlimited maxShardsPerNode automatically. Now the maxShardsPerNode parameter is always
- allowed during collection creation and maxShardsPerNode should be set correctly (if required) regardless of whether
- autoscaling policies are in effect or not. The default value of maxShardsPerNode continues to be 1 as before. It can
- be set to -1 during collection creation to fall back to the old behavior of unlimited maxShardsPerNode when using
- autoscaling policy.
- * SOLR-12861: Added a Solr factory for ByteBuffersDirectory, which will replace deprecated RAMDirectory in Solr 9.0.
- New Features
- ----------------------
- * SOLR-6280: {!collapse}: if you attempt to use CollapseQParser on a field that is multi-valued, you will now get an
- error. Previously, the collapsing behavior was unreliable and undefined despite no explicit error.
- (Munendra S N, David Smiley)
- * SOLR-9317: ADDREPLICA command should be able to add more than one replica to a collection,shard at a time.
- The API now supports 'nrtReplicas', 'tlogReplicas', 'pullReplicas' parameters as well 'createNodeSet' parameter.
- As part of this change, the CREATESHARD API now delegates placing replicas entirely to the ADDREPLICA command
- and uses the new parameters to add all the replicas in one API call. (shalin)
- * SOLR-11522: /autoscaling/suggestions now include rebalance options as well even if there are no violations (noble)
- * SOLR-12822: /autoscaling/suggestions to include suggestion to add-replica for lost replicas (noble)
- * SOLR-12815: Implement maxOps limit for IndexSizeTrigger. (ab)
- * SOLR-12843: Implement a MultiContentWriter in SolrJ to post multiple files/payload at once (noble)
- * SOLR-12780: Add support for Leaky ReLU and TanH activations in contrib/ltr NeuralNetworkModel class.
- (Kamuela Lau, Christine Poerschke)
- * SOLR-12846: Added support for "host" variable in autoscaling policy rules (noble)
- * SOLR-5004: Splitshard collections API now supports splitting into more than 2 sub-shards directly i.e. by providing a
- numSubShards parameter (Christine Poerschke, Anshum Gupta)
- * SOLR-12754: The UnifiedHighlighter has a new hl.weightMatches param defaulting to false (will be true in 8.0). It's
- the highest query accuracy mode, and furthermore phrase queries are highlighted as one. (David Smiley)
- * SOLR-12828: Add oscillate Stream Evaluator to support sine wave analysis. (Joel Bernstein)
- * SOLR-11907: Add convexHull and associated geometric Stream Evaluators. (Joel Bernstein)
- * SOLR-12811: Add enclosingDisk and associated geometric Stream Evaluators. (Joel Bernstein)
- * SOLR-12840: Add pairSort Stream Evaluator (Joel Bernstein)
- * SOLR-12862: Add log10 Stream Evaluator and allow the pow Stream Evaluator to accept a vector of exponents (Joel Bernstein)
- * SOLR-12938: Cluster Status returns results for aliases, instead of throwing exceptions (Gus Heck)
- * SOLR-11997: Suggestions API/UI should show an entry where a violation could not be resolved (noble)
- * SOLR-12971: Add pivot Stream Evaluator to pivot facet co-occurrence counts into a matrix (Joel Bernstein)
- * SOLR-12795: Introduce 'rows' and 'offset' parameter in FacetStream (Joel Bernstein, Amrit Sarkar, Varun Thacker)
- * SOLR-11572: Add recip Stream Evaluator to support reciprocal transformations (Joel Bernstein)
- * SOLR-12936: Allow percentiles Stream Evaluator to accept an array of percentiles to calculate (Joel bernstein)
- * SOLR-12829: Add plist (parallel list) Streaming Expression (Joel Bernstein)
- * SOLR-12975: Add ltrim and rtrim Stream Evaluators (Joel Bernstein)
- * SOLR-12962: Added a new 'uninvertible' option for fields and fieldtypes. This defaults to 'true' for
- backcompat allowing a FieldCache to be built for indexed fields as needed, but users are encouraged
- to set this to false (using docValues as needed) to reduce the risk of large fluxuations in heap
- size due to unexpected attempts to sort/facet/function on non-docValue fields. (hossman)
- Other Changes
- ----------------------
- * SOLR-12762: Fix javadoc for SolrCloudTestCase.clusterShape() method and add a method that validates only against
- Active slices (Anshum Gupta)
- * SOLR-12756: Refactor Assign and extract replica placement strategies out of it. Now, assignment is done with the help
- of a builder class instead of calling a method with large number of arguments. The number of special cases that had
- to be handled have been cut down as well. (shalin)
- * SOLR-12827: Migrate cluster wide defaults syntax in cluster properties to a nested structure. The structure has
- changed from {collectionDefaults: {nrtReplicas : 2}} to {defaults : {collection : {nrtReplicas : 2}}}.
- (ab, shalin)
- * SOLR-12835: Document statistics exposed by the Query Result Cache when maxRamMB is configured. (shalin)
- * SOLR-12423: Upgrade to Tika 1.19.1 when available (Tim Allison via Erick Erickson)
- * SOLR-12793: Move TestCloudJSONFacetJoinDomain and TestCloudJSONFacetSKG to the facet test package (Varun Thacker)
- * SOLR-12861: Add Solr factory for ByteBuffersDirectory.
- * SOLR-12746: Simplify the Ref Guide HTML structure and use semantic HTML tags where possible. Adds new template files
- for Asciidoctor HTML conversion. Building the HTML version now requires the Slim gem. (Cassandra Targett)
- * SOLR-12956: Add Javadoc @since tag to Analyzer component classes (Alexandre Rafalovitch)
- * SOLR-12966: Add Javadoc @since tag to URP classes (Alexandre Rafalovitch)
- * SOLR-12600: Fix parameter names in Solr JSON documentation (Alexandre Rafalovitch)
- * SOLR-12497: Add documentation to use Hadoop credential provider-based keystore/trustsore.
- (Mano Kovacs, Cassandra Targett)
- * SOLR-13006: ZkNodeProps to be able to load from both javabin and JSON (noble)
- Bug Fixes
- ----------------------
- * SOLR-12803: Ensure ConcurrentUpdateSolrClient sends documents to correct collection (Jason Gerlowski)
- * SOLR-11836: FacetStream works with bucketSizeLimit of -1 which will fetch all the buckets.
- (Alfonso Muñoz-Pomer Fuentes, Amrit Sarkar via Varun Thacker)
- * SOLR-12776: Setting of TMP in solr.cmd causes invisibility of Solr to JDK tools (Petr Bodnar via Erick Erickson)
- * SOLR-12648: Autoscaling framework based replica placement is not used unless a policy is specified or
- non-empty cluster policy exists. (shalin)
- * SOLR-12750: Migrate API should lock the collection instead of shard. (shalin)
- * SOLR-12767: When using min_rf, shard leader skipped bad replicas instead of marking them for recovery, this could
- create inconsistencies between replicas of the same shard. min_rf parameter is now deprecated, and even if provided
- replicas that don't ack an update from the leader will be marked for recovery. (Tomás Fernández Löbbe)
- * SOLR-12814: Metrics history causing "HttpParser URI is too large >8192" when many collections (janhoy)
- * SOLR-12836: ZkController creates a cloud solr client with no connection or read timeouts. Now the http client
- created by the update shard handler is used instead. (shalin)
- * SOLR-12729: SplitShardCmd should lock the parent shard to prevent parallel splitting requests. (ab)
- * SOLR-12851: Improvements and fixes to let and select Streaming Expressions (Joel Bernstein)
- * SOLR-12874: Java 9+ GC Logging filesize parameter should use a unit. (Tim Underwood via Uwe Schindler)
- * SOLR-12868: Request forwarding for v2 API is broken (noble)
- * SOLR-7557: Fix parsing of child documents using queryAndStreamResponse (Marvin Bredal Lillehaug/Stian Østerhaug via janhoy)
- * SOLR-12875: fix ArrayIndexOutOfBoundsException when unique(field) or uniqueBlock(_root_) is
- used with DVHASH method in json.facet. (Tim Underwood via Mikhail Khludnev)
- * SOLR-12023: Autoscaling policy engine shuffles replicas needlessly (noble)
- * SOLR-12243: Edismax missing phrase queries when phrases contain multiterm synonyms
- (Elizabeth Haubert, Alessandro Benedetti, Uwe Schindler, Steve Rowe)
- * SOLR-12977: Autoscaling tries to fetch metrics from dead nodes (noble)
- * SOLR-12978: In autoscaling NPE thrown for nodes where value is absent (noble)
- Improvements
- ----------------------
- * SOLR-12767: Solr now always includes in the response of update requests the achieved replication factor
- (Tomás Fernández Löbbe)
- * SOLR-12782: UninvertingReader wrapping is now a bit more lightweight: Does not create FieldInfo for fields that
- can't be uninverted (saves mem) and can avoid wrapping the reader altogether if there's nothing to uninvert.
- IndexSchema.getUninversionMap refactored to getUninversionMapper and no longer merges FieldInfos. (David Smiley)
- * SOLR-12739: Make autoscaling policy based replica placement the default strategy for placing replicas. (shalin)
- * SOLR-12806: use autoscaling policies with strict=false to prioritize node allocation (noble)
- * SOLR-10981: Support for stream.url or stream.file pointing to gzipped data. It's detected by either a content
- encoding header or file extension. (Andrew Lundgren via David Smiley, Jan Høydahl)
- * SOLR-12892: MapWriter to use CharSequence instead of String (noble)
- * SOLR-12699: Make contrib/ltr LTRScoringModel immutable and cache its hashCode.
- (Stanislav Livotov, Edward Ribeiro, Christine Poerschke)
- * LUCENE-8557: Some internal LeafReader.getFieldInfos implementations were being re-computed on-demand instead of
- once up front leading to some slowdowns in places like JSON Facets and field collapsing. (Tim Underwood, David Smiley)
- * SOLR-12964: Json Facets: use DocValuesIterator advanceExact() instead of advance() in FacetFieldProcessorByHashDV and
- UniqueSinglevaluedSlotAcc. (Tim Underwood)
- * SOLR-12880: Json Facets: Show the FacetProcessor class name instead of the FacetRequest in the JSON Facets debug-trace
- output (Tim Underwood)
- ================== 7.5.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.18
- Carrot2 3.16.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache ZooKeeper 3.4.11
- Jetty 9.4.11.v20180605
- Upgrade Notes
- ----------------------
- * The data-driven schema no longer returns the *_str field-copy of text fields by default. The *_str field is still
- created and can be used for e.g. sorting, but to retrieve it you now need to explicitly list it in "fl" (SOLR-12350)
- * LUCENE-7976: TieredMergePolicy now respects maxSegmentSizeMB by default when executing
- findForcedMerges (optimize) and findForcedDeletesMerges (expungeDeletes) (Erick Erickson)
- * SOLR-12395: SignificantTermsQParserPlugin's name is now 'significantTerms' and its old name 'sigificantTerms' is deprecated.
- * SOLR-11694: Extremely outdated UIMA contrib module has been removed (Alexandre Rafalovitch)
- * SOLR-12008: The configuration file for log4j2.xml is now in ../server/resources/log4j2.xml. All other copies have been removed.
- WINDOWS USERS: This JIRA corrects a bug in the start scripts that put example logs under ...\server, solr.log is
- now under ...\example. (Erick Erickson)
- * SOLR-12398: The heatmap facet response structure, when returned in JSON, changed from an even/odd name/value array to
- an object style. Although the object style makes more sense, this was an overlooked back-compat break; sorry.
- New Features
- ----------------------
- * SOLR-11865: The QueryElevationComponent now has a useConfiguredElevatedOrder setting. When multiple docs are elevated,
- this specifies whether their relative order should be the order in the configuration file or if not then should they
- be subject to whatever the sort criteria is. Additionally, QEC was extensively refactored to be more extensible.
- (Bruno Roustant, David Smiley)
- * SOLR-12474: Add an UpdateRequest Object that implements RequestWriter.ContentWriter (noble)
- * SOLR-12361: Allow nested child documents to be in field values of a SolrInputDocument as an alternative to
- add/get ChildDocuments off to the side. The latter is now referred to as "anonymous" child documents as opposed to
- "labelled" (by the field name). Anonymous child docs might be deprecated in the future. This is an internal change
- that should work for javabin/SolrJ; separate issues will address XML & JSON formats populating nested docs in this way.
- AddUpdateCommand and it's relationship with DirectUpdateHandler2 was reworked substantially. (Moshe Bla, David Smiley)
- * SOLR-12362: Uploading docs in JSON now supports child documents as field values, thus providing a label to the
- relationship instead of the current "anonymous" relationship. Use of this experimental feature sometimes requires a
- anonChildDocs=false parameter until Solr 8 due to syntax ambiguities. (Moshe Bla, David Smiley)
- * SOLR-12485: Uploading docs in XML now supports child documents as field values, thus providing a label to the
- relationship instead of the current "anonymous" relationship. (Moshe Bla, David Smiley)
- * SOLR-12441: (EXPERIMENTAL) New NestedUpdateProcessorFactory (URP) to populate special fields _nest_parent_ and
- _nest_path_ of nested (child) documents. It will generate a uniqueKey of nested docs if they were blank too.
- (Moshe Bla, David Smiley)
- * SOLR-12519: The [child] transformer now returns a nested child doc structure (attached as fields if provided this way)
- provided the schema has the _nest_path_ field. This is part of a broader enhancement of nested docs.
- (Moshe Bla, David Smiley)
- * SOLR-12722: The [child] transformer now takes an 'fl' param to specify which fields to return. It will evaluate
- doc transformers if present. In 7.5 a missing 'fl' defaults to the current behavior of all fields, but in 8.0
- defaults to the top/request "fl". (Moshe Bla, David Smiley)
- * SOLR-11578: Solr 7 Admin UI (Cloud > Graph) should reflect the Replica type to give a more accurate representation
- of the cluster. (Rhoit Singh via Erick Erickson)
- * SOLR-12507: Modify collection API should support un-setting properties. (shalin)
- * SOLR-12506: Add SolrJ support for the modify collection API. (shalin)
- * SOLR-12398: The JSON Facet API now supports type=heatmap facets, just as classic faceting does. (David Smiley)
- * SOLR-11985: Support percentage values in replica attribute in autoscaling policy (noble)
- * SOLR-12511: Support non integer values for replica in autoscaling policy (noble)
- * SOLR-12517: Support range values for replica in autoscaling policy (noble)
- * SOLR-12530: Ability to disable configset upload via -Dconfigset.upload.enabled=false startup parameter
- (Ishan Chattopadhyaya)
- * SOLR-12495: An #EQUAL function for replica in autoscaling policy to equally distribute replicas (noble)
- * SOLR-11986: Allow percentage in freedisk attribute in autoscaling policy rules (noble)
- * SOLR-12522: Support a runtime function `#ALL` for 'replica' in autoscaling policies (noble)
- * SOLR-12567: JSON Facet "functions" now support an extended "type:func" syntax, similar to other types
- of facets. This also allows additional local params to be specified for if the aggregation function
- can take advantage of them. (hossman)
- * SOLR-12581: the JSON Facet 'relatedness()' aggregate function now supports a 'min_popularity' option
- using the extended type:func syntax (hossman)
- * SOLR-12536: autoscaling policy support to equally distribute replicas on the basis of arbitrary properties (noble)
- * SOLR-8207: Add "Nodes" view to the Admin UI "Cloud" tab, listing nodes and key metrics (janhoy)
- * SOLR-7767: "ZK Status" sub menu under "Cloud" tab to see status of zookeeper ensemble (janhoy)
- * SOLR-11990: Make it possible to co-locate replicas of multiple collections together in a node. A collection may be
- co-located with another collection during collection creation time by specifying a 'withCollection' parameter. It can
- also be co-located afterwards by using the modify collection API. The co-location guarantee is enforced regardless of
- future cluster operations whether they are invoked manually via the Collection API or by the Autoscaling framework.
- (noble, shalin)
- * SOLR-12402: Factor out SolrDefaultStreamFactory class. (Christine Poerschke)
- * SOLR-12592: support #EQUAL function, range operator, decimal and percentage in cores in autoscaling policies (noble)
- * SOLR-12655: Add Korean morphological analyzer ("nori") to default distribution. This also adds examples
- for configuration in Solr's schema. (Uwe Schindler)
- * SOLR-11863: Add knnRegress Stream Evaluator to support nearest neighbor regression (Joel Bernstein)
- * SOLR-12702: Add zscores Stream Evaluator (Joel Bernstein)
- * SOLR-12687: Add functions to cache data structures and mathematical models (Joel Bernstein)
- * SOLR-12671: Add robust flag to knnRegress Stream Evaluator (Joel Bernstein)
- * SOLR-12660: Add outliers Stream Evaluator to support outlier detection with probability distributions
- (Joel Bernstein)
- * SOLR-12634: Add gaussfit Stream Evaluator (Joel Bernstein)
- * SOLR-12629: The predict evaluator should work with the polyfit function (Joel Bernstein)
- * SOLR-12715: NodeAddedTrigger should support adding replicas to new nodes by setting preferredOperation=addreplica.
- (shalin)
- * SOLR-11861: When creating a configSet via the API, the "baseConfigSet" parameter now defaults to "_default".
- (Amrit Sarkar, David Smiley)
- * SOLR-12716: NodeLostTrigger should support deleting replicas from lost nodes by setting preferredOperation=deletenode.
- (shalin)
- * SOLR-9418: Added a new (experimental) PhrasesIdentificationComponent for identifying potential phrases
- in query input based on overlapping shingles in the index. (Akash Mehta, Trey Grainger, hossman)
- * SOLR-11943: Add machine learning functions for location data (Joel Bernstein)
- * SOLR-12612: Cluster properties restriction of known keys only is relaxed, and now unknown properties starting with "ext."
- will be allowed. This allows custom to plugins set their own cluster properties. (Jeffery Yuan via Tomás Fernández Löbbe)
- * SOLR-12357: Time Routed Aliases now have a preemptiveCreateMath option to preemptively and asynchronously create the
- next collection in advance as new data gets within this time window of the end. (Gus Heck, David Smiley)
- Bug Fixes
- ----------------------
- * SOLR-12449: Response /autoscaling/diagnostics shows improper json (noble)
- * SOLR-11676: Keep nrtReplicas and replicationFactor in sync while creating a collection and modifying a collection
- (Varun Thacker)
- * SOLR-12489: User specified replicationFactor and maxShardsPerNode is used when specified during a restore operation.
- A user can now specify nrtReplicas/tlogReplicas/pullReplicas while restoring the collection.
- Specifying replicationFactor or nrtReplicas have the same effect and only one can be specified (Varun Thacker)
- * SOLR-11216: Race condition in PeerSync (Cao Manh Dat)
- * SOLR-11807: Restoring collection now treats maxShardsPerNode=-1 as unlimited (Varun Thacker)
- * SOLR-12413: If Zookeeper was pre-loaded with data before first-use, then the aliases information would be ignored.
- (David Smiley, Gaël Jourdan, Gus Heck)
- * SOLR-12482: Config API returns status 0 for failed operations. (Steve Rowe)
- * SOLR-12513: Reproducing TestCodecSupport.testMixedCompressionMode failure (Erick Erickson)
- * SOLR-11665: Improve error handling of shard splitting. Fix splitting of mixed replica types. (ab)
- * SOLR-12326: JSON Facet API: terms facet shard requests now indicate if they have more buckets to prevent
- unnecessary refinement requests. (yonk)
- * SOLR-12427: Improve error message for invalid 'start', 'rows' parameters. (Munendra S N via Jason Gerlowski)
- * SOLR-12395: Make 'significantTerms' the SignificantTermsQParserPlugin's name and deprecate its old 'sigificantTerms' name.
- (Tobias Kässmann, Christine Poerschke)
- * SOLR-12533 Collection collection fails if metrics are called during core creation (Peter Cseh, Mano Kovacs)
- * SOLR-2834: Fix SolrJ Field and Document analyzes for types that include CharacterFilter (Alexandre Rafalovitch)
- * SOLR-12516: Fix some bugs in 'type:range' Facet refinement when sub-facets are combined with non
- default values for the 'other' and 'include' options. (hossman)
- * SOLR-12343: Fixed a bug in JSON Faceting that could cause incorrect counts/stats when using non default
- sort options. This also adds a new configurable "overrefine" option. (Yonik Seeley, hossman)
- * SOLR-12553: Allow SignificantTerms Query Parser to use local parameters (Alexandre Rafalovitch)
- * SOLR-12570: OpenNLPExtractNamedEntitiesUpdateProcessor cannot support multi fields because pattern replacement
- doesn't work correctly. (Koji Sekiguchi)
- * SOLR-12576: Update ref guide for additional information displayed in cloud view (Erick Erickson)
- * SOLR-12597: Migrate API should fail requests that do not specify split.key parameter (shalin)
- * SOLR-12477: An update would return a client error(400) if it hit a AlreadyClosedException.
- We now return the error as a server error(500) instead (Jeffery via Varun Thacker)
- * SOLR-12606: Fix InfixSuggestersTest.testShutdownDuringBuild() failures. (Steve Rowe)
- * SOLR-12607: Fixed two separate bugs in shard splits which can cause data loss. The first case is when using TLOG
- replicas only, the updates forwarded from parent shard leader to the sub-shard leader are written only in tlog and
- not the index. If this happens after the buffered updates have been replayed then the updates can never be executed
- even though they remain the transaction log. The second case is when synchronously forwarding updates to sub-shard
- leader fails and the underlying errors are not propagated to the client. (Cao Manh Dat, shalin)
- * SOLR-12344: SolrSlf4jReporter doesn't set MDC context. (ab)
- * SOLR-12594: MetricsHistoryHandler.getOverseerLeader fails when hostname contains hyphen. (ab)
- * SOLR-12615: HashQParserPlugin will no longer throw an NPE if the hash key field is a string when there are documents
- with empty values. All documents with empty values ( string , numeric ) will be processed by worker=0
- This would fix the NPE when using the search stream with partitionKeys. (Varun Thacker)
- * SOLR-11770: NPE in tvrh if no field is specified and document doesn't contain any fields with term vectors
- * SOLR-12541: Metrics handler throws an error if there are transient cores. (ab)
- * SOLR-12470: Search Rate Trigger multiple bug fixes, improvements and documentation updates. (ab)
- * SOLR-12665: Autoscaling policy not being refreshed due to caching (noble)
- * SOLR-12649: CloudSolrClient retries requests unnecessarily exception from server (noble, shalin)
- * SOLR-12670: RecoveryStrategy logs wrong wait time when retrying recovery. (shalin)
- * SOLR-12668: Autoscaling trigger listeners should be executed in the order of their creation. (ab)
- * SOLR-12475: Fix MaxSizeAutoCommitTest failures (Rupa Shankar, Anshum Gupta)
- * SOLR-12674: RollupStream should not use the HashQueryParser for 1 worker. (Varun Thacker)
- * SOLR-12679: MiniSolrCloudCluster internal jetty list should never have duplicates (shalin)
- * SOLR-12598: Do not fetch non-stored fields (Nikolay Khitrin, Erick Erickson)
- * SOLR-12683: HashQuery will throw an exception if more than 4 partitionKeys is specified.
- Earlier after the 4th partitionKey the keys would be silently ignored. (Varun Thacker)
- * SOLR-10028: Fix and improvements to SegmentsInfoRequestHandlerTest (Christine Poerschke, Tomás Fernández Löbbe)
- * SOLR-11585: Solr SQL does not work with point numeric fields (Joel Bernstein, Kiran Chitturi)
- * SOLR-12704: Guard AddSchemaFieldsUpdateProcessorFactory against null field names and field values.
- (Steve Rowe, Varun Thacker)
- * SOLR-12733: SolrMetricReporterTest failure (Erick Erickson, David Smiley)
- * SOLR-12765: Incorrect format of JMX cache stats. (Bojan Smid, ab)
- * SOLR-12749: timeseries() expression missing sum() results for empty buckets (Joel Bernstein)
- Optimizations
- ----------------------
- * SOLR-12350: Do not use docValues as stored for _str (copy)fields in _default configset (janhoy)
- * SOLR-12455: Refactor JSON serialization code into SolrJ package (noble)
- * SOLR-11654: Time Routed Alias will now route documents to the ideal shard of a collection, thus avoiding a hop.
- Usually documents were already routed well but not always. (Gus Heck, David Smiley)
- * SOLR-12305: When a replica is applying updates, some kind of updates can skip buffering for faster recovery.
- (Cao Manh Dat)
- * SOLR-11598: The export handler does not limit users to 4 sort fields and is now unlimited. However the speed at
- which we can export is directly proportional to the number of sort fields specified. This change also allows streaming
- expressions to group by on more than 4 fields. (Aroop Ganguly, Amrit Sarkar, Varun Thacker)
- * SOLR-12509: Improve SplitShardCmd performance and reliability. A new method of splitting has been
- introduced (splitMethod=link) which uses hard-linking of index files when possible, resulting in
- significant speedups and reduced CPU / IO load on shard leader. (ab)
- * SOLR-11881: Retry update requests sent by leaders to it's followers (Varun Thacker, Mark Miller, Tomás Fernández Löbbe)
- * SOLR-12616: Optimize Export writer upto 4 sort fields to get better performance.
- This was removed in SOLR-11598 but brought back in the same version (Amrit Sarkar, Varun Thacker)
- * SOLR-12572: While exporting documents using the export writer, if a field is specified as a sort parameter and also
- in the fl (field list) parameter, we save on one doc-value lookup. This can bring performance improvements of 15%
- and upwards depending on how many fields are in common. (Amrit Sarkar, Varun Thacker)
- * SOLR-10697: HttpShardHandler now uses a default of 100k as maxConnections (10k previously) and default
- maxConnectionsPerHost as 100k (20 previously). They are now consisent with the UpdateShardHandler defaults.
- (Varun Thacker)
- * SOLR-12723: Reduce object creation in HashBasedRouter. (ab)
- * SOLR-12766: When retrying internal requests, backoff only once for the full batch of retries (Tomás Fernández Löbbe)
- Other Changes
- ----------------------
- * SOLR-12208: Renamed the autoscaling variable 'INDEX.sizeInBytes' to 'INDEX.sizeInGB' (noble)
- * SOLR-12523: Improve error reporting and docs regarding Collection backup feature shared-fs requirement (janhoy)
- * SOLR-12468: Upgrade Jetty to 9.4.11.v20180605 (Michael Braun, shalin)
- * SOLR-12527: factor out a test-framework/ConfigRequest class (Christine Poerschke)
- * SOLR-12412: Leader should give up leadership when IndexWriter.tragedy occur (Cao Manh Dat, Tomas Fernandez-Lobbe)
- * SOLR-12551: Upgrade to Tika 1.18 (Tim Allison via Erick Erickson)
- * SOLR-12464: Reduce Overseer.close() logging (for non-Overseer leaders) (Christine Poerschke)
- * SOLR-12454: Tweak Overseer leadership transition related logging for easier troubleshooting. (Christine Poerschke)
- * SOLR-12574: Put under a common "significantTerms" bucket all output by SignificantTerms Query Parser (Alexandre Rafalovitch)
- * SOLR-12164: Improve Ref Guide main landing page. (Cassandra Targett)
- * SOLR-10984: Clean up web.xml, removing old redirects and outdated comments (Varun Thacker, janhoy)
- * SOLR-12617: Remove Commons BeanUtils as a dependency (Varun Thacker)
- * SOLR-11766: Move Streaming Expressions section in Ref Guide to be a top-level section. (Cassandra Targett)
- * SOLR-12656: ShardSplitTest should extend AbstractFullDistribZkTestBase instead of BasicDistributedZkTest. (shalin)
- * LUCENE-8456: Upgrade Apache Commons Compress to v1.18 (Steve Rowe)
- * SOLR-12014: Cryptic error message when creating a collection with sharding that violates autoscaling policies (noble)
- * SOLR-12680: Fix ClassCastException and AIOOBE in TestSolrConfigHandlerConcurrent. (shalin)
- * SOLR-12675: Make LeaderVoteWaitTimeoutTest more resilient against side effects of test methods. (shalin)
- * SOLR-12130: CdcrReplicationDistributedZkTest is broken into two test classes, CdcrOpsAndBoundariesTest which does
- not require node restarts and CdcrWithNodesRestartsTest which does. The tests themselves are made faster and more
- resilient to spurious failures. (Varun Thacker, Amrit Sarkar via shalin)
- * SOLR-12625: Combine SolrDocumentFetcher and RetrieveFieldsOptimizer (Erick Erickson)
- * SOLR-12690: Regularize LoggerFactory declarations (Erick Erickson)
- * SOLR-12590: Improve Solr resource loader coverage in the ref guide.
- (Steve Rowe, Cassandra Targett, Christine Poerschke)
- * SOLR-12744: Improve logging messages and verbosity around recoveries (Cao Manh Dat, Varun Thacker)
- * SOLR-8742: In HdfsDirectoryTest replace RAMDirectory usages with ByteBuffersDirectory.
- (hossman, Mark Miller, Andrzej Bialecki, Steve Rowe)
- * SOLR-12771: Improve Autoscaling Policy and Preferences documentation. (hossman, Steve Rowe)
- ================== 7.4.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.17
- Carrot2 3.16.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.11
- Jetty 9.4.10.v20180503
- Upgrade Notes
- ----------------------
- * SOLR-7887: Solr now uses Log4J 2.11 . The log4j configuration is now in log4j2.xml rather than log4j.properties files.
- This is a server side change only and clients using SolrJ won't need any changes. Clients can still use any logging
- implementation which is compatible with SLF4J. We now let log4j2 handle rotation of solr logs at startup, and bin/solr
- start scripts will no longer attempt this nor move existing console or GC logs into logs/archived either (SOLR-12144).
- * SOLR-11673: Slave doesn't commit empty index when completely new index is detected on master during replication.
- To return the previous behavior pass false to skipCommitOnMasterVersionZero in slave section of replication
- handler configuration, or pass it to the fetchindex command.
- * SOLR-11453: Configuring slowQueryThresholdMillis now logs slow requests to a separate file - solr_slow_requests.log.
- Previously they would get logged in the solr.log file.
- New Features
- ----------------------
- * SOLR-12396: Upgrade Carrot2 to 3.16.0, HPPC to 0.8.1, morfologik to 2.1.5. (Dawid Weiss)
- * SOLR-11200: A new CMS config option 'ioThrottle' to manually enable/disable
- ConcurrentMergeSchedule.doAutoIOThrottle. (Amrit Sarkar, Nawab Zada Asad iqbal via Dawid Weiss)
- * SOLR-11670: Implement a periodic house-keeping task. This uses a scheduled autoscaling trigger and
- currently performs cleanup of old inactive shards. (ab, shalin)
- * SOLR-12015: Add support "add-distinct" in AtomicURP so that we can use the 'add-distict' as a request parameter e.g:
- atomic.<multival-field-name>=add-distict (Amrit Sarkar via noble)
- * SOLR-7887: Upgrade Solr to use Log4J 2.11
- (Tim Potter, Keith Laban, Shawn Heisey, Ralph Goers, Erick Erickson, Varun Thacker)
- * SOLR-12139: The "eq" (equals) function query now works with string fields, string literals, and perhaps anything.
- (Andrey Kudryavtsev, David Smiley)
- * SOLR-10783: Add support for Hadoop Credential Provider as SSL/TLS store password source.
- (Mano Kovacs via Mark Miller)
- * SOLR-12036: Factor out DefaultStreamFactory solrj class. (Christine Poerschke)
- * SOLR-12151: Add abstract MultiSolrCloudTestCase class. (Christine Poerschke)
- * SOLR-12181: Add index size autoscaling trigger, based on document count or size in bytes. (ab)
- * SOLR-11982: Add possibility to define replica order with the shards.preference parameter to e.g. prefer PULL replicas
- for distributed queries. (Ere Maijala, Tomás Fernández Löbbe)
- * SOLR-11336: DocBasedVersionConstraintsProcessorFactory is more extensible and now supports a list of versioned fields.
- (versionField config may now be a comma-delimited list). (Michael Braun via David Smiley)
- * SOLR-11913: SolrJ SolrParams now implements Iterable<Map.Entry<String, String[]>> and also has a stream() method
- using it for convenience. (David Smiley, Tapan Vaishnav)
- * SOLR-11924: Added the ability to listen to changes in the set of active collections in a cloud
- in the ZkStateReader, through the CloudCollectionsListener. (Houston Putman, Dennis Gove)
- * SOLR-8998: introducing uniqueBlock(_root_) aggregation as faster alternative to unique(_root_) for counting
- child value facets in parents via json.facet on block index (Dr Oleg Savrasov, Mikhail Khludnev)
- * SOLR-12278: Add IgnoreLargeDocumentProcessFactory (Cao Manh Dat, David Smiley)
- * SOLR-11277: Add auto hard-commit settings based on tlog size (Rupa Shankar, Anshum Gupta)
- * SOLR-9480: A new 'relatedness()' aggregate function for JSON Faceting to enable building Semantic
- Knowledge Graphs. (Trey Grainger, hossman)
- * SOLR-11453: Configuring slowQueryThresholdMillis logs slow requests to a separate file - solr_slow_requests.log.
- (Shawn Heisey, Remko Popma, Varun Thacker)
- * SOLR-12401: Add getValue() and setValue() Stream Evaluators (Joel Bernstein, janhoy)
- * SOLR-12378: Support missing versionField on indexed docs in DocBasedVersionConstraintsURP.
- (Oliver Bates, Michael Braun via Mark Miller)
- * SOLR-12388: Enable a strict ZooKeeper-connected search request mode, in which search
- requests will fail when the coordinating node can't communicate with ZooKeeper,
- by setting the "shards.tolerant" param to "requireZkConnected". (Steve Rowe)
- * SOLR-9685: #Tagging queries in JSON Query DSL, equivalent to LocalParams based query/filter
- tagging. Multiple tags are comma separated.
- LocalParams Example : {!tag=colorfilt}color:blue
- Equivalent JSON Example : { "#colorfilt" : "color:blue" }
- (Dmitry Tikhonov, Mikhail Khludnev, yonik)
- * SOLR-12328: JSON Facet API: Domain change with graph query.
- (Daniel Meehl, Kevin Watters, yonik)
- * SOLR-11779, SOLR-12438: Basic long-term collection of aggregated metrics. Historical data is
- maintained as multi-resolution time series using round-robin databases in the '.system'
- collection. New /admin/metrics/history API allows retrieval of this data in numeric
- or graph formats. (ab)
- * SOLR-12387: cluster-wide defaults for numShards, nrtReplicas, tlogReplicas, pullReplicas (noble)
- * SOLR-12389: support deeply nested json objects in clusterprops.json (noble)
- * SOLR-12376: Added the TaggerRequestHandler (AKA SolrTextTagger) for tagging text. It's used as a component of
- NER/ERD systems including query-understanding. See the ref guide for more info. (David Smiley)
- * SOLR-12266: Add discrete Fourier transform Stream Evaluators (Joel Bernstein)
- * SOLR-12158: Allow the monteCarlo Stream Evaluator to support variables (Joel Bernstein)
- * SOLR-11734: Add ones and zeros Stream Evaluators (Joel Bernstein)
- * SOLR-12273: Create Stream Evaluators for distance measures (Joel Bernstein)
- * SOLR-12159: Add memset Stream Evaluator (Joel Bernstein)
- * SOLR-12221: Add valueAt Stream Evaluator (Joel Bernstein)
- * SOLR-12175: Add random field type and dynamic field to the default managed-schema (Joel Bernstein)
- Bug Fixes
- ----------------------
- * SOLR-5351: Fixed More Like This Handler to use all fields provided in mlt.fl when used with
- content stream. The similarity is calculated between the content stream's value and all
- fields listed in mlt.fl. (Dawid Weiss)
- * SOLR-12103: Raise CryptoKeys.DEFAULT_KEYPAIR_LENGTH from 1024 to 2048. (Mark Miller)
- * SOLR-12107: Fixed a error in [child] transformer that could ocur if documentCache was not used (hossman)
- * SOLR-12108: Fixed the fallback behavior of [raw] and [xml] transformers when an incompatble 'wt' was
- specified, the field value was lost if documentCache was not used. (hossman)
- * SOLR-11551: Standardize CoreAdmin API success/failure status codes (Jason Gerlowski, Steve Rowe)
- * SOLR-12035: ExtendedDismaxQParser fails to include charfilters in nostopanalyzer (Tim Allison via
- Tomás Fernández Löbbe)
- * SOLR-10734: AtomicUpdateRequestProcessor can cause wrong/old values to be set under concurrent updates for the same
- document. Multithreaded test for AtomicUpdateRequestProcessor was also beefed up and fixed.
- (Ishan Chattopadhyaya, Noble Paul, Amrit Sarkar, shalin)
- * SOLR-11673: By default slave doesn't commit empty index when completely new index appears on master.
- See Upgrade Notes to find a way to get back to the previous behavior. (Mikhail Khludnev)
- * SOLR-9399: Delete requests do not send credentials & fails for Basic Authentication
- (Susheel Kumar, Aibao Luo, Nikkolay Martinov via Erick Erickson)
- * SOLR-12172: Fixed race condition that could cause an invalid set of collection properties to be kept in
- memory when multiple collection property changes are done in a short period of time. (Tomás Fernández Löbbe)
- * SOLR-11929: UpdateLog metrics are not initialized on core reload. (ab, Steve Rowe)
- * SOLR-11882: SolrMetric registries retained references to SolrCores when closed. A
- change of SolrMetricMAnager.registerGauge and SolrMetricProducer.initializeMetrics
- method signatures was required to fix it. Third party components may continue to use the old API
- but should be updated to avoid this bug (Eros Taborelli, Erick Erickson, ab)
- * SOLR-12199: TestReplicationHandler.doTestRepeater(): TEST_PORT interpolation failure:
- Server refused connection at: http://127.0.0.1:TEST_PORT/solr (Mikhail Khludnev, Dawid Weiss, Steve Rowe)
- * SOLR-12096: Fixed inconsistent results format of subquery transformer for distributed search (multi-shard).
- (Munendra S N, Mikhail Khludnev via Ishan Chattopadhyaya)
- * SOLR-12207: Just rethrowing AssertionError caused by jdk bug in reflection with invocation details.
- (ab, Dawid Weiss, Mikhail Khludnev)
- * SOLR-12155: Exception from UnInvertedField constructor puts threads to infinite wait.
- (Andrey Kudryavtsev, Mikhail Khludnev)
- * SOLR-12201: TestReplicationHandler.doTestIndexFetchOnMasterRestart(): handle unexpected replication failures
- (Steve Rowe)
- * SOLR-12190: Need to properly escape output in GraphMLResponseWriter. (yonik)
- * SOLR-12214: Leader may skip publish itself as ACTIVE when its last published state is DOWN (Cao Manh Dat)
- * SOLR-12150: Fix a test bug in CdcrBidirectionalTest.testBiDir (Steve Rowe, Amrit Sarkar via Varun Thacker)
- * SOLR-10513: ConjunctionSolrSpellChecker did not work with LuceneLevenshteinDistance (Amrit Sarkar via James Dyer)
- * SOLR-11840: Fix bin/solr help-text inconsistencies (Jason Gerlowski)
- * SOLR-10169: PeerSync will hit an NPE on no response errors when looking for fingerprint. (Erick Erickson)
- * SOLR-12187: Replica should watch clusterstate and unload itself if its entry is removed (Cao Manh Dat)
- * SOLR-6286: TestReplicationHandler.doTestReplicateAfterCoreReload(): stop checking for identical
- commits before/after master core reload; and make non-nightly mode test 10 docs instead of 0.
- (shalin, hossman, Mark Miller, Steve Rowe)
- * SOLR-9304: Fix Solr's HTTP handling to respect '-Dsolr.ssl.checkPeerName=false' aka SOLR_SSL_CHECK_PEER_NAME
- (Shawn Heisey, Carlton Findley, Robby Pond, hossman)
- * SOLR-12250: NegativeArraySizeException on TransactionLog if previous document more than 1.9GB (Cao Manh Dat)
- * SOLR-12253: Remove optimize button from the core admin page (Erick Erickson)
- * SOLR-11833: Allow searchRate trigger to delete replicas. Improve configurability of the trigger by specifying
- upper / lower thresholds and respective actions (ab)
- * SOLR-12261: If you attempt to delete a collection immediately after deleting an alias it used to be a part of, you may
- get an error that's it's a member of that alias. This check now ensures the alias state is sync()'ed with ZK first.
- (David Smiley)
- * SOLR-12275: wrong caching for {!filters} as well as for `filters` local param in {!parent} and {!child}
- (David Smiley, Mikhail Khluldnev)
- * SOLR-12284: WordBreakSolrSpellchecker will no longer add parenthesis in collations when breaking words in
- non-boolean queries. (James Dyer)
- * SOLR-12290: Do not close any servlet streams and improve our servlet stream closing prevention code for users
- and devs. (Mark Miller, janhoy, Andrzej Bialecki)
- * SOLR-12293: Updates need to use their own connection pool to maintain connection reuse and prevent spurious
- recoveries. (Mark Miller)
- * SOLR-12308: LISTALIASES is now assured to return an up-to-date response. Also, the test utility
- MiniSolrCloudCluster.deleteAllCollections will now first delete aliases since a collection cannot be deleted if an
- alias refers to it. (David Smiley)
- * SOLR-12192: Fixed a solr cli error message when ulimits are unlimited. (Martijn Koster)
- * SOLR-12258: A V2 request referencing a collection or alias may fail to resolve it if it was just recently created.
- Now we sync with ZooKeeper and try one more time. V1 partially did this but only for aliases; now it does both.
- (David Smiley)
- * SOLR-12170: JSON Facet API: Terms facet on a date field sometimes failed with an exception complaining
- about "Invalid Date String". (yonik)
- * SOLR-12307: exiting OverseerTriggerThread without endless noise in log when Zookeeper session is expired
- (Mikhail Khludnev)
- * SOLR-12200: abandon OverseerExitThread when ZkController is closed. (Mikhail Khludnev)
- * SOLR-12355: Fixes hash conflict in HashJoinStream and OuterHashJoinStream (Dennis Gove)
- * SOLR-12377: Don't spin off overseer when Zk controller is closed (Mikhail Khludnev)
- * SOLR-3567: Spellcheck custom parameters not being passed through due to wrong prefix creation.
- (Josh Lucas via shalin)
- * SOLR-12294: update processors loaded from runtime jars fail to load if they are specified
- in an update processor chain (noble)
- * SOLR-12358: Autoscaling suggestions fail randomly with sorting (noble)
- * SOLR-12314: Use http timeout's defined in solr.xml for creating ConcurrentUpdateSolrClient during
- indexing requests between leader and replica ( Mark Miller, Varun Thacker)
- * SOLR-12290: Do not close any servlet streams and improve our servlet stream closing prevention code for users
- and devs. (Mark Miller)
- * SOLR-12374: SnapShooter.getIndexCommit can forget to decref the searcher; though it's not clear in practice when.
- (David Smiley)
- * SOLR-12417: velocity response writer should enforce valid function name for v.json parameter (Mano Kovacs, yonik)
- * SOLR-12271: Fixed bug in how Analytics component reads negative values from float and double fields. (Houston Putman)
- * SOLR-12433: Recovering flag of a replica is set equals to leader even it failed to receive update
- on recovering. (Cao Manh Dat)
- * SOLR-12354: Register the /admin/info/key end-point at the startup time to avoid 404 (noble)
- * SOLR-12445: Upgrade Dropwizard Metrics to version 3.2.6. (ab)
- * SOLR-12434: bin/solr {config,healthcheck} ignore ZK_HOST in solr.in.{sh,cmd} (Steve Rowe)
- * SOLR-12481: update.autoCreateFields must be set via Config API command 'set-user-property',
- but 'bin/solr create' tells users to use the default action 'set-property', which fails
- because the property is not editable. (Steve Rowe)
- * SOLR-12416: When creating a time routed alias, the router.autoDeleteAge option wasn't considered.
- (Joachim Sauer via David Smiley)
- * SOLR-12450: Don't allow referal to external resources in various config files (CVE-2018-8026).
- (Yuyang Xiao, Uwe Schindler)
- Optimizations
- ----------------------
- * SOLR-11920: IndexFetcher now fetches only those files (from master/leader) that are different. This
- differential fetching now speeds up recovery times when full index replication is needed, but only
- a few segments diverge. (Ishan Chattopadhyaya, Shaun Sabo, John Gallagher)
- * SOLR-11731: LatLonPointSpatialField can now decode points from docValues when stored=false docValues=true,
- albeit with maximum precision of 1.37cm (Karthik Ramachandran, David Smiley)
- * SOLR-11891: DocStreamer now respects the ReturnFields when populating a SolrDocument, reducing the
- number of unneccessary fields a ResponseWriter will see if documentCache is used (wei wang, hossman)
- * SOLR-12312: Replication IndexFetcher should cap its internal buffer size when the file being transferred is small.
- (Jeff Miller, David Smiley)
- * SOLR-12333: Removed redundant lines for handling lists in JSON reponse writers. (David Smiley via Mikhail Khludnev)
- * SOLR-11880: Avoid creating new exceptions for every request made to MDCAwareThreadPoolExecutor by distributed
- search and update operations. (Varun Thacker, shalin)
- * SOLR-12375: Optimize Lucene needsScore / ScoreMode use:
- A non-cached filter query could be told incorrectly that scores were needed.
- The /export (ExportQParserPlugin) would declare incorrectly that scores are needed.
- Expanded docs (expand component) could be told incorrectly that scores are needed. (David Smiley)
- * SOLR-12338: Replay buffering tlog in parallel. (Cao Manh Dat, David Smiley)
- * SOLR-12366: A slow "live docs" implementation was being used instead of a bitset. Affects classic faceting
- enum method, JSON Facets enum method, UnInvertedField faceting, GraphTermsQParser, JoinQParser. (David Smiley)
- * SOLR-12337: Remove the obsolete QueryWrapperFilter intermediate wrapper, which also removed some needless uses of
- SolrConstantScoreQuery as well. QWF since v5.4.0 sometimes needlessly internally executed and cached the query.
- Affects ExpandComponent, ChildDocTransformer, CurrencyFieldType, TermsQParser. (David Smiley)
- * SOLR-9922: Write buffering updates to another tlog. (Cao Manh Dat)
- * SOLR-12233: QParserPlugin's built-in static registry now holds actual QParserPlugin instances instead of class
- references. This is consistent with other plugin registries and allows a SolrCore to load faster.
- (Jeff Miller, David Smiley)
- * SOLR-12198: Stream Evaluators should not copy matrices needlessly (Joel Bernstein)
- Other Changes
- ----------------------
- * SOLR-12018: Remove comments.apache.org integration for the Ref Guide; the comments system has been down since December 2017 and there is no concrete plan to bring it back. (Cassandra Targett)
- * SOLR-12076: Remove unnecessary printLayout usage in CDCR tests (Varun Thacker)
- * SOLR-12086: Fix format problem in FastLRUCache description string shown on Cache Statistics page.
- (Sathiya N Sundararajan via shalin)
- * SOLR-12090: Move DistribStateManager, NodeStateProvider and SolrCloudManager interfaces out of the
- autoscaling package. (shalin)
- * SOLR-12091: Rename TimeSource.getTime to getTimeNs. (ab)
- * SOLR-12101: ZkTestServer was not handling connection timeout settings properly. (Gus Heck via Mark Miller)
- * SOLR-11331: Ability to run and debug standalone Solr and a single node SolrCloud server from Eclipse.
- Also being able to run all Lucene and Solr tests as a configuration (Karthik Ramachandran via
- Varun Thacker, Uwe Schindler)
- * SOLR-12118: Solr Ref-Guide can now use some ivy version props directly as attributes in content (hossman)
- * SOLR-12152: Split up TriggerIntegrationTest into multiple tests to isolate and increase reliability. (shalin)
- * SOLR-12133: Fix race conditions that caused TriggerIntegrationTest.testEventQueue and testNodeMarkersRegistration
- to fail. (Mark Miller, shalin)
- * SOLR-12169: Fix ComputePlanActionTest.testSelectedCollections fails on jenkins by aggressively cleaning up
- trigger state left by other test methods in the test setup. (shalin)
- * SOLR-12144: SOLR_LOG_PRESTART_ROTATION now defaults to false, we leverage log4j2 for log rotation on startup (janhoy)
- * SOLR-12095: AutoScalingHandler validates trigger configurations before updating Zookeeper. (ab)
- * SOLR-12165: Ref Guide: DisMax default mm param value is improperly documented as 100%. (Steve Rowe)
- * SOLR-12154: Disallow explicit usage of Log4j2 logger via forbidden APIs. (Varun Thacker, Tomás Fernández Löbbe)
- * SOLR-12176: Improve FORCELEADER to handle the case when a replica win the election but does not present
- in clusterstate (Cao Manh Dat)
- * SOLR-12134: ref-guide 'bare-bones html' validation is now part of 'ant documentation' and validates
- javadoc links locally. (hossman)
- * SOLR-12142: EmbeddedSolrServer should use req.getContentWriter (noble)
- * SOLR-12252: Fix minor compiler and intellij warnings in autoscaling policy framework. (shalin)
- * SOLR-11914: The following SolrParams methods are now deprecated: toSolrParams (use NamedList.toSolrParams instead),
- toMap, toMultiMap, toFilteredSolrParams, getAll. The latter ones have no direct replacement but are easy to
- implement yourself as-needed. (David Smiley)
- * SOLR-10036: Upgrade jackson from 2.5.4 to 2.9.5 (Shashank Pedamallu, Shawn Heisey, Varun Thacker)
- * SOLR-12289: Add more MDC logging information to collection admin requests (Varun Thacker)
- * SOLR-12288: Add more MDC logging information to core admin requests (Varun Thacker)
- * SOLR-12265: Upgrade Jetty to 9.4.10.v20180503 (Varun Thacker, Steve Rowe)
- * SOLR-12374: Added SolrCore.withSearcher(lambda) to make grabbing the searcher easier than the more awkward
- RefCounted API. (David Smiley)
- * SOLR-12183: Refactor Streaming Expression test cases (Joel Bernstein)
- * SOLR-12437: Document 'bin/solr config' in the ref guide. (Steve Rowe)
- * SOLR-12435: Fix bin/solr help and ref guide text to describe ZK_HOST in solr.in.sh/solr.in.cmd
- as an alternative to -z cmdline param. (Steve Rowe)
- ================== 7.3.1 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.17
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.11
- Jetty 9.4.8.v20171121
- Bug Fixes
- ----------------------
- * SOLR-12204: Upgrade commons-fileupload dependency to 1.3.3 to address CVE-2016-1000031. (Steve Rowe)
- * SOLR-12256: Fixed some eventual-consistency issues with collection aliases by using ZooKeeper.sync(). (David Smiley)
- * SOLR-12087: Deleting replicas sometimes fails and causes the replicas to exist in the down
- state (Cao Manh Dat)
- * SOLR-12146: LIR should skip deleted replicas (Cao Manh Dat)
- * SOLR-12066: Cleanup deleted core when node start (Cao Manh Dat)
- * SOLR-12065: A successful restore collection should mark the shard state as active and not buffering
- (Rohit, Varun Thacker)
- * SOLR-11724: Cdcr bootstrapping should ensure that non-leader replicas should sync with the leader
- (Amrit Sarkar, Varun Thacker)
- * SOLR-12202: Fix errors in solr-exporter.cmd. (Minoru Osuka via koji)
- * SOLR-12316: Do not allow to use absolute URIs for including other files in solrconfig.xml
- and schema parsing (CVE-2018-8010). (Ananthesh, Ishan Chattopadhyaya, Uwe Schindler)
- ================== 7.3.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.16
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.11
- Jetty 9.4.8.v20171121
- Upgrade Notes
- ----------------------
- * SOLR-11748: The throttling mechanism used to limit the rate of autoscaling events processed
- has been removed. This deprecates the 'actionThrottlePeriodSeconds' setting in the set-properties
- Autoscaling API which is now a no-op. Use the 'triggerCooldownPeriodSeconds' instead to pause event
- processing.
- * SOLR-11798: The top-level <highlighting> syntax in solrconfig.xml is now formally
- deprecated in favour of <searchComponent> equivalent syntax. See also SOLR-1696.
- * SOLR-11809: QueryComponent's rq parameter parsing no longer considers the defType parameter.
- * SOLR-11747: The behaviour of the autoscaling system has been modified to pause all triggers from execution between
- the start of actions and end of cool down period. The triggers will be resumed after the cool down period expires.
- Previously, the cool down period was a fixed period started after actions for a trigger event complete and during
- this time, all triggers continued to run but any events were rejected to be tried later.
- * SOLR-11624: Collections created without specifying a configset name use a copy of the _default configset since 7.0.
- Before 7.3, the copied over configset was named the same as the collection name, but 7.3 onwards it will be named
- with an additional ".AUTOCREATED" suffix.
- * SOLR-11702: The old Leader-In-Recovery implementation (SOLR-5495) is now deprecated and replaced. Solr will support
- rolling upgrades from old 7.x versions of Solr to future 7.x releases until the last release of
- the 7.x major version. This means in order to upgrade to Solr 8 in the future, you must be on Solr 7.3 or higher.
- * LUCENE-8161: If you are using the spatial JTS library with Solr, you must upgrade to 1.15.0. This new version
- of JTS is now dual-licensed to include a BSD style license.
- * SOLR-12051: A new mechanism is introduced in SOLR-11702 to maintain consistency in SolrCloud between leader and replicas.
- This mechanism lets Solr know whether a replica is in-sync with the leader or not, even when the leader is not live.
- If all the replicas who participate in the leader election are out-of-sync with previous leader, the election will
- pause until a timeout (named "leaderVoteWait") before allowing an out-of-sync replica to become leader. Note that the
- new leader still needs to contains more updates than any other active replicas in the same shard. Therefore by
- increasing leaderVoteWait will increase the consistency (over availability) of the system. The default value of
- leaderVoteWait is 180,000 ms (3 minutes) and it can be adjusted in the "solrcloud" section of the solr.xml
- * SOLR-11957: The default Solr log file size and number of backups is raised to 32MB and 10 respectively
- * SOLR-12067: The default value of `autoReplicaFailoverWaitAfterExpiration` has been increased to 120 seconds
- from the earlier default of 30 seconds. This affects how soon Solr adds new replicas to replace the replicas
- on nodes which have either crashed or shutdown.
- New Features
- ----------------------
- * SOLR-11285: Simulation framework for autoscaling. (ab)
- * LUCENE-2899: In the Solr analysis-extras contrib, added support for the
- OpenNLP-based analysis components in the Lucene analysis/opennlp module:
- tokenization, part-of-speech tagging, phrase chunking, and lemmatization.
- Also added OpenNLP-based named entity extraction as a Solr update request
- processor. (Lance Norskog, Grant Ingersoll, Joern Kottmann, Em, Kai Gülzau,
- Rene Nederhand, Robert Muir, Steven Bower, Steve Rowe)
- * SOLR-11201: Implement autoscaling trigger for arbitrary metrics that creates events when
- a given metric breaches a threshold (shalin)
- * SOLR-11653: TimeRoutedAlias URP now auto-creates new collections on the fly according to alias metadata
- rules that sets the time interval for each collection. An internal Overseer command "ROUTEDALIAS_CREATECOLL"
- was created to facilitate this. (David Smiley)
- * SOLR-11062: new tag "diskType" in autoscaling policy (noble)
- * SOLR-11063: Suggesters should accept required freedisk as a hint (noble)
- * SOLR-3218: Added range faceting support for CurrencyFieldType. This includes both "facet.range" as well
- as json.facet's "type:range" (Andrew Morrison, Jan Høydahl, Vitaliy Zhovtyuk, hossman)
- * SOLR-11064: Collection APIs should use the disk space hint when using policy framework (noble)
- * SOLR-11854: multivalued primitive fields can now be sorted by implicitly choosing the min/max
- value for asc/desc sort orders. (hossman)
- * SOLR-11592: Add OpenNLP language detection to the langid contrib. (Koji, Steve Rowe)
- * SOLR-11648: A new admin UI to display and execute suggestions (Apoorv Bhawsar , noble)
- * SOLR-11722: Added "time routed alias" creation support to the CREATEALIAS command. It's for managing multiple
- collections partitioned by time. (Gus Heck, David Smiley)
- * SOLR-11782: Refactor LatchWatcher.await to protect against spurious wakeup (Tomás Fernández Löbbe, David Smiley, Dawid Weiss)
- * SOLR-11617: Alias properties (formerly "metadata") are now mutable via a new ALIASPROP command.
- These properties are returned from LISTALIASES. (Gus Heck via David Smiley)
- * SOLR-11702: Redesign current LIR implementation (Cao Manh Dat, shalin)
- * SOLR-11376: Support computing plans for only specific collections. (ab)
- * SOLR-11681: Add ttest and pairedTtest Stream Evaluators (Joel Bernstein)
- * SOLR-11785: Add multiVariateNormalDistribution Stream Evaluator (Joel Bernstein)
- * SOLR-11789: Add integrate Stream Evaluator to support integral calculations (Joel Bernstein)
- * SOLR-11791: Add density Stream Evaluator (Joel Bernstein)
- * SOLR-11172: Add Mann-Whitney U test Stream Evaluator (Mathew Skaria, Joel Bernstein)
- * SOLR-11808: Add sumSq Stream Evaluator (Joel Bernstein)
- * SOLR-11430: Add lerp and akima Stream Evaluators to support linear and akima spline interpolation (Joel Bernstein)
- * SOLR-11683: Add chiSquareDataSet Stream Evaluator (Joel Bernstein)
- * SOLR-10716: Add termVectors Stream Evaluator (Joel Bernstein)
- * SOLR-11737: Add kmeans Stream Evaluator to support kmeans clustering (Joel Bernstein)
- * SOLR-11736: Rename knn Streaming Expression to knnSearch and add new knn Stream Evaluator (Joel Bernstein)
- * SOLR-11867: Add indexOf, rowCount and columnCount StreamEvaluators (Joel Bernstein)
- * SOLR-11862: Add fuzzyKmeans Stream Evaluatory (Joel Bernstein)
- * SOLR-11890: Add multiKmeans Stream Evaluator (Joel Bernstein)
- * SOLR-11916: new SortableTextField which supports analysis/searching just like TextField, but also
- sorting/faceting just like StrField. By default uses only the first 1024 chars of the original
- input string values, but this is configurable. (hossman)
- * SOLR-11778: Add per-stage RequestHandler metrics. (ab)
- * SOLR-11925: Time Routed Aliases can have their oldest collections automatically deleted via the "router.autoDeleteAge"
- setting. (David Smiley)
- * SOLR-11941: Add abstract contrib/ltr AdapterModel to facilitate the development of scoring models that delegate
- scoring to an opaque pre-trained model. (Christine Poerschke)
- * SOLR-11689: Add l1norm, l2norm and linfnorm Stream Evaluators (Joel Bernstein)
- * SOLR-11588: Add matrixMult Stream Evaluator to support matrix multiplication (Joel Bernstein)
- * SOLR-12006: Add a '*_t' and '*_t_sort' dynamic field for single valued text fields (Varun Thacker)
- * SOLR-11597: Add contrib/ltr NeuralNetworkModel class. (Michael A. Alcorn, Yuki Yano, Christine Poerschke)
- * SOLR-11066: Implement a scheduled autoscaling trigger that runs on a fixed interval beginning with a
- given start time. (David Smiley, Gus Heck, ab, shalin)
- * SOLR-11795: Add Solr metrics exporter for Prometheus (Minoru Osuka via koji)
- * SOLR-11267: Add support for "add-distinct" atomic update operation (Amrit Sarkar via noble )
- * SOLR-11960: Add collection level properties similar to cluster properties (Peter Rusko, Tomás Fernández Löbbe)
- * SOLR-12077: Add support for autoAddReplicas in the collection creation dialog in Admin UI. (shalin)
- * SOLR-9510: introducing {!filters param=$fq excludeTags=f} query parser.
- Introducing {!.. filters=$fq excludeTags=t,q} in {!parent} and {!child} (Dr. Oleg Savrasov via Mikhail Khludnev)
- Bug Fixes
- ----------------------
- * SOLR-11783: Rename core in solr standalone mode is not persisted (Erick Erickson)
- * SOLR-11555: If the query terms reduce to nothing, filter(clause) produces an NPE whereas
- fq=clause does not (Erick Erickson)
- * SOLR-11824: Fixed bucket ordering in distributed json.facet type:range when mincount>0 (hossman)
- * SOLR-11821: ConcurrentModificationException in SimSolrCloudTestCase.tearDown (shalin)
- * SOLR-11631: The Schema API should return non-zero status when there are failures.
- (Noble Paul, Steve Rowe)
- * SOLR-11839: Fix test failures resulting from SOLR-11218 (Erick Erickson)
- * SOLR-11794: PULL replicas stop replicating after collection RELOAD (Samuel Tatipamula, Tomás Fernández Löbbe)
- * SOLR-11714: AddReplicaSuggester / ComputePlanAction infinite loop. (ab)
- * SOLR-11895: Logging Screen in the Admin UI will now show "No Events available" when there are no events to show.
- Also, the spinner icon is removed to prevent users thinking the page has hung. (Cassandra Targett, Shawn Heisey)
- * SOLR-10525: Stacked recovery requests do no cancel an in progress recovery first. (Mike Drob via Cao Manh Dat)
- * SOLR-11873: Use time based expiration cache in all necessary places in HdfsDirectoryFactory. (Mihaly Toth via Mark Miller)
- * SOLR-11661: New HDFS collection reuses unremoved data from a deleted HDFS collection with same name causes
- inconsistent view of documents (Cao Manh Dat, shalin)
- * SOLR-11459: In-place update of nonexistent doc following existing doc update fails to create the doc.
- (Andrey Kudryavtsev via Mikhail Khludnev)
- * SOLR-11931: Fix contrib/ltr custom inner class feature/normaliser/model persistence. (Christine Poerschke)
- * SOLR-10261: In case of in-place updates, failure in leader to follower replica update request now throws the
- follower replica in leader-initiated-recovery (Ishan Chattopadhyaya, Steve Rowe)
- * SOLR-11898: ConcurrentModificationException when calling org.apache.solr.core.SolrInfoBean.getMetricsSnapshot
- (Jeff Miller via Erick Erickson)
- * SOLR-11950: Allow CLUSTERSTATUS "shard" parameter to accept comma (,) delimited list (Chris Ulicny via Jason Gerlowski)
- * SOLR-11739: Fix race condition that made Solr accept duplicate async IDs in collection API operations (Tomás Fernánadez Löbbe)
- * SOLR-11988: Fix exists() method in EphemeralDirectoryFactory/MockDirectoryFactory to prevent false positives (hossman)
- * SOLR-11971: Don't allow referal to external resources in DataImportHandler's dataConfig request parameter (CVE-2018-1308).
- (麦 香浓郁, Uwe Schindler)
- * SOLR-12021: Fixed a bug in ApiSpec and other JSON resource loading that was causing unclosed file handles (hossman)
- * SOLR-10720: Aggressive removal of a collection breaks cluster status API. (Alexey Serba, shalin)
- * SOLR-12050: UTILIZENODE does not enforce policy rules (hossman, noble)
- * SOLR-11843: Admin UI collection creation was not properly handling the router.field and router.name parameters.
- Also changed the display label in the Admin UI from routerField to router.field to match the actual API.
- (Shawn Heisey via Cassandra Targett)
- * SOLR-12011: Consistence problem when in-sync replicas are DOWN. (Cao Manh Dat)
- * SOLR-12020: JSON Facet API: terms facet on date field fails in refinement phase with
- "Invalid Date String" error. (yonik)
- * SOLR-12061: Fix substitution bug in API V1 to V2 migration when using SolrJ with V2 API. (Tomás Fernánadez Löbbe)
- * SOLR-11976: TokenizerChain.normalize: only the first filter that is a MultiTermAwareComponent was participating
- in normalization instead of all. This bug normally doesn't matter since TextField doesn't call it.
- (Tim Allison via David Smiley)
- * SOLR-12072: Invalid path string using ZkConfigManager.copyConfigDir(String fromConfig, String toConfig)
- (Alessandro Hoss via Erick Erickson)
- * SOLR-12064: JSON Facet API: fix bug where a limit of -1 in conjunction with multiple facets or
- missing=true caused an NPE or AIOOBE. (Karthik Ramachandran via yonik)
- * SOLR-12083: Fix RealTime GET to work on a cluster running CDCR when using Solr's in-place updates
- (Amrit Sarkar, Varun Thacker)
- * SOLR-12063: Fix PeerSync, Leader Election failures and CDCR checkpoint inconsistencies on a cluster running CDCR
- (Amrit Sarkar, Varun Thacker)
- * SOLR-12110: Replica which failed to register in Zk can become leader (Cao Manh Dat)
- * SOLR-12129: After the core is reloaded, term of the core will not be watched (Cao Manh Dat)
- * SOLR-12141: Fix "bin/solr" shell scripts (Windows/Linux/Mac) to correctly detect major Java version
- and use numerical version comparison to enforce minimum requirements. Also remove obsolete "UseParNewGC" option.
- This allows to start Solr with Java 10 or later. (Uwe Schindler)
- Optimizations
- ----------------------
- * SOLR-11711: Fixed distributed processing of facet.field/facet.pivot sub requests to prevent requesting
- unneccessary and excessive '0' count terms from each shard (Houston Putman via hossman)
- * LUCENE-8149: NRTCachingDirectory does not need to preemptively delete segment files and generate exceptions
- (Erick Erickson)
- * SOLR-11879: avoid EOFException for empty input streams (noble)
- * SOLR-8327: Cluster state caching to avoid live fetch from ZK of cluster state for forwarding requests on nodes
- that do not host any replica of the collection (Jessica Cheng Mallet, John Gallagher, Noble Paul, Ishan Chattopadhyaya)
- * SOLR-11769: Optimize when useFilterForSortedQuery=true and there are no filter queries by avoiding
- needless match-all-docs bitset construction. (Betim Deva, David Smiley)
- Other Changes
- ----------------------
- * SOLR-11629: Add more intuitive CloudSolrClient.Builder constructors (Varun Thacker, Jason Gerlowski)
- * SOLR-11575: Improve ref-guide solrj snippets via mock 'print()' method (Jason Gerlowski via hossman)
- * SOLR-11757: In tests, fix race condition on SolrException.ignoreException.
- Also ensure we register "ignore_exception" in @BeforeClass (previously only @AfterClass) (David Smiley)
- * SOLR-11754: Remove AbstractSolrTestCase which has long been supplanted by SolrTestCaseJ4. (David Smiley)
- * SOLR-11701: Upgrade to Tika 1.17 when available (Tim Allison, Karthik Ramachandran via Erick Erickson)
- * SOLR-11703: Solr Should Send Log Notifications if Ulimits are too low (Kevin Cowan via Erick Eickson)
- * SOLR-11793: Reduce code duplication w.r.t. RestTestHarness(es). (Christine Poerschke)
- * SOLR-7733: remove "optimize" from the UI. (Erick Erickson)
- * SOLR-11748: Remove Autoscaling action throttle. (shalin)
- * SOLR-11805: SolrJ's SolrResponse.getElaspedTime was sometimes a millisecond off. (David Smiley)
- * SOLR-11798: Formally deprecate top-level <highlighting> syntax in solrconfig.xml
- in favour of <searchComponent> equivalent syntax. (Christine Poerschke)
- * SOLR-11801: Support customisation of the "highlighting" query response element.
- (Ramsey Haddad, Pranav Murugappan, David Smiley, Christine Poerschke)
- * SOLR-11692: SolrDispatchFilter's use of a "close shield" in tests should not be applied to
- further servlet chain processing. (Jeff Miller, David Smiley)
- * SOLR-11218: Fail and return an error when attempting to delete a collection that's part of an alias (Erick Erickson)
- * SOLR-11817: Move Collections API classes to it's own package (Varun Thacker)
- * SOLR-11810: Upgrade Jetty to 9.4.8.v20171121 (Varun Thacker, Erick Erickson)
- * SOLR-11747: Pause triggers until actions finish executing and the cool down period expires. (shalin)
- * SOLR-11871: MoveReplicaSuggester should not suggest leader if other replicas are available (noble)
- * SOLR-11624: Collections created from _default configset will now be associated with a configset with a suffix
- .AUTOCREATED. For example, a new collection "mycollection", created without specifying a configset name, will
- use the _default configset and the associated configset name will be "mycollection.AUTOCREATED". If this
- collection is deleted and re-created, the autocreated configset will be left behind and will be re-used for
- the re-created collection (Ishan Chattopadhyaya, Abhishek Kumar Singh)
- * SOLR-11051: Use disk free metric in default cluster preferences (noble)
- * SOLR-11658: Upgrade ZooKeeper dependency to 3.4.11 (Jason Gerlowski, Steve Rowe, Erick Erickson)
- * SOLR-11480: Remove unused "Admin Extra" files and mentions. (Eric Pugh, Christine Poerschke)
- * SOLR-11067: REPLACENODE should identify appropriate nodes if targetNode is not provided (noble)
- * SOLR-11848: Update Ref Guide to include info on grouping operations and using curl for large files. (Dariusz Wojtas
- via Cassandra Targett)
- * SOLR-11613: Make message for missing dataimport config in UI more explicit. (Shawn Heisey, Amrit Sarkar via
- Cassandra Targett)
- * SOLR-11933: Make DIH UI page safer by not default checking the clean checkbox (Eric Pugh via Tomás Fernández Löbbe)
- * SOLR-11349: Rename ResponseBuilder's getQueryCommand to createQueryCommand. (Christine Poerschke)
- * SOLR-11902: Clarify in bin/solr help text whether commands can be run remotely (Jason Gerlowski)
- * SOLR-3089: RequestBuilder now exposes isDistrib() method. Using this, plugins can know whether a request is
- distributed. (Rok Rejc, Frank Wesemann, Abhishek Kumar Singh, Mikhail Khludnev via Ishan Chattopadhyaya)
- * SOLR-8090: Make text elements in the UI darker for better contrast and readability (Cassandra Targett)
- * SOLR-6057: Change highlight color in UI Analysis screen (Cassandra Targett)
- * SOLR-11897: Add toggle to disable auto-refresh of Logging page in the UI (Tommy Marshment-Howell via
- Cassandra Targett)
- * SOLR-12017: Remove BadApple and AwaitsFix annotations that link to closed JIRAs (Erick Erickson)
- * SOLR-12027: Increase thread lingering timeout to 80s. (Mikhail Khludnev)
- * SOLR-10809: Get precommit lint warnings out of Solr core (Erick Erickson)
- * SOLR-12028: BadApple and AwaitsFix annotations usage (Erick Erickson, Uwe Schindler)
- * SOLR-12031: Refactor Policy framework to make simulated changes affect more than a single node (noble)
- * SOLR-11957: Increase MaxFileSize=32MB and MaxBackupIndex=10 for RollingFileAppender in log4j.properties
- (Varun Thacker, shalin)
- * SOLR-12047: Increase checkStateInZk timeout (Cao Manh Dat, Varun Thacker)
- * SOLR-12051: Election timeout when no replicas are qualified to become leader (Cao Manh Dat)
- * SOLR-12067: Increase autoAddReplicas default 30 second wait time to 120 seconds.
- (Varun Thacker, Mark Miller via shalin)
- * SOLR-12078: Fixed reproducable Failure in TestReplicationHandler.doTestIndexFetchOnMasterRestart that happened
- due to using stale http connections. (Gus Heck, shalin)
- * SOLR-12099: Remove reopenReaders attribute from 'IndexConfig in SolrConfig' page in ref guide. (shalin)
- * SOLR-12098: Document the Lucene spins auto-detection and its effect on CMS dynamic defaults.
- (Cassandra Targett, shalin)
- * SOLR-12097: Document the diskType policy attribute and usage of disk space in Collection APIs.
- (Cassandra Targett, shalin)
- ================== 7.2.1 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.16
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.10
- Jetty 9.3.20.v20170531
- Bug Fixes
- ----------------------
- * SOLR-11771: Overseer can never process some last messages (Cao Manh Dat)
- * SOLR-11783: Rename core in solr standalone mode is not persisted (Erick Erickson)
- * SOLR-11809: QueryComponent.prepare rq parsing could fail under SOLR 7.2.0 - fix:
- QueryComponent's rq parameter parsing no longer considers the defType parameter.
- (Christine Poerschke and David Smiley in response to bug report/analysis
- from Dariusz Wojtas and Diego Ceccarelli)
- * SOLR-11555: If the query terms reduce to nothing, filter(clause) produces an NPE whereas
- fq=clause does not (Erick Erickson)
- ================== 7.2.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.16
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.10
- Jetty 9.3.20.v20170531
- Upgrade Notes
- ----------------------
- * SOLR-11501: Starting a query string with local-params {!myparser ...} is used to switch the query parser to another,
- and is intended for use by Solr system developers, not end users doing searches. To reduce negative side-effects of
- unintended hack-ability, we've limited the cases that local-params will be parsed to only contexts in which the
- default parser is "lucene" or "func".
- So if defType=edismax then q={!myparser ...} won't work. In that example, put the desired query parser into defType.
- Another example is if deftype=edismax then hl.q={!myparser ...} won't work for the same reason. In that example,
- either put the desired query parser into hl.qparser or set hl.qparser=lucene. Most users won't run into these cases
- but some will and must change.
- If you must have full backwards compatibility, use luceneMatchVersion=7.1.0 or something earlier. (David Smiley)
- * SOLR-11501: The edismax parser by default no longer allows subqueries that specify a Solr parser using either
- local-params, or the older _query_ magic field trick. For example
- {!prefix f=myfield v=enterp} or _query_:"{!prefix f=myfield v=enterp}" are not supported by default anymore.
- If you want to allow power-users to do this, set uf=* _query_ or some other value that includes _query_.
- If you must have full backwards compatibility, use luceneMatchVersion=7.1.0 or something earlier. (David Smiley)
- New Features
- ----------------------
- * SOLR-11448: Implement an option in collection commands to wait for final results. (ab)
- * SOLR-11072: Implement trigger for searchRate event type. (ab)
- * SOLR-11524: A new autoscaling/suggestions API end-point which gives autoscaling suggestions (noble)
- * SOLR-11519: Implement autoscaling suggestions for replica count violations (noble)
- * SOLR-11518: Implement autoscaling Suggestions for freedisk violations (noble)
- * SOLR-10132: A new optional facet.matches parameter to return facet buckets only
- for terms that match a regular expression. (Gus Heck, Christine Poerschke)
- * SOLR-11520: Implement autoscaling suggestions for cores count violations (noble)
- * SOLR-11438: Solr should return rf when min_rf is specified for deletes as well as adds (Erick Erickson)
- * SOLR-11003: Support bi-directional syncing of cdcr clusters. We still only support active indexing in one cluster,
- but have the ability to switch indexing clusters and cdcr will replicate correctly. (Amrit Sarkar, Varun Thacker)
- * SOLR-11538: Implement suggestions for port,ip_*, nodeRole,sysprop.*, metrics:* (noble)
- * SOLR-11487: Collection Aliases may now have metadata (currently an internal feature).
- (Gus Heck, David Smiley)
- * SOLR-11542: New TimeRoutedAliasUpdateProcessor URP that routes documents to another collection
- in the same Alias defined set based on a time field (currently an internal feature).
- (David Smiley)
- * SOLR-9743: A new UTILIZENODE command (noble)
- * SOLR-11202: Implement a set-property command for AutoScaling API. (ab, shalin)
- * SOLR-11250: A new DefaultWrapperModel class for loading of large and/or externally stored
- LTRScoringModel definitions. (Yuki Yano, shalin, Christine Poerschke)
- * SOLR-11662: New synonymQueryStyle option to configure whether SynonymQuery, a DisjunctionMaxQuery, or BooleanQuery
- occurs over query terms that overlap their position. (Doug Turnbull, David Smiley)
- * SOLR-11429: Add loess Stream Evaluator to support local regression (Joel Bernstein)
- * SOLR-11568: Add matrix Stream Evaluator to support efficient matrix operations (Joel Bernstein)
- * SOLR-11566: Add transpose Stream Evaluator to support transposing of matrices (Joel Bernstein)
- * SOLR-11565: Add unit Stream Evaluator to support unitizing of vectors (Joel Bernstein)
- * SOLR-11567: Add triangularDistribution Stream Evaluator (Joel Bernstein)
- * SOLR-11593: Add support for covariance matrices to the cov Stream Evaluator (Joel Bernstein)
- * SOLR-10680: Add minMaxScale Stream Evaluator (Joel Bernstein)
- * SOLR-11599: Change normalize function to standardize and make it work with matrices (Joel Bernstein)
- * SOLR-11602: Add Markov Chain Stream Evaluator (Joel Bernstein)
- * SOLR-11607: Add grandSum, sumRows, sumColumns, scalarDivide, scalarMultiply, scalarAdd,
- scalarSubtract Stream Evaluators (Joel Bernstein)
- * SOLR-11571: Add diff Stream Evaluator to support time series differencing (Mathew Skaria, Joel Bernstein)
- * SOLR-11570: Add support for correlation matrices to the corr Stream Evaluator (Joel Bernstein)
- * SOLR-11569: Add support for distance matrices to the distance Stream Evaluator (Joel Bernstein)
- * SOLR-11674: Support ranges in the probability Stream Evaluator (Joel Bernstein)
- * SOLR-11680: Add normalizeSum Stream Evaluator (Joel Bernstein)
- * SOLR-11697: Add geometricDistribution Stream Evaluator (Joel Bernstein)
- * SOLR-11485: Add olsRegress, spline and derivative Stream Evaluators (Joel Bernstein)
- Bug Fixes
- ----------------------
- * SOLR-11423: Overseer queue needs a hard cap (maximum size) that clients respect (Scott Blum, Joshua Humphries, Noble Paul)
- * SOLR-11445: Overseer should not hang when process bad message. (Cao Manh Dat, shalin)
- * SOLR-11447: ZkStateWriter should process commands in atomic. (Cao Manh Dat, shalin)
- * SOLR-11491: Support retrieval of cluster properties in HttpClusterStateProvider. (ab)
- * SOLR-11146: Small fixes to the mapping functions in the Analytics Component (Houston Putman)
- * SOLR-11326: A bootstrap of a target cluster does not need to download the tlog files from the source cluster
- (Amrit Sarkar, Varun Thacker)
- * SOLR-10874: Fix AIOOBE caused by FloatPayloadValueSource calling PostingsEnum.nextPosition()
- more than the given term's frequency in overridden FloatDocValues.floatVal().
- (Michael Kosten, Erik Hatcher, Steve Rowe)
- * SOLR-11484: CloudSolrClient does not invalidate cache or retry for RouteException (noble, hossman)
- * SOLR-11532: Solr hits NPE when fl only contains DV fields and any of them is a spatial field. (Cao Manh Dat, David Smiley)
- * SOLR-11557: Fix SolrZkClient.checkInterrupted (Tomás Fernández Löbbe)
- * SOLR-11413: SolrGraphiteReporter fails to report metrics due to non-thread safe code. (Erik Persson, ab)
- * SOLR-9440: The ZkStateReader.removeCollectionStateWatcher method can cache a DocCollection reference and
- never update it causing stale state to be returned in ClusterState. (shalin)
- * SOLR-11560: Specifying the replicationFactor parameter while restoring a collection would lead to extra tlog
- and pull replicas being created (Peter Szantai-Kis, Varun Thacker)
- * SOLR-11586: Restored collection should use stateFormat=2 instead of 1. (Varun Thacker)
- * SOLR-11503: Collections created with legacyCloud=true cannot be opened if legacyCloud=false (Erick Erickson)
- * SOLR-11619: V2 requests that needed to be forwarded to other nodes would get an NPE. (David Smiley)
- * SOLR-11231: Guard against unset fields when performing language detection.
- (Chris Beer via Steve Rowe)
- * SOLR-11553: JSON Facet API: facet refinement could use UIF in phase one and DV uninversion in phase 2, resulting
- in too much memory use. (yonik)
- * SOLR-11645: When the java commandline had exact duplicate arguments, the
- admin UI dashboard would not display any commandline arguments.
- (Webster Homer via Shawn Heisey)
- * SOLR-11608: Correctly parse the new core-name in the V2 core rename API.
- (Jason Gerlowski via Anshum Gupta)
- * SOLR-11256: The queue size for ConcurrentUpdateSolrClient should default to 10 instead of throwing an
- IllegalArgumentException. (Jason Gerlowski, Anshum Gupta)
- * SOLR-11616: Snapshot the segments more robustly such that segments created during a backup does does not fail the
- operation (Varun Thacker)
- * SOLR-11687: SolrCore.getNewIndexDir falsely returns {dataDir}/index on any IOException reading index.properties
- (Nikolay Martynov, Erick Erickson)
- * SOLR-9137: bin/solr script ignored custom STOP_PORT on shutdown.
- (Joachim Kohlhammer, Steve Rowe, Christine Poerschke)
- * SOLR-11458: Improve error handling in MoveReplicaCmd to avoid potential loss of data. (ab)
- * SOLR-11590: Synchronize ZK connect/disconnect handling so that they are processed in linear order
- (noble, Varun Thacker)
- * SOLR-11664: JSON Facet API: range facets containing unique, hll, min, max aggregations over string fields
- produced incorrect results since 7.0 (Volodymyr Rudniev, yonik)
- * SOLR-11691: V2 requests for create-alias didn't work when the collections param was an array.
- (Jason Gerlowski, Gus Heck, David Smiley, noble)
- Optimizations
- ----------------------
- * SOLR-11285: Refactor autoscaling framework to avoid direct references to Zookeeper and Solr
- to make testing and large scale simulations easier. (ab)
- * SOLR-11443: Remove the usage of workqueue for Overseer. (Cao Manh Dat, Scott Blum)
- * SOLR-11320: Lock autoscaling triggers when changes they requested are being made. This helps to
- ensure that cluster is in a stable state before processing any new trigger events. (ab)
- * SOLR-11641: Change `frange` to default to `cost=100` so default behavior is to PostFilter if user specifies
- `cache=false` (hossman)
- * SOLR-11595: SolrIndexSearcher.localCollectionStatistics is now faster by leveraging an existing
- cached MultiFields. Noticeable when many fields are searched. (David Smiley)
- Other Changes
- ----------------------
- * SOLR-11478: Solr should remove itself from live_nodes in zk immediately on shutdown. (Cao Manh Dat)
- * SOLR-11145: Adds comprehensive unit tests for the Analytics Component v2 (Houston Putman)
- * SOLR-11389: For Solr(Shard|Cluster)Reporter instances the SolrMetricManager.registerReporter
- method is now called after the SolrCore or CoreContainer has been set for the instance.
- (Christine Poerschke)
- * SOLR-11464, SOLR-11493, SOLR-11511: Minor refactorings to DistributedUpdateProcessor. (Gus Heck, David Smiley)
- * SOLR-11444: Improved consistency of collection alias handling, and collection references that are
- comma delimited lists of collections, across the various places collections can be referred to.
- Updates are delivered to the first in a list. It's now possible to refer to a comma delimited list
- of them in the path, ex: /solr/colA,colB/select?... (David Smiley)
- * SOLR-11165: Ref guide documentation for Autoscaling APIs, triggers, listeners, actions for Solr 7.1
- (ab, Cassandra Targett, Noble Paul, shalin)
- * SOLR-11562: Restore Solr logo ASCII-art in startup log by removing unnecessary default confdir logging (janhoy)
- * SOLR-11380: SolrJ must stream docs to server instead of writing to a buffer first (noble)
- * SOLR-11603: Remove unused (public) LTRScoringModel.hasParams() method. (Christine Poerschke)
- * SOLR-11606: Disable tests automatically if Mockito does not work with Java runtime (Java 10).
- (Uwe Schindler)
- * SOLR-11618: Tone down verbosity of BackupManager logging (Varun Thacker)
- * SOLR-11621: Fix spurious failures of TriggerIntegrationTest due to timing issues. (shalin)
- * SOLR-11628: Add documentation of maxRamMB for filter cache and query result cache. (shalin)
- * SOLR-11610: Refactored payload handling to use lucene's PayloadDecoder
- framework (Alan Woodward)
- * SOLR-9120: Reduce log level for inconsequential NoSuchFileException that LukeRequestHandler may encounter (hossman)
- * SOLR-10469: Move CloudSolrClient.setParallelUpdates to its Builder. (David Smiley)
- * SOLR-11507: SOLR-11638: Randomize SolrTestCaseJ4.CloudSolrClientBuilder more, and simplify it.
- (Jason Gerlowski, David Smiley)
- * SOLR-11291: Factor out abstract metrics/SolrCore[Container]Reporter classes.
- (Omar Abdelnabi, Christine Poerschke)
- * SOLR-11713: Fixed CdcrUpdateLogTest.testSubReader() failure which was a test bug (Varun Thacker, Amrit Sarkar)
- ================== 7.1.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.16
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.10
- Jetty 9.3.20.v20170531
- Detailed Change List
- ----------------------
- Upgrade Notes
- ----------------------
- * 'autoAddReplicas' feature is ported to autoscaling framework. Existing users of this feature should not have
- to change anything. Note these changes:
- 1. Behaviour: Changing the autoAddReplicas property from disabled to enabled using MODIFYCOLLECTION API
- no longer replaces down replicas for the collection immediately. Instead, replicas are only added
- if a node containing them went down while autoAddReplicas was enabled. The params
- autoReplicaFailoverBadNodeExpiration and autoReplicaFailoverWorkLoopDelay are no longer used.
- 2. Deprecations: Enabling/disabling autoAddReplicas cluster wide with the API will be deprecated; use
- suspend/resume trigger APIs with name='.auto_add_replicas' instead.
- * SOLR-11195: shard and cluster metric reporter configuration now requires a class attribute.
- If a reporter configures the group="shard" attribute then please also configure the
- class="org.apache.solr.metrics.reporters.solr.SolrShardReporter" attribute.
- If a reporter configures the group="cluster" attribute then please also configure the
- class="org.apache.solr.metrics.reporters.solr.SolrClusterReporter" attribute.
- * SOLR-11254: the abstract DocTransformer class now has an abstract score-less transform method variant.
- * SOLR-11283: all Stream Evaluators in solrj.io.eval have been refactored to have a simplier and more
- robust structure. This simplifies and condenses the code required to implement a new Evaluator and
- makes it much easier for evaluators to handle differing data types (primitives, objects, arrays,
- lists, and so forth). (Dennis Gove)
- * SOLR-10962: in the ReplicationHandler the master.commitReserveDuration sub-element is deprecated. Instead
- please configure a direct commitReserveDuration element for use in all modes (master, slave, cloud).
- * SOLR-11482: RunExecutableListener was removed for security reasons. If you want to listen to
- events caused by updates, commits, or optimize, write your own listener as native Java class
- as part of a Solr plugin.
- * SOLR-11477: in the XML query parser (defType=xmlparser or {!xmlparser ... })
- the resolving of external entities is now disallowed by default.
- New Features
- ----------------------
- * SOLR-10339: New set-trigger and remove-trigger APIs for autoscaling. (shalin)
- * SOLR-10340: New set-listener and remove-listener API for autoscaling. (shalin)
- * SOLR-10358: New suspend-trigger and resume-trigger APIs for autoscaling. (shalin)
- * SOLR-10376: Implement autoscaling trigger for nodeAdded event. (shalin)
- * SOLR-10396: Implement trigger support for nodeLost event type (Cao Manh Dat, shalin)
- * SOLR-10496: New ComputePlanAction for autoscaling which uses the policy framework to compute cluster
- operations upon a trigger fire. (Noble Paul, shalin)
- * SOLR-10965: New ExecutePlanAction for autoscaling which executes the operations computed by ComputePlanAction
- against the cluster. (shalin)
- * SOLR-11019: Add addAll Stream Evaluator (Joel Bernstein)
- * SOLR-10996: Implement TriggerListener API (ab, shalin)
- * SOLR-11046: Add residuals Stream Evaluator (Joel Bernstein)
- * SOLR-10858: Make UUIDUpdateProcessorFactory as Runtime URP (Amit Sarkar, noble)
- * SOLR-11031: Implement SystemLogListener for autoscaling (ab)
- * SOLR-11205: Any metrics value can be directly accessed in autoscaling policies (noble)
- * SOLR-11199: Payloads supports an "operator" param. Supported operators are 'or', "phrase" ( default ).
- A new "sum" function is also added. Example :
- {!payload_score f=payload_field func=sum operator=or}A B C" (Varun Thacker)
- * SOLR-11215: Make a metric accessible through a single param. (ab)
- * SOLR-11244: Query DSL for Solr (Cao Manh Dat)
- * SOLR-11317: JSON Facet API: min/max aggregations on numeric fields are now typed better so int/long
- fields return an appropriate integral type rather than a double. (yonik)
- * SOLR-11316: JSON Facet API: min/max aggregations are now supported on single-valued date fields.
- (yonik)
- * SOLR-10962: Make ReplicationHandler's commitReserveDuration configurable in SolrCloud mode.
- (Ramsey Haddad, Christine Poerschke, hossman)
- * SOLR-11382: Lucene's Geo3D (surface of sphere & ellipsoid) is now supported on spatial RPT fields by
- setting spatialContextFactory="Geo3D". Furthermore, this is the first time Solr has out of the box
- support for polygons. (David Smiley)
- * SOLR-11160: Add normalDistribution, uniformDistribution, sample and kolmogorovSmirnov Stream Evaluators
- (Joel Bernstein)
- * SOLR-11225: Add cumulativeProbability Stream Evaluator (Joel Bernstein)
- * SOLR-11241: Add discrete counting and probability Stream Evaluators (Joel Bernstein)
- * SOLR-11321: Add ebeAdd, ebeSubtract, ebeDivide, ebeMultiply, dotProduct and cosineSimilarity Stream Evaluators
- (Joel Bernstein)
- * SOLR-11338: Add Kendall's Tau-b rank and Spearmans rank correlation Stream Evaluators (Joel Bernstein)
- * SOLR-11339: Add Canberra, Chebyshev, Earth Movers and Manhattan Distance Stream Evaluators (Joel Bernstein)
- * SOLR-11342: Add sumDifference and meanDifference Stream Evaluators (Joel Bernstein)
- * SOLR-11350: Add primes Stream Evaluator (Joel Bernstein)
- * SOLR-11354: Add factorial and movingMedian Stream Evaluators (Joel Bernstein)
- * SOLR-11377: Add expMovingAverage (exponential moving average) and binomialCoefficient Stream Evaluators
- (Mathew Skaria, Joel Bernstein)
- * SOLR-11388: Add monteCarlo Stream Evaluator to support Monte Carlo simulations (Joel Bernstein)
- * SOLR-11398: Add weibullDistribution Stream Evaluator (Joel Bernstein)
- * SOLR-11400: Add logNormalDistribution Stream Evaluator (Joel Bernstein)
- * SOLR-11401: Add zipFDistribution Stream Evaluator (Joel Bernstein)
- * SOLR-11414: Add gammaDistribution Stream Evaluator (Joel Bernstein)
- * SOLR-11415: Add betaDistribution Stream Evaluator (Joel Bernstein)
- * SOLR-11436: Add polyfit and polyfitDerivative Stream Evaluators (Joel Bernstein)
- * SOLR-11439: Add harmonicFit Stream Evaluator (Joel Bernstein)
- * SOLR-11076: New /autoscaling/history API to return past cluster events and actions. (ab)
- Bug Fixes
- ----------------------
- * SOLR-10602: Triggers should be able to restore state from old instances when taking over. (shalin)
- * SOLR-10714: OverseerTriggerThread does not start triggers on overseer start until autoscaling
- config watcher is fired. (shalin)
- * SOLR-10738: TriggerAction is initialised even if the trigger is never scheduled. (shalin)
- * SOLR-10668: fix NPE at sort=childfield(..) .. on absent values (Mikhail Khludnev)
- * SOLR-8984: EnumField's error reporting to now indicate the field name in failure log (Lanny Ripple,
- Ann Addicks via Ishan Chattopadhyaya)
- * SOLR-11012: Fix three (JavaBinCodec not being closed) Resource Leak warnings. (Christine Poerschke)
- * SOLR-11026: MoveReplicaSuggester must check if the target becomes more 'loaded' than the source
- if an operation is performed (noble)
- * SOLR-10994: CREATE, CREATESHARD & ADDREPLICA to use policy framework & support replica types (noble)
- * SOLR-11011: Assign.buildCoreName can lead to error in creating a new core when legacyCloud=false (Cao Manh Dat)
- * SOLR-10944: Get expression fails to return EOF tuple (Susheel Kumar, Joel Bernstein)
- * SOLR-6086: Replica is active during autowarming resulting in queries being sent to a replica that
- may not have a registered searcher. This causes spikes in response times when adding a replica
- in busy clusters. (Ludovic Boutros, Timothy Potter, shalin)
- * SOLR-11190: GraphQuery also supports string fields which are indexed=false and docValues=true. Please refer to the
- Javadocs for DocValuesTermsQuery for it's performance characteristics. (Karthik Ramachandran, Varun Thacker)
- * SOLR-11084: Issue with starting script with solr.home (-s) == solr (Leil Ireson, Amrit Sarkar via Erick Erickson)
- * SOLR-11255: Fix occasional ConcurrentModificationException when using SolrInfoMBeanHandler. (ab)
- * SOLR-11272: fix NPE when EmbeddedSolrServer handles /admin/* request and so one (Stephen Allen via Mikhail Khludnev)
- * SOLR-11289: fix comma handling in terms component. (yonik)
- * SOLR-11164, SOLR-11180, SOLR-11220: Fix NullPointerException and always-returns-zero
- contrib/ltr OriginalScoreFeature issues in SolrCloud mode.
- (Yuki Yano, Jonathan Gonzalez, Ryan Yacyshyn, Christine Poerschke)
- * SOLR-11278: Stopping CDCR should cancel a running bootstrap operation. (Amrit Sarkar, shalin)
- * SOLR-11293: Potential data loss in TLOG replicas when masterVersion equals zero (noble, Cao Manh Dat)
- * SOLR-10101: TestLazyCores hangs (Erick Erickson)
- * SOLR-11332: Fix sorting on 'enum' fieldTypes that use sortMissingFirst or sortMissingLast (hossman)
- * SOLR-11348: Fix the DIH database example (James Dyer)
- * SOLR-11363: JSON Facet API: repeated values in a numeric points field with docValues enabled
- were double counted. (Hossman, yonik)
- * SOLR-11085: Improve resiliency of autoscaling actions against overseer restarts and operation failures. (shalin)
- * SOLR-11297: Message "Lock held by this virtual machine" during startup. Solr is trying to start some cores twice.
- (Luiz Armesto, Shawn Heisey, Erick Erickson)
- * SOLR-11399: The UnifiedHighlighter was ignoring the hl.fragsize parameter when hl.bs.type=SEPARATOR
- (Marc Morissette via David Smiley)
- * SOLR-11224: SolrStream.close can hit an NPE (Erick Erickson)
- * SOLR-11278: Fix a race condition in the CDCR bootstrap process which could lead to bootstraps cancelling itself
- (Amrit Sarkar, shalin, Varun Thacker)
- * SOLR-11425: SolrClientBuilder does not allow infinite timeout (value 0). (Peter Szantai-Kis via Mark Miller)
- * SOLR-11449: MoveReplicaCmd mistakenly called registerCollectionStateWatcher on failure. (ab)
- * SOLR-11477: Disallow resolving of external entities in the XML query parser (defType=xmlparser).
- (Michael Stepankin, Olga Barinova, Uwe Schindler, Christine Poerschke)
- * SOLR-12444: Updating a cluster policy fails (noble)
- Optimizations
- ----------------------
- * SOLR-10985: Remove unnecessary toString() calls in solr-core's search package's debug logging.
- (Michael Braun via Christine Poerschke)
- * SOLR-11000: Changes made via AutoScalingHandler should be atomic. (ab, shalin)
- * SOLR-11124: MoveReplicaCmd should skip deleting old replica in case of its node is not live (Cao Manh Dat)
- * SOLR-10769: Allow nodeAdded / nodeLost events to report multiple nodes in one event. (ab)
- * SOLR-11242: QueryParser: re-use the LookaheadSuccess exception. (Michael Braun via David Smiley)
- * SOLR-11314: FastCharStream: re-use the READ_PAST_EOF exception. (Michael Braun via David Smiley)
- * SOLR-8344: Decide default when requested fields are both column and row stored. (Cao Manh Dat, David Smiley)
- * SOLR-10285: Skip LEADER messages when there are leader only shards (Cao Manh Dat, Joshua Humphries)
- * SOLR-11424: When legacyCloud=false, cores should not publish itself as DOWN on startup. (Cao Manh Dat)
- Other Changes
- ----------------------
- * SOLR-10643: Throttling strategy for triggers and policy executions. (shalin)
- * SOLR-10764: AutoScalingHandler should validate policy and preferences before updating zookeeper. (shalin)
- * SOLR-10827: Factor out abstract FilteringSolrMetricReporter class. (Christine Poerschke)
- * SOLR-10957: Changed SolrCoreParser.init to use the resource loader from getSchema()
- instead of the resource loader from getCore(). (Christine Poerschke)
- * SOLR-10748: Make stream.body configurable and disabled by default (janhoy)
- * SOLR-10964: Reduce SolrIndexSearcher casting in LTRRescorer. (Christine Poerschke)
- * SOLR-11075: Refactor handling of params in CloudSolrStream and FacetStream (Erick Erickson)
- * SOLR-11052: Remove unnecessary Long-to-Integer and back casts in ReplicationHandler.
- (Ramsey Haddad via Christine Poerschke)
- * SOLR-11106: TestLBHttpSolrClient.testReliablity takes 30 seconds because of the wrong server name
- (Kensho Hirasawa via Erick Erickson)
- * SOLR-10338: Configure SecureRandom non blocking for tests. (Mihaly Toth, hossman, Ishan Chattopadhyaya, via Mark Miller)
- * SOLR-10916: Convert tests that extend LuceneTestCase and use MiniSolrCloudCluster
- to instead extend SolrCloudTestCase. (Steve Rowe)
- * SOLR-11131: Document 'assert' as a command option in bin/solr, and bin/solr.cmd scripts.
- (Jason Gerlowski via Anshum Gupta)
- * SOLR-11140: Remove unused parameter in (private) SolrMetricManager.prepareCloudPlugins method.
- (Omar Abdelnabi via Christine Poerschke)
- * SOLR-11187: contrib/ltr TestModelManagerPersistence improvements. (Yuki Yano via Christine Poerschke)
- * SOLR-10397: Port 'autoAddReplicas' feature to the autoscaling framework and make it work with non-shared filesystems
- (Cao Manh Dat, shalin)
- * SOLR-11157: remove-policy must fail if a policy to be deleted is used by a collection (noble)
- * SOLR-11090: Add Replica.getProperty accessor. (Christine Poerschke)
- * SOLR-11061: Add a spins metric for data directory paths. (ab)
- * SOLR-11071: Improve TestIntervalFacets.testRandom (Tomás Fernández Löbbe)
- * SOLR-11195: Require class attribute for shard and cluster metric reporter configuration. (Christine Poerschke)
- * SOLR:10822: Share a Policy.session object between multiple collection admin calls to get the correct computations (noble)
- * SOLR-11249: Upgrade Jetty from 9.3.14.v20161028 to 9.3.20.v20170531 (Michael Braun via David Smiley)
- * SOLR-11270: Automatically added SystemLogListener should not prevent deleting a trigger. (ab)
- * SOLR-5129: Timeout property for waiting ZK get started. (Cao Manh Dat, Hrishikesh Gadre, Varun Thacker)
- * SOLR-10628: Less verbose output from bin/solr commands. (Jason Gerlowski, janhoy)
- * SOLR-11240: Raise UnInvertedField internal limit. (Toke Eskildsen)
- * SOLR-11254: Add score-less (abstract) DocTransformer.transform method. (Christine Poerschke)
- * SOLR-11209: Upgrade HttpClient to 4.5.3. (Hrishikesh Gadre via Mark Miller)
- * SOLR-11322: JSON Facet API: instead of returning NaN, min & max aggregations omit
- the value for any bucket with no values in the numeric field. (yonik)
- * SOLR-10990: Breakup QueryComponent.process method for readability. (Christine Poerschke)
- * SOLR-11132: Refactor common getSortField logic in various FieldTypes (Jason Gerlowski, hossman)
- * SOLR-11351: Make LTRScoringModel model more extensible. (Christine Poerschke)
- * SOLR-10451: Remove contrib/ltr/lib from lib includes in the techproducts example config (sungjunyoung via janhoy)
- * SOLR-11306: Fix inaccurate comments on docValues and StrField in the example schemas
- (Tom Burton-West, Jason Gerlowski, Varun Thacker)
- * SOLR-11482: RunExecutableListener was removed for security reasons. (Michael Stepankin,
- Olga Barinova, Uwe Schindler, Tomás Fernández Löbbe)
- * SOLR-10335: Upgrade to Tika 1.16. (Tim Allison, Tomás Fernández Löbbe via shalin)
- ================== 7.0.1 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.10
- Jetty 9.3.14.v20161028
- Bug Fixes
- ----------------------
- * SOLR-11297: Message "Lock held by this virtual machine" during startup. Solr is trying to start some cores twice.
- (Luiz Armesto, Shawn Heisey, Erick Erickson)
- * SOLR-11406: Solr 7.0 cannot read indexes from 6.x versions. (Shawn Heisey, Steve Rowe)
- ================== 7.0.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.10
- Jetty 9.3.14.v20161028
- Upgrading from Solr 6.x
- ----------------------
- * All Trie* numeric and date field types have been deprecated in favor of *Point field types.
- Point field types are better at range queries (speed, memory, disk), however simple field:value queries underperform
- relative to Trie. Either accept this, or continue to use Trie fields.
- This shortcoming may be addressed in a future release.
- * The default response type is now JSON ("wt=json") instead of XML, and line indentation is now on by default
- ("indent=on"). If you expect the responses to your queries to be returned in the previous format (XML
- format, no indentation), you must now you must now explicitly pass in "wt=xml" and "indent=off" as query
- parameters, or configure them as defaults on your request handlers. See SOLR-10494 for more details.
- * the cluster property 'legacyCloud' is set to false from 7.0. This means 'zookeeper is the truth' by
- default. If an entry for a replica does not exist in the state.json, that replica cannot get
- registered. This may affect users who use that feature where they bring up replicas and they are
- automatically registered as a part of a shard. However, it is possible to fall back to the old behavior by
- setting the property legacyCloud=true , in the cluster properties using the following command
- ./server/scripts/cloud-scripts/zkcli.sh -zkhost 127.0.0.1:2181 -cmd clusterprop -name legacyCloud -val true
- * HttpClientInterceptorPlugin is now HttpClientBuilderPlugin and must work with a
- SolrHttpClientBuilder rather than an HttpClientConfigurer.
- * HttpClientUtil now allows configuring HttpClient instances via SolrHttpClientBuilder
- rather than an HttpClientConfigurer. Use of env variable SOLR_AUTHENTICATION_CLIENT_CONFIGURER
- no longer works, please use SOLR_AUTHENTICATION_CLIENT_BUILDER
- * SolrClient implementations now use their own internal configuration for socket timeouts,
- connect timeouts, and allowing redirects rather than what is set as the default when
- building the HttpClient instance. Use the appropriate setters on the SolrClient instance.
- * HttpSolrClient#setAllowCompression has been removed and compression must be enabled as
- a constructor param.
- * HttpSolrClient#setDefaultMaxConnectionsPerHost and
- HttpSolrClient#setMaxTotalConnections have been removed. These now default very
- high and can only be changed via param when creating an HttpClient instance.
- * Query time join with scoring {!join score=none} (even none) doesn't handle single value numeric fields.
- Users are advised to convert these fields into string and reindex.
- * Deprecated collection and configset methods on MiniSolrCloudCluster have been
- removed
- * Index-time boosts are not supported anymore. If any boosts are provided, they
- will be ignored by the indexing chain. As a replacement, index-time scoring
- factors should be indexed in a separate field and combined with the query
- score using a function query.
- * Deprecated method getNumericType() has been removed from FieldType. Use getNumberType() instead
- * MBean names and attributes now follow hierarchical names used in metrics. This is reflected also in
- /admin/mbeans and /admin/plugins output, and can be observed in the UI Plugins tab, because now all these
- APIs get their data from the metrics API. The old (mostly flat) JMX view has been removed.
- * <jmx> element in solrconfig.xml is no longer supported. Equivalent functionality can be configured in
- solr.xml using <metrics><reporter ...> element and SolrJmxReporter implementation. Limited back-compatibility
- is offered by automatically adding a default instance of SolrJmxReporter if it's missing, AND when a local
- MBean server is found (which can be activated either via ENABLE_REMOTE_JMX_OPTS in solr.in.sh or via system
- properties, eg. -Dcom.sun.management.jmxremote). This default instance exports all Solr metrics from all
- registries as hierarchical MBeans. This behavior can be also disabled by specifying a SolrJmxReporter
- configuration with a boolean init arg "enabled" set to "false". For a more fine-grained control users
- should explicitly specify at least one SolrJmxReporter configuration.
- * The sow (split-on-whitespace) request param now defaults to false (true in previous versions).
- This affects the edismax and standard/"lucene" query parsers: if the sow param is not specified,
- query text will not be split on whitespace before analysis. See
- https://lucidworks.com/2017/04/18/multi-word-synonyms-solr-adds-query-time-support/ .
- * Setting <solrQueryParser defaultOperator="..."/> in schema is no longer allowed and will cause an exception.
- Please use "q.op" parameter on the request instead. For more details, see SOLR-10584.
- * Setting <defaultSearchField> in schema is no longer allowed and will cause an exception.
- Please use "df" parameter on the request instead. For more details, see SOLR-10585.
- * The PostingsSolrHighlighter is deprecated. Furthermore, it now internally works via a re-configuration
- of the UnifiedSolrHighlighter.
- * Deprecated LatLonType, GeoHashField, SpatialPointVectorFieldType, and SpatialTermQueryPrefixTreeFieldType.
- Instead, switch to LatLonPointSpatialField or SpatialRecursivePrefixTreeFieldType or RptWithGeometrySpatialField.
- * The 'lucenePlusSort' QParser has been deprecated, and is no longer implicitly defined. If you wish to continue using
- this QParser untill Solr 8, you must explicitly register it in your solrconfig.xml:
- '<queryParser name="lucenePlusSort" class="solr.OldLuceneQParserPlugin"/>'
- * In solrconfig.xml the deprecated <mergePolicy> and <mergeFactor> and <maxMergeDocs> elements have
- been removed in favor of the <mergePolicyFactory> element introduced by SOLR-8621 in Solr 5.5.0.
- * Custom SolrMetricReporter classes must implement a new, factored out doInit() method and the validate() method
- must pass for all reporters including reporters that are not enabled, please see SOLR-10671 for details.
- * TemplateUpdateRequestProcessorFactory uses {} instead of ${} for template
- * SOLR-9565: The name of TemplateUpdateRequestProcessorFactory' is changed to 'template' from 'Template' and the
- name of 'AtomicUpdateProcessorFactory' is changed to 'atomic' from 'Atomic'
- * The default for eDismax parameter 'lowercaseOperators' now depends on the luceneMatchVersion setting in solrconfig.
- It remains 'true' for luceneMatchVersion < 7.0.0 and changes to 'false' from 7.0.0. See also SOLR-4646
- * The unused 'valType' option has been removed from ExternalFileField, if you have this in your schema you
- can safely remove it. see SOLR-10929 for more details.
- * Config sets basic_configs and data_driven_schema_configs have now been merged into _default. It has data driven nature
- enabled by default, and can be turned off (after creating a collection) with:
- curl http://host:8983/solr/mycollection/config -d '{"set-user-property": {"update.autoCreateFields":"false"}}'
- Please see SOLR-10574 for details.
- * The data driven config (now _default) for auto-creating fields earlier defaulted to "string" for text input.
- Now the default is to use "text_general" and to add a copyField to the schema, copying to a "*_str" dynamic field,
- with a cutoff at 256 characters. This enables full text search as well as faceting. See SOLR-9526 for more.
- * SOLR-10123: The Analytics Component has been upgraded to support distributed collections, expressions over multivalued
- fields, a new JSON request language, and more. DocValues are now required for any field used in the analytics expression
- whereas previously docValues was not required. Please see SOLR-10123 for details.
- * solrconfig.xml: <requestDispatcher handleSelect="..."> now defaults to false when luceneMatchVersion >= 7.0,
- thus ignoring "qt". Regardless, "qt" is still used as a SolrJ special parameter that specifies the request handler
- (tail URL path) to use. If you have request handlers without a leading '/', you can set handleSelect="true"
- or better yet consider migrating.
- * StandardRequestHandler is deprecated. Simply use SearchHandler instead.
- * The parameter names 'fromNode' for MOVEREPLICA and 'source', 'target' for REPLACENODE have been deprecated and
- replaced with 'sourceNode' and 'targetNode' instead. The old names will continue to work for back-compatibility
- but they will be removed in 8.0. See SOLR-11068 for more details.
- * All deperated methods of ClusterState (except getZkClusterStateVersion())
- have been removed. Use DocCollection methods instead.
- * SOLR-11023: EnumField has been deprecated in favor of new EnumFieldType.
- * SOLR-11239: The use of maxShardsPerNode is not supported when a cluster policy is in effect or
- when a collection specific policy is specified during collection creation.
- * V2 APIs are now available at /api, in addition to /v2 (which is now deprecated). Legacy APIs continue to remain
- available at /solr.
- * Solr was tested and is compatible with the final release candidate of Java 9. All startup scripts
- detect Java 9 correctly and setup Garbage Collector logging. If the configuration file contains
- logging options that are no longer supported with Java 9, startup will fail.
- * SOLR-10307: If starting Jetty without the Solr start script, you must now pass keystore and truststore
- passwords via the env variables SOLR_SSL_KEY_STORE_PASSWORD and SOLR_SSL_TRUST_STORE_PASSWORD rather
- than system properties.
- * SOLR-10379: ManagedSynonymFilterFactory has been deprecated in favor of ManagedSynonymGraphFilterFactory.
- * SOLR-10503: CurrencyField has been deprecated in favor of new CurrencyFieldType.
- New Features
- ----------------------
- * SOLR-9857, SOLR-9858: Collect aggregated metrics from nodes and shard leaders in overseer. (ab)
- * SOLR-9835: Create another replication mode for SolrCloud
- * SOLR-10356: Adds basic math Streaming Evaluators (Dennis Gove)
- * SOLR-10393: Adds UUID Streaming Evaluator (Dennis Gove)
- * SOLR-10046: Add UninvertDocValuesMergePolicyFactory class. (Keith Laban, Christine Poerschke)
- * SOLR-10547: JSON Facet API: Implement support for single-valued string fields for min/max aggregations.
- (yonik)
- * SOLR-10262: Add support for configurable metrics implementations. (ab)
- * SOLR-10431: Make it possible to invoke v2 api calls using SolrJ (Cao Manh Dat, Noble Paul, shalin)
- * SOLR-10233: Add support for different replica types, that can handle updates differently:
- - NRT: Writes updates to transaction log and indexes locally. Replicas of type “NRT” support NRT
- (soft commits) and RTG. Any NRT replica can become a leader. This was the only type supported
- in SolrCloud until now and it’s the default type.
- - TLOG: Writes to transaction log, but not to index, uses replication to copy segment files from the
- shard leader. Any TLOG replica can become leader (by first applying all local transaction log
- elements). If a replica is of type TLOG but is also the leader, it will behave as a NRT. This
- is exactly what was added in SOLR-9835 (non-realtime replicas), just the API and naming changes.
- - PULL: Doesn’t index or writes to transaction log, just replicates from the shard leader. PULL replicas
- can’t become shard leaders (i.e., if there are only PULL replicas in the collection at some point,
- updates will fail same as if there is no leaders, queries continue to work), so they don’t even
- participate in elections.
- (Tomás Fernández Löbbe)
- * SOLR-10278: A new DSL to set cluster-wide preferences and policies on how to allocate replicas to nodes
- (noble, shalin)
- * SOLR-10373: Implement read API for autoscaling configuration at /admin/autoscaling or
- /cluster/autoscaling paths. (shalin)
- * SOLR-10677: Expose a diagnostics API to return nodes sorted by load in descending order and
- any policy violations. (shalin)
- * SOLR-7452: Refinement for JSON Facet API: Adding refine:true to any terms facet will cause an
- additional distributed search phase (overlapped with field retrieval) that requests additional info
- for top facet buckets from shards that did not previously contribute to that bucket.
- This will correct counts (and other statistics) for those top buckets collected in the first
- phase. (yonik)
- * SOLR-10433: CollectionAdmin requests in SolrJ to support V2 calls (noble)
- * SOLR-9989: Add support for PointFields in FacetModule (JSON Facets) (Cao Manh Dat)
- * SOLR-10406: v2 API error messages list the URL request path as /solr/____v2/... when the original path was /v2/... (Cao Manh Dat, noble)
- * SOLR-10574: New _default config set replacing basic_configs and data_driven_schema_configs.
- (Ishan Chattopadhyaya, noble, shalin, hossman, David Smiley, janhoy, Alexandre Rafalovitch)
- * SOLR-10272: Use _default config set if no collection.configName is specified with CREATE (Ishan Chattopadhyaya)
- * SOLR-9526: Data driven schema now indexes text field "foo" as both "foo" (text_general) and as "foo_str" (string)
- to facilitate both search and faceting. AddSchemaFieldsUpdateProcessor now has the ability to add a "copyField" to
- the type mappings, with an optional maxChars limitation. You can also define one typeMappings as default.
- This also solves issues SOLR-8495, SOLR-6966, and SOLR-7058
- (janhoy, Steve Rowe, hossman, Alexandre Rafalovitch, Shawn Heisey, Cao Manh Dat)
- * SOLR-10123: Upgraded the Analytics Component to version 2.0 which now supports distributed collections, expressions over
- multivalued fields, a new JSON request language, and more. DocValues are now required for any field used in the analytics
- expression whereas previously docValues was not required. Please see SOLR-10123 for details. (Houston Putman)
- * SOLR-10282: bin/solr support for enabling Kerberos authentication (Ishan Chattopadhyaya, Jason Gerlowski)
- * SOLR-11093: Add support for PointFields for {!graph} query. (yonik)
- * SOLR-10845: Add support for PointFields to {!graphTerms} query that is internally
- used by some graph traversal streaming expressions. (yonik)
- * SOLR-10939: Add support for PointsFields to {!join} query. Joined fields should
- also have docValues enabled. (yonik)
- * SOLR-11173 TermsComponent support for Points fields. (yonik)
- * SOLR-10849: MoreLikeThisComponent should expose setMaxDocFreqPct (maxDoc
- frequency percentage). (Dawid Weiss)
- * SOLR-10307: Allow Passing SSL passwords through environment variables. (Mano Kovacs, Michael Suzuki via Mark Miller)
- * SOLR-10379: Add ManagedSynonymGraphFilterFactory, deprecate ManagedSynonymFilterFactory. (Steve Rowe)
- * SOLR-10479: Adds support for HttpShardHandlerFactory.loadBalancerRequests(MinimumAbsolute|MaximumFraction)
- configuration. (Ramsey Haddad, Daniel Collins, Christine Poerschke)
- * SOLR-3702: concat(...) function query (Andrey Kudryavtsev via Mikhail Khludnev)
- * SOLR-10767: Add movingAvg Stream Evaluator (Joel Bernstein)
- * SOLR-10813: Add arraySort Stream Evaluator (Joel Bernstein)
- * SOLR-10696: Add cumulative probability function (Joel Bernstein)
- * SOLR-10765: Add anova Stream Evaluator (Joel Bernstein)
- * SOLR-10754: Add hist Stream Evaluator (Joel Bernstein)
- * SOLR-10753: Add array Stream Evaluator (Joel Bernstein)
- * SOLR-10747: Allow /stream handler to execute Stream Evaluators directly (Joel Bernstein)
- * SOLR-10743: Add sequence StreamEvaluator (Joel Bernstein)
- * SOLR-10684: Add finddelay Stream Evaluator (Joel Bernstein)
- * SOLR-10731: Add knn Streaming Expression (Joel Bernstein)
- * SOLR-10724: Add describe Stream Evaluator (Joel Bernstein)
- * SOLR-10693: Add copyOfRange Stream Evaluator (Joel Bernstein)
- * SOLR-10623: Add sql Streaming Expression (Joel Bernstein)
- * SOLR-10661: Add copyOf Stream Evaluator (Joel Bernstein)
- * SOLR-10663: Add distance Stream Evaluator (Joel Bernstein)
- * SOLR-10664: Add scale Stream Evaluator (Joel Bernstein)
- * SOLR-10666: Add rank transformation Stream Evaluator (Joel Bernstein)
- * SOLR-10662: Add length Stream Evaluator (Joel Bernstein)
- * SOLR-10660: Add reverse Stream Evaluator (Joel Bernstein)
- * SOLR-9910: Add solr/solr.cmd parameter to append jetty parameters to the start script.
- (Mano Kovacs via Mark Miller)
- * SOLR-6671: Possible to set solr.data.home property as root dir for all data (janhoy, Shawn Heisey, Mark Miller)
- Bug Fixes
- ----------------------
- * SOLR-9262: Connection and read timeouts are being ignored by UpdateShardHandler after SOLR-4509.
- (Mark Miller, shalin)
- * SOLR-9837: Fix 55% performance regression of FieldCache uninvert time of
- numeric fields. (yonik)
- * SOLR-10408: v2 API introspect should return useful message for non-existent command (Cao Manh Dat)
- * SOLR-10411: v2 Collection API "modify" command specification's replicationFactor property is incorrectly typed as string,
- should be integer (Cao Manh Dat)
- * SOLR-10405: v2 API introspect response contains multiple copies of the experimental format WARNING (Cao Manh Dat)
- * SOLR-10412: v2 API: many API command specification properties are typed "number" but should instead be typed "integer"
- (Steve Rowe, Cao Manh Dat)
- * SOLR-10413: v2 API: parsed JSON type should be coerced to expected type (Cao Manh Dat, Noble Paul)
- * SOLR-10223: Allow running examples as root on Linux with -force option (janhoy)
- * SOLR-10830: Solr now correctly enforces that the '_root_' field has the same fieldType as the
- uniqueKey field. With out this enforcement, child document updating was unreliable. (hossman)
- * SOLR-10876: Regression in loading runtime UpdateRequestProcessors like TemplateUpdateProcessorFactory (noble)
- * SOLR-10886: Using V2Request.process(solrClient) method throws NPE if the API returns an error (Cao Manh Dat)
- * SOLR-10921: Work around the static Lucene BooleanQuery.maxClauseCount that causes Solr's maxBooleanClauses
- setting behavior to be "last core wins". This patch sets BooleanQuery.maxClauseCount to its maximum value,
- thus disabling the global check, and replaces it with specific checks where desired via
- QueryUtils.build(). (yonik)
- * SOLR-10948: Fix extraction component to treat DatePointField the same as TrieDateField (hossman)
- * SOLR-10506: Fix memory leak (upon collection reload or ZooKeeper session expiry) in ZkIndexSchemaReader.
- (Torsten Bøgh Köster, Christine Poerschke, Jörg Rathlev, Mike Drob)
- * SOLR-6807: CloudSolrClient's ZK state version check with the server was ignored when handleSelect=false
- (David Smiley)
- * SOLR-10878: MOVEREPLICA command may lose data when replicationFactor is 1. (ab, shalin)
- * SOLR-10879: DELETEREPLICA and DELETENODE commands should prevent data loss when
- replicationFactor is 1. (ab)
- * SOLR-10983: Fix DOWNNODE -> queue-work explosion (Scott Blum, Joshua Humphries)
- * SOLR-10826: Fix CloudSolrClient to expand the collection parameter correctly (Tim Owen via Varun Thacker)
- * SOLR-11039: Next button in Solr admin UI for collection list pagination does not work. (janhoy)
- * SOLR-11041: MoveReplicaCmd do not specify ulog dir in case of HDFS (Cao Manh Dat)
- * SOLR-11045: The new replica created by MoveReplica will have to have same name and coreName as the
- old one in case of HDFS (Cao Manh Dat)
- * SOLR-11043: Fix facet.range.method=dv and interval facets on single-valued float fields with negative values.
- (Tomás Fernández Löbbe, Steve Rowe)
- * SOLR-11073: Fix overflow in interval faceting when querying Long limits (e.g. (Long.MAX_VALUE TO Long.MAX_VALUE])
- (Tomás Fernández Löbbe)
- * SOLR-11057: Fix overflow in point range queries when querying the type limits
- (e.g. q=field_i:{Integer.MAX_VALUE TO Integer.MAX_VALUE]) (Tomás Fernández Löbbe)
- * SOLR-11136: Fix solrj XMLResponseParser when nested docs transformer is used with indented XML (hossman)
- * SOLR-11130: V2Request in SolrJ should return the correct collection name so that the request is forwarded to the
- correct node (noble)
- * SOLR-11151: SolrInfoMBeanHandler.getDiff() ADD case non-functional: NPE when a bean value goes from null -> non-null.
- (Steve Rowe)
- * SOLR-11154: Child documents' return fields now include useDocValuesAsStored fields (Mohammed Sheeri Shaketi Nauage via
- Ishan Chattopadhyaya)
- * SOLR-11163: Fix contrib/ltr Normalizer persistence after solr core reload or restart.
- (Yuki Yano via Christine Poerschke)
- * SOLR-11182: A split shard failure on IOException should be logged (Varun Thacker)
- * SOLR-10353: TestSQLHandler reproducible failure: No match found for function signature min(<NUMERIC>) (Kevin Risden)
- * SOLR-11221: SolrJmxReporter broken on core reload. This resulted in some or most metrics not being reported
- via JMX after core reloads, depending on timing. (ab)
- * SOLR-11235: Some SolrCore metrics should check if core is closed before reporting. (ab)
- * SOLR-10698: StreamHandler should allow connections to be closed early (Joel Bernstein, Varun Thacker, Erick Erickson)
- * SOLR-11243: Replica Placement rules are ignored if a cluster policy exists. (shalin)
- * SOLR-11268: AtomicUpdateProcessor complains missing UpdateLog (noble, Ishan Chattopadhyaya)
- * SOLR-8689: Fix bin/solr.cmd so it can run properly on Java 9 (Uwe Schindler, hossman)
- * SOLR-10723 JSON Facet API: resize() implemented incorrectly for CountSlotAcc, HllAgg.NumericAcc
- resulting in exceptions when using a hashing faceting method and sorting by hll(numeric_field).
- (yonik)
- * SOLR-10719: Creating a core.properties fails if the parent of core.properties is a symlinked dierctory
- (Erick Erickson)
- * SOLR-10360: Solr HDFS snapshot export fails due to FileNotFoundException error when using MR1 instead of
- yarn. (Hrishikesh via Mark Miller)
- * SOLR-10137: Ensure that ConfigSets created via API are mutable. (Hrishikesh via Mark Miller)
- * SOLR-10829: Fixed IndexSchema to enforce that uniqueKey can not be Points based for correctness (hossman)
- * SOLR-10836: The query parsers igain, significantTerms, and tlogit (used by streaming expressions by
- the same name) might throw a NullPointerException if the referenced field had no indexed data in some
- shards. The fix included an optimization to use Solr's cached AtomicReader instead of re-calculating.
- (David Smiley)
- * SOLR-10715: /v2/ should not be an alias for /v2/collections (Cao Manh Dat)
- * SOLR-10835: Add support for point fields in Export Handler (Tomás Fernández Löbbe)
- * SOLR-10704: REPLACENODE may cause data loss when replicationFactor is 1. (ab, shalin)
- * SOLR-10833: Point numeric fields should throw SolrException(BAD_REQUEST) for malformed numbers in queries.
- Trie numeric fields should throw SolrException(BAD_REQUEST) for malformed docValues range queries.
- (hossman, Tomás Fernández Löbbe)
- * SOLR-10832: Fixed VersionInfo.getMaxVersionFromIndex when using PointsField with indexed="true" (hossman)
- * SOLR-10763: Admin UI replication tab sometimes empty when failed replications (janhoy, Bojan Vitnik)
- * SOLR-10824: fix NPE ExactSharedStatsCache, fixing maxdocs skew for terms which are absent at one of shards
- when using one of Exact*StatsCache (Mikhail Khludnev)
- * SOLR-10963: Fix example json in MultipleAdditiveTreesModel javadocs.
- (Stefan Langenmaier via Christine Poerschke)
- * SOLR-10914: RecoveryStrategy's sendPrepRecoveryCmd can get stuck for 5 minutes if leader is unloaded. (shalin)
- * SOLR-11198: downconfig downloads empty file as folder (Erick Erickson)
- Optimizations
- ----------------------
- * SOLR-4509: Move to non deprecated HttpClient impl classes to remove stale connection
- check on every request and move connection lifecycle management towards the client.
- (Ryan Zezeski, Mark Miller, Shawn Heisey, Steve Davids)
- * SOLR-9255: Rename SOLR_AUTHENTICATION_CLIENT_CONFIGURER -> SOLR_AUTHENTICATION_CLIENT_BUILDER (janhoy)
- * SOLR-9579: Make Solr's SchemaField implement Lucene's IndexableFieldType, removing the
- creation of a Lucene FieldType every time a field is indexed. (John Call, yonik)
- * SOLR-9822: JSON Facet API: Recover performance lost due to the DocValues transition to
- an iterator API (LUCENE-7407). This only fixes calculating counts for single-valued
- string fields from the FieldCache, resulting in up to 56% better throughput for those cases.
- (yonik)
- * SOLR-10727: Avoid polluting the filter cache for certain types of faceting (typically ranges) when
- the base docset is empty. (David Smiley)
- * SOLR-11070: Make docValues range queries behave the same as Trie/Point fields for Double/Float Infinity cases
- (Tomás Fernández Löbbe, Andrey Kudryavtsev)
- * SOLR-10634: JSON Facet API: When a field/terms facet will retrieve all buckets (i.e. limit:-1)
- and there are no nested facets, aggregations are computed in the first collection phase
- so that the second phase which would normally involve calculating the domain for the bucket
- can be skipped entirely, leading to large performance improvements. (yonik)
- * SOLR-10722: Speed up Solr's use of the UnifiedHighlighter be re-using FieldInfos. (David Smiley)
- Other Changes
- ----------------------
- * SOLR-10236: Removed FieldType.getNumericType(). Use getNumberType() instead. (Tomás Fernández Löbbe)
- * SOLR-10347: Removed index level boost support from "documents" section of the admin UI (Amrit Sarkar via
- Tomás Fernández Löbbe)
- * SOLR-9959: SolrInfoMBean category and hierarchy cleanup. Per-component statistics are now obtained from
- the metrics API, legacy JMX support has been replaced with SolrJmxReporter functionality. Several reporter
- improvements (support for multiple prefix filters, "enabled" flag, reuse of service clients). (ab)
- * SOLR-10418: Expose safe system properties via metrics API as 'system.properties' in 'solr.jvm' group.
- Add support for selecting specific properties from any compound metric using 'property' parameter to
- /admin/metrics handler. (ab)
- * SOLR-10557: Make "compact" format default for /admin/metrics. (ab)
- * SOLR-10310: By default, stop splitting on whitespace prior to analysis
- in edismax and standard/"lucene" query parsers. (Steve Rowe)
- * SOLR-10647: Move the V1 <-> V2 API mapping to SolrJ (noble)
- * SOLR-10584: We'll now always throw an exception if defaultOperator is found in schema. This config has
- been deprecated since 3.6, and enforced for new configs since 6.6 (janhoy)
- * SOLR-10585: We'll now always throw an exception if defaultSearchField is found in schema. This config has
- been deprecated since 3.6, and enforced for new configs since 6.6 (janhoy, David Smiley)
- * SOLR-10414: RecoveryStrategy is now a Runnable instead of a Thread. (Tomás Fernández Löbbe)
- * SOLR-10042: Delete old deprecated Admin UI, leaving the AngularJS UI the only one supported (janhoy)
- * SOLR-10378: Clicking Solr logo on AdminUI shows blank page (Takumi Yoshida via janhoy)
- * SOLR-10700: Deprecated and converted the PostingsSolrHighlighter to extend UnifiedSolrHighlighter and thus no
- longer use the PostingsHighlighter. It should behave mostly the same. (David Smiley)
- * SOLR-10710: Fix LTR failing tests. (Diego Ceccarelli via Tomás Fernández Löbbe)
- * SOLR-10755: delete/refactor many solrj deprecations (hossman)
- * SOLR-10752: replicationFactor (nrtReplicas) default is 0 if tlogReplicas is specified when creating a collection
- (Tomás Fernández Löbbe)
- * SOLR-10757: delete/refactor/cleanup CollectionAdminRequest deprecations (hossman)
- * SOLR-10793: BlobHandler should have a well-known permission name (noble)
- * SOLR-10744: Update noggit to newer version (0.8) (noble)
- * SOLR-10792: Deprecate and remove implicit registration of "lucenePlusSort" aka OldLuceneQParser (hossman)
- * SOLR-10791: Remove deprecated options in SSLTestConfig (hossman)
- * LUCENE-7852: Correct copyright year(s) in solr/LICENSE.txt file.
- (Christine Poerschke, Steve Rowe)
- * SOLR-8668: In solrconfig.xml remove <mergePolicy> (and related <mergeFactor> and <maxMergeDocs>)
- support in favor of the <mergePolicyFactory> element introduced by SOLR-8621 in Solr 5.5.0.
- (Christine Poerschke, hossman)
- * SOLR-10799: Extracted functionality to collect eligible replicas from HttpShardHandler.prepDistributed()
- to a new method (Domenico Fabio Marino via Tomás Fernández Löbbe)
- * SOLR-10801: Remove several deprecated methods that were exposed to plugin writers (hossman)
- * SOLR-10671: Add abstract doInit method to the SolrMetricReporter base class.
- (Christine Poerschke, Anshum Gupta)
- * SOLR-10713: Ignore .pid and .out files in solr working directory (Jason Gerlowski via Mike Drob)
- * SOLR-10764: AutoScalingHandler should validate policy and preferences before updating zookeeper. (shalin)
- * SOLR-10782: Improve error handling and tests for Snitch and subclasses and general cleanups. (Noble Paul, shalin)
- * SOLR-10419: All collection APIs should use the new Policy framework for replica placement. (Noble Paul, shalin)
- * SOLR-10800: Factor out HttpShardHandler.transformReplicasToShardUrls from HttpShardHandler.prepDistributed.
- (Domenico Fabio Marino, Christine Poerschke)
- * SOLR-10779: JavaBinCodec should use close consistently rather than having marshal() and close() call finish()
- (which closes the underlying stream). (Erick Erickson)
- * SOLR-9623: Disable remote streaming in example configs by default. Adjust Upload Limit defaults (janhoy, yonik)
- * SOLR-4646: eDismax lowercaseOperators now defaults to "false" for luceneMatchVersion >= 7.0.0 (janhoy, David Smiley)
- * SOLR-8256: Set legacyCloud=false as default (Cao Manh Dat)
- * SOLR-10929: Removed unused 'valType' option from ExternalFileField (hossman)
- * SOLR-10864: Simplified how Trie vs Points based numerics are randomized by SolrTestCaseJ4 by adding a static
- option to PointsField to ignore 'precisionStep' attribute. This change also begins to attempt to randomize
- 'docValues' on numeric field types unless tests explicity enable/disable them. (hossman, Steve Rowe)
- * LUCENE-7883: Solr no longer uses the context class loader when resolving
- resources, they are only resolved against Solr's own or "core" class loader
- by default. (Uwe Schindler)
- * SOLR-10915: Make builder based SolrClient constructors to be the only valid way to construct client objects and
- increase the visibility of builder elements to be protected so extending the builder, and the clients is possible.
- (Jason Gerlowski, Anshum Gupta)
- * SOLR-10823: Add reporting period to SolrMetricReporter base class. (Christine Poerschke)
- * SOLR-10807: Randomize Points based numeric field types in all existing tests & test schemas
- where Trie numerics were previously hardcoded. (hossman, Steve Rowe, Anshum Gupta)
- * SOLR-6807: Changed requestDispatcher's handleSelect to default to false, thus ignoring "qt".
- Simplified configs to not refer to handleSelect or "qt". Switch all tests that assumed true to assume false
- (added leading '/' in request handlers). Switch all tests referring to "standard" request handler to
- instead refer to "/select" with SearchHandler. Deprecated the old StandardRequestHandler. (David Smiley)
- * SOLR-10456: Deprecate timeout related setters from SolrClients, and replace with Builder based implementation
- (Jason Gerlowski, Anshum Gupta)
- * SOLR-11004: Consolidate SolrClient builder code in an abstract base class (Jason Gerlowski, Anshum Gupta)
- * SOLR-10967: Cleanup the default configset. The changes involve some documentation corrections, removing the currency
- field from the examples and a few dynamic fields (Varun Thacker)
- * SOLR-11016: Fix TestCloudJSONFacetJoinDomain test-only bug (hossman)
- * SOLR-11021: The elevate.xml config-file is made optional in the ElevationComponent.
- The default configset doesn't ship with a elevate.xml file anymore (Varun Thacker)
- * SOLR-10898: Fix SOLR-10898 to not deterministicly fail 1/512 runs (hossman)
- * SOLR-10796: TestPointFields: increase randomized testing of non-trivial values. (Steve Rowe)
- * SOLR-11068: MOVEREPLICA and REPLACENODE API parameter names are now 'sourceNode' and 'targetNode'. The old names
- viz. 'fromNode' for MOVEREPLICA and 'source', 'target' for REPLACENODE have been deprecated. (shalin)
- * SOLR-11088: Fix sporadic failures of MetricsHandlerTest.testPropertyFilter on jenkins (shalin)
- * SOLR-11037: Refactor to provide NodeConfig.getSolrDataHome internal API. (ab, janhoy, shalin)
- * SOLR-11119: Switch from Trie to Points field types in the .system collection schema. (Steve Rowe)
- * SOLR-10494: Make default response format JSON (wt=json), and also indent text responses formats
- (indent=on) by default (Trey Grainger & Cassandra Targett via hossman)
- * SOLR-10760,SOLR-11315,SOLR-11313: Remove trie field types and fields from example schemas. (Steve Rowe)
- * SOLR-11056: Add random range query test that compares results across Trie*, *Point and DocValue-only fields
- (Tomás Fernández Löbbe)
- * SOLR-10926: Increase the odds of randomly choosing point fields in our SolrTestCaseJ4 numeric type randomization.
- (hossman, Steve Rowe)
- * SOLR-10846: ExternalFileField/FloatFieldSource should throw a clear exception on initialization with
- a Points-based keyField, which is not supported. (hossman, Steve Rowe)
- * SOLR-11155: /analysis/field and /analysis/document requests should support points fields.
- (Jason Gerlowski, Steve Rowe)
- * SOLR-10756: Undeprecate ZkStateReader.updateClusterState(), mark as @lucene.internal, and rename to
- forciblyRefreshAllClusterStateSlow(). (hossman, shalin, Steve Rowe)
- * SOLR-11036: Separately report disk space metrics for solr.data.home and core root directory. (ab)
- * SOLR-10919: ord & rord functions give confusing errors with PointFields. (hossman, Steve Rowe)
- * SOLR-10847: Provide a clear exception when attempting to use the terms component with points fields.
- (hossman, Steve Rowe)
- * SOLR-9321: Remove deprecated methods of ClusterState. (Jason Gerlowski, ishan, Cao Manh Dat)
- * SOLR-10033: When attempting to facet with facet.mincount=0 over points fields, raise mincount to 1
- and log a warning. (Steve Rowe)
- * SOLR-11178: Change error handling in AutoScalingHandler to be consistent w/ other APIs (noble)
- * SOLR-11023: Added EnumFieldType, a non-Trie-based version of EnumField, and deprecated EnumField
- in favor of EnumFieldType. (hossman, Steve Rowe)
- * SOLR-10803: Mark all Trie/LegacyNumeric based fields @deprecated in Solr7. (Steve Rowe)
- * SOLR-10821: Ref guide documentation for Autoscaling (Noble Paul, Cassandra Targett, shalin)
- * SOLR-11239: A special value of -1 can be specified for 'maxShardsPerNode' to denote that
- there is no limit. The bin/solr script send maxShardsPerNode=-1 when creating collections. The
- use of maxShardsPerNode is not supported when a cluster policy is in effect or when a
- collection specific policy is specified during collection creation.
- (Noble Paul, shalin)
- * SOLR-11183: V2 APIs are now available at /api endpoint. (Ishan Chattopadhyaya)
- * SOLR-10617: JDBCStream accepts columns of type TIME, DATE & TIMESTAMP as well as CLOBs and decimal
- numeric types (James Dyer)
- * SOLR-10400: Replace (instanceof TrieFooField || instanceof FooPointField) constructs with
- FieldType.getNumberType() or SchemaField.getSortField() where appropriate. (hossman, Steve Rowe)
- * SOLR-10438: Assign explicit useDocValuesAsStored values to all points field types in
- schema-point.xml/TestPointFields. (hossman, Steve Rowe)
- * LUCENE-7705: Allow CharTokenizer-derived tokenizers and KeywordTokenizer to configure the max token length.
- (Amrit Sarkar via Erick Erickson)
- * SOLR-10659: Remove ResponseBuilder.getSortSpec use in SearchGroupShardResponseProcessor.
- (Judith Silverman via Christine Poerschke)
- * SOLR-10741: Factor out createSliceShardsStr method from HttpShardHandler.prepDistributed.
- (Domenico Fabio Marino via Christine Poerschke)
- * SOLR-10790: Fix warnings in Assign.java and ReplicaAssigner.java classes.
- (Christine Poerschke)
- * SOLR-8437: Improve RAMDirectory details in sample solrconfig files (Mark Miller, Varun Thacker)
- * SOLR-8762: return child docs in DIH debug (Gopikannan Venugopalsamy via Mikhail Khludnev)
- * SOLR-10501: Test sortMissing{First,Last} with points fields. (Steve Rowe)
- * SOLR-10761: Switch trie numeric/date fields to points in data-driven-enabled example and test schemas.
- (Steve Rowe)
- * SOLR-10851: SolrClients should clarify expectations for solrServerUrl parameter (Jason Gerlowski
- via Tomás Fernández Löbbe)
- * SOLR-10891: BBoxField should support point-based number sub-fields. (Steve Rowe)
- * SOLR-10834: Fixed tests and test configs to stop using numeric uniqueKey fields (hossman)
- * SOLR-10883: Ref guide: Escape replacement substitutions, e.g. => to right arrow, so that they are
- rendered visibly in the PDF. Also add .adoc file checks to the top-level validate target, including
- for the invisible substitutions PDF problem. (Steve Rowe)
- * SOLR-10503,SOLR-10502: Deprecate CurrencyField in favor of new CurrencyFieldType, which works
- with point fields and provides control over dynamic fields used for the raw amount and currency
- code sub-fields. (hossman, Steve Rowe)
- * SOLR-11261, SOLR-10966: Upgrade to Hadoop 2.7.4 to fix incompatibility with Java 9.
- (Uwe Schindler)
- * SOLR-11324: Clean up mention of trie fields in documentation and source comments. (Steve Rowe)
- ================== 6.6.5 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.10
- Jetty 9.3.14.v20161028
- New Features
- ----------------------
- * SOLR-12530: Ability to disable configset upload via -Dconfigset.upload.enabled=false startup parameter
- (Ishan Chattopadhyaya)
- Bug Fixes
- ----------------------
- * SOLR-12450: Don't allow referal to external resources in various config files (CVE-2018-8026).
- (Yuyang Xiao, Uwe Schindler)
- ================== 6.6.4 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.17
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.11
- Jetty 9.4.10.v20180503
- Bug Fixes
- ----------------------
- * SOLR-12316: Do not allow to use absolute URIs for including other files in solrconfig.xml and schema parsing.
- (Ananthesh, Ishan Chattopadhyaya, Uwe Schindler)
- ================== 6.6.3 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.17
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.11
- Jetty 9.4.8.v20171121
- Bug Fixes
- ----------------------
- * SOLR-11971: Don't allow referal to external resources in DataImportHandler's dataConfig request parameter.
- (麦 香浓郁, Uwe Schindler)
- * SOLR-11503: Collections created with legacyCloud=true cannot be opened if legacyCloud=false (Erick Erickson)
- * SOLR-11993: LeaderInitiatedRecoveryThread does not retry on UnknownHostException (shalin, Cao Manh Dat, Steve Rowe)
- ================== 6.6.2 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.16
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.10
- Jetty 9.3.14.v20161028
- Upgrade Notes
- ----------------------
- * SOLR-11477: in the XML query parser (defType=xmlparser or {!xmlparser ... })
- the resolving of external entities is now disallowed by default.
- * SOLR-11482: RunExecutableListener was deprecated and is disabled by default for
- security reasons. Legacy applications still using it must explicitely pass
- '-Dsolr.enableRunExecutableListener=true' to the Solr command line.
- Be aware that you should really disable API-based config editing at the same
- time, using '-Ddisable.configEdit=true'! (Uwe Schindler)
- Bug Fixes
- ----------------------
- * SOLR-11477: Disallow resolving of external entities in the XML query parser (defType=xmlparser).
- (Michael Stepankin, Olga Barinova, Uwe Schindler, Christine Poerschke)
- * SOLR-11297: Message "Lock held by this virtual machine" during startup. Solr is trying to start some cores twice.
- (Luiz Armesto, Shawn Heisey, Erick Erickson)
- Other Changes
- ----------------------
- * SOLR-10335: Upgrade to Tika 1.16. (Tim Allison, Tomás Fernández Löbbe via shalin)
- ================== 6.6.1 ==================
- Bug Fixes
- ----------------------
- * SOLR-10857: standalone Solr loads UNLOADed core on request (Erick Erickson, Mikhail Khludnev)
- * SOLR-11024: ParallelStream should set the StreamContext when constructing SolrStreams (Joel Bernstein)
- * SOLR-10908: CloudSolrStream.toExpression incorrectly handles fq clauses (Rohit via Erick Erickson)
- * SOLR-11177: CoreContainer.load needs to send lazily loaded core descriptors to the proper list rather than send
- them all to the transient lists. (Erick Erickson)
- * SOLR-11122: Creating a core should write a core.properties file first and clean up on failure
- (Erick Erickson)
- * SOLR-10910: Clean up a few details left over from pluggable transient core and untangling
- CoreDescriptor/CoreContainer references (Erick Erickson)
- * SOLR-10721: Provide a way to know when Core Discovery is finished and when all async cores are done loading
- (Erick Erickson)
- * SOLR-11069: CDCR bootstrapping can get into an infinite loop when a core is reloaded (Amrit Sarkar, Erick Erickson)
- * SOLR-11221: SolrJmxReporter broken on core reload. This resulted in some or most metrics not being reported
- via JMX after core reloads, depending on timing. (ab)
- * SOLR-11261, SOLR-10966: Upgrade to Hadoop 2.7.4 to fix incompatibility with Java 9.
- (Uwe Schindler)
- * SOLR-11228: Exclude static html files in the partials directory from authentication and authorization checks. The UI
- will open correctly with kerberos enabled (Ishan Chattopadhyaya, Varun Thacker)
- ================== 6.6.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.10
- Jetty 9.3.14.v20161028
- Upgrade Notes
- ----------------------
- * Solr contribs map-reduce, morphlines-core and morphlines-cell have been removed.
- * JSON Facet API now uses hyper-log-log for numBuckets cardinality calculation and
- calculates cardinality before filtering buckets by any mincount greater than 1.
- * ZooKeeper dependency has been upgraded from 3.4.6 to 3.4.10.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-9992: Add support for grouping with PointFIelds. (Cao Manh Dat)
- * SOLR-9994: Add support for CollapseQParser with PointFields. (Varun Thacker, Cao Manh Dat)
- * SOLR-10076: Hide keystore and truststore passwords from /admin/info/* outputs. (Mano Kovacs via Mark Miller)
- * SOLR-6736: Adding support for uploading zipped configsets using ConfigSets API (Varun Rajput, Ishan Chattopadhyaya,
- Noble Paul, Anshum Gupta, Gregory Chanan)
- * SOLR-10349: Add totalTermFreq support to TermsComponent. (Shai Erera)
- * SOLR-9993: Add support for ExpandComponent with PointFields. (Cao Manh Dat)
- * SOLR-10239: MOVEREPLICA API (Cao Manh Dat, Noble Paul, shalin)
- * SOLR-9936: Allow configuration for recoveryExecutor thread pool size. (Tim Owen via Mark Miller)
- * SOLR-10447: Collections API now supports a LISTALIASES command to return a list of all collection aliases.
- (Yago Riveiro, Ishan Chattopadhyaya, Mark Miller, Steve Molloy, Shawn Heisey, Mike Drob, janhoy)
- * SOLR-10446: CloudSolrClient can now be initialized using the base URL of a Solr instance instead of
- ZooKeeper hosts. This is possible through the use of newly introduced HttpClusterStateProvider.
- To fetch a list of collection aliases, this depends on LISTALIASES command, and hence this way of
- initializing CloudSolrClient would not work if you have collection aliases on older versions of Solr
- server that doesn't support LISTALIASES. (Ishan Chattopadhyaya, Noble Paul)
- * SOLR-10082: Variance and Standard Deviation aggregators for the JSON Facet API.
- Example: json.facet={x:"stddev(field1)", y:"variance(field2)"}
- (Rustam Hashimov, yonik)
- * SOLR-10505: Add multi-field support to TermsComponent when requesting terms' statistics. (Shai Erera)
- * SOLR-10537: SolrJ: Added SolrParams.toLocalParamsString() and ClientUtils.encodeLocalParamVal. (David Smiley)
- * SOLR-10507: Core Admin status command to emit collection details of each core (noble)
- * SOLR-10521: introducing sort=childfield(field) asc for searching by {!parent} (Mikhail Khludnev)
- * SOLR-9596: Add Solr support for SimpleTextCodec, via <codecFactory class="solr.SimpleTextCodecFactory"/>
- in solrconfig.xml (per-field specification in the schema is not possible). (Steve Rowe)
- * SOLR-1485: Add payload support with payload() value source and {!payload_score} and {!payload_check}
- query parsers. (Erik Hatcher)
- * SOLR-10430: Add ls command to ZkCLI for listing only sub-directories. (Peter Szantai-Kis via Mark Miller)
- * SOLR-10583: JSON Faceting now supports a query time 'join' domain change option (hossman)
- * SOLR-9530: An Update Processor to convert normal update operation to an atomic operations such as
- add, set,inc, remove ,set, removeregex (Amrit Sarkar, noble)
- * SOLR-10303: Add date/time Stream Evaluators (Gethin James, Dennis Gove, Joel Bernstein)
- * SOLR-10351: Add analyze Stream Evaluator to support streaming NLP (Joel Bernstein)
- * SOLR-10426: Add shuffle Streaming Expression (Joel Bernstein)
- * SOLR-10274: The search Streaming Expression should work in non-SolrCloud mode (Joel Bernstein)
- * SOLR-10504: Add echo Streaming Expression (Joel Bernstein)
- * SOLR-10516: Add eval Streaming Expression (Joel Bernstein)
- * SOLR-10566: Add timeseries Streaming Expression (Joel Bernstein)
- * SOLR-10559: Add let, get and tuple Streaming Expressions (Dennis Gove, Joel Bernstein)
- * SOLR-10582: Add Correlation Stream Evaluator (Joel Bernstein)
- * SOLR-10536: stats Streaming Expression should work in non-SolrCloud mode (Joel Bernstein)
- * SOLR-10622: Add regress and predict Stream Evaluators (Joel Bernstein)
- * SOLR-10626: Add covariance Stream Evaluator (Joel Bernstein)
- * SOLR-10625: Add convolution Stream Evaluator (Joel Bernstein)
- * SOLR-10638: Add normalize Stream Evaluator (Joel Bernstein)
- * SOLR-8440: Support for enabling basic authentication using bin/solr|bin/solr.cmd. (Ishan Chattopadhyaya, janhoy,
- Noble Paul, Hrishikesh Gadre)
- * SOLR-10292: Adds CartesianProductStream which turns a single tuple with a multi-valued field into N
- tuples, one for each value in the multi-valued field. (Dennis Gove)
- Optimizations
- ----------------------
- * SOLR-9184: Add a static convenience method ModifiableSolrParams#of(SolrParams) which returns the same
- instance if it already is modifiable, otherwise creates a new ModifiableSolrParams instance.
- (Jörg Rathlev via Koji)
- * SOLR-10499: facet.heatmap is now significantly faster when the docset (base query) matches everything and there are no
- deleted docs. It's also faster when the docset matches a small fraction of the index or none. (David Smiley)
- * SOLR-9217: Reduced heap consumption for filter({!join ... score=...})
- (Andrey Kudryavtsev, Gopikannan Venugopalsamy via Mikhail Khludnev)
- * SOLR-10548: JSON Facet API now uses hyper-log-log++ for determining the number of buckets
- when merging requests from a multi-shard distributed request. (yonik)
- * SOLR-10524: Better ZkStateWriter batching (Cao Manh Dat, Noble Paul, shalin, Scott Blum)
- * SOLR-10619: Optimize using cache for DistributedQueue in case of single-consumer (Cao Manh Dat, Scott Blum)
- Bug Fixes
- ----------------------
- * SOLR-10281: ADMIN_PATHS is duplicated in two places and inconsistent. This can cause automatic
- retries to /admin/metrics handler by the CloudSolrClient. (shalin)
- * SOLR-10108: bin/solr script recursive copy broken (Erick Erickson)
- * SOLR-10362: "Memory Pool not found" error when reporting JVM metrics. (ab)
- * SOLR-10369: bin\solr.cmd delete and healthcheck now works again; fixed continuation chars ^ (Luis Goes via janhoy)
- * SOLR-10387: zkTransfer normalizes destination path incorrectly if source is a windows directory
- (gopikannan venugopalsamy, Erick Erickson)
- * SOLR-10323: fix to SpellingQueryConverter to properly strip out colons in field-specific queries.
- (Amrit Sarkar via James Dyer)
- * SOLR-10264: Fixes multi-term synonym parsing in ManagedSynonymFilterFactory.
- (Jörg Rathlev, Steve Rowe, Christine Poerschke)
- * SOLR-8807: fix Spellcheck "collateMaxCollectDocs" parameter to work with queries that have the
- CollpasingQParserPlugin applied. (James Dyer)
- * SOLR-10474: TestPointFields.testPointFieldReturn() depends on order of unsorted hits. (Steve Rowe)
- * SOLR-10473: Correct LBHttpSolrClient's confusing SolrServerException message when timeAllowed is exceeded.
- (Christine Poerschke)
- * SOLR-10047: Mismatched Docvalues segments cause exception in Sorting/Faceting. Solr now uninverts per segment
- to avoid such exceptions. (Keith Laban via shalin)
- * SOLR-10472: Fixed uninversion (aka: FieldCache) bugs with the numeric PointField classes, and CurrencyField (hossman)
- * SOLR-5127: Multiple highlight fields and wildcards are now supported e.g. hl.fl=title,text_*
- (Sven-S. Porst, Daniel Debray, Simon Endele, Christine Poerschke)
- * SOLR-10493: Investigate SolrCloudExampleTest failures. (Erick Erickson)
- * SOLR-10552: JSON Facet API numBuckets was not consistent between distributed and non-distributed requests
- when there was a mincount > 1. This has been corrected by changing numBuckets cardinality processing to
- ignore mincount > 1 for non-distributed requests. (yonik)
- * SOLR-10520: child.facet.field doubled counts at least when rows>0. (Dr. Oleg Savrasov via Mikhail Khludnev)
- * SOLR-10480: Full pagination in JSON Facet API using offset does not work. (yonik)
- * SOLR-10526: facet.heatmap didn't honor facet exclusions ('ex') for distributed search. (David Smiley)
- * SOLR-10500: nested child docs are adopted by neighbour when several parents come in update/json/docs
- (Alexey Suprun,noble via Mikhail Khludnev)
- * SOLR-10316: Unloading a core can remove a ZK SolrCore registration entry for the wrong SolrCore. (Mark Miller)
- * SOLR-10588: Prevent redundant core reload on config update (Mikhail Khludnev)
- * SOLR-10549: The new 'large' attribute had been forgotten in /schema/fieldtypes?showDefaults=true (David Smiley)
- * SOLR-10615: requests are suspended until SolrDispatchFilter initialization is completed.
- After core container shutdown or severe initialization problem Solr responds with
- http stauts 404 Not Found instead of 500 as it was before (Mikhail Khludnev)
- * SOLR-8149: Admin UI - Plugins / Stats - active item is now highlighted (Labuzov Dmitriy via janhoy)
- * SOLR-10630: HttpSolrCall.getAuthCtx().new AuthorizationContext() {...}.getParams()
- sometimes throws java.lang.NullPointerException (hu xiaodong via shalin)
- * SOLR-9527: Improve distribution of replicas when restoring a collection
- (Hrishikesh Gadre, Stephen Lewis, Rohit, Varun Thacker)
- * LUCENE-7821: The classic and flexible query parsers, as well as Solr's
- "lucene"/standard query parser, should require " TO " in range queries,
- and accept "TO" as endpoints in range queries. (hossman, Steve Rowe)
- * SOLR-10735: Windows script (solr.cmd) didn't work properly with directory containing spaces. Adding quotations
- to fix (Uwe Schindler, janhoy, Tomas Fernandez-Lobbe, Ishan Chattopadhyaya)
- Ref Guide
- ----------------------
- * SOLR-10758: Modernize the Solr ref guide's Chinese language analysis coverage. (Steve Rowe)
- Other Changes
- ----------------------
- * SOLR-9221: Remove Solr contribs: map-reduce, morphlines-core and morphlines-cell. (Steve Rowe)
- * SOLR-10249: Refactor IndexFetcher.doFetch() to return a more detailed result. (Jeff Miller via David Smiley)
- * SOLR-10304: Refactor Document handling out of SolrIndexSearcher into a new class "SolrDocumentFetcher".
- Deprecated SolrPluginUtils.docListToSolrDocumentList(). (David Smiley)
- * SOLR-10352: bin/solr script now prints warning when available system entropy is lower than 300 (Esther Quansah via
- Ishan Chattopadhyaya)
- * SOLR-10344: Update Solr default/example and test configs to use WordDelimiterGraphFilterFactory. (Steve Rowe)
- * SOLR-10343: Update Solr default/example and test configs to use SynonymGraphFilterFactory. (Steve Rowe)
- * SOLR-10365: Handle a SolrCoreInitializationException while publishing core state during SolrCore creation
- (Ishan Chattopadhyaya)
- * SOLR-10357: Enable edismax and standard query parsers to handle the option combination
- sow=false / autoGeneratePhraseQueries="true" by setting QueryBuilder.autoGenerateMultiTermSynonymsQuery.
- (Steve Rowe)
- * SOLR-10147: Admin UI -> Cloud -> Graph: Impossible to see shard state (Amrit Sarkar, janhoy)
- * SOLR-10399: Generalize some internal facet logic to simplify points/non-points field handling (Adrien Grand, hossman)
- * SOLR-7383: New DataImportHandler 'atom' example, replacing broken 'rss' example (Alexandre Rafalovitch)
- * SOLR-9601: Redone DataImportHandler 'tika' example, removing all unused and irrelevant definitions (Alexandre Rafalovitch)
- * SOLR-8906: Make transient core cache pluggable (Erick Erickson)
- * SOLR-9745: print errors from solr.cmd (Gopikannan Venugopalsamy via Mikhail Khludnev)
- * SOLR-10394: Rename getSortWithinGroup to getWithinGroupSort in search.grouping.Command class.
- (Judith Silverman, Christine Poerschke)
- * SOLR-10440: LBHttpSolrClient.doRequest is now always wrapped in a Mapped Diagnostic Context (MDC).
- (Christine Poerschke)
- * SOLR-10429: UpdateRequest#getRoutes()should copy the response parser (noble)
- * SOLR-10007: Clean up references to CoreContainer and CoreDescriptors (Erick Erickson)
- * SOLR-10151: Use monotonically incrementing counter for doc ids in TestRecovery. (Peter Szantai-Kis, Mano Kovacs via Mark Miller)
- * SOLR-10514: Upgrade Metrics library to 3.2.2. (ab)
- * SOLR-9386: Upgrade Zookeeper to 3.4.10. (Shawn Heisey, Steve Rowe)
- * SOLR-10519: SolrCLI.atPath cannot handle children that begin with a slash. (Erick Erickson)
- * SOLR-9867: Adding isLoading=true as core status. Fixing start after stop scenario in bin/solr
- (Andrey Kudryavtsev, Mikhail Khludnev)
- * SOLR-7041: Cutover tests to using 'q.op' and 'df' instead of schema 'defaultOperator' and 'defaultSearchField' (janhoy)
- * SOLR-10601: StreamExpressionParser should handle white space around = in named parameters (Joel Bernstein)
- * SOLR-10614: Static fields have turned to instance's field in SimplePostTool.
- Enabled TestSolrCLIRunExample.testTechproductsExample(). (Andrey Kudryavtsev, Mikhail Khludnev)
- * SOLR-10522: Revert SpellCheckComponent response format change from SOLR-9972 (rel. 6.5.0). While this
- was an improvement for the json "arrntv" format, it caused problems for the default json format.
- (James Dyer, reported by Nikita Pchelintsev)
- * SOLR-10644: solr.in.sh installed by install script should be writable by solr user (janhoy)
- * SOLR-10729: Deprecated LatLonType, GeoHashField, SpatialPointVectorFieldType, and SpatialTermQueryPrefixTreeFieldType.
- Instead, switch to LatLonPointSpatialField or SpatialRecursivePrefixTreeFieldType or RptWithGeometrySpatialField.
- (David Smiley)
- ================== 6.5.1 ==================
- Bug Fixes
- ----------------------
- * SOLR-10383: Fix debug related NullPointerException in solr/contrib/ltr OriginalScoreFeature class.
- (Vitezslav Zak, Christine Poerschke)
- * SOLR-10416: The JSON output of /admin/metrics is fixed to write the container as a
- map (SimpleOrderedMap) instead of an array (NamedList). (shalin)
- * SOLR-10277: On 'downnode', lots of wasteful mutations are done to ZK.
- (Joshua Humphries, Scott Blum, Varun Thacker, shalin)
- * SOLR-10421: Fix params persistence for solr/contrib/ltr (MinMax|Standard)Normalizer classes.
- (Jianxiong Dong, Christine Poerschke)
- * SOLR-10404: The fetch() streaming expression wouldn't work if a value included query syntax chars (like :+-).
- Fixed, and enhanced the generated query to not pollute the queryCache. (David Smiley)
- * SOLR-10423: Disable graph query production via schema configuration <fieldtype ... enableGraphQueries="false">.
- This fixes broken queries for ShingleFilter-containing query-time analyzers when request param sow=false.
- (Steve Rowe)
- * SOLR-10425: Fix indexed="false" on numeric PointFields (Tomás Fernández Löbbe, hossman)
- * SOLR-10341: SQL AVG function mis-interprets field type. (Joel Bernstein)
- * SOLR-10444: SQL interface does not use client cache. (Joel Bernstein)
- * SOLR-10420: Solr 6.x leaking one SolrZkClient instance per second (Scott Blum, Cao Manh Dat, Markus Jelsma, Steve Rowe)
- * SOLR-10439: The new 'large' attribute had been forgotten in /schema/fields?showDefaults=true (David Smiley)
- * SOLR-10527: edismax with sow=false fails to create dismax-per-term queries when any field is boosted.
- (Steve Rowe)
- ================== 6.5.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.3.14.v20161028
- Apache Calcite 1.11.0
- Detailed Change List
- ----------------------
- Upgrade Notes
- ----------------------
- * SOLR-10226: JMX metric "avgTimePerRequest" (and the corresponding metric in the metrics API for
- each handler) used to be a simple non-decaying average based on total cumulative time and the
- number of requests. New Codahale Metrics implementation applies exponential decay to this value,
- which heavily biases the average towards the last 5 minutes. (ab)
- * SOLR-8593: Parallel SQL now uses Apache Calcite as its SQL framework. As part of this change
- the default aggregation mode has been changed to facet rather than map_reduce. There has also been changes
- to the SQL aggregate response and some SQL syntax changes. Consult the documentation for full details.
- New Features
- ----------------------
- * SOLR-9836: Add ability to recover from leader when index corruption is detected on SolrCore creation.
- (Mike Drob via Mark Miller)
- * SOLR-9926: Allow passing arbitrary java system properties to zkcli. (Hrishikesh Gadre via Mark Miller)
- * SOLR-9885: Allow pre-startup Solr log management in Solr bin scripts to be disabled. (Mano Kovacs via Mark Miller)
- * SOLR-9481: Authentication and Authorization plugins now work in standalone mode if security.json is placed in
- SOLR_HOME on every node. Editing config through API is supported but affects only that one node. (janhoy)
- * SOLR-8029: Added new style APIs and a framework for creating new APIs and mapping old APIs to new
- (noble, Steve Rowe, Cassandra Targett, Timothy Potter)
- * SOLR-9933: SolrCoreParser now supports configuration of custom SpanQueryBuilder classes.
- (Daniel Collins, Christine Poerschke)
- * SOLR-7955: Auto create .system collection on first request if it does not exist (noble)
- * SOLR-10087: StreamHandler now supports registering custom streaming expressions from the blob store (Kevin Risden)
- * SOLR-9997: Enable configuring SolrHttpClientBuilder via java system property. (Hrishikesh Gadre via Mark Miller)
- * SOLR-9912: Add facet.excludeTerms parameter support. (Jonny Marks, David Smiley, Christine Poerschke)
- * SOLR-9916: Adds Stream Evaluators to support evaluating values from tuples. Supports boolean,
- numeric, and conditional evaluators. BooleanOperations have been removed in preference of
- BooleanEvaluators. (Dennis Gove)
- * SOLR-9903: Stop interrupting the update executor on shutdown, it can cause graceful shutdowns to put replicas into Leader
- Initiated Recovery among other undesirable things. (Mark Miller)
- * SOLR-8396: Add support for PointFields in Solr (Ishan Chattopadhyaya, Tomás Fernández Löbbe)
- * SOLR-9987: Add support for MultiValued DocValues in PointFields using SortedNumericDocValues (Tomás Fernández Löbbe)
- * SOLR-5944: In-place updates of Numeric DocValues. To leverage this, the _version_ field and the updated
- field must both be stored=false, indexed=false, docValues=true. (Ishan Chattopadhyaya, hossman, noble,
- shalin, yonik)
- * SOLR-10158: Add support for "preload" option in MMapDirectoryFactory.
- (Amrit Sarkar via Uwe Schindler)
- * SOLR-10153 & SOLR-10152: The Unified and Postings based highlighters: Add hl.bs.type=SEPARATOR along with new param
- hl.bs.separator to break passages by a provided single character. (Amrit Sarkar, David Smiley)
- * SOLR-10156: Add significantTerms Streaming Expression (Joel Bernstein)
- * SOLR-8593: Integrate Apache Calcite into the SQLHandler (Kevin Risden, Cao Manh Dat, Joel Bernstein)
- * SOLR-10146: Added button to the Admin UI 'Collection' tab for deleting an inactive shard (Amrit Sarkar, janhoy)
- * SOLR-9999: Instrument DirectUpdateHandler2. This registers existing statistics under metrics API and adds
- more metrics to track the rates of update and delete commands. (ab)
- * SOLR-9986: Implement DatePointField (Cao Manh Dat, Tomás Fernández Löbbe)
- * SOLR-8045: Deploy V2 API at /v2 instead of /solr/v2 (Cao Manh Dat, Noble Paul)
- * SOLR-10039: New LatLonPointSpatialField replacement for LatLonType (and some uses of RPT). Multi-value capable
- indexed geo lat-lon points, query by rect or circle. Efficient distance sorting/boosting too. (David Smiley)
- * SOLR-10250: CloudSolrClient can now return versions for documents added or deleted when "versions=true" is passed.
- However, if there is a leader election while this request is in transit, the versions may not be returned from that
- shard. (Boris Naguet, Ishan Chattopadhyaya)
- * SOLR-9045: Make RecoveryStrategy settings configurable. (Christine Poerschke)
- * SOLR-10224: Add disk total and disk free metrics. (ab)
- * SOLR-10085: SQL result set fields should be ordered by the field list (Joel Bernstein)
- * SOLR-10254: significantTerms Streaming Expression should work in non-SolrCloud mode (Joel Bernstein)
- * SOLR-10286: string/text fields may now declare themselves as large="true" in the schema. Large fields are always
- lazy loaded and will only take up space in the document cache if the actual value is < 512KB. This option
- requires "stored" and must not be multiValued. It's intended for fields that might have very large values so that
- they don't get cached in memory. (David Smiley)
- * SOLR-9185: Solr's edismax and "Lucene"/standard query parsers will no longer split on whitespace before sending
- terms to analysis, if given the "sow=false" request param ("sow"=>"split on whitespace"). This enables multi-term
- source synonyms to match at query-time using SynonymGraphFilterFactory; other analysis components will also now
- work at query time, e.g. ShingleFilterFactory. By default, and when the "sow=true" param is specified, these
- parsers' behavior remains the same: queries will be split on whitespace before sending individual terms to analysis.
- (Steve Rowe)
- Bug Fixes
- ----------------------
- * SOLR-9976: Fix init bug in SegmentsInfoRequestHandlerTest (hossman)
- * SOLR-9977: Fix config bug in DistribDocExpirationUpdateProcessorTest that allowed false assumptions
- about when index version changes (hossman)
- * SOLR-9979: Macro expansion should not be done in shard requests (Tomás Fernández Löbbe)
- * SOLR-9114: NPE using TermVectorComponent, MoreLikeThisComponent in combination with ExactStatsCache (Cao Manh Dat, Varun Thacker)
- * SOLR-10049: Collection deletion leaves behind the snapshot metadata (Hrishikesh Gadre via yonik)
- * SOLR-10120: A SolrCore reload can remove the index from the previous SolrCore during replication index rollover. (Mark Miller)
- * SOLR-10124: Replication can skip removing a temporary index directory in some cases when it should not. (Mark Miller)
- * SOLR-9996: Unstored IntPointField returns Long type (Ishan Chattopadhyaya)
- * SOLR-10104: BlockDirectoryCache release hooks do not work with multiple directories. (Mike Drob, Mark Miller)
- * SOLR-10121: Fix race conditions in HDFS BlockCache that can contribute to corruption in high
- concurrency situations. (yonik)
- * SOLR-10141: Upgrade to Caffeine 2.4.0 since v1.0.1 contributed to BlockCache corruption because the
- removal listener was called more than once for some items and not at all for other items. (Ben Manes, yonik)
- * SOLR-10114: Reordered delete-by-query causes inconsistenties between shards that have
- child documents (Mano Kovacs, Mihaly Toth, yonik)
- * SOLR-10159: When DBQ is reordered with an in-place update, upon whose updated value the DBQ is based
- on, the DBQ fails due to excessive caching in DeleteByQueryWrapper (Ishan Chattopadhyaya)
- * SOLR-10020: CoreAdminHandler silently swallows some errors. (Mike Drob via Erick Erickson)
- * SOLR-10063: CoreContainer shutdown has race condition that can cause a hang on shutdown. (Mark Miller)
- * SOLR-10170: ClassCastException in RecoveryStrategy. (Mark Miller)
- * SOLR-9846: Overseer is not always closed after being started. (Mark Miller)
- * SOLR-10168: ShardSplit can fail with NPE in OverseerCollectionMessageHandler#waitForCoreAdminAsyncCallToComplete. (Mark Miller)
- * SOLR-9824: Some bulk update paths could be very slow due to CUSC polling. (David Smiley, Mark Miller)
- * SOLR-10055: Linux installer now renames existing bin/solr.in.* as bin/solr.in.*.orig to make the installed config in
- /etc/defaults be the one found by default when launching solr manually. (janhoy)
- * SOLR-10196: ElectionContext#runLeaderProcess can hit NPE on core close. (Mark Miller)
- * SOLR-10225: Fix HDFS BlockCache evictions metric to not count explicit removal
- due to a directory close. (yonik)
- * SOLR-10088: Installer script does not put zoo.cfg in SOLR_HOME (janhoy)
- * SOLR-10226: add back "totalTime" metric to all handlers. See also the back-compat note. (ab)
- * SOLR-9838: "inc" atomic update doesn't respect default field value (hoss, Amrit Sarkar, Ishan Chattopadhyaya)
- * SOLR-10269: MetricsHandler JSON output incorrect. (ab)
- * SOLR-10279: The autoAddReplica feature can result in SolrCores being assigned new shards when using
- legacyCloud=false and will also fail on a state check when taking over a core registration with a new
- core. (Mark Miller, Hrishikesh Gadre, Patrick Dvorack)
- * SOLR-10184: Fix bin/solr so it can run properly on java9 (hossman, Uwe Schindler)
- * SOLR-9516: Admin UI (angular) now works with Kerberos, by excluding serving of /solr/libs/* through
- SolrDispatchFilter. (Cassandra Targett, Amrit Sarkar via Ishan Chattopadhyaya)
- * SOLR-10302: Solr's zkcli scripts now able to find the metrics libraries, which it couldn't earlier (kiran, Ishan Chattopadhyaya)
- * SOLR-10283: Learning to Rank (LTR) SolrFeature to reject searches with missing efi (External Feature Information) used by fq.
- (Christine Poerschke)
- * SOLR-10237: Poly-fields should work with subfields that have docValues=true (Tomás Fernández Löbbe, David Smiley)
- * SOLR-10218: The Schema API commands "add-field-type" and "replace-field-type" improperly specify SimilarityFactory params.
- (Benjamin Deininger, Troy Mohl, Steve Rowe)
- * SOLR-10319: SolrCore "instanceDir" metric not visible in JMX. (ab)
- Optimizations
- ----------------------
- * SOLR-9941: Clear the deletes lists at UpdateLog before replaying from log. This prevents redundantly pre-applying
- DBQs, during the log replay, to every update in the log as if the DBQs were out of order. (hossman, Ishan Chattopadhyaya)
- * SOLR-9764: All filters that match all documents in the index now share the same memory (DocSet).
- (Michael Sun, yonik)
- * SOLR-9584: Support Solr being proxied with another endpoint than default /solr, by using relative links
- in AdminUI javascripts (Yun Jie Zhou via janhoy)
- * SOLR-10143: PointFields will create IndexOrDocValuesQuery when a field is both, indexed=true and docValues=true
- (Tomás Fernández Löbbe)
- * SOLR-10273: The field with the longest value (if it exceeds 4K) is moved to be last in the Lucene Document in order
- to benefit from stored field optimizations in Lucene that can avoid reading it when it's not needed. If the field is
- multi-valued, they all move together to the end to retain order. (David Smiley)
- Other Changes
- ----------------------
- * SOLR-9980: Expose configVersion in core admin status (Jessica Cheng Mallet via Tomás Fernández Löbbe)
- * SOLR-9972: SpellCheckComponent collations and suggestions returned as a JSON object rather than a list
- (Christine Poerschke in response to bug report from Ricky Oktavianus Lazuardy)
- * SOLR-9983: Fixing NullPointerException failure by TestManagedSchemaThreadSafety
- adding check for Zookeeper session expiration (Steve Rowe, Mikhail Khludnev)
- * SOLR-10043: Reduce logging of pre-start log rotation (janhoy)
- * SOLR-10018: Increase the default hl.maxAnalyzedChars to 51200 for the Unified & Postings Highlighter so that all
- highlighters now have this same default. (David Smiley)
- * SOLR-6246: Added tests to check that the changes in LUCENE-7564 and LUCENE-7670
- enable AnalyzingInfixSuggester and BlendedInfixSuggester to play nicely with core reload.
- SolrSuggester.build() now throws SolrCoreState.CoreIsClosedException when interrupted
- by a core reload/shutdown. (Steve Rowe)
- * SOLR-9800: Factor out FacetComponent.newSimpleFacets method. (Jonny Marks via Christine Poerschke)
- * SOLR-9914: SimpleFacets: refactor "contains" check into "SubstringBytesRefFilter" class.
- (Jonny Marks, David Smiley, Christine Poerschke)
- * SOLR-10072: The test TestSelectiveWeightCreation appears to be unreliable. (Michael Nilsson via Mark Miller)
- * SOLR-10011: Refactor PointField & TrieField to now have a common base class, NumericFieldType. The
- TrieField.TrieTypes and PointField.PointTypes are now consolidated to NumericFieldType.NumberType. This
- refactoring also fixes a bug whereby PointFields were not using DocValues for range queries for
- indexed=false, docValues=true fields. (Ishan Chattopadhyaya, Tomás Fernández Löbbe)
- * SOLR-9890: factor out ShardResultTransformerUtils.[un]marshSortValue methods
- (Judith Silverman, Christine Poerschke)
- * SOLR-9966: Convert/migrate tests using EasyMock to Mockito (Cao Manh Dat, Uwe Schindler)
- * SOLR-10173: Make HttpShardHandlerFactory.getReplicaListTransformer more extensible.
- (Ramsey Haddad via Christine Poerschke)
- * SOLR-9842: UpdateRequestProcessors have no way to guarantee the closing of resources used for a request.
- (Mark Miller)
- * SOLR-9848: Lower solr.cloud.wait-for-updates-with-stale-state-pause back down from 7 seconds.
- (Mark Miller)
- * SOLR-10020: Cannot reload a core if it fails initialization. (Mike Drob via Erick Erickson)
- * SOLR-9450: The docs/ folder in the binary distribution now contains a single index.html file linking
- to the online documentation, reducing the size of the download (janhoy, Shawn Heisey, Uwe Schindler)
- * SOLR-7453: Remove replication & backup scripts in the solr/scripts directory of the checkout (Varun Thacker)
- * SOLR-10214: Remove unused HDFS BlockCache metrics and add storeFails, as well as adding total
- counts for lookups, hits, and evictions. (yonik)
- * SOLR-10134: EmbeddedSolrServer responds on Schema API requests (Robert Alexandersson via Mikhail Khludnev)
- * SOLR-10219: re-enable HDFS tests under JDK9 (hossman, Uwe Schindler)
- * SOLR-10155: For numeric types facet.contains= and facet.prefix= are now rejected.
- (Gus Heck, Christine Poerschke)
- * SOLR-10171: Add Constant Reduction Rules to Calcite Planner (Kevin Risden)
- * SOLR-10230: default TTL of PKIAuthenticationPlugin increased to 10secs (noble)
- * SOLR-10235: Fix DIH's TestJdbcDataSource to work with Java 9 and other Java runtimes that
- do not use the same DriverManager implementation like Oracle's original one. The test now
- uses a fully implemented Driver instance returning a mock connection. The test also works
- correct now if other drivers were installed before test execution (e.g., through IDE).
- (hossman, Uwe Schindler)
- * SOLR-8876: change morphline test config files to work around 'importCommands' bug when using java9 (hossman)
- * SOLR-10247: Support non-numeric metrics and a "compact" format of /admin/metrics output. (ab)
- * SOLR-9990: Add PointFields in example/default schemas (Tomás Fernández Löbbe)
- ================== 6.4.2 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.3.14.v20161028
- Detailed Change List
- ----------------------
- Bug Fixes
- ----------------------
- * SOLR-10130, SOLR-10182: Serious performance degradation in Solr 6.4.1 due to the new metrics collection.
- Default settings in solrconfig.xml /config/indexConfig/metrics have been changed to turn off
- IndexWriter metrics collection. Directory level metrics collection has been completely removed until
- a better design is found. (ab, ishan)
- * SOLR-10138: Transaction log replay can hit an NPE due to new Metrics code. (ab)
- * SOLR-10083: Fix instanceof check in ConstDoubleSource.equals (Pushkar Raste via Christine Poerschke)
- * SOLR-10190: Fix NPE in CloudSolrClient when reading stale alias (Janosch Woschitz via Tomás Fernández Löbbe)
- * SOLR-10192: Fix copy/paste in solr-ltr pom.xml template. (Christine Poerschke)
- ================== 6.4.1 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.3.14.v20161028
- Bug Fixes
- ----------------------
- * SOLR-9969: "Plugin/Stats" section of the UI doesn't display empty metric types (Tomás Fernández Löbbe)
- * SOLR-8491: solr.cmd SOLR_SSL_OPTS is overwritten (Sam Yi, Andy Hind, Marcel Berteler, Kevin Risden)
- * SOLR-10031: Validation of filename params in ReplicationHandler (Hrishikesh Gadre, janhoy)
- * SOLR-10054: Core swapping doesn't work with new metrics changes in place (ab)
- ================== 6.4.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.3.14.v20161028
- Detailed Change List
- ----------------------
- Upgrade Notes
- ----------------------
- * SOLR-9166: Export handler returns zero for numeric fields that are not in the original doc. One
- consequence of this change is that you must be aware that some tuples will not have values if
- there were none in the original document.
- * SOLR-8785: Metrics related classes in org.apache.solr.util.stats have been removed in favor of
- the dropwizard metrics library. Any custom plugins using these classes should be changed to use
- the equivalent classes from the metrics library.
- As part of this, the following changes were made to the output of Overseer Status API:
- * The "totalTime" metric has been removed because it is no longer supported
- * The metrics "75thPctlRequestTime", "95thPctlRequestTime", "99thPctlRequestTime"
- and "999thPctlRequestTime" in Overseer Status API have been renamed to "75thPcRequestTime", "95thPcRequestTime"
- and so on for consistency with stats output in other parts of Solr.
- * The metrics "avgRequestsPerMinute", "5minRateRequestsPerMinute" and "15minRateRequestsPerMinute" have been
- replaced by corresponding per-second rates viz. "avgRequestsPerSecond", "5minRateRequestsPerSecond"
- and "15minRateRequestsPerSecond" for consistency with stats output in other parts of Solr.
- * SOLR-9708: You are encouraged to try out the UnifiedHighlighter by setting hl.method=unified and report feedback. It
- might become the default in 7.0. It's more efficient/faster than the other highlighters, especially compared to the
- original Highlighter. That said, some options aren't supported yet.
- It will get more features in time, especially with your input. See HighlightParams.java
- for a listing of highlight parameters annotated with which highlighters use them.
- hl.useFastVectorHighlighter is now considered deprecated in lieu of hl.method=fastVector.
- * SOLR-9712: maxWarmingSearchers now defaults to 1, and more importantly commits will now block if this
- limit is exceeded instead of throwing an exception (a good thing). Consequently there is no longer a
- risk in overlapping commits. Nonetheless users should continue to avoid excessive committing. Users are
- advised to remove any pre-existing maxWarmingSearchers entries from their solrconfig.xml files.
- * SOLR-7466: complexphrase query parser now supports leading wildcards, beware of its' possible heaviness.
- Users are encouraged to use ReversedWildcardFilter in index time analysis.
- New Features
- ----------------------
- * SOLR-9918: Add SkipExistingDocumentsProcessor that skips duplicate inserts and ignores updates to missing docs
- (Tim Owen via koji)
- * SOLR-9293: Solrj client support for hierarchical clusters and other topics
- marker. (Dawid Weiss)
- * SOLR-9681: FacetModule / JSON Facet API added the ability to add filters directly to
- any facet command. The filters are applied after any domain change operations.
- Example: { type:terms, field:category, filter:"user:yonik" }
- (yonik)
- * SOLR-9442, SOLR-9787: Adds Array of Name Type Value (json.nl=arrntv) style to JSONResponseWriter.
- (Jonny Marks, Christine Poerschke, hossman)
- * SOLR-8542: Adds Solr Learning to Rank (LTR) plugin for reranking results with machine learning models.
- (Michael Nilsson, Diego Ceccarelli, Joshua Pantony, Jon Dorando, Naveen Santhapuri, Alessandro Benedetti, David Grohmann, Christine Poerschke)
- * SOLR-9055: Make collection backup/restore extensible. (Hrishikesh Gadre, Varun Thacker, Mark Miller)
- * SOLR-9682: JSON Facet API: added "param" query type to facet domain filter specification to obtain
- filters via query parameters. (yonik)
- * SOLR-9038: Add a command-line tool to manage the snapshots functionality (Hrishikesh Gadre via yonik)
- * SOLR-9633: Limit memory consumed by FastLRUCache with a new 'maxRamMB' config parameter.
- (yonik, Michael Sun, shalin)
- * SOLR-9666: SolrJ LukeResponse support dynamic fields (Fengtan via Kevin Risden)
- * SOLR-9077: Streaming expressions should support collection alias (Kevin Risden)
- * SOLR-9324: Support Secure Impersonation / Proxy User for solr authentication
- (Gregory Chanan, Hrishikesh Gadre via yonik)
- * SOLR-9721: javabin Tuple parser for streaming and other end points (noble)
- * SOLR-9708: Added UnifiedSolrHighlighter, a highlighter adapter for Lucene's UnifiedHighlighter. The adapter is a
- derivative of the PostingsSolrHighlighter, supporting mostly the same parameters with some differences.
- Introduced "hl.method" parameter which can be set to original|fastVector|postings|unified to pick the highlighter at
- runtime without the need to modify solrconfig from the default configuration. hl.useFastVectorHighlighter is now
- considered deprecated in lieu of hl.method=fastVector. (Timothy Rodriguez, David Smiley)
- * SOLR-9728: Ability to specify Key Store type in solr.in.sh file for SSL (Michael Suzuki, Kevin Risden)
- * SOLR-5043: New solr.dns.prevent.reverse.lookup system property that can be used to prevent long core
- (re)load delays on systems with missconfigured hostname/DNS (hossman)
- * SOLR-9844: FieldCache information fetched via the mbeans handler or seen via the UI now displays the total size used.
- The individual cache entries in the response are now formatted better as well. (Varun Thacker)
- * SOLR-9513: Generic authentication plugins (GenericHadoopAuthPlugin and ConfigurableInternodeAuthHadoopPlugin) that delegate
- all functionality to Hadoop authentication framework. (Hrishikesh Gadre via Ishan Chattopadhyaya)
- * SOLR-9860: Enable configuring invariantParams via HttpSolrClient.Builder (Hrishikesh Gadre, Ishan Chattopadhyaya)
- * SOLR-4735, SOLR-9921: Improve metrics reporting. This uses the dropwizard metric library, adding an internal
- API for registering and reporting metrics from Solr components. Several new metrics and an improved JMX
- reporter have been added (Alan Woodward, Jeff Wartes, Christine Poerschke, Kelvin Wong, shalin, ab)
- * SOLR-9788: Use instrumented jetty classes provided by the dropwizard metric library. (shalin)
- * SOLR-9805: Use metrics-jvm library to instrument jvm internals such as GC, memory usage and others. (shalin)
- * SOLR-9812, SOLR-9911, SOLR-9960: Added a new /admin/metrics API to return all metrics collected by Solr via API.
- API supports four optional multi-valued parameters:
- - 'group' (all,jvm,jetty,node,core),
- - 'type' (all,counter,timer,gauge,histogram),
- - 'prefix' that filters the returned metrics,
- - 'registry' that selects one or more registries by prefix (eg. solr.jvm,solr.core.collection1)
- - Example: http://localhost:8983/solr/admin/metrics?group=jvm,jetty&type=counter
- - Example: http://localhost:8983/solr/admin/metrics?group=jvm&prefix=buffers,os
- - Example: http://localhost:8983/solr/admin/metrics?registry=solr.node,solr.core&prefix=ADMIN
- (shalin, ab)
- * SOLR-9884: Add version to segments handler output (Steven Bower via Erick Erickson)
- * SOLR-9725: Substitute properties into JdbcDataSource configuration ( Jamie Jackson, Yuri Sashevsky via Mikhail Khludnev)
- * SOLR-9877: SOLR-9923: SOLR-9948: Use instrumented http client and connection pool in HttpShardHandler and
- UpdateShardHandler. The metrics are collected per query-less URL and method by default but it can be configured
- to host/method and per-method as well. (shalin)
- * SOLR-9880: Add Ganglia, Graphite and SLF4J metrics reporters. (ab)
- * SOLR-9897: Add hl.requireFieldMatch toggle support when using the UnifiedHighlighter. Defaults to false like the
- other highlighters that support this. (David Smiley)
- * SOLR-9905: Add NullStream to isolate the performance of the ExportWriter (Joel Bernstein)
- * SOLR-9891: Add mkroot command to bin/solr and bin/solr.cmd (Erick Erickson)
- * SOLR-9668,SOLR-7197: introduce cursorMark='true' in SolrEntityProcessor (Yegor Kozlov, Raveendra Yerraguntl via Mikhail Khludnev)
- * SOLR-9684: Add priority Streaming Expression (Joel Bernstein, David Smiley)
- * SOLR-9896: Instrument and collect metrics from query, update, core admin and core load thread pools. (shalin)
- * SOLR-9854: Collect metrics for index merges and index store IO (ab)
- * SOLR-8530: Add HavingStream to Streaming API and StreamingExpressions (Joel Bernstein)
- * SOLR-7466: Enable leading wildcard in complexphrase query parser, optimize it with ReversedWildcardFilterFactory
- when it's provided (Mikhail Khludnev)
- * SOLR-9935: Add hl.fragsize support when using the UnifiedHighlighter to avoid snippets/Passages that are too small.
- Defaults to 70. (David Smiley)
- * SOLR-9856: Collect metrics for shard replication and tlog replay on replicas (ab).
- * SOLR-9886: Add a 'enable' flag to caches to enable/disable them (Pushkar Raste, noble)
- * SOLR-9947: Clean up some SolrInfoMBean categories. Add an alternative hierarchical view in JMX
- for SolrInfoMBeans, which uses similar conventions to SolrJmxReporter. (ab)
- Optimizations
- ----------------------
- * SOLR-9704: Facet Module / JSON Facet API: Optimize blockChildren facets that have
- filters specified by using those filters as acceptDocs. (yonik)
- * SOLR-9726: Reduce number of lookupOrd calls made by the DocValuesFacets.getCounts method.
- (Jonny Marks via Christine Poerschke)
- * SOLR-9772: Deriving distributed sort values (fieldSortValues) should reuse
- comparator and only invalidate leafComparator. (John Call via yonik)
- * SOLR-9786: FieldType has a new getSetQuery() method that can take a set of terms
- and create a more efficient query (such as TermsQuery). The solr query parser has been
- changed to use this method when appropriate. The parser also knows when it is being
- used to parse a filter and will create TermsQueries from large lists of normal terms
- or numbers, resulting in a query that will execute faster. This also acts to avoid
- BooleanQuery maximum clause limit. Query parsing itself has also been optimized,
- resulting in less produced garbage and 5-7% better performance.
- (yonik)
- * SOLR-9902: StandardDirectoryFactory should use Files API for it's move implementation. (Mark Miller, Mike Drob)
- Bug Fixes
- ----------------------
- * SOLR-9701: NPE in export handler when "fl" parameter is omitted.
- (Erick Erickson)
- * SOLR-9433: SolrCore clean-up logic uses incorrect path to delete dataDir on failure to create a core.
- (Evan Sayer, shalin)
- * SOLR-9360: Solr script not properly checking SOLR_PID
- (Alessandro Benedetti via Erick Erickson)
- * SOLR-9716: RecoveryStrategy sends prep recovery command without setting read time out which can cause
- replica recovery to hang indefinitely on network partitions. (Cao Manh Dat, shalin)
- * SOLR-9624: In Admin UI, do not attempt to highlight CSV output (Alexandre Rafalovitch)
- * SOLR-9005: In files example, add a guard condition to javascript URP script (Alexandre Rafalovitch)
- * SOLR-9519: JSON Facet API: don't stop at an empty facet bucket if any sub-facets still have a chance
- of matching something due to filter exclusions (which can widen the domain again).
- (Michael Sun, yonik)
- * SOLR-9740: A bug in macro expansion of multi-valued parameters caused non-expanded values
- after the first expanded value in the same multi-valued parameter to be dropped.
- (Erik Hatcher, yonik)
- * SOLR-9751: PreAnalyzedField can cause managed schema corruption. (Steve Rowe)
- * SOLR-9736: Solr resolves the collection name against the first available leader or first replica
- of the first slice. This puts undue pressure on leader cores and likely on the wrong ones. This is
- fixed to randomly pick a leader on updates or a replica core otherwise. (Cao Manh Dat via shalin)
- * SOLR-9284: The HDFS BlockDirectoryCache should not let it's keysToRelease or names maps grow indefinitely.
- (Mark Miller, Michael Sun)
- * SOLR-9729: JDBCStream improvements (Kevin Risden)
- * SOLR-9626: new Admin UI now also highlights matched terms in the Analysis screen. (Alexandre Rafalovitch)
- * SOLR-9512: CloudSolrClient's cluster state cache can break direct updates to leaders (noble)
- * SOLR-5260: Facet search on a docvalue field in a multi shard collection (Trym Møller, Erick Erickson)
- * SOLR-9768: RecordingJsonParser produces incomplete json (Wojciech Stryszyk via ab)
- * SOLR-9616: Solr throws exception when expand=true on empty index (Timo Hund via Ishan Chattopadhyaya)
- * SOLR-9832: Schema modifications are not immediately visible on the coordinating node. (Steve Rowe)
- * SOLR-9834: A variety of spots in the code can create a collection zk node after the collection has been
- removed. (Mark Miller)
- * SOLR-9707: Don't forward DeleteByQuery requests to down replicas. (Jessica Cheng Mallet via Varun Thacker)
- * SOLR-9823: CoreContainer incorrectly setting MDCLoggingContext for core (Jessica Cheng Mallet via Erick Erickson)
- * SOLR-1953: It may be possible for temporary files to accumulate until the Solr process is shut down.
- (Karl Wright, Mark Miller)
- * SOLR-9847: Stop blocking further schema updates while waiting for a pending update to propagate to other replicas.
- This reduces the likelihood of a (time-limited) distributed deadlock during concurrent schema updates.
- (Mark Miller, Steve Rowe)
- * SOLR-9760: Windows script doesn't need write permission (Alex Crome by Mikhail Khludnev)
- * SOLR-9699,SOLR-4668: fix exception from core status in parallel with core reload (Mikhail Khludnev)
- * SOLR-9859: replication.properties cannot be updated after being written and neither replication.properties or
- index.properties are durable in the face of a crash. (Pushkar Raste, Chris de Kok, Cao Manh Dat, Mark Miller)
- * SOLR-9901: Implement move in HdfsDirectoryFactory. (Mark Miller)
- * SOLR-9900: fix false positives on range queries with ReversedWildcardFilterFactory (Yonik Seeley via Mikhail Khludnev)
- * SOLR-9495: AIOBE with confusing message for incomplete sort spec in Streaming Expression (Gus Heck, Joel Bernstein)
- * SOLR-9154: Fix DirectSolrSpellChecker to work when added through the Config API. (Anshum Gupta)
- * SOLR-9919: random Streaming Expression is not registered in /stream or /graph handler (Joel Bernstein)
- * SOLR-7495: Support Facet.field on a non-DocValued, single-value, int field (Varun Thacker, Scott Stults)
- * SOLR-9917: JSON Facet API percentile function caused a NullPointerException in distributed mode when
- there were no values in a bucket from a shard. (yonik)
- * SOLR-9931: JSON Facet API hll (hyper-log-log) function returned 0 for non-empty buckets with no field values
- in local mode, but nothing for distributed mode. Both modes now return 0. (yonik)
- * SOLR-9503: NPE in Replica Placement Rules when using Overseer Role with other rules (Tim Owen via noble)
- * SOLR-9883: Example schemaless solr config files can lead to invalid tlog replays: when updates are buffered,
- update processors ordered before DistributedUpdateProcessor, e.g. field normalization, are never run. (Steve Rowe)
- * SOLR-9644: SimpleMLTQParser and CloudMLTQParser did not handle field boosts properly
- and CloudMLTQParser included extra strings from the field definitions in the query.
- (Ere Maijala via Anshum Gupta)
- * SOLR-9954: Prevent against failure during failed snapshot cleanup from swallowing the actual cause
- for the snapshot to fail. (thelabdude)
- Other Changes
- ----------------------
- * SOLR-7539: Upgrade the clustering plugin to Carrot2 3.15.0. (Dawid Weiss)
- * SOLR-9621: Remove several Guava & Apache Commons calls in favor of java 8 alternatives.
- (Michael Braun via David Smiley)
- * SOLR-9720: Refactor Responsewriters to remove dependencies on TupleStream,
- Tuple, Explanation (noble)
- * SOLR-9717: Refactor '/export' to not hardcode the JSON output and to use an API (noble)
- * SOLR-9739: JavabinCodec implements PushWriter interface (noble)
- * SOLR-8332: Factor HttpShardHandler[Factory]'s url shuffling out into a ReplicaListTransformer class.
- (Christine Poerschke, Noble Paul)
- * SOLR-9597: Add setReadOnly(String ...) to ConnectionImpl (Kevin Risden)
- * SOLR-9609: Change hard-coded keysize from 512 to 1024 (Jeremy Martini via Erick Erickson)
- * SOLR-8785: Use Dropwizard Metrics library for core metrics. The copied over code in
- org.apache.solr.util.stats has been removed. (Jeff Wartes, Kelvin Wong, Christine Poerschke, shalin)
- * SOLR-9784: Refactor CloudSolrClient to eliminate direct dependency on ZK (noble)
- * SOLR-9801: Upgrade jetty to 9.3.14.v20161028 (shalin)
- * SOLR-9783: (Search|Top)Group[s]ShardResponseProcessor.process: turned sortWithinGroup null check into assert.
- (Christine Poerschke)
- * SOLR-9660: in GroupingSpecification factor [group](sort|offset|limit) into [group](sortSpec)
- (Judith Silverman, Christine Poerschke)
- * SOLR-9819: Upgrade commons-fileupload to 1.3.2, fixing a potential vulnerability CVE-2016-3092 (Anshum Gupta)
- * SOLR-9827: ConcurrentUpdateSolrClient creates a RemoteSolrException if the remote host responded with a non-ok
- response (instead of a SolrException) and includes the remote error message as part of the exception message
- (Tomás Fernández Löbbe)
- * SOLR-9846: OverseerAutoReplicaFailoverThread can take too long to stop and leak out of unit tests. (Mark Miller)
- * SOLR-8959: Refactored TestSegmentSorting out of TestMiniSolrCloudCluster (hossman)
- * SOLR-9874: Solr will reject CREATEALIAS requests if target collections don't exist (Tomás Fernández Löbbe)
- * SOLR-9878: fixing lazy logic for retrieving ReversedWildcardFilterFactory in SolrQueryParserBase (Mikhail Khludnev)
- * SOLR-9758: refactor preferLocalShards implementation (Christine Poerschke)
- * SOLR-9448: providing a test to workaround a differently named uniqueKey field (Mikhail Khludnev)
- * SOLR-9899: StandardDirectoryFactory should use optimizations for all FilterDirectorys not just NRTCachingDirectory.
- (Mark Miller)
- * SOLR-9915: PeerSync alreadyInSync check is not backwards compatible and results in full replication during a rolling restart
- (Tim Owen via noble)
- * SOLR-3990: Moves getIndexSize() from ReplicationHandler to SolrCore (Shawn Heisey)
- * SOLR-9944: Map the nodes function name to the GatherNodesStream (Joel Bernstein)
- * SOLR-9777: IndexFingerprinting should use getCombinedCoreAndDeletesKey() instead of getCoreCacheKey() for per-segment caching (Ishan Chattopadhyaya)
- * SOLR-9934: SolrTestCase.clearIndex has been improved to take advantage of low level test specific logic that
- clears the index metadata more completely then a normal *:* DBQ can due to update versioning. (hossman)
- * SOLR-9893: Update Mockito to version 2.6.2 for Java 9 support. Disable all legacy EasyMock tests when running
- on Java 9 until they were migrated to Mockito. (Uwe Schindler)
- ================== 6.3.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.12.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.3.8.v20160314
- Detailed Change List
- ----------------------
- Upgrade Notes
- ----------------------
- * If you use the JSON Facet API (json.facet) with method=stream, you must now set sort='index asc' to get the streaming
- behavior; otherwise it won't stream. Reminder: "method" is a hint that doesn't change defaults of other parameters.
- * If you use the JSON Facet API (json.facet) to facet on a numeric field and if you use mincount=0 or if you set the
- prefix, then you will now get an error as these options are incompatible with numeric faceting.
- * Solr's logging verbosity at the INFO level has been greatly reduced, and
- you may need to update the log configs to use the DEBUG level to see all the
- logging messages you used to see at INFO level before.
- * We are no longer backing up solr.log and solr_gc.log files in date-stamped copies forever. If you relied on
- the solr_log_<date> or solr_gc_log_<date> being in the logs folder that will no longer be the case.
- See SOLR-9570 for details.
- * The create/deleteCollection methods on MiniSolrCloudCluster have been
- deprecated. Clients should instead use the CollectionAdminRequest API. In
- addition, MiniSolrCloudCluster#uploadConfigDir(File, String) has been
- deprecated in favour of #uploadConfigSet(Path, String)
- * The bin/solr.in.sh (bin/solr.in.cmd on Windows) is now completely commented by default. Previously, this wasn't so,
- which had the effect of masking existing environment variables.
- New Features
- ----------------------
- * SOLR-5725: facet.method=enum can bypass exact counts calculation with facet.exists=true, it just returns 1 for
- terms which exists in result docset. (Alexey Kozhemiakin, Sebastian Koziel, Radoslaw Zielinski via Mikhail Khludnev)
- * SOLR-9127: Excel workbook (.xlsx) response writer. use 'wt=xlsx' (Tony Moriarty, noble)
- * SOLR-9469: JettySolrRunner now has the option of restarting using a different
- port (Alan Woodward)
- * SOLR-9319: DELETEREPLICA can accept a 'count' and remove appropriate replicas (Nitin Sharma, noble)
- * SOLR-8186: Reduce logging to logs/solr-<port>-console.log when not running in foreground mode
- Show timestamp also in foreground log. Also removes some logging noise. (janhoy)
- * SOLR-8487: Adds CommitStream to support sending commits to a collection being updated. (Dennis Gove)
- * SOLR-9534: You can now set Solr's log level through environment variable SOLR_LOG_LEVEL
- Also adds conveience arguments -q (quiet: WARN) and -v (verbose: DEBUG) to bin/solr (janhoy)
- * SOLR-9537: Support facet scoring with the scoreNodes expression (Joel Bernstein)
- * SOLR-9558: DIH TemplateTransformerto to support multivalued fields (Ted Sullivan via noble)
- * SOLR-9557: Every implicit requesthandler now has a default 'useParams' attribute (noble)
- * SOLR-9572: config API to show expanded useParams for request handlers inline (noble)
- * SOLR-9258: Optimizing, storing and deploying AI models with Streaming Expressions (Cao Manh Dat, Joel Bernstein)
- * SOLR-9205: Added method LukeResponse.getSchemaFlags() which returns field
- information as an EnumSet (Fengtan, Alan Woodward)
- * SOLR-9520: Kerberos delegation support in SolrJ (Ishan Chattopadhyaya, noble)
- * SOLR-9146: Parallel SQL engine should support >, >=, <, <=, <>, != syntax (Timothy Potter, Joel Bernstein, Kevin Risden)
- * SOLR-9337: Add fetch Streaming Expression (Joel Bernstein)
- * SOLR-9103: Restore ability for users to add custom Streaming Expressions (Cao Manh Dat)
- * SOLR-9657: New TemplateUpdateProcessorFactory added (noble)
- * SOLR-9417: Allow daemons to terminate when they finish iterating a topic (Joel Bernstein)
- * SOLR-8370: Display configured Similarity in Schema-Browser, both global/default and per-field/field-type
- (janhoy, Alexandre Rafalovitch)
- * SOLR-9326: Ability to create/delete/list snapshots at collection level.
- (Hrishikesh Gadre via yonik)
- * SOLR-9662: New parameter -u <user:pass> in bin/post to pass basicauth credentials (janhoy)
- * SOLR-9654: Add "overrequest" parameter to JSON Facet API to control amount of overrequest
- on a distributed terms facet. (yonik)
- * SOLR-2212: Add a factory class corresponding to Lucene's NoMergePolicy. (Lance Norskog, Cao Manh Dat via shalin)
- * SOLR-9670: Support SOLR_AUTHENTICATION_OPTS in solr.cmd (janhoy)
- * SOLR-9559: Add ExecutorStream to execute stored Streaming Expressions (Joel Bernstein)
- * SOLR-1085: Add support for MoreLikeThis queries and responses in SolrJ client.
- (Maurice Jumelet, Bill Mitchell, Cao Manh Dat via shalin)
- Bug Fixes
- ----------------------
- * SOLR-9310: PeerSync fails on a node restart due to IndexFingerPrint mismatch (Pushkar Raste, noble)
- * SOLR-9484: The modify collection API should wait for the modified properties to show up in the
- cluster state. (Cao Manh Dat, shalin)
- * SOLR-9507: CoreContainer threads now correctly set their MDC logging values
- (Alan Woodward)
- * SOLR-9522: Improve error handling in ZKPropertiesWriter (Varun Thacker)
- * SOLR-8080: bin/solr start script now exits with informative message if using wrong Java version (janhoy)
- * SOLR-9475: bin/install_solr_service.sh script got improved detection of Linux distro, especially within
- virtualized/Docker environment through parsing of /etc/*-release files. Now also supports CentOS. (janhoy)
- * SOLR-9524: SolrIndexSearcher.getIndexFingerprint uses dubious synchronization (Mike Drob, noble)
- * SOLR-9542: Kerberos delegation tokens requires Jackson library (Ishan Chattopadhyaya via noble)
- * SOLR-9330: Fix AlreadyClosedException on admin/mbeans?stats=true (Mikhail Khludnev)
- * SOLR-9411: Better validation for Schema API add-field and add-dynamic-field (janhoy, Steve Rowe)
- * SOLR-9504: A replica with an empty index becomes the leader even when other more qualified replicas
- are in line. (shalin)
- * SOLR-9554: Fix NullPointerException when cores are loaded in parallel and switch schema.xml to managed-scheme.
- (Alan Woodward, Mikhail Khludnev)
- * SOLR-9556: OverseerAutoFailoverReplicaThread was not exiting on interrupt
- (Alan Woodward)
- * SOLR-9563: Collection creation could fail if an ADDREPLICA subrequest arrived
- at a node before its local state had updated with the new collection data
- (Alan Woodward)
- * SOLR-9278: Index replication interactions with IndexWriter can cause deadlock. (Xunlong via Mark Miller)
- * SOLR-9604: Pooled SSL connections were not being re-used (Alan Woodward,
- Mikhail Khludnev, hossman)
- * SOLR-9325: solr.log is now written to $SOLR_LOGS_DIR without changing log4j.properties (janhoy)
- * SOLR-9518: Kerberos Delegation Tokens don't work without a chrooted ZK (Ishan Chattopadhyaya,via noble)
- * SOLR-9687: Fixed Interval Facet count issue in cases of open/close intervals on the same values
- (Andy Chillrud, Tomás Fernández Löbbe)
- * SOLR-9441: Solr collection backup on HDFS can only be manipulated by the Solr process owner.
- (Hrishikesh Gadre via Mark Miller)
- * SOLR-9536: OldBackupDirectory timestamp field needs to be initialized to avoid NPE.
- (Hrishikesh Gadre, hossman via Mark Miller)
- * SOLR-2039: Multivalued fields with dynamic names does not work properly with DIH.
- (K A, ruslan.shv, Cao Manh Dat via shalin)
- * SOLR-4164: group.limit=-1 was not supported for grouping in distributed mode.
- (Cao Manh Dat, Lance Norskog, Webster Homer, hossman, yonik)
- * SOLR-9692: blockUnknown property makes inter-node communication impossible (noble)
- * SOLR-2094: XPathEntityProcessor should reinitialize the XPathRecordReader instance if
- the 'forEach' or 'xpath' attributes are templates & it is not a root entity (Cao Manh Dat, noble)
- * SOLR-9697: zk upconfig broken on windows (Xavier Jmlucjav via janhoy)
- Optimizations
- ----------------------
- * SOLR-9374: Speed up Jmx MBean retrieval for FieldCache. (Tim Owen via shalin)
- * SOLR-9449: Example schemas do not index _version_ field anymore because the field
- has DocValues enabled already. (shalin)
- * SOLR-9447: Do not clone SolrInputDocument if update processor chain does not contain custom processors.
- (shalin)
- * SOLR-9452: JsonRecordReader should not deep copy document before handler.handle(). (noble, shalin)
- * SOLR-9142: JSON Facet API: new method=dvhash can be chosen for fields with high cardinality. (David Smiley)
- * SOLR-9446: Leader failure after creating a freshly replicated index can send nodes into recovery even if
- index was not changed (Pushkar Raste, noble)
- * SOLR-9592: retrieving docValues as stored values was sped up by using the proper leaf
- reader rather than ask for a global view. In extreme cases, this leads to a 100x speedup.
- (Takahiro Ishikawa, yonik)
- * SOLR-9566: Don't put replicas into recovery when first creating a Collection
- (Alan Woodward)
- * SOLR-9546: Eliminate unnecessary boxing/unboxing going on in SolrParams (Pushkar Raste, noble)
- * SOLR-9506: cache IndexFingerprint for each segment (Pushkar Raste, yonik, noble)
- * SOLR-7506: Roll over GC logs by default via bin/solr scripts (shalin, janhoy)
- Other Changes
- ----------------------
- * SOLR-9412: Add failOnMissingParams option to MacroExpander, add TestMacroExpander class.
- (Jon Dorando, Christine Poerschke)
- * SOLR-9406: SolrSuggester should selectively register close hook (Gethin James, Joel Bernstein)
- * SOLR-8961: Add a test module for solr-test-framework (Alan Woodward)
- * SOLR-9474: MiniSolrCloudCluster will not reuse ports by default when
- restarting its JettySolrRunners (Alan Woodward)
- * SOLR-9498: Remove HDFS properties from DIH solrconfig.xml, as started in SOLR-6943 (Alexandre Rafalovitch)
- * SOLR-9365: Reduce noise in solr logs during graceful shutdown. (Cao Manh Dat via shalin)
- * SOLR-9451: Make clusterstatus command logging less verbose. (Varun Thacker)
- * SOLR-9502: ResponseWriters should natively support MapSerializable (noble)
- * SOLR-9538: Relocate (BinaryResponse|JSON|Smile)Writer tests to org.apache.solr.response
- which is the package of the classes they test. (Jonny Marks via Christine Poerschke)
- * SOLR-9508: Install script install_solr_service.sh now checks existence of tools.
- New option -n to avoid starting service after installation (janhoy)
- * SOLR-7826: Refuse "bin/solr create" if run as root, unless -force is specified (janhoy, Binoy Dalal)
- * SOLR-6871: Updated the quickstart tutorial to cover the 6.2.0 release, and added ant target
- "generate-website-quickstart" to convert the bundled version of the tutorial into one suitable
- for the website.
- * SOLR-5563: Move lots of SolrCloud logging from 'info' to 'debug' (janhoy, Alan
- Woodward)
- * SOLR-9544: Allow ObjectReleaseTracker more time to check for asynchronously
- closing resources (Alan Woodward)
- * SOLR-6677: Reduced logging during startup and shutdown, moved more logs to DEBUG level
- (janhoy, Shawn Heisey, Alan Woodward)
- * SOLR-6090: Remove unreachable printLayout usage in cloud tests. (Cao Manh Dat via shalin)
- * SOLR-9551: Add JSONWriter constructor variant, JSONWriterTest.testConstantsUnchanged test.
- (Jonny Marks, Christine Poerschke)
- * SOLR-9500: Add a LogLevel annotation to set log levels on specific tests (Alan
- Woodward)
- * SOLR-9548: The beginning of solr.log now starts with a more informative welcome message (janhoy)
- * SOLR-9547: Do not allow bin/solr start as root user, unless -force param specified (janhoy)
- * SOLR-9567: Make ReRankQParserPlugin's private ReRankCollector a public class of its own. (Christine Poerschke)
- * SOLR-7436: Solr stops printing stacktraces in log and output (janhoy, hossman, Markus Jelsma)
- * SOLR-9576: Make FieldAnalysisRequestHandler, DocumentAnalysisRequestHandler & DumpRequestHandler
- implicit (noble)
- * SOLR-9574: Factor out AbstractReRankQuery from ReRankQParserPlugin's private ReRankQuery. (Christine Poerschke)
- * SOLR-5041: Add a test to make sure that a leader always recovers from log on startup. (Cao Manh Dat, shalin)
- * SOLR-9588: Remove Guava dependency from SolrJ (Ishan Chattopadhyaya, noble)
- * SOLR-8140: Remove mentions of unimplemented admin-extra from the new Admin UI (Alexandre Rafalovitch)
- * SOLR-9589: Remove jackson dependency from SolrJ (Ishan Chattopadhyaya, noble)
- * SOLR-8385: Narrow StreamFactory.withFunctionName clazz parameter to prevent misconfiguration (Jason Gerlowski, Kevin Risden)
- * SOLR-8969: SQLHandler causes NPE in non-cloud mode (Markus Jelsma, Kevin Risden)
- * SOLR-9610: New AssertTool in SolrCLI for easier cross platform assertions from command line (janhoy)
- * SOLR-9680: Better error messages in SolrCLI when authentication required (janhoy)
- * SOLR-9639: Test only fix. Prevent CDCR tests from removing collection during recovery that used to blow up jvm (Mikhail Khludnev)
- * SOLR-9625: Add HelloWorldSolrCloudTestCase class (Christine Poerschke, Alan Woodward, Alexandre Rafalovitch)
- * SOLR-9642: Refactor the core level snapshot cleanup mechanism to rely on Lucene (Hrishikesh Gadre via yonik)
- * SOLR-9627: Add QParser.getSortSpec, deprecate misleadingly named QParser.getSort (Judith Silverman, Christine Poerschke)
- * SOLR-9632: Add MiniSolrCloudCluster#deleteAllCollections() method (Alan Woodward)
- * SOLR-9634: Deprecate collection methods on MiniSolrCloudCluster (Alan Woodward)
- * SOLR-7850: Moved defaults within bin/solr.in.sh (and bin/solr.in.cmd on Windows) to bin/solr (and bin/solr.cmd)
- such that the default state of these files is to set nothing. This makes Solr work better with Docker. (David Smiley)
- * SOLR-9570: Various log tidying now happens at Solr startup:
- Old solr_log_<date> and solr_gc_log_<date> files are removed, avoiding disks to fill up,
- solr.log.X files are rotated, preserving solr.log from last run in solr.log.1, solr.log.1 => solr.log.2 etc
- solr-*-console.log files are moved into $SOLR_LOGS_DIR/archived/ instead of being overwritten
- Last JVM garbage collection log solr_gc.log is moved into $SOLR_LOGS_DIR/archived/
- (janhoy)
- * SOLR-4531: Add tests to ensure that recovery does not fail on corrupted tlogs.
- (Simon Scofield, Cao Manh Dat via shalin)
- * SOLR-5245: Add a test to ensure that election contexts are keyed off both collection name and coreNodeName
- so that killing a shard in one collection does not result in leader election in a different collection.
- See SOLR-5243 for the related bug. (Cao Manh Dat via shalin)
- * SOLR-9533: Reload core config when a core is reloaded (Gethin James, Joel Bernstein)
- * SOLR-9371: Fix bin/solr calculations for start/stop wait time and RMI_PORT.
- (Shawn Heisey via Erick Erickson)
- ================== 6.2.1 ==================
- Bug Fixes
- ----------------------
- * SOLR-9494: Use of {!collapse} sometimes doesn't correctly return true for Collector.needsScores(), especially when the
- query was cached. This can cause an exception when 'q' is a SpanQuery or potentially others. (David Smiley)
- * SOLR-6744: fl renaming / alias of uniqueKey field generates null pointer exception in SolrCloud configuration
- (Mike Drob via Tomás Fernández Löbbe)
- * SOLR-9445: Admin requests are retried by CloudSolrClient and LBHttpSolrClient on failure. (shalin)
- * SOLR-9439: Shard split clean up logic for older failed splits is faulty. The delete shard API
- has also been made more resilient against failures resulting from non-existent cores. (shalin)
- * SOLR-9430: Fix locale lookup in DIH <propertyWriter/> to use BCP47 language tags
- to be consistent with other places in Solr. Language names still work for backwards
- compatibility. (Uwe Schindler, Boris Steiner)
- * SOLR-9389: HDFS Transaction logs stay open for writes which leaks Xceivers. (Tim Owen via Mark Miller)
- * SOLR-9188: blockUnknown property makes inter-node communication impossible (noble)
- * SOLR-9455: Deleting a sub-shard in recovery state can mark parent shard as inactive. (shalin)
- * SOLR-9461: DELETENODE, REPLACENODE should pass down the 'async' param to subcommands (shalin, noble)
- * SOLR-9444: Fix path usage for cloud backup/restore. (Hrishikesh Gadre, Uwe Schindler, Varun Thacker)
- * SOLR-9381: Snitch for freedisk uses '/' instead of 'coreRootDirectory' (Tim Owen, noble)
- * SOLR-9488: Shard split can fail to write commit data on shutdown/restart causing replicas to recover
- without replicating the index. This can cause data loss. (shalin)
- * SOLR-9490: Fixed bugs in BoolField that caused it to erroneously return "false" for all docs depending
- on usage (Colvin Cowie, Dan Fox, hossman)
- * SOLR-9438: Shard split can be marked successful and sub-shard states switched to 'active' even when
- one or more sub-shards replicas do not recover due to the leader crashing or restarting between the time
- the replicas are created and before they can recover. This can cause data loss. (shalin)
- * SOLR-9408: Fix TreeMergeOutputFormat to add timestamp metadata to a commit. SolrCloud replication relies on this.
- (Jessica Cheng Mallet via Varun Thacker)
- Other Changes
- ----------------------
- * SOLR-7362: Fix TestReqParamsAPI test failures (noble, Varun Thacker)
- ================== 6.2.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.12.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.3.8.v20160314
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-9187: Support dates and booleans in /export handler, support boolean DocValues fields (Erick Erickson)
- * SOLR-8048: bin/solr script should support basic auth credentials provided in solr.in.sh (noble)
- * SOLR-7374: Core level Backup/Restore now supports specifying the directory implementation to use
- via the "repository" parameter. (Hrishikesh Gadre, Varun Thacker, Mark Miller)
- * SOLR-9216: Support collection.configName in MODIFYCOLLECTION request (Keith Laban, noble)
- * SOLR-9251: Support for a new tag 'role' in replica placement rules (noble)
- * SOLR-9194: Enhance the bin/solr script to perform file operations to/from Zookeeper (Erick Erickson, janhoy)
- * SOLR-9242: Collection Backup/Restore now supports specifying the directory implementation to use
- via the "repository" parameter. (Hrishikesh Gadre, Varun Thacker)
- * SOLR-9193: Add scoreNodes Streaming Expression (Joel Bernstein)
- * SOLR-9243: Add terms.list parameter to the TermsComponent to fetch the docFreq for a list of terms
- (Joel Bernstein)
- * SOLR-9090: Add directUpdatesToLeadersOnly flag to solrj CloudSolrClient.
- (Marvin Justice, Christine Poerschke)
- * SOLR-9270: Allow spatialContextFactory to be simply "JTS". And if any spatial params include the old
- Spatial4j package "com.spatial4j.core" it is rewritten to "org.locationtech.spatial4j" with a warning.
- (David Smiley)
- * SOLR-9240: Support parallel ETL with the topic expression (Joel Bernstein)
- * SOLR-9275: XML QueryParser support (defType=xmlparser) now extensible via configuration.
- (Christine Poerschke)
- * SOLR-9200: Add Delegation Token Support to Solr.
- (Gregory Chanan)
- * SOLR-9038: Solr core snapshots: The current commit can be snapshotted which retains the commit and associates it with
- a name. The core admin API can create snapshots, list them, and delete them. Snapshot names can be referenced in
- doing a core backup, and in replication. Snapshot metadata is stored in a new snapshot_metadata/ dir.
- (Hrishikesh Gadre via David Smiley)
- * SOLR-9279: New boolean comparison function queries comparing numeric arguments: gt, gte, lt, lte, eq
- (Doug Turnbull, David Smiley)
- * SOLR-9252: Feature selection and logistic regression on text (Cao Manh Dat, Joel Bernstein)
- * SOLR-6465: CDCR: fall back to whole-index replication when tlogs are insufficient.
- (Noble Paul, Renaud Delbru, shalin)
- * SOLR-9320: A REPLACENODE command to decommission an existing node with another new node
- (noble, Nitin Sharma, Varun Thacker)
- * SOLR-9318: A DELETENODE command to delete all replicas in that node (noble, Nitin Sharma, Varun Thacker)
- Bug Fixes
- ----------------------
- * SOLR-9191: OverseerTaskQueue.peekTopN() fatally flawed (Scott Blum, Noble Paul)
- * SOLR-9199: ZkController#publishAndWaitForDownStates logic is inefficient (Hrishikesh Gadre)
- * SOLR-9161: Change SolrPluginUtils.invokeSetters implementation to accommodate setter variants.
- (Christine Poerschke, Steve Rowe, Uwe Schindler)
- * SOLR-9234: srcField parameter works only when all fields are captured in the /update/json/docs
- endpoint (noble)
- * SOLR-8546: SOLR-8546: TestLazyCores is failing a lot on the Jenkins cluster. (Erick Erickson)
- * SOLR-9237: DefaultSolrHighlighter.doHighlightingByFastVectorHighlighter can't be overidden (janhoy)
- * SOLR-8626: 404 error when clicking nodes in cloud graph view in angular UI. (janhoy, Trey Grainger via shalin)
- * SOLR-9254: GraphTermsQueryQParserPlugin throws NPE when field being searched is not present in segment
- (Joel Bernstein)
- * SOLR-8657: Fix SolrRequestInfo error logs if QuerySenderListener is being used (Pascal Chollet,
- Tomás Fernández Löbbe)
- * SOLR-8777: Duplicate Solr process can cripple a running process. (Jessica Cheng Mallet, Scott Blum, shalin)
- * SOLR-9246: If the JDBCStream sees an unknown column type it will now throw a detailed exception. (Dennis Gove)
- * SOLR-9181: Fix some races in CollectionStateWatcher API (Alan Woodward, Scott
- Blum)
- * SOLR-9235: Fixed NPE when using non-numeric range query in deleteByQuery (hossman)
- * SOLR-9088: Fixed TestManagedSchemaAPI failures which exposed race conditions in the schema API ( Varun Thacker, noble)
- * SOLR-9207: PeerSync recovery failes if number of updates requested is high. A new useRangeVersions config option
- is introduced (defaults to true) to send version ranges instead of individual versions for peer sync.
- (Pushkar Raste, shalin)
- * SOLR-8858: SolrIndexSearcher#doc() completely ignores field filters unless lazy field loading is enabled.
- (Caleb Rackliffe, David Smiley, shalin)
- * SOLR-9236: AutoAddReplicas will append an extra /tlog to the update log location on replica failover.
- (Eungsop Yoo, Mark Miller)
- * SOLR-9291: ZkSolrResourceLoader should not retry fetching resources if the server has been shutdown.
- (shalin)
- * SOLR-9287: Including 'score' in the 'fl' param when doing an RTG no longer causes an NPE
- (hossman, Ishan Chattopadhyaya)
- * SOLR-7280: In cloud-mode sort the cores smartly before loading & limit threads to improve cluster stability
- (noble, Erick Erickson, shalin)
- * SOLR-9285: Fixed AIOOBE when using ValueSourceAugmenter in single node RTG (hossman)
- * SOLR-9288: Fix [docid] transformer to return -1 when used in RTG with uncommitted doc (hossman)
- * SOLR-9309: Fix SolrCloud RTG response structure when multi ids requested but only 1 found (hossman)
- * SOLR-9334: CloudSolrClient.collectionStateCache is unbounded (noble)
- * SOLR-9339: NPE in CloudSolrClient when the response is null (noble)
- * SOLR-8596: Web UI doesn't correctly generate queries which include local parameters (Alexandre Rafalovitch, janhoy)
- * SOLR-8645: managed-schema is now syntax highlighted in cloud->Tree view (Alexandre Rafalovitch via janhoy)
- * SOLR-8379: UI Cloud->Tree view now shows .txt files correctly (Alexandre Rafalovitch via janhoy)
- * SOLR-9003: New Admin UI's Dataimport screen now correctly displays DIH Debug output (Alexandre Rafalovitch)
- * SOLR-9308: Fix distributed RTG to forward request params, fixes fq and non-default fl params (hossman)
- * SOLR-9179: NPE in IndexSchema using IBM JDK (noble, Colvin Cowie)
- * SOLR-9397: Config API does not support adding caches (noble)
- * SOLR-9405: ConcurrentModificationException in ZkStateReader.getStateWatchers.
- (Alan Woodward, Edward Ribeiro, shalin)
- * SOLR-9232: Admin UI now fully implements Swap Cores interface (Alexandre Rafalovitch)
- * SOLR-8715: Admin UI's Schema screen now works for fields with stored=false and some content indexed (Alexandre Rafalovitch)
- * SOLR-8911: In Admin UI, enable scrolling for overflowing Versions and JVM property values (Alexandre Rafalovitch)
- * SOLR-9002: Admin UI now correctly displays json and text files in the collection/Files screen (Upayavira, Alexandre Rafalovitch)
- * SOLR-8993: Admin UI now correctly supports multiple DIH handler end-points (Upayavira, Alexandre Rafalovitch)
- * SOLR-9032: Admin UI now correctly implements Create Alias command (Upayavira, Alexandre Rafalovitch)
- * SOLR-9391: LBHttpSolrClient.request now correctly returns Rsp.server when
- previously skipped servers were successfully tried. (Christine Poerschke)
- Optimizations
- ----------------------
- * SOLR-9219: Make hdfs blockcache read buffer sizes configurable and improve cache concurrency. (Mark Miller)
- * SOLR-9264: Optimize ZkController.publishAndWaitForDownStates to not read all collection states and
- watch relevant collections instead. (Hrishikesh Gadre, shalin)
- * SOLR-9335: Solr cache/search/update stats counters now use LongAdder which are supposed to have higher throughput
- under high contention. (Varun Thacker)
- * SOLR-9350: JSON Facets: method="stream" will no longer always uses & populates the filter cache, likely
- flushing it. 'cacheDf' can be configured to set a doc frequency threshold, now defaulting to 1/16th doc count.
- Using -1 Disables use of the cache. (David Smiley, yonik)
- Other Changes
- ----------------------
- * SOLR-9195: Remove unnecessary allocation and null check in UpdateRequestProcessorChain's
- getReqProcessors method. (Christine Poerschke)
- * SOLR-8981: Upgraded Extraction module to Apache Tika 1.13.
- (Tim Allison, Lewis John McGibbney via Uwe Schindler)
- * SOLR-9076: Update to Hadoop 2.7.2
- (Mark Miller, Gregory Chanan)
- * SOLR-8787: TestAuthenticationFramework should not extend TestMiniSolrCloudCluster. (Trey Cahill via shalin)
- * SOLR-9180: More comprehensive tests of psuedo-fields for RTG and SolrCloud requests (hossman)
- * SOLR-7930: Comment out trappy references to example docs in elevate.xml files (Erick Erickson)
- * SOLR-9277: Clean up some more remnants of supporting old and new style solr.xml in tests (Erick Erickson)
- * SOLR-9163: Sync up basic_configs and data_driven_schema_configs, removing almost all differences
- except what is required for schemaless. (yonik)
- * SOLR-9340: Change ZooKeeper disconnect and session expiry related logging from INFO to WARN to
- make debugging easier (Varun Thacker)
- * SOLR-9358: [AngularUI] In Cloud->Tree file view area, collapse metadata by default (janhoy)
- * SOLR-9256: asserting hasNext() contract in JdbcDataSource in DataImportHandler (Kristine Jetzke via Mikhai Khludnev)
- * SOLR-9209: extracting JdbcDataSource.createResultSetIterator() for extension (Kristine Jetzke via Mikhai Khludnev)
- * SOLR-9353: Factor out ReRankQParserPlugin.ReRankQueryRescorer private class. (Christine Poerschke)
- * SOLR-9392: Fixed CDCR Test failures which were due to leaked resources. (shalin)
- * SOLR-9385: Add QParser.getParser(String,SolrQueryRequest) variant. (Christine Poerschke)
- * SOLR-9367: Improved TestInjection's randomization logic to use LuceneTestCase.random() (hossman)
- * SOLR-9331: Remove ReRankQuery's length constructor argument and member. (Christine Poerschke)
- * SOLR-9092: For the delete replica command we attempt to send the core admin delete request only
- if that node is actually up. (Jessica Cheng Mallet, Varun Thacker)
- * SOLR-9410: Make ReRankQParserPlugin's private ReRankWeight a public class of its own. (Christine Poerschke)
- * SOLR-9404: Refactor move/renames in JSON FacetProcessor and FacetFieldProcessor. (David Smiley)
- * SOLR-9421: Refactored out OverseerCollectionMessageHandler to smaller classes (noble)
- * SOLR-8643: BlockJoinFacetComponent is substituted by BlockJoinFacetDocSetComponent. It doesn't need to change solrconfig.xml (Mikhail Khludnev)
- * SOLR-8644: Test asserts that block join facets work with parent level fq exclusions. (Dr. Oleg Savrasov via Mikhail Khludnev)
- ================== 6.1.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.7
- Carrot2 3.12.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.3.8.v20160314
- Upgrading from Solr any prior release
- ----------------------
- * If you use historical dates, specifically on or before the year 1582, you should re-index.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-8782: Add asynchronous sugar methods to the SolrJ Collections API. You
- can now call .processAsync() to run a method asynchronously, or
- .processAndWait() to wait for a call to finish without holding HTTP
- collections open. (Alan Woodward)
- * SOLR-8765: Enforce required parameters at query construction time in the SolrJ
- Collections API, add static factory methods, and deprecate old setter methods.
- (Alan Woodward, Jason Gerlowski)
- * SOLR-8842: authorization APIs do not use name as an identifier for a permission
- for update, delete commands and 'before' attribute (noble)
- * SOLR-8814: Support GeoJSON response writer and general spatial formatting. Adding
- &wt=geojson&geojson.field=<your geometry field>
- Will return a FeatureCollection for each SolrDocumentList and a Feature with the
- requested geometry for each SolrDocument. The requested geometry field needs
- to either extend AbstractSpatialFieldType or store a GeoJSON string. This also adds
- a [geo] DocumentTransformer that can return the Shape in a variety of formats:
- &fl=[geo f=<your geometry field> w=(GeoJSON|WKT|POLY)]
- The default format is GeoJSON. For information on the supported formats, see:
- https://github.com/locationtech/spatial4j/blob/master/FORMATS.md
- To return the FeatureCollection as the root element, add '&omitHeader=true" (ryan)
- * SOLR-8859: Spatial fields like RPT can now be configured to use Spatial4j registered shape formats
- e.g. via format="GeoJSON". (ryan, David Smiley)
- * SOLR-445: new TolerantUpdateProcessorFactory to support skipping update commands that cause
- failures when sending multiple updates in a single request.
- (Erick Erickson, Tomás Fernández Löbbe, Anshum Gupta, hossman)
- * SOLR-8890: New static method in DistributedUpdateProcessorFactory to allow UpdateProcessorFactories
- to indicate request params that should be forwarded when DUP distributes updates. (hossman)
- * SOLR-8888: Add shortestPath Streaming Expression. This expression performs a breadth first
- graph traversal to find the shortest path(s) in an unweighted, directed graph stored in a
- SolrCloud collection. (Joel Bernstein)
- * SOLR-8938: Add optional --excluderegex argument to ZkCLI. (Christine Poerschke)
- * SOLR-8976: Add SolrJ support for REBALANCELEADERS Collections API (Anshum Gupta)
- * SOLR-8962: Add sort Streaming Expression. The expression takes a single input stream and a
- comparator and outputs tuples in stable order of the comparator. (Dennis Gove)
- * SOLR-8349: Allow sharing of large in memory data structures across cores (Gus Heck, noble)
- * SOLR-9009: Adds ability to get an Explanation of a Streaming Expression (Dennis Gove)
- * SOLR-8918: Adds Streaming to the admin page under the collections section. Includes
- ability to see graphically the expression explanation (Dennis Gove)
- * SOLR-8913: When using a shared filesystem we should store data dir and tlog dir locations in
- the cluster state. (Mark Miller)
- * SOLR-8809: Implement Connection.prepareStatement (Kevin Risden)
- * SOLR-9020: Implement StatementImpl/ResultSetImpl get/set fetch* methods and proper errors for traversal methods (Kevin Risden)
- * SOLR-9041: 'core-admin-read' and 'core-admin-edit' are well known permissions (noble)
- * SOLR-8986: Add Random Streaming Expression (Joel Bernstein)
- * SOLR-8925: Add gatherNodes Streaming Expression to support breadth first traversals (Joel Bernstein)
- * SOLR-9027: Add GraphTermsQuery to limit traversal on high frequency nodes (Joel Bernstein, David Smiley)
- * SOLR-5750: Add /admin/collections?action=BACKUP and RESTORE assuming access to a shared file system.
- (Varun Thacker, David Smiley)
- * SOLR-9049: RuleBasedAuthorizationPlugin supports regex in param values eg: "command" : "REGEX:(i?)create" (noble)
- * SOLR-8972: Add GraphHandler and GraphMLResponseWriter to support graph visualizations (Joel Bernstein)
- * SOLR-9026: Extend facet telemetry support to legacy (non-json) facets under "debug/facet-debug" in
- the response. (Michael Sun, yonik)
- * SOLR-7117: Provide an option to limit the maximum number of cores that can be created on a node by the
- Auto Add Replica feature. For this you can set a "maxCoresPerNode" property via the Cluster Property API
- (Varun Thacker, Mark Miller)
- * SOLR-8208: [subquery] document transformer executes separate requests per result document. (Cao Manh Dat via Mikhail Khludnev)
- * SOLR-8323, SOLR-9113: Add CollectionStateWatcher API (Alan Woodward, Scott Blum)
- * SOLR-8988: Adds query option facet.distrib.mco which when set to true allows the use of facet.mincount=1 in cloud mode.
- (Keith Laban, Dennis Gove)
- * SOLR-8583: Apply highlighting to hl.alternateField by default for Default and FastVectorHighlighter.
- Turn off with hl.highlightAlternate=false (janhoy, David Smiley)
- * SOLR-7123: '/update/json/docs' path supports nested documents (noble)
- * SOLR-8610: Resolve variables in encryptKeyFile of DIH's JdbcDataSource (Kristine Jetzke via Mikhail Khludnev)
- * SOLR-7739: Add a new ClassificationUpdateProcessorFactory. (Alessandro Benedetti via Tommaso Teofili)
- Bug Fixes
- ----------------------
- * SOLR-8855: The HDFS BlockDirectory should not clean up it's cache on shutdown. (Mark Miller)
- * SOLR-8948: OverseerTaskQueue.containsTaskWithRequestId encounters json parse error if a
- SolrResponse node is in the overseer queue. (Jessica Cheng Mallet via shalin)
- * SOLR-7729: ConcurrentUpdateSolrClient ignores the collection parameter in some methods.
- (Nicolas Gavalda, Jorge Luis Betancourt Gonzalez via Mark Miller)
- * SOLR-8662: SchemaManager waits correctly for replicas to be notified of a new change.
- (sarowe, Noble Paul, Varun Thacker)
- * SOLR-8983: Cleanup clusterstate and replicas for a failed create collection request
- (Varun Thacker, Anshum Gupta)
- * SOLR-9029: fix rare ZkStateReader visibility race during collection state format update (Scott Blum, hossman)
- * SOLR-9046: Fix solr.cmd that wrongly assumes Jetty will always listen on 0.0.0.0.
- (Bram Van Dam, Uwe Schindler)
- * SOLR-9064: Adds an explanation of the incoming stream to an UpdateStream's explanation (Dennis Gove)
- * SOLR-9128: Fix error handling issues in Streaming classes (Joel Bernstein)
- * SOLR-9151: Fix SolrCLI so that bin/solr -e cloud example can be run from any CWD (janhoy)
- * SOLR-9141: Fix ClassCastException when using the /sql handler count() function with
- single-shard collections (Minoru Osuka via James Dyer)
- * SOLR-9165: Spellcheck does not return collations if "maxCollationTries" is used with "cursorMark".
- (James Dyer)
- * SOLR-8940: Fix group.sort option (hossman)
- * SOLR-8612: closing JDBC Statement on failures in DataImportHandler (DIH) (Kristine Jetzke via Mikhail Khludnev)
- * SOLR-8676: keep LOG4J_CONFIG in solr.cmd (Kristine Jetzke via Mikhail Khludnev)
- * SOLR-9198: config APIs unable to add multiple values with same name (noble)
- * SOLR-8812: edismax: turn off mm processing if no explicit mm spec is provided
- and there are explicit operators (except for AND) - addresses problems caused by SOLR-2649.
- (Greg Pendlebury, Jan Høydahl, Erick Erickson, Steve Rowe)
- * SOLR-9176: facet method ENUM was sometimes unnecessarily being rewritten to
- FCS, causing slowdowns (Alessandro Benedetti, Jesse McLaughlin, Alan Woodward)
- Optimizations
- ----------------------
- * SOLR-8722: Don't force a full ZkStateReader refresh on every Overseer operation.
- (Scott Blum via shalin)
- * SOLR-8745: Deprecate costly ZkStateReader.updateClusterState(), replace with a narrow
- forceUpdateCollection(collection) (Scott Blum via shalin)
- * SOLR-8856: Do not cache merge or 'read once' contexts in the hdfs block cache. (Mark Miller, Mike Drob)
- * SOLR-8922: Optimize filter creation (DocSetCollector) to minimize the amount of garbage
- produced. This resulted in up to 3x throughput when small filter creation was the bottleneck,
- as well as orders of magnitude less garbage. (Jeff Wartes, yonik)
- * SOLR-8937: bin/post (SimplePostTool) now streams the standard input instead of buffering fully.
- (David Smiley)
- * SOLR-8973: Zookeeper frenzy when a core is first created. (Janmejay Singh, Scott Blum, shalin)
- * SOLR-9014: Deprecate and reduce usage of ClusterState methods which may make calls to ZK via
- the lazy collection reference. (Scott Blum, shalin)
- * SOLR-9106: Cluster properties are now cached on ZkStateReader. (Alan Woodward)
- * SOLR-9147: Upgrade commons-io to 2.5, avoid expensive array resizing in EmbeddedSolrServer (Mikhail Khludnev)
- * SOLR-8744: Overseer operations performed with fine grained mutual exclusion (noble, Scott Blum)
- * SOLR-9204: Improve performance of getting directory size with hdfs. (Mark Miller)
- Other Changes
- ----------------------
- * SOLR-8860: Remove back-compat handling of router format made in SOLR-4221 in 4.5.0. (shalin)
- * SOLR-8866: UpdateLog will now throw an exception if it doesn't know how to serialize a value.
- (David Smiley)
- * SOLR-8842: security rules made more foolproof by asking the requesthandler about the well known
- permission name.
The APIs are also modified to ue 'index' as the unique identifier instead of name.
- Name is an optional attribute
now and only to be used when specifying well-known permissions (noble)
- * SOLR-5616: Simplifies grouping code to use ResponseBuilder.needDocList() to determine if it needs to
- generate a doc list for grouped results. (Steven Bower, Keith Laban, Dennis Gove)
- * SOLR-8869: Optionally disable printing field cache entries in SolrFieldCacheMBean (Gregory Chanan)
- * SOLR-8892: Allow SolrInfoMBeans to return different statistics for /jmx vs web ui calls.
- (Gregory Chanan, Mark Miller)
- * SOLR-8097: Implement builder pattern design for constructing SolrJ clients and also deprecate direct construction
- of client objects. (Jason Gerlowski, Shawn Heisey, Anshum Gupta)
- * SOLR-9015: Adds SelectStream as a default function in the StreamHandler (Dennis Gove)
- * SOLR-8929: Add an idea module for solr/server to enable launching start.jar (Scott Blum, Steve Rowe)
- * SOLR-8933: Solr should not close container streams. (Mike Drob, Uwe Schindler, Mark Miller)
- * SOLR-9037: Replace multiple "/replication" strings with one static constant. (Christine Poerschke)
- * SOLR-9047: zkcli should allow alternative locations for log4j configuration (Gregory Chanan)
- * SOLR-9066: Make CountMetric return long instead of double (Kevin Risden)
- * SOLR-9065, SOLR-9072, SOLR-9132: Migrate some distributed tests to SolrCloudTestCase. (Alan Woodward)
- * SOLR-8184: Negative tests for JDBC Connection String (Susheel Kumar, Jason Gerlowski, Kevin Risden)
- * SOLR-8458: Add Streaming Expressions tests for parameter substitution (Joel Bernstein, Cao Manh Dat, Dennis Gove, Kevin Risden)
- * SOLR-8467: CloudSolrStream and FacetStream should take a SolrParams object rather than a
- Map<String, String> to allow more complex Solr queries to be specified. (Erick Erickson)
- * SOLR-9083: Remove all <types> and <fields> from schemas. NOTE: as in the JIRA I left a few in to insure the (no cost)
- back compat. (Erick Erickson)
- * SOLR-9105: Fix a bunch of typos across 103 files (Bartosz Krasiński via janhoy)
- * SOLR-9159: New cloud based concurrent atomic update test (hossman)
- * SOLR-9119: several static methods in ValueSourceParser have been made private (hossman)
- * SOLR-9110: Move JoinFromCollection- SubQueryTransformer- BlockJoinFacet- Distrib Tests to SolrCloudTestCase (Mikhail Khludnev)
- * SOLR-9136: Separate out the error statistics into server-side error vs client-side error
- (Jessica Cheng Mallet via Erick Erickson)
- * SOLR-9107: new @RandomizeSSL annotation for more fine grained control of SSL testing (hossman, sarowe)
- * SOLR-9081: Make SolrTestCaseJ4.beforeClass() / .afterClass() public so it
- works with Mockito (Georg Sorst, Alan Woodward)
- * SOLR-8445: fix line separator in log4j.properties files (Ahmet Arslan via Mikhail Khludnev)
- * SOLR-2199: DataImportHandler (DIH) JdbcDataSource supports multiple resultsets per query (Kristine Jetzke, Mark Waddle via Mikhail Khludnev)
- ================== 6.0.1 ==================
- Upgrade Notes
- ----------------------
- * If you use historical dates, specifically on or before the year 1582, you should re-index.
- Bug Fixes
- ----------------------
- * SOLR-8914: ZkStateReader's refreshLiveNodes(Watcher) is not thread safe. (Scott Blum, hoss,
- sarowe, Erick Erickson, Mark Miller, shalin)
- * SOLR-9016: Fix SolrIdentifierValidator to not allow empty identifiers. (Shai Erera)
- * SOLR-8992: Restore Schema API GET method functionality removed in 6.0 (noble, Steve Rowe)
- * SOLR-9080, SOLR-9085: (6.0 bug) For years <= 1582, date math (round,add,sub) introduced error. Range faceting
- on such dates was also affected. With this fixed, this is the first release range faceting works on BC years.
- (David Smiley)
- * SOLR-8857: HdfsUpdateLog does not use configured or new default number of version buckets and is
- hard coded to 256. (Mark Miller, yonik, Gregory Chanan)
- * SOLR-8902: Make sure ReturnFields only returns the requested fields from (fl=) evn when
- DocumentTransformers ask for getExtraRequestFields() (ryan)
- * SOLR-8875: SolrCloud Overseer clusterState could unexpectedly be null resulting in NPE.
- (Scott Blum via David Smiley)
- * SOLR-8946: bin/post failed to detect stdin usage on Ubuntu; maybe other unixes. (David Smiley)
- * SOLR-9004: Fix "name" field type definition in films example. (Alexandre Rafalovitch via Varun Thacker)
- * SOLR-8990: Fix top term links from schema browser page to use {!term} parser (hossman)
- * SOLR-8971: Preserve root cause when wrapping exceptions (hossman)
- * SOLR-9034: Atomic updates failed to work when there were copyField targets that had docValues
- enabled. (Karthik Ramachandran, Ishan Chattopadhyaya, yonik)
- * SOLR-9028: Fixed some test related bugs preventing SSL + ClientAuth from ever being tested (hossman)
- * SOLR-9059: NPE in SolrClientCache following collection reload (Joel Bernstein, Ryan Yacyshyn)
- * SOLR-8792: ZooKeeper ACL support fixed. (Esther Quansah, Ishan Chattopadhyaya, Steve Rowe)
- * SOLR-9030: The 'downnode' overseer command can trip asserts in ZkStateWriter.
- (Scott Blum, Mark Miller, shalin)
- * SOLR-9036: Solr slave is doing full replication (entire index) of index after master restart.
- (Lior Sapir, Mark Miller, shalin)
- * SOLR-9058: Makes HashJoinStream and OuterHashJoinStream support different field names in the
- incoming streams, eg. fieldA=fieldB. (Dennis Gove, Stephan Osthold)
- * SOLR-9093: Fix NullPointerException in TopGroupsShardResponseProcessor. (Christine Poerschke)
- * SOLR-9118: HashQParserPlugin should trim partition keys (Joel Bernstein)
- * SOLR-9117: The first SolrCore is leaked after reload. (Jessica Cheng Mallet via shalin)
- * SOLR-9116: Race condition causing occasional SolrIndexSearcher leak when SolrCore is reloaded.
- (Jessica Cheng Mallet via shalin)
- * SOLR-8801: /bin/solr create script always returns exit code 0 when a collection/core already exists.
- (Khalid Alharbi, Marius Grama via Steve Rowe)
- * SOLR-9134: Fix RestManager.addManagedResource return value. (Christine Poerschke)
- Other Changes
- ----------------------
- * SOLR-7516: Improve javadocs for JavaBinCodec, ObjectResolver and enforce the single-usage policy.
- (Jason Gerlowski, Benoit Vanalderweireldt, shalin)
- * SOLR-8967: In SolrCloud mode, under the 'Core Selector' dropdown in the UI the Replication tab won't be displayed
- anymore. The Replication tab is only beneficial to users running Solr in master-slave mode. (Varun Thacker)
- * SOLR-8985: Added back support for 'includeDynamic' flag to /schema/fields endpoint (noble)
- * SOLR-9131: Fix "start solr" text in cluster.vm Velocity template (janhoy)
- * SOLR-9053: Upgrade commons-fileupload to 1.3.1, fixing a potential vulnerability (Jeff Field, Mike Drob via janhoy)
- * SOLR-9115: Get rid of javax.xml.bind.DatatypeConverter in SimplePostTool
- for Java 9 compatibility. (Uwe Schindler)
- * SOLR-5776,SOLR-9068,SOLR-8970:
- - Refactor SSLConfig so that SSLTestConfig can provide SSLContexts using a NullSecureRandom
- to prevent SSL tests from blocking on entropy starved machines.
- - SSLTestConfig: Alternate (psuedo random) NullSecureRandom for Constants.SUN_OS.
- - SSLTestConfig: Replace NullSecureRandom w/ NotSecurePsuedoRandom.
- - Change SSLTestConfig to use a keystore file that is included as a resource in the
- test-framework jar so users subclassing SolrTestCaseJ4 don't need to preserve magic paths.
- (hossman)
- ================== 6.0.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release
- Versions of Major Components
- ---------------------
- Apache Tika 1.7
- Carrot2 3.12.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.3.8.v20160314
- System Requirements
- ----------------------
- * LUCENE-5950: Move to Java 8 as minimum Java version.
- (Ryan Ernst, Uwe Schindler)
- Upgrading from Solr 5.x
- ----------------------
- * The deprecated SolrServer and subclasses have been removed, use SolrClient
- instead.
- * The deprecated <nrtMode> configuration in solrconfig.xml has been removed.
- Please remove it from solrconfig.xml.
- * SolrClient.shutdown() has been removed, use SolrClient.close() instead.
- * The deprecated zkCredientialsProvider element in solrcloud section of solr.xml
- is now removed. Use the correct spelling (zkCredentialsProvider) instead.
- * SOLR-7957: internal/expert - ResultContext was significantly changed and expanded
- to allow for multiple full query results (DocLists) per Solr request.
- TransformContext was rendered redundant and was removed. (yonik)
- * Several changes have been made regarding the "Similarity" used in Solr, in order to provide
- better default behavior for new users. There are 3 key impacts of these changes on existing
- users who upgrade:
- * DefaultSimilarityFactory has been removed. If you currently have DefaultSimilarityFactory explicitly
- referenced in your schema.xml, edit your config to use the functionally identical
- ClassicSimilarityFactory. See SOLR-8239 for more details.
- * The implicit default Similarity used when no <similarity/> is configured in schema.xml has
- been changed to SchemaSimilarityFactory. Users who wish to preserve back-compatible behavior should
- either explicitly configure ClassicSimilarityFactory, or ensure that the luceneMatchVersion
- for the collection is less then 6.0. See SOLR-8270 + SOLR-8271 for details.
- * SchemaSimilarityFactory has been modified to use BM25Similarity as the default for fieldTypes that
- do not explicitly declare a Similarity. The legacy behavior of using ClassicSimilarity as the
- default will occur if the luceneMatchVersion for the collection is less then 6.0, or the
- 'defaultSimFromFieldType' configuration option may be used to specify any default of your choosing.
- See SOLR-8261 + SOLR-8329 for more details.
- * If your solrconfig.xml file doesn't explicitly mention the schemaFactory to use then Solr will choose
- the ManagedIndexSchemaFactory by default. Previously it would have chosen ClassicIndexSchemaFactory.
- This means that the Schema APIs ( /<collection>/schema ) are enabled and the schema is mutable.
- When Solr starts your schema.xml file will be renamed to managed-schema. If you want to retain the old behaviour
- then please ensure that the solrconfig.xml explicitly uses the ClassicIndexSchemaFactory :
- <schemaFactory class="ClassicIndexSchemaFactory"/> or your luceneMatchVersion in the solrconfig.xml is less than 6.0
- * SolrIndexSearcher.QueryCommand and QueryResult were moved to their own classes. If you reference them
- in your code, you should import them under o.a.s.search (or use your IDE's "Organize Imports").
- * SOLR-8698: 'useParams' attribute specified in request handler cannot be overridden from request params
- * When requesting stats in date fields, "sum" is now a double value instead of a date. See SOLR-8671
- * SOLR-8736: The deprecated GET methods for schema are now accessible through the bulk API. The output
- has less details and is not backward compatible.
- * In the past, Solr guaranteed that retrieval of multi-valued fields would preserve the order of values.
- Because values may now be retrieved from column-stored fields (docValues="true"), in conjunction with the
- fact that docValues do not currently preserve order, means that users should set useDocValuesAsStored="false"
- to prevent future optizations from using the column-stored values over the row-stored values when
- fields have both stored="true" and docValues="true".
- * Formatted date-times from Solr have some differences. If the year is more than 4 digits, there is a leading '+'.
- When there is a non-zero number of milliseconds, it is padded with zeros to 3 digits. Negative year (BC) dates are
- now possible. Parsing: It is now an error to supply a portion of the date out of its, range, like 67 seconds.
- * SolrJ no longer includes DateUtil. If for some reason you need to format or parse dates, simply use Instant.format()
- and Instant.parse().
- * If you are using an RPT or other spatial field referencing Spatial4j in its configuration, then replace the string
- "com.spatial4j.core" with "org.locationtech.spatial4j". Consider updating direct to Solr 6.2 which accepts the
- old value, albeit with a warning.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-3085: New edismax param mm.autoRelax which helps in certain cases of the stopwords/zero-hits issue (janhoy)
- * SOLR-7560: Parallel SQL Support (Joel Bernstein)
- * SOLR-7707: Add StreamExpression Support to RollupStream (Dennis Gove, Joel Bernstein)
- * SOLR-7903: Add the FacetStream to the Streaming API and wire it into the SQLHandler (Joel Bernstein)
- * SOLR-7986: JDBC Driver for SQL Interface (Uwe Schindler, Joel Bernstein)
- * SOLR-8038: Add the StatsStream to the Streaming API and wire it into the SQLHandler (Joel Bernstein)
- * SOLR-8086: Add support for SELECT DISTINCT queries to the SQL interface (Joel Bernstein)
- * SOLR-7543: Basic graph traversal query
- Example: {!graph from="node_id" to="edge_id"}id:doc_1
- (Kevin Watters, yonik)
- * SOLR-6273: Cross Data Center Replication. Active/passive replication for separate
- SolrClouds hosted on separate data centers. (Renaud Delbru, Yonik Seeley via Erick Erickson)
- * SOLR-7938: MergeStream now supports merging more than 2 streams together (Dennis Gove)
- * SOLR-8198: Change ReducerStream to use StreamEqualitor instead of StreamComparator (Dennis Gove)
- * SOLR-8268: StatsStream now implements the Expressible interface (Dennis Gove)
- * SOLR-7584: Adds Inner and LeftOuter Joins to the Streaming API and Streaming Expressions (Dennis Gove, Corey Wu)
- * SOLR-8188: Adds Hash and OuterHash Joins to the Streaming API and Streaming Expressions (Dennis Gove)
- * SOLR-7669: Add SelectStream and Tuple Operations to the Streaming API and Streaming Expressions (Dennis Gove)
- * SOLR-8337: Add ReduceOperation and wire it into the ReducerStream (Joel Bernstein)
- * SOLR-7904: Add StreamExpression Support to FacetStream (Dennis Gove)
- * SOLR-6398: Add IterativeMergeStrategy to support running Parallel Iterative Algorithms inside of Solr
- (Joel Bernstein)
- * SOLR-8436: Real-time get now supports filters. (yonik)
- * SOLR-7535: Add UpdateStream to Streaming API and Streaming Expression (Jason Gerlowski, Joel Bernstein)
- * SOLR-8479: Add JDBCStream to Streaming API and Streaming Expressions for integration with external data sources
- (Dennis Gove)
- * SOLR-8002: Add column alias support to the Parallel SQL Interface (Joel Bernstein)
- * SOLR-7525: Add ComplementStream and IntersectStream to the Streaming API and Streaming Expressions
- (Dennis Gove, Jason Gerlowski, Joel Bernstein)
- * SOLR-8415: Provide command to switch between non/secure mode in ZK
- (Mike Drob, Gregory Chanan)
- * SOLR-8556: Add ConcatOperation to be used with the SelectStream (Joel Bernstein, Dennis Gove)
- * SOLR-8550: Add asynchronous DaemonStreams to the Streaming API (Joel Bernstein)
- * SOLR-8285: Ensure the /export handler works with NULL field values (Joel Bernstein)
- * SOLR-8502: Improve Solr JDBC Driver to support SQL Clients like DBVisualizer (Kevin Risden, Joel Bernstein)
- * SOLR-8588: Add TopicStream to the streaming API to support publish/subscribe messaging (Joel Bernstein, Kevin Risden)
- * SOLR-8666: Adds header 'zkConnected' to response of SearchHandler and PingRequestHandler to notify the client when
- a connection to zookeeper has been lost and there is a possibility of stale data on the node the request is coming
- from. (Keith Laban, Dennis Gove)
- * SOLR-8522: Make it possible to use ip fragments in replica placement rules , such as ip_1, ip_2 etc (Arcadius Ahouansou, noble)
- * SOLR-8698: params.json can now specify 'appends' and 'invariants' (noble)
- * SOLR-8831: allow _version_ field to be retrievable via docValues (yonik)
- Bug Fixes
- ----------------------
- * SOLR-8386: Add field option in the new admin UI schema page loads up even when no schemaFactory has been
- explicitly specified since the default is ManagedIndexSchemaFactory. (Erick Erickson, Upayavira, Varun Thacker)
- * SOLR-8191: Guard against CloudSolrStream close method NullPointerException
- (Kevin Risden, Joel Bernstein)
- * SOLR-8485: SelectStream now properly handles non-lowercase and/or quoted select field names (Dennis Gove)
- * SOLR-8525: Fix a few places that were failing to pass dimensional
- values settings when copying a FieldInfo (Ishan Chattopadhyaya via
- Mike McCandless)
- * SOLR-8409: Ensures that quotes in solr params (eg. q param) are properly handled (Dennis Gove)
- * SOLR-8640: CloudSolrClient does not send credentials for update request (noble, hoss)
- * SOLR-8461: CloudSolrStream and ParallelStream can choose replicas that are not active
- (Cao Manh Dat, Varun Thacker, Joel Bernstein)
- * SOLR-8527: Improve JdbcTest to cleanup properly on failures (Kevin Risden, Joel Bernstein)
- * SOLR-8578: Successful or not, requests are not always fully consumed by Solrj clients and we
- count on HttpClient or the JVM. (Mark Miller)
- * SOLR-8683: Always consume the full request on the server, not just in the case of an error.
- (Mark Miller)
- * SOLR-8416: The collections create API should return after all replicas are active.
- (Michael Sun, Mark Miller, Alexey Serba)
- * SOLR-8701: CloudSolrClient decides that there are no healthy nodes to handle a request too early.
- (Mark Miller)
- * SOLR-8694: DistributedMap/Queue can create too many Watchers and some code simplification.
- (Scott Blum via Mark Miller)
- * SOLR-8695: Ensure ZK watchers are not triggering our watch logic on connection events and
- make this handling more consistent. (Scott Blum via Mark Miller)
- * SOLR-8633: DistributedUpdateProcess processCommit/deleteByQuery call finish on DUP and
- SolrCmdDistributor, which violates the lifecycle and can cause bugs. (hossman via Mark Miller)
- * SOLR-8656: PeerSync should use same nUpdates everywhere. (Ramsey Haddad via Mark Miller)
- * SOLR-8697, SOLR-8837: Scope ZK election nodes by session to prevent elections from interfering with each other
- and other small LeaderElector improvements. (Scott Blum via Mark Miller, Alan
- Woodward)
- * SOLR-8599: After a failed connection during construction of SolrZkClient attempt to retry until a connection
- can be made. (Keith Laban, Dennis Gove)
- * SOLR-8497: Merge index does not mark the Directory objects it creates as 'done' and they are retained in the
- Directory cache. (Sivlio Sanchez, Mark Miller)
- * SOLR-8696: Start the Overseer before actions that need the overseer on init and when reconnecting after
- zk expiration and improve init logic. (Scott Blum, Mark Miller)
- * SOLR-8420: Fix long overflow in sumOfSquares for Date statistics. (Tom Hill, Christine Poerschke,
- Tomás Fernández Löbbe)
- * SOLR-8748: OverseerTaskProcessor limits number of concurrent tasks to just 10 even though the thread pool
- size is 100. The limit has now been increased to 100. (Scott Blum, shalin)
- * SOLR-8375: ReplicaAssigner rejects valid nodes (Kelvin Tan, noble)
- * SOLR-8738: Fixed false success response when invalid deleteByQuery requests intially hit non-leader
- cloud nodes (hossman)
- * SOLR-8771: Multi-threaded core shutdown creates executor per core. (Mike Drob via Mark Miller)
- * SOLR-8145: Fix position of OOM killer script when starting Solr in the background (Jurian Broertjes via
- Timothy Potter)
- * SOLR-8769: Fix document exclusion in mlt query parser in Cloud mode for schemas that have non-"id"
- unique field (Erik Hatcher, Anshum Gupta)
- * SOLR-8728: ReplicaAssigner throws NPE when a partial list of nodes are only participating in replica
- placement. splitshard should preassign nodes using rules, if rules are present (noble, Shai Erera)
- * SOLR-8779: Fix missing InterruptedException handling in ZkStateReader.java (Varun Thacker)
- * SOLR-8449: Fix the core restore functionality to allow restoring multiple times on the same core
- (Johannes Brucher, Varun Thacker)
- * SOLR-8155: JSON Facet API - field faceting on a multi-valued string field without
- docValues (i.e. UnInvertedField implementation), but with a prefix or with a sort
- other than count, resulted in incorrect results. This has been fixed, and facet.prefix
- support for facet.method=uif has been enabled. (Mikhail Khludnev, yonik)
- * SOLR-8790: Collections API responses contain node name in the core-level responses that are
- returned. (Anshum Gupta)
- * SOLR-8804: Fix a race condition in the ClusterStatus API call whereby the call would fail when a concurrent delete
- collection api command was executed (Alexey Serba, Varun Thacker)
- * SOLR-8835: JSON Facet API: fix faceting exception on multi-valued numeric fields that
- have docValues. (yonik)
- * SOLR-8838: Returning non-stored docValues is incorrect for negative floats and doubles.
- (Ishan Chattopadhyaya, Steve Rowe)
- * SOLR-8867: {!frange} queries will now avoid matching documents without a value in the
- numeric field. For more complex functions, FunctionValues.exists() must also return true
- for the document to match. (yonik)
- * SOLR-8886: Fix TrieField.toObject(IndexableField) to work for field with docValues
- enabled. (yonik)
- * SOLR-8891: Fix StrField.toObject and toExternal to work with docValue IndexableField
- instances. (yonik)
- * SOLR-8865: Real-time get sometimes fails to retrieve stored fields from docValues.
- (Ishan Chattopadhyaya, yonik)
- Optimizations
- ----------------------
- * SOLR-7876: Speed up queries and operations that use many terms when timeAllowed has not been
- specified. Speedups of up to 8% were observed. (yonik)
- * SOLR-8037: Speed up creation of filters from term range queries (i.e. non-numeric range queries)
- and use the filter cache for term range queries that are part of larger queries. Some observed
- speedups were up to 2.5x for production of filters, and up to 10x for query evaluation with
- embedded term range queres that resulted in filter cache hits. (yonik)
- * SOLR-8559: FCS facet performance optimization which significantly speeds up processing when terms
- are high cardinality and the matching docset is small. When facet minCount > 0 and the number of
- matching documents is small (or 0) this enhancement prevents considering terms which have a 0
- count. Also includes change to move to the next non-zero term value when selecting a segment
- position. (Keith Laban, Steve Bower, Dennis Gove)
- * SOLR-8532: Optimize GraphQuery when maxDepth is set by not collecting edges at the maxDepth level.
- (Kevin Watters via yonik)
- * SOLR-8669: Non binary responses use chunked encoding because we flush the outputstream early.
- (Mark Miller)
- * SOLR-8720: ZkController#publishAndWaitForDownStates should use #publishNodeAsDown. (Mark Miller)
- * SOLR-8082: Can't query against negative float or double values when indexed="false"
- docValues="true" multiValued="false". (hossman, Ishan Chattopadhyaya, yonik, Steve Rowe)
- Other Changes
- ----------------------
- * SOLR-6127: Improve example docs, using films data (Varun Thacker via ehatcher)
- * SOLR-6895: Deprecated SolrServer classes have been removed (Alan Woodward,
- Erik Hatcher)
- * SOLR-6954: Deprecated SolrClient.shutdown() method removed (Alan Woodward)
- * SOLR-7355: Switch from Google's ConcurrentLinkedHashMap to Caffeine. Only
- affects HDFS support. (Ben Manes via Shawn Heisey)
- * SOLR-7624: Remove deprecated zkCredientialsProvider element in solrcloud section of solr.xml.
- (Xu Zhang, Per Steffensen, Ramkumar Aiyengar, Mark Miller)
- * SOLR-7513: Add Equalitors to Streaming Expressions (Dennis Gove, Joel Bernstein)
- * SOLR-7528: Simplify Interfaces used in Streaming Expressions (Dennis Gove, Joel Bernstein)
- * SOLR-7554: Add checks in Streams for incoming stream order (Dennis Gove, Joel Bernstein)
- * SOLR-7441: Improve overall robustness of the Streaming stack: Streaming API,
- Streaming Expressions, Parallel SQL (Joel Bernstein)
- * SOLR-8153: Support upper case and mixed case column identifiers in the SQL interface
- (Joel Bernstein)
- * SOLR-8132: HDFSDirectoryFactory now defaults to using the global block cache. (Mark Miller)
- * SOLR-8261: Change SchemaSimilarityFactory default to BM25Similarity (hossman)
- * SOLR-8259: Remove deprecated JettySolrRunner.getDispatchFilter()
- * SOLR-8258: Change default hdfs tlog replication factor from 1 to 3. (Mark Miller)
- * SOLR-8270: Change implicit default Similarity to use BM25 when luceneMatchVersion >= 6 (hossman)
- * SOLR-8271: Change implicit default Similarity to use SchemaSimilarityFactory when luceneMatchVersion >= 6 (hossman)
- * SOLR-8179: SQL JDBC - DriverImpl loadParams doesn't support keys with no values in the connection string
- (Kevin Risden, Joel Bernstein)
- * SOLR-8131: Make ManagedIndexSchemaFactory the default schemaFactory when luceneMatchVersion >= 6
- (Uwe Schindler, shalin, Varun Thacker)
- * SOLR-8266: Remove Java Serialization from the Streaming API. The /stream handler now only accepts
- Streaming Expressions. (Jason Gerlowski, Joel Bernstein)
- * SOLR-8426: Enable /export, /stream and /sql handlers by default and remove them from example configs. (shalin)
- * SOLR-8443: Change /stream handler http param from "stream" to "expr" (Joel Bernstein, Dennis Gove)
- * SOLR-5209: Unloading or deleting the last replica of a shard now no longer
- cascades to remove the shard from the clusterstate. (Christine Poerschke)
- * SOLR-8190: Implement Closeable on TupleStream (Kevin Risden, Joel Bernstein)
- * SOLR-8529: Improve JdbcTest to not use plain assert statements (Kevin Risden, Joel Bernstein)
- * SOLR-7339: Upgrade Jetty to v9.3.8.v20160314. (Gregg Donovan, shalin, Mark Miller, Steve Rowe)
- * SOLR-5730: Make Lucene's SortingMergePolicy and EarlyTerminatingSortingCollector configurable in Solr.
- (Christine Poerschke, hossmann, Tomás Fernández Löbbe, Shai Erera)
- * SOLR-8677: Prevent shards containing invalid characters from being created. Checks added server-side
- and in SolrJ. (Shai Erera, Jason Gerlowski, Anshum Gupta)
- * SOLR-8693: Improve ZkStateReader logging. (Scott Blum via Mark Miller)
- * SOLR-8710: Upgrade morfologik-stemming to version 2.1.0. (Dawid Weiss)
- * SOLR-8711: Upgrade Carrot2 clustering dependency to 3.12.0. (Dawid Weiss)
- * SOLR-8690: Make peersync fingerprinting optional with solr.disableFingerprint system
- property. (yonik)
- * SOLR-8691: Cache index fingerprints per searcher. (yonik)
- * SOLR-8746: Renamed Overseer.getInQueue to getStateUpdateQueue, getInternalQueue to getInternalWorkQueue
- and added javadocs. (Scott Blum, shalin)
- * SOLR-8752: Add a test for SizeLimitedDistributedMap and improve javadocs. (shalin)
- * SOLR-8671: Date statistics: make "sum" a double instead of a long/date (Tom Hill, Christine Poerschke,
- Tomás Fernández Löbbe)
- * SOLR-8713: new UI and example solrconfig files point to Reference Guide for Solr Query Syntax instead
- of the wiki. (Marius Grama via Tomás Fernández Löbbe)
- * SOLR-8758: Add a new SolrCloudTestCase class, using MiniSolrCloudCluster (Alan
- Woodward)
- * SOLR-8736: schema GET operations on fields, dynamicFields, fieldTypes, copyField are
- reimplemented as a part of the bulk API with less details (noble)
- * SOLR-8766: Remove deprecated <admin> tag in solrconfig.xml and support for admin/gettableFiles
- (noble, Jason Gerlowski, Varun Thacker)
- * SOLR-8799: Improve error message when tuple can't be read by SolrJ JDBC (Kevin Risden, Joel Bernstein)
- * SOLR-8836: Return 400, and a SolrException when an invalid json is provided to the update handler
- instead of 500. (Jason Gerlowski via Anshum Gupta)
- * SOLR-8740: docValues are now enabled by default for most non-text (string, date, and numeric) fields
- in the schema templates. (yonik)
- * SOLR-8819: Implement DatabaseMetaDataImpl getTables() and fix getSchemas(). (Trey Cahill,
- Joel Bernstein, Kevin Risden)
- * SOLR-8810: Implement Connection.setReadOnly, Statement.set/getFetchSize,
- ResultSet.getType (Kevin Risden)
- * SOLR-8904: All dates are formatted via Instant.toString() (ISO-8601); see Solr upgrade notes for differences. Will
- now parse (and format) dates with a leading '+' or '-' (BC dates or dates > 4 digit year.
- [value] and ms() and contrib/analytics now parse with date math. (David Smiley)
- * SOLR-8904: DateUtil in SolrJ moved to the extraction contrib as ExtractionDateUtil. Obsolete methods were removed.
- (David Smiley)
- ======================= 5.5.5 =======================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.7
- Carrot2 3.10.4
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.2.13.v20150730
- Upgrade Notes
- ----------------------
- * SOLR-11477: in the XML query parser (defType=xmlparser or {!xmlparser ... })
- the resolving of external entities is now disallowed by default.
- * SOLR-11482: RunExecutableListener was deprecated and is disabled by default for
- security reasons. Legacy applications still using it must explicitely pass
- '-Dsolr.enableRunExecutableListener=true' to the Solr command line.
- Be aware that you should really disable API-based config editing at the same
- time, using '-Ddisable.configEdit=true'! (Uwe Schindler)
- Bug Fixes
- ----------------------
- * SOLR-10420: Leaking one SolrZkClient instance per second (Scott Blum, Cao Manh Dat, Markus Jelsma, Steve Rowe)
- * SOLR-11477: Disallow resolving of external entities in the XML query parser (defType=xmlparser).
- (Michael Stepankin, Olga Barinova, Uwe Schindler, Christine Poerschke)
- Other
- ----------------------
- * SOLR-11486: Update jmatio to 1.2 and prevent deserialization inside Matlab files.
- (Uwe Schindler, Steve Rowe)
- ======================= 5.5.4 =======================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.15.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.3.14.v20161028
- Other Changes
- ----------------------
- * SOLR-9819: Upgrade commons-fileupload to 1.3.2, fixing a potential vulnerability CVE-2016-3092 (Anshum Gupta)
- * SOLR-10031: Validation of filename params in ReplicationHandler (Hrishikesh Gadre, janhoy)
- ======================= 5.5.3 =======================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.13
- Carrot2 3.12.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.3.8.v20160314
- (No Changes)
- ======================= 5.5.2 =======================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.7
- Carrot2 3.10.4
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.2.13.v20150730
- Bug Fixes
- ---------------------
- * SOLR-8695: Ensure ZK watchers are not triggering our watch logic on connection events and
- make this handling more consistent. (Scott Blum via Mark Miller)
- * SOLR-9198: config APIs unable to add multiple values with same name (noble)
- * SOLR-9191: OverseerTaskQueue.peekTopN() fatally flawed (Scott Blum, Noble Paul)
- * SOLR-8812: edismax: turn off mm processing if no explicit mm spec is provided
- and there are explicit operators (except for AND) - addresses problems caused by SOLR-2649.
- (Greg Pendlebury, Jan Høydahl, Erick Erickson, Steve Rowe)
- * SOLR-9034: Atomic updates failed to work when there were copyField targets that had docValues
- enabled. (Karthik Ramachandran, Ishan Chattopadhyaya, yonik)
- * SOLR-8940: Fix group.sort option (hossman)
- * SOLR-8857: HdfsUpdateLog does not use configured or new default number of version buckets and is
- hard coded to 256. (Mark Miller, yonik, Gregory Chanan)
- * SOLR-8875: SolrCloud Overseer clusterState could unexpectedly be null resulting in NPE.
- (Scott Blum via David Smiley)
- * SOLR-8946: bin/post failed to detect stdin usage on Ubuntu; maybe other unixes. (David Smiley)
- * SOLR-9004: Fix "name" field type definition in films example. (Alexandre Rafalovitch via Varun Thacker)
- * SOLR-8990: Fix top term links from schema browser page to use {!term} parser (hossman)
- * SOLR-8971: Preserve root cause when wrapping exceptions (hossman)
- * SOLR-8792: ZooKeeper ACL support fixed. (Esther Quansah, Ishan Chattopadhyaya, Steve Rowe)
- * SOLR-9030: The 'downnode' overseer command can trip asserts in ZkStateWriter.
- (Scott Blum, Mark Miller, shalin)
- * SOLR-9036: Solr slave is doing full replication (entire index) of index after master restart.
- (Lior Sapir, Mark Miller, shalin)
- * SOLR-9093: Fix NullPointerException in TopGroupsShardResponseProcessor. (Christine Poerschke)
- * SOLR-9118: HashQParserPlugin should trim partition keys (Joel Bernstein)
- * SOLR-9117: The first SolrCore is leaked after reload. (Jessica Cheng Mallet via shalin)
- * SOLR-9116: Race condition causing occasional SolrIndexSearcher leak when SolrCore is reloaded.
- (Jessica Cheng Mallet via shalin)
- * SOLR-8801: /bin/solr create script always returns exit code 0 when a collection/core already exists.
- (Khalid Alharbi, Marius Grama via Steve Rowe)
- * SOLR-9134: Fix RestManager.addManagedResource return value. (Christine Poerschke)
- * SOLR-9151: Fix SolrCLI so that bin/solr -e cloud example can be run from any CWD (janhoy)
- * SOLR-9165: Spellcheck does not return collations if "maxCollationTries" is used with "cursorMark".
- (James Dyer)
- * SOLR-8612: closing JDBC Statement on failures in DataImportHandler (DIH) (Kristine Jetzke via Mikhail Khludnev)
- * SOLR-8676: keep LOG4J_CONFIG in solr.cmd (Kristine Jetzke via Mikhail Khludnev)
- * SOLR-9176: facet method ENUM was sometimes unnecessarily being rewritten to
- FCS, causing slowdowns (Alessandro Benedetti, Jesse McLaughlin, Alan Woodward)
- Other Changes
- ----------------------
- * SOLR-7516: Improve javadocs for JavaBinCodec, ObjectResolver and enforce the single-usage policy.
- (Jason Gerlowski, Benoit Vanalderweireldt, shalin)
- * SOLR-8967: In SolrCloud mode, under the 'Core Selector' dropdown in the UI the Replication tab won't be displayed
- anymore. The Replication tab is only beneficial to users running Solr in master-slave mode. (Varun Thacker)
- * SOLR-9131: Fix "start solr" text in cluster.vm Velocity template (janhoy)
- * SOLR-9053: Upgrade commons-fileupload to 1.3.1, fixing a potential vulnerability (Jeff Field, Mike Drob via janhoy)
- * SOLR-8866: UpdateLog will now throw an exception if it doesn't know how to serialize a value.
- (David Smiley)
- * SOLR-8933: Solr should not close container streams. (Mike Drob, Uwe Schindler, Mark Miller)
- * SOLR-9037: Replace multiple "/replication" strings with one static constant. (Christine Poerschke)
- * SOLR-9047: zkcli should allow alternative locations for log4j configuration (Gregory Chanan)
- * SOLR-9105: Fix a bunch of typos across 103 files (Bartosz Krasiński via janhoy)
- * SOLR-8445: fix line separator in log4j.properties files (Ahmet Arslan via Mikhail Khludnev)
- * SOLR-8674: Stop ignoring sysprop solr.tests.mergePolicy, and make tests randomly choose between
- setting <mergePolicy> and <mergePolicyFactory>, which was added in SOLR-8621. (Christine Poerschke)
- ======================= 5.5.1 =======================
- Bug Fixes
- ----------------------
- * SOLR-8737: Managed synonym lists do not include the original term in the expand (janhoy)
- * SOLR-8734: fix (maxMergeDocs|mergeFactor) deprecation warnings: in solrconfig.xml
- <maxMergeDocs|mergeFactor> may not be combined with <mergePolicyFactory> and
- <maxMergeDocs|mergeFactor> on their own or combined with <mergePolicy> is a warning.
- (Christine Poerschke, Shai Erera)
- * SOLR-8712: Variable solr.core.instanceDir was not being resolved (Kristine
- Jetzke, Shawn Heisey, Alan Woodward)
- * SOLR-8793: Fix Core admin status API to not fail when computing the size of the segments_N
- file if the file no longer exists (for example, if a commit happened and the IndexReader
- hasn't refreshed yet). In this case the reported size of the file is -1.
- (Shai Erera, Alexey Serba, Richard Coggins)
- * SOLR-8728: ReplicaAssigner throws NPE when a partial list of nodes are only participating in replica
- placement. splitshard should preassign nodes using rules, if rules are present (noble, Shai Erera)
- * SOLR-8838: Returning non-stored docValues is incorrect for negative floats and doubles.
- (Ishan Chattopadhyaya, Steve Rowe)
- * SOLR-8870: AngularJS Query tab no longer URL-encodes the /select part of the request, fixing possible 404 issue
- when Solr is behind a proxy. Also, now supports old-style &qt param when handler not prefixed with "/" (janhoy)
- * SOLR-8725: Allow hyphen in collection, core, shard, and alias name as the non-first character
- (Anshum Gupta) (from 6.0)
- * SOLR-8155: JSON Facet API - field faceting on a multi-valued string field without
- docValues (i.e. UnInvertedField implementation), but with a prefix or with a sort
- other than count, resulted in incorrect results. This has been fixed, and facet.prefix
- support for facet.method=uif has been enabled. (Mikhail Khludnev, yonik)
- * SOLR-8835: JSON Facet API: fix faceting exception on multi-valued numeric fields that
- have docValues. (yonik)
- * SOLR-8908: Fix to OnReconnect listener registration to allow listeners to deregister, such
- as when a core is reloaded or deleted to avoid a memory leak. (Timothy Potter)
- * SOLR-8662: SchemaManager waits correctly for replicas to be notified of a new change
- (sarowe, Noble Paul, Varun Thacker)
- * SOLR-9007: Remove mention of the managed_schema_configs as valid config directory when creating
- the collection for the SolrCloud example. (Timothy Potter)
- * SOLR-8983: Cleanup clusterstate and replicas for a failed create collection request
- (Varun Thacker, Anshum Gupta)
- * SOLR-8578: Successful or not, requests are not always fully consumed by Solrj clients and we
- count on HttpClient or the JVM. (Mark Miller)
- * SOLR-8683: Always consume the full request on the server, not just in the case of an error.
- (Mark Miller)
- * SOLR-8701: CloudSolrClient decides that there are no healthy nodes to handle a request too early.
- (Mark Miller)
- * SOLR-8416: The collections create API should return after all replicas are active.
- (Michael Sun, Mark Miller, Alexey Serba)
- * SOLR-8914: ZkStateReader's refreshLiveNodes(Watcher) is not thread safe. (Scott Blum, hoss,
- sarowe, Erick Erickson, Mark Miller, shalin)
- * SOLR-8973: Zookeeper frenzy when a core is first created. (Janmejay Singh, Scott Blum, shalin)
- * SOLR-8694: DistributedMap/Queue can create too many Watchers and some code simplification.
- (Scott Blum via Mark Miller)
- * SOLR-8633: DistributedUpdateProcess processCommit/deleteByQuery call finish on DUP and
- SolrCmdDistributor, which violates the lifecycle and can cause bugs. (hossman via Mark Miller)
- * SOLR-8656: PeerSync should use same nUpdates everywhere. (Ramsey Haddad via Mark Miller)
- * SOLR-8697, SOLR-8837: Scope ZK election nodes by session to prevent elections from interfering with each other
- and other small LeaderElector improvements. (Scott Blum via Mark Miller, Alan
- Woodward)
- * SOLR-8599: After a failed connection during construction of SolrZkClient attempt to retry until a connection
- can be made. (Keith Laban, Dennis Gove)
- * SOLR-8420: Fix long overflow in sumOfSquares for Date statistics. (Tom Hill, Christine Poerschke,
- Tomás Fernández Löbbe)
- * SOLR-8748: OverseerTaskProcessor limits number of concurrent tasks to just 10 even though the thread pool
- size is 100. The limit has now been increased to 100. (Scott Blum, shalin)
- * SOLR-8375: ReplicaAssigner rejects valid nodes (Kelvin Tan, noble)
- * SOLR-8738: Fixed false success response when invalid deleteByQuery requests intially hit non-leader
- cloud nodes (hossman)
- * SOLR-8771: Multi-threaded core shutdown creates executor per core. (Mike Drob via Mark Miller)
- * SOLR-8145: Fix position of OOM killer script when starting Solr in the background (Jurian Broertjes via
- Timothy Potter)
- * SOLR-8769: Fix document exclusion in mlt query parser in Cloud mode for schemas that have non-"id"
- unique field (Erik Hatcher, Anshum Gupta)
- * SOLR-8728: ReplicaAssigner throws NPE when a partial list of nodes are only participating in replica
- placement. splitshard should preassign nodes using rules, if rules are present (noble, Shai Erera)
- * SOLR-8779: Fix missing InterruptedException handling in ZkStateReader.java (Varun Thacker)
- * SOLR-8449: Fix the core restore functionality to allow restoring multiple times on the same core
- (Johannes Brucher, Varun Thacker)
- * SOLR-8790: Collections API responses contain node name in the core-level responses that are
- returned. (Anshum Gupta)
- * SOLR-8804: Fix a race condition in the ClusterStatus API call whereby the call would fail when a concurrent delete
- collection api command was executed (Alexey Serba, Varun Thacker)
- * SOLR-9016: Fix SolrIdentifierValidator to not allow empty identifiers. (Shai Erera)
- * SOLR-8886: Fix TrieField.toObject(IndexableField) to work for field with docValues
- enabled. (yonik)
- * SOLR-8891: Fix StrField.toObject and toExternal to work with docValue IndexableField
- instances. (yonik)
- * SOLR-8865: Real-time get sometimes fails to retrieve stored fields from docValues.
- (Ishan Chattopadhyaya, yonik)
- * SOLR-9046: Fix solr.cmd that wrongly assumes Jetty will always listen on 0.0.0.0.
- (Bram Van Dam, Uwe Schindler)
- Other Changes
- ----------------------
- * SOLR-8758: Add a new SolrCloudTestCase class, using MiniSolrCloudCluster (Alan
- Woodward)
- ======================= 5.5.0 =======================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release
- Versions of Major Components
- ---------------------
- Apache Tika 1.7
- Carrot2 3.10.4
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.2.13.v20150730
- Upgrading from Solr 5.4
- -----------------------
- * The Solr schema version has been increased to 1.6. Since schema version 1.6, all non-stored docValues fields
- will be returned along with other stored fields when all fields (or pattern matching globs) are specified
- to be returned (e.g. fl=*) for search queries. This behavior can be turned on and off by setting
- 'useDocValuesAsStored' parameter for a field or a field type to true (default since schema version 1.6)
- or false (default till schema version 1.5).
- Note that enabling this property has performance implications because DocValues are column-oriented and may
- therefore incur additional cost to retrieve for each returned document. All example schema are upgraded to
- version 1.6 but any older schemas will default to useDocValuesAsStored=false and continue to work as in
- older versions of Solr. If this new behavior is desirable, then you should set version attribute in your
- schema file to '1.6'. Re-indexing is not necessary to upgrade the schema version.
- Also note that while returning non-stored fields from docValues (default in schema versions 1.6+, unless
- useDocValuesAsStored is false), the values of a multi-valued field are returned in sorted order.
- If you require the multi-valued fields to be returned in the original insertion order, then make your
- multi-valued field as stored. This requires re-indexing.
- See SOLR-8220 for more details.
- * All protected methods from CoreAdminHandler other than handleCustomAction() is removed by SOLR-8476 and can
- no more be overridden. If you still wish to override those methods, override the handleRequestBody()
- * The PERSIST CoreAdmin action which was a NOOP and returned a deprecated message has been removed. See SOLR-8476
- for more details. The corresponding SolrJ action has also been removed.
- * bin/post now defaults application/json files to the /update/json/docs end-point. Use `-format solr` to force
- files to the /update end-point. See SOLR-7042 for more details.
- * In solrconfig.xml the <mergePolicy> element is deprecated in favor of a similar <mergePolicyFactory> element,
- the <mergeFactor> and <maxMergeDocs> elements are also deprecated, please see SOLR-8621 for full details.
- To migrate your existing solrconfig.xml, you can replace elements as follows:
- <!-- TieredMergePolicy example -->
- <!-- deprecated -->
- <mergeFactor>??</mergeFactor>
- <mergePolicy class="org.apache.lucene.index.TieredMergePolicy">
- <bool name="useCompoundFile">???</bool> <!-- deprecated since Lucene/Solr 4.4.0 -->
- ...
- </mergePolicy>
- <!-- replacement -->
- <useCompoundFile>???</useCompoundFile> <!-- since Lucene/Solr 4.4.0 -->
- <mergePolicyFactory class="org.apache.solr.index.TieredMergePolicyFactory">
- <int name="maxMergeAtOnce">??</int> <!-- formerly the <mergeFactor> element implicitly set this -->
- <int name="segmentsPerTier">??</int> <!-- formerly the <mergeFactor> element implicitly set this -->
- ...
- </mergePolicyFactory>
- <!-- Log(ByteSize|Doc)MergePolicy example -->
- <!-- deprecated -->
- <maxMergeDocs>????</maxMergeDocs>
- <mergeFactor>??</mergeFactor>
- <mergePolicy class="org.apache.lucene.index.Log?MergePolicy">
- <bool name="useCompoundFile">???</bool> <!-- deprecated since Lucene/Solr 4.4.0 -->
- ...
- </mergePolicy>
- <!-- replacement -->
- <useCompoundFile>???</useCompoundFile> <!-- since Lucene/Solr 4.4.0 -->
- <mergePolicyFactory class="org.apache.solr.index.Log?MergePolicyFactory">
- <int name="maxMergeDocs">????</int> <!-- formerly the <maxMergeDocs> element set this -->
- <int name="mergeFactor">??</int> <!-- formerly the <mergeFactor> element set this -->
- ...
- </mergePolicyFactory>
- * Clearing up stored async collection api responses via REQUESTSTATUS call is now deprecated and would be
- removed in 6.0. See SOLR-8648 for more details.
- * SOLR-6594: Deprecated the old schema API which will be removed in a later major release
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-7928: Improve CheckIndex to work against HdfsDirectory
- (Mike Drob, Gregory Chanan)
- * SOLR-8378: Add upconfig and downconfig commands to the bin/solr script
- (Erick Erickson)
- * SOLR-8434: Add wildcard support to role, to match any role in RuleBasedAuthorizationPlugin (noble)
- * SOLR-4280: Allow specifying "spellcheck.maxResultsForSuggest" as a percentage of filter
- query results (Markus Jelsma via James Dyer)
- * SOLR-8429: Add a flag 'blockUnknown' to BasicAuthPlugin to block unauthenticated requests (noble)
- * SOLR-8230: JSON Facet API: add "facet-info" into debug section of response when debugQuery=true
- (Michael Sun, yonik)
- * SOLR-8428: RuleBasedAuthorizationPlugin adds an 'all' permission (noble)
- * SOLR-5743: BlockJoinFacetComponent and BlockJoinDocSetFacetComponent for calculating facets by
- child.facet.field parameter with {!parent ..}.. query. They count facets on children documents
- aggregating (deduplicating) counts by parent documents (Dr. Oleg Savrasov via Mikhail Khludnev)
- * SOLR-8220: Read field from DocValues for non stored fields.
- (Keith Laban, yonik, Erick Erickson, Ishan Chattopadhyaya, shalin)
- * SOLR-8470: Make TTL of PKIAuthenticationPlugin's tokens configurable through a system property
- (pkiauth.ttl) (noble)
- * SOLR-8477: Let users choose compression mode in SchemaCodecFactory (Tomás Fernández Löbbe)
- * SOLR-839: XML QueryParser support (defType=xmlparser)
- Lucene includes a queryparser that supports the creation of Lucene queries from XML.
- The queries supported by lucene.queryparser.xml.CoreParser are now supported by the newly
- created solr.search.SolrCoreParser and in future SolrCoreParser could support additional
- queries also.
- Example: <BooleanQuery fieldName="description">
- <Clause occurs="must"> <TermQuery>shirt</TermQuery> </Clause>
- <Clause occurs="mustnot"> <TermQuery>plain</TermQuery> </Clause>
- <Clause occurs="should"> <TermQuery>cotton</TermQuery> </Clause>
- <Clause occurs="must">
- <BooleanQuery fieldName="size">
- <Clause occurs="should"> <TermsQuery>S M L</TermsQuery> </Clause>
- </BooleanQuery>
- </Clause>
- </BooleanQuery>
- (Erik Hatcher, Karl Wettin, Daniel Collins, Nathan Visagan, Ahmet Arslan, Christine Poerschke)
- * SOLR-8312: Add domain size and numBuckets to facet telemetry info (facet debug info
- for the new Facet Module). (Michael Sun, yonik)
- * SOLR-8534: Add generic support for collection APIs to be async. Thus more actions benefit from having async
- support. The commands that additionally get async support are: delete/reload collection, create/delete alias,
- create/delete shard, delete replica, add/delete replica property, add/remove role,
- overseer status, balance shard unique, rebalance leaders, modify collection, migrate state format (Varun Thacker)
- * SOLR-4619: Improve PreAnalyzedField query analysis. (Andrzej Bialecki, Steve Rowe)
- * SOLR-8560: Added RequestStatusState enum which can be used when comparing states of
- asynchronous requests. (Shai Erera)
- * SOLR-8586: added index fingerprint, a hash over all versions currently in the index.
- PeerSync now uses this to check if replicas are in sync. (yonik)
- * SOLR-8500: Allow the number of threads ConcurrentUpdateSolrClient StreamingSolrClients configurable by a
- system property. NOTE: this is an expert option and can result in more often needing to do full index replication
- for recovery, the sweet spot for using this is very high volume, leader-only indexing. (Tim Potter, Erick Erickson)
- * SOLR-8642: SOLR allows creation of collections with invalid names
- (Jason Gerlowski via Erick Erickson)
- * SOLR-8621: Deprecate <mergePolicy> in favor of <mergePolicyFactory>. It allows to configure
- both the "simple" merge policies, but also more advanced ones, e.g. UpgradeIndexMergePolicy.
- (Christine Poerschke, Shai Erera)
- * SOLR-8648: DELETESTATUS API for selective deletion and flushing of stored async collection API responses.
- (Anshum Gupta)
- * SOLR-8466: adding facet.method=uif to bring back UnInvertedField faceting which is used to work on
- facet.method=fc. It's more performant for rarely changing indexes. Note: it ignores prefix and contains yet.
- (Jamie Johnson via Mikhail Khludnev)
- Bug Fixes
- ----------------------
- * SOLR-8175: Word Break Spellchecker would throw AIOOBE with certain queries containing
- "should" clauses. (Ryan Josal via James Dyer)
- * SOLR-2556: The default spellcheck query converter was ignoring terms consisting entirely
- of digits. (James Dyer)
- * SOLR-8366: ConcurrentUpdateSolrClient attempts to use response's content type as charset encoding
- for parsing exception. (shalin)
- * SOLR-6271: Fix ConjunctionSolrSpellChecker to not compare StringDistance by instance.
- (Igor Kostromin via James Dyer)
- * SOLR-7304: Fix Spellcheck Collate to not invalidate range queries. (James Dyer)
- * SOLR-8373: KerberosPlugin: Using multiple nodes on same machine leads clients to
- fetch TGT for every request (Ishan Chattopadhyaya via noble)
- * SOLR-8367: Fix the LeaderInitiatedRecovery 'all replicas participate' fail-safe.
- (Mark Miller, Mike Drob)
- * SOLR-8401: Windows start script fails when executed from a different drive.
- (Nicolas Gavalda via Erick Erickson)
- * SOLR-6992: Fix "Files" UI to show the managed-schema file as well.
- (Shawn Heisey, Varun Thacker)
- * SOLR-2649: MM ignored in edismax queries with operators.
- (Greg Pendlebury, Jan Høydahl et. al. via Erick Erickson)
- * SOLR-8372: Canceled recovery can rarely lead to inconsistent shards:
- If a replica is recovering via index replication, and that recovery fails
- (for example if the leader goes down), and then some more updates are received
- (there could be a few left to be processed from the leader that just went down),
- and then that replica is brought down, it will think it is up-to-date when
- restarted. (shalin, Mark Miller, yonik)
- * SOLR-8419: TermVectorComponent for distributed search when distrib.singlePass could include term
- vectors for documents that matched the query yet weren't in the returned documents. (David Smiley)
- * SOLR-8015: HdfsLock may fail to close a FileSystem instance if it cannot immediately
- obtain an index lock. (Mark Miller)
- * SOLR-8422: When authentication enabled, requests fail if sent to a node that doesn't host
- the collection (noble)
- * SOLR-8059: &debug=results for distributed search when distrib.singlePass (sometimes activated
- automatically) could result in an NPE. (David Smiley, Markus Jelsma)
- * SOLR-8460: /analysis/field could throw exceptions for custom attributes. (David Smiley, Uwe Schindler)
- * SOLR-8276: Atomic updates and realtime-get do not work with non-stored docvalues.
- (Ishan Chattopadhyaya, yonik via shalin)
- * SOLR-7462: AIOOBE in RecordingJSONParser (Scott Dawson, noble)
- * SOLR-8494: SimplePostTool and therefore the bin/post script cannot upload files larger than 2.1GB. (shalin)
- * SOLR-8451: We should not call method.abort in HttpSolrClient or HttpSolrCall#remoteQuery and
- HttpSolrCall#remoteQuery should not close streams. (Mark Miller)
- * SOLR-8450: Our HttpClient retry policy is too permissive. (Mark Miller, shalin)
- * SOLR-8533: Raise default maxUpdateConnections and maxUpdateConnectionsPerHost to 100k each.
- (Mark Miller)
- * SOLR-8453: Solr should attempt to consume the request inputstream on errors as we cannot
- count on the container to do it. (Mark Miller, Greg Wilkins, yonik, Joakim Erdfelt)
- * SOLR-6279: cores?action=UNLOAD now waits for the core to close before unregistering it from ZK.
- (Christine Poerschke)
- * SOLR-2798: Fixed local params to work correctly with multivalued params
- (Demian Katz via hossman)
- * SOLR-8541: Highlighting a geo RPT field would throw an NPE instead of doing nothing.
- (Pawel Rog via David Smiley)
- * SOLR-8548: Core discovery was not following symlinks (Aaron LaBella via Alan
- Woodward)
- * SOLR-8564: Fix Embedded ZooKeeper to use <solrHome>/zoo_data for it's data directory
- * SOLR-8371: Try and prevent too many recovery requests from stacking up and clean up some faulty
- cancel recovery logic. (Mark Miller)
- * SOLR-8582 : memory leak in JsonRecordReader affecting /update/json/docs. Large payloads
- cause OOM (noble, shalin)
- * SOLR-8605: Regular expression queries starting with escaped forward slash caused
- an exception. (Scott Blum, yonik)
- * SOLR-8607: The Schema API refuses to add new fields that match existing dynamic fields.
- (Jan Høydahl, Steve Rowe)
- * SOLR-8575: Fix HDFSLogReader replay status numbers, a performance bug where we can reopen
- FSDataInputStream much too often, and an hdfs tlog data integrity bug.
- (Mark Miller, Patrick Dvorack, yonik)
- * SOLR-8651: The commitWithin parameter is not passed on for deleteById in UpdateRequest in
- distributed queries (Jessica Cheng Mallet via Erick Erickson)
- * SOLR-8551: Make collection deletion more robust. (Mark Miller)
- Optimizations
- ----------------------
- * SOLR-8501: Specify the entity request size when known in HttpSolrClient. (Mark Miller)
- * SOLR-8615: Just like creating cores, we should use multiple threads when closing cores.
- (Mark Miller)
- * SOLR-7281: Add an overseer action to publish an entire node as 'down'. (Mark Miller, shalin)
- * SOLR-8669: Non binary responses use chunked encoding because we flush the outputstream early.
- (Mark Miller)
- Other Changes
- ----------------------
- * LUCENE-6900: Added test for score ordered grouping, and refactored TopGroupsResultTransformer.
- (David Smiley)
- * SOLR-8336: CoreDescriptor now takes a Path for its instance directory, rather
- than a String (Alan Woodward)
- * SOLR-8351: Improve HdfsDirectory toString representation
- (Mike Drob via Gregory Chanan)
- * SOLR-8321: add a (SolrQueryRequest free) SortSpecParsing.parseSortSpec variant
- (Christine Poerschke)
- * SOLR-8338: in OverseerTest replace strings such as "collection1" and "state" with variable
- or enum equivalent (Christine Poerschke)
- * SOLR-8333: Several API tweaks so that public APIs were no longer refering to private classes
- (ehatcher, Shawn Heisey, hossman)
- * SOLR-8357: UpdateLog.RecentUpdates now implements Closeable (Alan Woodward)
- * SOLR-8339: Refactor SolrDocument and SolrInputDocument to have a common base abstract class
- called SolrDocumentBase. Deprecated methods toSolrInputDocument and toSolrDocument in ClientUtils.
- (Ishan Chattopadhyaya via shalin)
- * SOLR-8353: Support regex for skipping license checksums (Gregory Chanan)
- * SOLR-8313: SimpleQueryParser doesn't use MultiTermAnalysis for Fuzzy Queries (Tom Hill via Erick Erickson)
- * SOLR-8359: Restrict child classes from using parent logger's state
- (Jason Gerlowski, Mike Drob, Anshum Gupta)
- * SOLR-8131: All example config sets now explicitly use the ManagedIndexSchemaFactory
- instead of ClassicIndexSchemaFactory. This means that the Schema APIs ( /<collection>/schema )
- are enabled by default and the schema is mutable. The schema file will be called managed-schema
- (Uwe Schindler, shalin, Varun Thacker)
- * SOLR-8381: Cleanup data_driven managed-schema and solrconfig.xml files. Commented out copyFields are removed
- and solrconfig.xml doesn't refer to field which are not defined. (Varun Thacker)
- * SOLR-7774: revise BasicDistributedZkTest.test logic w.r.t. 'commitWithin did not work on some nodes'
- (Christine Poerschke)
- * SOLR-8360: simplify ExternalFileField.getValueSource implementation (Christine Poerschke)
- * SOLR-8387: All example configs shipped with Solr explicitly use ManagedIndexSchemaFactory, the schema file will
- be called managed-schema instead of schema.xml . It is not advised to use hand edit the managed-schema. You should
- use the schema APIs instead ( /<collection>/schema ) . If you do not want this behaviour in the example configs,
- before you start solr rename managed-schema to schema.xml and change the schemaFactory in solrconfig.xml file
- to explicitly use ClassicIndexSchemaFactory instead : <schemaFactory class="ClassicIndexSchemaFactory"/>
- (Varun Thacker)
- * SOLR-8305: replace LatLonType.getValueSource's QParser use (Christine Poerschke)
- * SOLR-8388: factor out response/TestSolrQueryResponse.java from servlet/ResponseHeaderTest.java
- more TestSolrQueryResponse.java tests; add SolrReturnFields.toString method, ReturnFieldsTest.testToString test;
- (Christine Poerschke)
- * SOLR-8383: SolrCore.java + QParserPlugin.java container initialCapacity tweaks
- (Christine Poerschke, Mike Drob)
- * LUCENE-6925: add RandomForceMergePolicy class in test-framework (Christine Poerschke)
- * SOLR-8404: tweak SolrQueryResponse.getToLogAsString, add TestSolrQueryResponse.testToLog (Christine Poerschke)
- * SOLR-8352: randomise unload order in UnloadDistributedZkTest.testUnloadShardAndCollection (Christine Poerschke)
- * SOLR-8414: AbstractDistribZkTestBase.verifyReplicaStatus could throw NPE (Christine Poerschke)
- * SOLR-8410: Add all read paths to 'read' permission in RuleBasedAuthorizationPlugin (noble)
- * SOLR-8279: Add a new test fault injection approach and a new SolrCloud test that stops and starts the cluster
- while indexing data and with random faults. (Mark Miller)
- * SOLR-8419: TermVectorComponent for distributed search now requires a uniqueKey in the schema. Also, it no longer
- returns "uniqueKeyField" in the response. (David Smiley)
- * SOLR-8317: add & use responseHeader and response accessors to SolrQueryResponse. (Christine Poerschke)
- * SOLR-8452: replace "partialResults" occurrences with SolrQueryResponse.RESPONSE_HEADER_PARTIAL_RESULTS_KEY
- (Christine Poerschke)
- * SOLR-8454: ZkStateReader logging improvements and cleanup of dead code (Shai Erera, Anshum Gupta)
- * SOLR-8455: RecovertStrategy logging improvements and sleep-between-recovery-attempts bug fix.
- (Shai Erera)
- * SOLR-8481: TestSearchPerf no longer needs to duplicate SolrIndexSearcher.(NO_CHECK_QCACHE|NO_CHECK_FILTERCACHE)
- (Christine Poerschke)
- * SOLR-8486: No longer require jar/unzip for bin/solr (Steven E. Harris, janhoy)
- * SOLR-8483: relocate 'IMPORTANT NOTE' in open-exchange-rates.json test-file to avoid
- OpenExchangeRatesOrgProvider.java warnings (Christine Poerschke)
- * SOLR-8489: TestMiniSolrCloudCluster.createCollection to support extra & alternative collectionProperties
- (Christine Poerschke)
- * SOLR-8482: add & use QueryCommand.[gs]etTerminateEarly accessors. (Christine Poerschke)
- * SOLR-8498: Improve error message when a large value is stored in an indexed string field. (shalin)
- * SOLR-8484: refactor update/SolrIndexConfig.LOCK_TYPE_* into core/DirectoryFactory.LOCK_TYPE_*
- (Christine Poerschke)
- * SOLR-8504: (IndexSchema|SolrIndexConfig)Test: private static finals for
- solrconfig.xml and schema.xml String literals. (Christine Poerschke)
- * SOLR-8505: core/DirectoryFactory.LOCK_TYPE_HDFS - add & use it instead of String literals
- (Christine Poerschke)
- * SOLR-7042: bin/post now uses /update/json/docs for application/json content types, including support for
- .jsonl (JSON Lines) files. (Erik Hatcher and shalin)
- * SOLR-8476: Refactor and cleanup CoreAdminHandler (noble, Varun Thacker)
- * SOLR-8535: Support forcing define-lucene-javadoc-url to be local (Gregory Chanan)
- * SOLR-8549: Solr start script checks for cores which have failed to load as well before attempting to
- create a core with the same name (Varun Thacker)
- * SOLR-8555: SearchGroupShardResponseProcessor (initialCapacity) tweaks (Christine Poerschke)
- * LUCENE-6978: Refactor several code places that lookup locales
- by string name to use BCP47 locale tag instead. LuceneTestCase
- now also prints locales on failing tests this way. In addition,
- several places in Solr now additionally support BCP47 in config
- files. (Uwe Schindler, Robert Muir)
- * SOLR-7907: Remove CLUSTERSTATUS related exclusivity checks while running commands in the Overseer because the
- CLUSTERSTATUS request is served by the individual nodes itself and not via the Overseer node (Varun Thacker)
- * SOLR-8566: various initialCapacity tweaks (Fix Versions: trunk 5.5)
- (Christine Poerschke)
- * SOLR-8565: add & use CommonParams.(ROWS|START)_DEFAULT constants (Christine Poerschke)
- * SOLR-8595: Use BinaryRequestWriter by default in HttpSolrClient and ConcurrentUpdateSolrClient. (shalin)
- * SOLR-8597: add default, no-op QParserPlugin.init(NamedList) method (Christine Poerschke)
- * SOLR-7968: Make QueryComponent more extensible. (Markus Jelsma via David Smiley)
- * SOLR-8600: add & use ReRankQParserPlugin parameter [default] constants,
- changed ReRankQuery.toString to use StringBuilder. (Christine Poerschke)
- * SOLR-8308: Core gets inaccessible after RENAME operation with special characters
- (Erik Hatcher, Erick Erickson)
- * SOLR-3141: Warn in logs when expensive optimize calls are made (yonik, janhoy)
- ================== 5.4.1 ==================
- Bug Fixes
- ----------------------
- * SOLR-8460: /analysis/field could throw exceptions for custom attributes. (David Smiley, Uwe Schindler)
- * SOLR-8373: KerberosPlugin: Using multiple nodes on same machine leads clients to
- fetch TGT for every request (Ishan Chattopadhyaya via noble)
- * SOLR-8059: &debug=results for distributed search when distrib.singlePass (sometimes activated
- automatically) could result in an NPE. (David Smiley, Markus Jelsma)
- * SOLR-8422: When authentication enabled, requests fail if sent to a node that doesn't host
- the collection (noble)
- * SOLR-7462: AIOOBE in RecordingJSONParser (Scott Dawson, noble)
- * SOLR-8496: SolrIndexSearcher.getDocSet(List<Query>) incorrectly included deleted documents
- when all of the queries were uncached (or there was no filter cache). This caused
- multi-select faceting (including the JSON Facet API) to include deleted doc counts
- when the remaining non-excluded filters were all uncached. This bug was first introduced in 5.3.0
- (Andreas Müller, Vasiliy Bout, Erick Erickson, Shawn Heisey, Hossman, yonik)
- * SOLR-8418: Adapt to changes in LUCENE-6590 for use of boosts with MLTHandler and
- Simple/CloudMLTQParser (Jens Wille, Ramkumar Aiyengar)
- New Features
- ----------------------
- * SOLR-8470: Make TTL of PKIAuthenticationPlugin's tokens configurable through a system property
- (pkiauth.ttl) (noble)
- ================== 5.4.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release
- Versions of Major Components
- ---------------------
- Apache Tika 1.7
- Carrot2 3.10.4
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.2.13.v20150730
- Upgrading from Solr 5.3
- -----------------------
- * DefaultSimilarityFactory has been renamed to ClassicSimilarityFactory to match the underlying rename of
- DefaultSimilarity to ClassicSimilarity and the (eventual) move away from using it as a default.
- If you currently have DefaultSimilarityFactory explicitly referenced in your schema.xml, you will now get
- a warning urging you to edit your config to use the functionally identical ClassicSimilarityFactory.
- DefaultSimilarityFactory will be removed completely in Solr 6. See SOLR-8239 for more details.
- * SOLR-7859: The following APIs are now deprecated:
- - SolrCore.getStartTime: Use SolrCore.getStartTimeStamp instead.
- - SolrIndexSearcher.getOpenTime: Use SolrIndexSearcher.getOpenTimeStamp instead.
- * SOLR-8307: EmptyEntityResolver was moved from core to solrj, and moved from the org.apache.solr.util
- package to org.apache.solr.common. If you are using this class, you will need to adjust the import package.
- * Logger declarations in most source files have changed to code that
- no longer needs to explicitly state the class name. This fixes situations
- where a logger for a different class was incorrectly used. See SOLR-8324
- and its sub-issues for details.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-5756: A utility Collection API to move a collection from shared clusterstate.json (stateFormat=1,
- default until 4.x) to the per-collection state.json stored in ZooKeeper (stateFormat=2,
- default since 5.0) seamlessly without any application down-time.
- Example:
- http://localhost:8983/solr/admin/collections?action=MIGRATESTATEFORMAT&collection=<collection_name>
- (Noble Paul, Scott Blum, shalin)
- * SOLR-7219: filterCache access added to the solr query syntax.
- Example: description:HDTV OR filter(+promotion:tv +promotion_date:[NOW/DAY TO NOW/DAY+7DAY])
- (yonik)
- * SOLR-7775: Allow fromIndex parameter to ScoreJoinQParserPlugin {!join score=.. fromIndex=..}..
- to refer to a single-sharded collection that has a replica on all nodes where there is a
- replica in the to index (Andrei Beliakov via Mikhail Khludnev)
- * SOLR-7961: Print Solr's version with command bin/solr version (janhoy)
- * SOLR-7789: Introduce a ConfigSet management API (Gregory Chanan)
- * SOLR-4316: Add a collections dropdown to angular admin UI (Upayavira, Shalin Shekhar Mangar)
- * SOLR-7915: Provide pluggable context tool support for VelocityResponseWriter (Erik Hatcher)
- * LUCENE-6795: SystemInfoHandler was improved to also show detailed operating
- system statistics on IBM J9 virtual machines. It also no longer fails on Java 9
- with Jigsaw module system. (Uwe Schindler)
- * SOLR-8053: Basic auth support in SolrJ (noble)
- * SOLR-7995: Add a LIST command to ConfigSets API (Gregory Chanan)
- * SOLR-4388: In Angular UI, add a Collections UI when in cloud mode (Upayavira)
- * SOLR-7858, SOLR-8199: Add links between original and new Admin UIs (Upayavira)
- * SOLR-7888: Analyzing suggesters can now filter suggestions by a context field (Arcadius Ahouansou, janhoy)
- * SOLR-8217: JSON Facet API: add "method" param to terms/field facets to give an execution
- hint for what method should be used to facet. (yonik)
- * SOLR-8113: CloneFieldUpdateProcessorFactory now supports choosing a "dest" field name based on a regex
- pattern and replacement init options. (Gus Heck, hossman)
- * SOLR-8139: Create/delete fields/dynamic fields/copy fields via schema tab on Angular UI
- * SOLR-8166: Introduce possibility to configure ParseContext in
- ExtractingRequestHandler/ExtractingDocumentLoader (Andriy Binetsky
- via Uwe Schindler)
- * SOLR-7569: A collection API to force elect a leader, called FORCELEADER, when all replicas in a shard are down
- (Ishan Chattopadhyaya, Mark Miller, shalin, noble)
- * SOLR-6168: Add a 'sort' local param to the collapse QParser to support using complex sort options
- to select the representitive doc for each collapsed group. (Umesh Prasad, hossman)
- * SOLR-8329: SchemaSimilarityFactory now supports a 'defaultSimFromFieldType' init option for using
- a fieldType name to identify which Similarity to use as a default. (hossman)
- * SOLR-7912: Add boost support, and also exclude the queried document in MoreLikeThis QParser
- (Jens Wille via Anshum Gupta)
- Bug Fixes
- ----------------------
- * SOLR-7859: Fix usage of currentTimeMillis instead of nanoTime in multiple places,
- whitelist valid uses of currentTimeMillis (Ramkumar Aiyengar)
- * SOLR-7836: Possible deadlock when closing refcounted index writers.
- (Jessica Cheng Mallet, Erick Erickson, Mark Miller, yonik)
- * SOLR-7869: Overseer does not handle BadVersionException correctly and, in some cases,
- can go into an infinite loop if cluster state in ZooKeeper is modified externally.
- (Scott Blum, shalin)
- * SOLR-7920: Resolve XSS issue in Admin UI Schema Browser (David Chiu via Upayavira)
- * SOLR-7935: Fix very rare race condition that can cause an update to fail
- via NullPointerException during a core reload. (yonik)
- * SOLR-7941: multivalued params are concatenated when using config API (noble)
- * SOLR-7956: There are interrupts on shutdown in places that can cause ChannelAlreadyClosed
- exceptions which prevents proper closing of transaction logs, interfere with the IndexWriter,
- the hdfs client and other things. (Mark Miller, Scott Blum)
- * SOLR-7954: Fixed an integer overflow bug in the HyperLogLog code used by the 'cardinality' option
- of stats.field to prevent ArrayIndexOutOfBoundsException in a distributed search when a large precision
- is selected and a large number of values exist in each shard (hossman)
- * SOLR-7844: Zookeeper session expiry during shard leader election can cause multiple leaders.
- (Mike Roberts, Mark Miller, Jessica Cheng)
- * SOLR-7984: wrong and misleading error message 'no default request handler is registered' (noble, hossman)
- * SOLR-8001: Fixed bugs in field(foo,min) and field(foo,max) when some docs have no values
- (David Smiley, hossman)
- * SOLR-7819: ZK connection loss or session timeout do not stall indexing threads anymore. All activity
- related to leader initiated recovery is performed by a dedicated LIR thread in the background.
- (Ramkumar Aiyengar, shalin)
- * SOLR-7746: Ping requests stopped working with distrib=true in Solr 5.2.1.
- (Alexey Serba, Michael Sun via Gregory Chanan)
- * SOLR-6547: ClassCastException in SolrResponseBase.getQTime on update response from CloudSolrClient
- when parallelUpdates is enabled (default) and multiple docs are sent as a single update.
- (kevin, hossman, shalin)
- * SOLR-8058: Fix the exclusion filter so that collections that start with js, css, img, tpl
- can be accessed. (Upayavira, Steve Rowe, Anshum Gupta)
- * SOLR-8069: Ensure that only the valid ZooKeeper registered leader can put a replica into Leader
- Initiated Recovery. (Mark Miller, Jessica Cheng, Anshum Gupta)
- * SOLR-8077: Replication can still cause index corruption. (Mark Miller)
- * SOLR-8104: Config API does not work for spellchecker (noble)
- * SOLR-8095: Allow disabling HDFS Locality Metrics and disable by default as it may have performance
- implications on rapidly changing indexes. (Mike Drob via Mark Miller)
- * SOLR-8085: Fix a variety of issues that can result in replicas getting out of sync. (yonik, Mark Miller)
- * SOLR-8094: HdfsUpdateLog should not replay buffered documents as a replacement to dropping them.
- (Mark Miller)
- * SOLR-8075: Leader Initiated Recovery should not stop a leader that participated in an election with all
- of it's replicas from becoming a valid leader. (Mark Miller)
- * SOLR-8072: Rebalance leaders feature does not set CloudDescriptor#isLeader to false when bumping leaders.
- (Mark Miller)
- * SOLR-7666: Many small fixes to Angular UI (Upayavira, Alexandre Rafalovitch)
- * SOLR-7967: AddSchemaFieldsUpdateProcessorFactory does not check if the ConfigSet is immutable (Gregory Chanan)
- * SOLR-6188: Skip the automatic loading of resources in the "lib" subdirectory
- by SolrResourceLoader, but only if we are loading resources from the solr
- home directory. Fixes the inability to use ICU analysis components with a
- "solr." prefix on the classname. (Shawn Heisey)
- * SOLR-8130: Solr's hdfs safe mode detection does not catch all cases of being in safe mode.
- (Mark Miller, Mike Drob)
- * SOLR-8128: Set v.locale specified locale for all LocaleConfig extending VelocityResponseWriter tools.
- (Erik Hatcher)
- * SOLR-8152: Overseer Task Processor/Queue can miss responses, leading to timeouts.
- (Gregory Chanan)
- * SOLR-8107: bin/solr -f should use exec to start the JVM (Martijn Koster via Timothy Potter)
- * SOLR-8050: Partial update on document with multivalued date field fails to parse date and can
- also fail to remove dates in some cases. (Burkhard Buelte, Luc Vanlerberghe, shalin)
- * SOLR-8167: Authorization framework does not work with POST params (noble)
- * SOLR-8162: JmxMonitoredMap#clear triggers a query on all the MBeans thus generating lots of warnings.
- (Marius Dumitru Florea, shalin)
- * SOLR-7843: DataImportHandler's delta imports leak memory because the delta keys are kept in memory
- and not cleared after the process is finished. (Pablo Lozano via shalin)
- * SOLR-8189: eTag calculation during HTTP Cache Validation uses unsynchronized WeakHashMap causing
- threads to be stuck in runnable state. (shalin)
- * SOLR-7993: Raw json output for fields stopped working in 5.3.0 when requested fields do not include
- the unique key field name. (Bill Bell, Ryan McKinley via shalin)
- * SOLR-8192: JSON Facet API allBuckets:true did not work correctly when faceting
- on a multi-valued field with sub-facets / facet functions. (yonik)
- * SOLR-8206: JSON Facet API limit:0 did not always work correctly. (yonik)
- * SOLR-8126: update-<component-name> does not work if the component is only
- present in solrconfig.xml (noble)
- * SOLR-8203: Stop processing updates more quickly on node shutdown. When a node
- is shut down, streaming updates would continue, but new update requests would
- be aborted. This can cause big update reorders that can cause replicas to
- get out of sync. (Mark Miller, yonik)
- * SOLR-6406: ConcurrentUpdateSolrClient hang in blockUntilFinished. If updates are still
- flowing and shutdown is called on the executor service used by ConcurrentUpdateSolrClient,
- a race condition can cause that client to hang in blockUntilFinished.
- (Mark Miller, yonik)
- * SOLR-8215: Only active replicas should handle incoming requests against a collection (Varun Thacker)
- * SOLR-8223: Avoid accidentally swallowing OutOfMemoryError (in LeaderInitiatedRecoveryThread.java
- or CoreContainer.java) (Mike Drob via Christine Poerschke)
- * SOLR-8255: MiniSolrCloudCluster needs to use a thread-safe list to keep track
- of its child nodes (Alan Woodward)
- * SOLR-8254: HttpSolrCore.getCoreByCollection() can throw NPE (Alan Woodward,
- Mark Miller)
- * SOLR-8262: Comment out /stream handler from sample solrconfig.xml's for security reasons
- (Joel Bernstein)
- * SOLR-7989: After a new leader is elected it should change it's state to ACTIVE even
- if the last published state is something else if it has already registered with ZK.
- (Ishan Chattopadhyaya, Mark Miller via noble)
- * SOLR-8287: TrieDoubleField and TrieLongField now override toNativeType
- (Ishan Chattopadhyaya via Christine Poerschke)
- * SOLR-8284: JSON Facet API - fix NPEs when short form "sort:index" or "sort:count"
- are used. (Michael Sun via yonik)
- * SOLR-8295: Fix NPE in collapse QParser when collapse field is missing from all docs in a segment (hossman)
- * SOLR-8280: Fixed bug in SimilarityFactory initialization that prevented SolrCoreAware factories -- such
- as SchemaSimilarityFactory -- from functioning properly with managed schema features. (hossman)
- * SOLR-5971: Fix error 'Illegal character in query' when proxying request.
- (Uwe Schindler, Ishan Chattopadhyaya, Eric Bus)
- * SOLR-8307: Fix XXE vulnerability in MBeansHandler "diff" feature (Erik Hatcher)
- * SOLR-8073: Solr fails to start on Windows with obscure errors when using relative path.
- (Alexandre Rafalovitch, Ishan Chattopadhyaya via shalin)
- * SOLR-7169: bin/solr status should return exit code 3, not 0 if Solr is not running
- (Dominik Siebel via Timothy Potter)
- * SOLR-8341: Fix JSON Facet API excludeTags when specified in the
- form of domain:{excludeTags:mytag} (yonik)
- * SOLR-8326: If BasicAuth enabled, inter node requests fail after node restart (noble, Anshum Gupta)
- * SOLR-8340: Fixed NullPointerException in HighlightComponent.
- (zengjie via Christine Poerschke)
- * SOLR-8355: update permissions were failing node recovery (noble , Anshum Gupta)
- Optimizations
- ----------------------
- * SOLR-7918: Filter (DocSet) production from term queries has been optimized and
- is anywhere from 20% to over 100% faster and produces less garbage on average.
- (yonik)
- * SOLR-6760: New optimized DistributedQueue implementation for overseer increases
- message processing performance by ~470%.
- (Noble Paul, Scott Blum, shalin)
- * SOLR-6629: Watch /collections zk node on all nodes so that cluster state updates
- are more efficient especially when cluster has a mix of collections in stateFormat=1
- and stateFormat=2. (Scott Blum, shalin)
- * SOLR-7971: Reduce memory allocated by JavaBinCodec to encode small strings by an amount
- equal to the string.length(). JavaBinCodec now uses a double pass approach to write strings
- larger than 64KB to avoid allocating buffer memory equal to string's UTF8 size.
- (yonik, Steve Rowe, Mikhail Khludnev, Noble Paul, shalin)
- * SOLR-7983: Utils.toUTF8 uses larger buffer than necessary for holding UTF8 data. (shalin)
- * SOLR-8222: JSON Facet API optimization to faceting by count on docvalue fields (or indexed fields
- with method=dv) when there are multiple hits expected for enoug buckets. For example, this
- more than doubled the performance of faceting 5M documents over a field with 1M unique values.
- (yonik)
- * SOLR-8288: DistributedUpdateProcessor#doFinish should explicitly check and ensure it
- does not try to put itself into LIR. (Mark Miller)
- Other Changes
- ----------------------
- * SOLR-8294: Cleanup solrconfig.xmls under solr/example/example-DIH/solr (removed
- obsolete clustering handler sections). (Dawid Weiss)
- * SOLR-7969: Unavailable clustering engines should not fail the core. (Dawid Weiss)
- * SOLR-7790, SOLR-7791: Update Carrot2 clustering component to
- version 3.10.4. Upgrade HPPC library to version 0.7.1. (Dawid Weiss)
- * SOLR-7831: Start Scripts: Allow a configurable stack size [-Xss] (Steve Davids via Mark Miller)
- * SOLR-7870: Write a test which asserts that requests to stateFormat=2 collection succeed on a node
- even after all local replicas of that collection have been removed.
- (Scott Blum via shalin)
- * SOLR-7902: Split out use of child timers from RTimer to a sub-class
- (Ramkumar Aiyengar)
- * SOLR-7943: Upgrade Jetty to 9.2.13.v20150730. (Bill Bell, shalin)
- * SOLR-7007: DistributedUpdateProcessor now logs replay flag as boolean instead of int
- (Mike Drob via Christine Poerschke)
- * SOLR-7960: Start scripts now gives generic help for bin/solr -h and bin/solr --help (janhoy)
- * SOLR-7970: Factor out a SearchGroupsFieldCommandResult class.
- (Christine Poerschke)
- * SOLR-7942: Previously removed unlockOnStartup option (LUCENE-6508) now logs warning if configured,
- will be an error in 6.0. Also improved error msg if an index is locked on startup (hossman)
- * SOLR-7979: Fix two typos (in a CoreAdminHandler log message and a TestCloudPivotFacet comment).
- (Mike Drob via Christine Poerschke)
- * SOLR-7966: Solr Admin UI Solr now sets the HTTP header X-Frame-Options to DENY
- to avoid clickjacking. (yonik)
- * SOLR-7999: SolrRequestParser tests no longer depend on external URLs
- that may fail to work. (Uwe Schindler)
- * SOLR-8034: Leader no longer puts replicas in recovery in case of a failed update, when minRF
- isn't achieved. (Jessica Cheng, Timothy Potter, Anshum Gupta)
- * SOLR-8066: SolrCore.checkStale method doesn't restore interrupt status. (shalin)
- * SOLR-8068: Throw a SolrException if the core container has initialization errors or is
- shutting down (Ishan Chattopadhyaya, Noble Paul, Anshum Gupta)
- * SOLR-8083: Convert the ZookeeperInfoServlet to a handler at /admin/zookeeper (noble)
- * SOLR-8025: remove unnecessary ResponseBuilder.getQueryCommand() calls (Christine Poerschke)
- * SOLR-8150: Fix build failure due to too much output from QueryResponseTest (janhoy)
- * SOLR-8151: OverseerCollectionMessageHandler was logging info data as WARN
- (Alan Woodward)
- * SOLR-8116: SearchGroupsResultTransformer tweaks (String literals, list/map initialCapacity)
- (Christine Poerschke)
- * SOLR-8114: in Grouping.java rename groupSort and sort to withinGroupSort and groupSort
- (Christine Poerschke)
- * SOLR-8074: LoadAdminUIServlet directly references admin.html (Mark Miller, Upayavira)
- * SOLR-8195: IndexFetcher download trace now includes bytes-downloaded[-per-second]
- (Christine Poerschke)
- * SOLR-4854: Add a test to assert that [elevated] DocTransfer works correctly with javabin
- response format. (Ray, shalin)
- * SOLR-8196: TestMiniSolrCloudCluster.testStopAllStartAll case plus necessary
- MiniSolrCloudCluster tweak (Christine Poerschke)
- * SOLR-8221: MiniSolrCloudCluster should create subdirectories for its nodes
- (Alan Woodward)
- * SOLR-8218: DistributedUpdateProcessor (initialCapacity) tweaks
- (Christine Poerschke)
- * SOLR-8147: contrib/analytics FieldFacetAccumulator now throws IOException instead of SolrException
- (Scott Stults via Christine Poerschke)
- * SOLR-8239: Added ClassicSimilarityFactory, marked DefaultSimilarityFactory as deprecated. (hossman)
- * SOLR-8253: AbstractDistribZkTestBase can sometimes fail to shut down its
- ZKServer (Alan Woodward)
- * SOLR-8260: Use NIO2 APIs in core discovery (Alan Woodward)
- * SOLR-8259: Deprecate JettySolrRunner.getDispatchFilter(), add
- .getSolrDispatchFilter() and .getCoreContainer() (Alan Woodward)
- * SOLR-8278: Use NIO2 APIs in ConfigSetService (Alan Woodward)
- * SOLR-8286: Remove instances of solr.hdfs.blockcache.write.enabled from tests
- and docs (Gregory Chanan)
- * SOLR-8269: Upgrade commons-collections to 3.2.2. This fixes a known serialization vulnerability (janhoy)
- * SOLR-8246: Fix SolrCLI to clean the config directory in case creating a core failed.
- (Jason Gerlowski via Shai Erera)
- * SOLR-8290: remove SchemaField.checkFieldCacheSource's unused QParser argument (Christine Poerschke)
- * SOLR-8300: Use constants for the /overseer_elect znode (Varun Thacker)
- * SOLR-8283: factor out StrParser from QueryParsing.StrParser and SortSpecParsing[Test]
- from QueryParsing[Test] (Christine Poerschke)
- * SOLR-8298: small preferLocalShards implementation refactor (Christine Poerschke)
- * SOLR-8315: Removed default core checks in the dispatch filter since we don't have a default
- core anymore (Varun Thacker)
- * SOLR-8302: SolrResourceLoader now takes a Path as its instance directory (Alan
- Woodward, Shawn Heisey)
- * SOLR-8303: CustomBufferedIndexInput now includes resource description when
- throwing EOFException. (Mike Drob via Uwe Schindler)
- * SOLR-8194: Improve error reporting for null documents in UpdateRequest (Markus
- Jelsma, Alan Woodward)
- * SOLR-8277: (Search|Top)GroupsFieldCommand tweaks (Christine Poerschke)
- * SOLR-8299: ConfigSet DELETE operation no longer allows deletion of config sets that
- are currently in use by other collections (Anshum Gupta)
- * SOLR-8101: Improve Linux service installation script (Sergey Urushkin via Timothy Potter)
- * SOLR-8180: jcl-over-slf4j should have officially been a SolrJ dependency; it now is.
- (David Smiley, Kevin Risden)
- * SOLR-8330: Standardize and fix logger creation and usage so that they aren't shared
- across source files.(Jason Gerlowski, Uwe Schindler, Anshum Gupta)
- * SOLR-8363: Fix check-example-lucene-match-version Ant task and addVersion.py script to
- check and update luceneMatchVersion under solr/example/ configs as well logic. (Varun Thacker)
- ================== 5.3.2 ==================
- Bug Fixes
- ----------------------
- * SOLR-8460: /analysis/field could throw exceptions for custom attributes. (David Smiley, Uwe Schindler)
- * SOLR-8373: KerberosPlugin: Using multiple nodes on same machine leads clients to
- fetch TGT for every request (Ishan Chattopadhyaya via noble)
- * SOLR-8340: Fixed NullPointerException in HighlightComponent. (zengjie via Christine Poerschke)
- * SOLR-8059: &debug=results for distributed search when distrib.singlePass (sometimes activated
- automatically) could result in an NPE. (David Smiley, Markus Jelsma)
- * SOLR-8167: Authorization framework does not work with POST params (noble)
- * SOLR-8355: update permissions were failing node recovery (noble , Anshum Gupta)
- * SOLR-8326: If BasicAuth enabled, inter node requests fail after node restart (noble, Anshum Gupta)
- * SOLR-8269: Upgrade commons-collections to 3.2.2. This fixes a known serialization vulnerability (janhoy)
- * SOLR-8422: When authentication enabled, requests fail if sent to a node that doesn't host
- the collection (noble)
- * SOLR-8496: SolrIndexSearcher.getDocSet(List<Query>) incorrectly included deleted documents
- when all of the queries were uncached (or there was no filter cache). This caused
- multi-select faceting (including the JSON Facet API) to include deleted doc counts
- when the remaining non-excluded filters were all uncached. This bug was first introduced in 5.3.0
- (Andreas Müller, Vasiliy Bout, Erick Erickson, Shawn Heisey, Hossman, yonik)
- ================== 5.3.1 ==================
- Bug Fixes
- ----------------------
- * SOLR-7949: Resolve XSS issue in Admin UI stats page (David Chiu via janhoy)
- * SOLR-8000: security.json is not loaded on server start (noble)
- * SOLR-8004: RuleBasedAuthorization plugin does not work for the collection-admin-edit permission (noble)
- * SOLR-7972: Fix VelocityResponseWriter template encoding issue.
- Templates must be UTF-8 encoded. (Erik Hatcher)
- * SOLR-7929: SimplePostTool (also bin/post) -filetypes "*" now works properly in 'web' mode (Erik Hatcher)
- * SOLR-7978: Fixed example/files update-script.js to be Java 7 and 8 compatible. (Erik Hatcher)
- * SOLR-7988: SolrJ could not make requests to handlers with '/admin/' prefix (noble , ludovic Boutros)
- * SOLR-7990: Use of timeAllowed can cause incomplete filters to be cached and incorrect
- results to be returned on subsequent requests. (Erick Erickson, yonik)
- * SOLR-8041: Fix VelocityResponseWriter's $resource.get(key,baseName,locale) to use specified locale.
- (Erik Hatcher)
- ================== 5.3.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release
- Versions of Major Components
- ---------------------
- Apache Tika 1.7
- Carrot2 3.9.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.2.11.v20150529
- Upgrading from Solr 5.2
- -----------------------
- * SolrJ's CollectionAdminRequest class is now marked as abstract. Use one of its concrete
- sub-classes instead.
- * Solr no longer supports forcefully unlocking an index.
- This is no longer supported by the underlying Lucene locking
- framework. The setting in solrconfig.xml has no effect anymore.
- Background: If you use native lock factory, unlocking should
- not be needed, because the locks are cleared after process
- shutdown automatically by the operating system. If you are
- using simple lock factory (not recommended) or hdfs lock
- factory, you may need to manually unlock by deleting the lock
- file from filesystem / HDFS.
- * The zkCredientialsProvider element in solrcloud section of solr.xml is now deprecated.
- Use the correct spelling (zkCredentialsProvider) instead.
- * class TransformerWithContext is deprecated . Use DocTransformer directly
- * The "name" parameter in ADDREPLICA Collections API call has be deprecated. One cannot specify
- the core name for a replica. See SOLR-7499 for more info.
- * The ShardHandler interface has changed. The interface used to provide a
- `checkDistributed` function which doubled up in purpose to determine if the
- request is distributed, and to prepare for distributed requests. This unfortunately
- meant that the object had to be instantiated even when the request is not
- distributed. The task of initially determining if the request is distributed
- is now done by SearchHandler using the distrib/shards parameters, and a
- ShardHandler object is created only if the request is distributed. The interface
- now has a `prepDistributed` function instead of the `checkDistributed` function,
- which can then be used to prepare for the distributed request. Users with custom
- ShardHandler implementations would need to modify their code to this effect.
- * The system property "solr.solrxml.location" is not supported any more. Now, solr.xml is first
- looked up in zookeeper, and if not found, fallback to SOLR_HOME. See SOLR-7735 for more info.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-7724: SolrJ now supports parsing the output of the clustering component.
- (Alessandro Benedetti via Dawid Weiss)
- * SOLR-7389: Expose znodeVersion property for each of the collections returned for the clusterstatus
- operation in the collections API (Marius Grama via shalin)
- * SOLR-7622: A DocTransformer can now request fields from the SolrIndexSearcher that are not
- necessarily returned in the file SolrDocument by returning a list of fields from
- DocTransformer#getExtraRequestFields (ryan)
- * SOLR-7458: Expose HDFS Block Locality Metrics via JMX (Mike Drob via Mark Miller)
- * SOLR-7676: Faceting on nested objects / Block-join faceting with the new JSON Facet API.
- Example: Assuming books with nested pages and an input domain of pages, the following
- will switch the domain to books before faceting on the author field:
- authors:{ type:terms, field:author, domain:{toParent:"type:book"} }
- (yonik)
- * SOLR-7668: Add 'port' tag support in replica placement rules (Adam McElwee, Noble Paul)
- * SOLR-5886: Response for an async call is now stored in zk so that it can be returned by the REQUESTSTATUS API.
- Also, the number of stored (failed and successful) responses are now restricted to 10,000 each as a safety net.
- (Anshum Gupta)
- * SOLR-7639: MoreLikeThis QParser now supports all options provided by the MLT Handler i.e. mintf, mindf,
- minwl, maxwl, maxqt, and maxntp.
- * SOLR-7182: Make the Schema-API a first class citizen of SolrJ. The new SchemaRequest and its inner
- classes can be used to make requests to the Schema API. (Sven Windisch, Marius Grama via shalin)
- * SOLR-7651: New response format added wt=smile (noble)
- * SOLR-4212: SOLR-6353: Let facet queries and facet ranges hang off of pivots. Example:
- facet.range={!tag=r1}price&facet.query={!tag=q1}somequery&facet.pivot={!range=r1 query=q1}category,manufacturer
- (Steve Molloy, hossman, shalin)
- * SOLR-7742: Support for Immutable ConfigSets (Gregory Chanan)
- * SOLR-2522: new two argument option for the existing field() function; picks the min/max value of a
- docValues field to use as a ValueSource: "field(field_name,min)" and "field(field_name,max)" (hossman)
- * SOLR-6234: Scoring for query time join (Mikhail Khludnev)
- * SOLR-5882: score local parameter for block join query parser {!parent} (Andrey Kudryavtsev, Mikhail Khludnev)
- * SOLR-7799: Added includeIndexFieldFlags (backwards compatible default is true) to /admin/luke.
- When there are many fields in the index, setting this flag to false can dramatically speed up requests. (ehatcher)
- * SOLR-7769: Add bin/post -p alias for -port parameter. (ehatcher)
- * SOLR-7766: support creation of a coreless collection via createNodeSet=EMPTY (Christine Poerschke)
- * SOLR-7849: Solr-managed inter-node authentication when authentication enabled (Noble Paul)
- * SOLR-7220: Nested C-style comments in queries. (yonik)
- * SOLR-7757: Improved security framework where security components can be edited/reloaded, Solr
- now watches /security.json. Components can choose to make their config editable
- (Noble Paul, Anshum Gupta, Ishan Chattopadhyaya)
- * SOLR-7838: An authorizationPlugin interface where the access control rules are stored/managed in
- ZooKeeper (Noble Paul, Anshum Gupta, Ishan Chattopadhyaya)
- * SOLR-7837: An AuthenticationPlugin which implements the HTTP BasicAuth protocol and stores credentials
- securely in ZooKeeper (Noble Paul, Anshum Gupta,Ishan Chattopadhyaya)
- Bug Fixes
- ----------------------
- * SOLR-7361: Slow loading SolrCores should not hold up all other SolrCores that have finished loading from serving
- requests. (Mark Miller, Timothy Potter, Ramkumar Aiyengar)
- * SOLR-4506: Clean-up old (unused) index directories in the background after initializing a new index;
- previously, Solr would leave old index.yyyyMMddHHmmssSSS directories left behind after failed recoveries
- in the data directory, which unnecessarily consumes disk space. (Mark Miller, Timothy Potter)
- * SOLR-7108: Change default query used by /admin/ping to not rely on other parameters such as query parser or
- default field. (ehatcher)
- * SOLR-6835: ReRankQueryParserPlugin checks now whether the reRankQuery parameter is present and not empty.
- (帅广应, Marius Grama via shalin)
- * SOLR-7566: Search requests should return the shard name that is down. (Marius Grama, shalin)
- * SOLR-7675: Add missing _root_ field to managed-schema template so that the default data driven
- config set can index nested documents by default. (yonik)
- * SOLR-7635: Limit lsof port check in bin/solr to just listening ports
- (Upayavira, Ramkumar Aiyengar)
- * SOLR-7091: Nested documents with unknown fields don't work in schemaless mode.
- (Steve Rowe)
- * SOLR-7682: Schema API: add-copy-field should accept the maxChars parameter. (Steve Rowe)
- * SOLR-7693: Fix the bin/solr -e cloud example to work if lsof is not installed
- on the local machine by waiting for 10 seconds before starting the second node.
- (hossman, Timothy Potter)
- * SOLR-7689: ReRankQuery rewrite method can change the QueryResultKey causing cache misses.
- (Emad Nashed, Yonik Seeley, Joel Bernstein)
- * SOLR-7697: Schema API doesn't take class or luceneMatchVersion attributes into
- account for the analyzer when adding a new field type. (Marius Grama, Steve Rowe)
- * SOLR-7679: Schema API doesn't take similarity attribute into account when adding
- field types. (Marius Grama, Steve Rowe)
- * SOLR-7664: Throw correct exception (RemoteSolrException) on receiving a HTTP 413.
- (Ramkumar Aiyengar, Eirik Lygre)
- * SOLR-6686: facet.threads can return wrong results when using facet.prefix multiple
- times on same field. (Michael Ryan, Tim Underwood via shalin)
- * SOLR-7673: Race condition in shard splitting can cause operation to hang indefinitely
- or sub-shards to never become active. (shalin)
- * SOLR-7741: Add missing fields to SolrIndexerConfig.toMap
- (Mike Drob, Christine Poerschke via Ramkumar Aiyengar)
- * SOLR-7748: Fix bin/solr to start on IBM J9. (Shai Erera)
- * SOLR-7143: MoreLikeThis Query parser should handle multiple field names
- (Jens Wille, Anshum Gupta)
- * SOLR-7132: The Collections API ADDREPLICA command property.name is not reflected
- in the clusterstate until after Solr restarts (Erick Erickson)
- * SOLR-7172: addreplica API fails with incorrect error msg "cannot create collection"
- (Erick Erickson)
- * SOLR-7705: CoreAdminHandler Unload no longer handles null core name and throws NPE
- instead of a bad request error. (John Call, Edward Ribeiro via shalin)
- * SOLR-7529: CoreAdminHandler Reload throws NPE on null core name instead of a bad
- request error. (Jellyfrog, Edward Ribeiro via shalin)
- * SOLR-7781: JSON Facet API: Terms facet on string/text fields with sub-facets caused
- a bug that resulted in filter cache lookup misses as well as the filter cache
- exceeding it's configured size. (yonik)
- * SOLR-7810: map-reduce contrib script to set classpath for convenience refers to example
- rather than server. (Mark Miller)
- * SOLR-7765: Hardened the behavior of TokenizerChain when null arguments are used in constructor.
- This prevents NPEs in some code paths. (Konstantin Gribov, hossman)
- * SOLR-7829: Fixed a bug in distributed pivot faceting that could result in a facet.missing=true count
- which was lower then the correct count if facet.sort=index and facet.pivot.mincount > 1 (hossman)
- * SOLR-7842: ZK connection loss or session expiry events should not fire config directory listeners.
- (noble, shalin)
- * SOLR-6357: Allow delete documents by doing a score join query. (Mikhail Khludnev, Timothy Potter)
- * SOLR-7756: Fixed ExactStatsCache and LRUStatsCache to not throw an NPE when a term is not present on a shard.
- (Varun Thacker, Anshum Gupta)
- * SOLR-7818: Fixed distributed stats to be calculated for all the query terms. Earlier the stats were calculated with
- the terms that are present in the last shard of a distributed request. (Varun Thacker, Anshum Gupta)
- * SOLR-7866: VersionInfo caused an unhandled NPE when trying to determine the max value for the
- version field. (Timothy Potter)
- * SOLR-7666 (and linked tickets): Many fixes to AngularJS Admin UI bringing it close to feature
- parity with existing UI. (Upayavira)
- * SOLR-7908: SegmentsInfoRequestHandler gets a ref counted IndexWriter and does not properly release it.
- (Mark Miller, shalin)
- * SOLR-7921: The techproducts example fails when running in a directory that contains spaces.
- (Ishan Chattopadhyaya via Timothy Potter)
- * SOLR-7934: SolrCLI masks underlying cause of create collection failure. (Timothy Potter)
- Optimizations
- ----------------------
- * SOLR-7660: Avoid redundant 'exists' calls made to ZK while fetching cluster state updates. (shalin)
- * SOLR-7714: Reduce SearchHandler's use of ShardHandler objects across shards in a search,
- from one for each shard and the federator, to just one for the federator.
- (Christine Poerschke via Ramkumar Aiyengar)
- * SOLR-7751: Minor optimizations to QueryComponent.process (reduce eager instantiations,
- cache method calls) (Christine Poerschke via Ramkumar Aiyengar)
- * SOLR-7455: Terms facets with the JSON Facet API now defer calculating non-sorting stats
- until a second phase, after the top N facets are found. This improves performance
- proportional to the number of non-sorting statistics being calculated in addition to
- the number of buckets and domain documents.
- For Example: The facet request {type:terms, field:field1, facet:{x:"unique(field2)"}}
- saw a 7x improvement when field1 and 1M unique terms and field2 had 1000 unique terms.
- (yonik)
- * SOLR-7840: ZkStateReader.updateClusterState fetches watched collections twice from ZK. (shalin)
- * SOLR-7875: Speedup SolrQueryTimeoutImpl. Avoid setting a timeout time when timeAllowed
- parameter is not set. (Tomás Fernández Löbbe)
- Other Changes
- ----------------------
- * SOLR-7787: Removed fastutil and java-hll dependency, integrated HyperLogLog from java-hll
- into Solr core. (Dawid Weiss)
- * SOLR-7595: Allow method chaining for all CollectionAdminRequests in Solrj. (shalin)
- * SOLR-7146: MiniSolrCloudCluster based tests can fail with ZooKeeperException NoNode for /live_nodes.
- (Vamsee Yarlagadda via shalin)
- * SOLR-7590: Finish and improve MDC context logging support. (Mark Miller)
- * SOLR-7599: Remove cruft from SolrCloud tests. (shalin)
- * SOLR-7636: CLUSTERSTATUS API is executed at CollectionsHandler (noble)
- * LUCENE-6508: Remove ability to forcefully unlock an index.
- This is no longer supported by the underlying Lucene locking
- framework. (Uwe Schindler, Mike McCandless, Robert Muir)
- * SOLR-3719: Add as-you-type "instant search" to example/files /browse.
- (Esther Quansah, ehatcher)
- * SOLR-7645: Remove explicitly defined request handlers from example and test solrconfig's that are
- already defined implicitly, such as /admin/ping, /admin/system, and several others. (ehatcher)
- * SOLR-7603: Fix test only bug in UpdateRequestProcessorFactoryTest (hossman)
- * SOLR-7634: Upgrade Jetty to 9.2.11.v20150529 (Bill Bell, shalin)
- * SOLR-7659: Rename releaseCommitPointAndExtendReserve in DirectoryFileStream
- to extendReserveAndReleaseCommitPoint, and reverse the code to match.
- (shalin, Shawn Heisey)
- * SOLR-7624: Add correct spelling (zkCredentialsProvider) as an alternative to
- zkCredientialsProvider element in solrcloud section of solr.xml.
- (Xu Zhang, Per Steffensen, Ramkumar Aiyengar, Mark Miller)
- * SOLR-7619: Fix SegmentsInfoRequestHandlerTest when more than one segment is created.
- (Ramkumar Aiyengar, Steve Rowe)
- * SOLR-7678: Switch RTimer to use nanoTime (improves accuracy of QTime, and other times
- returned by Solr handlers) (Ramkumar Aiyengar)
- * SOLR-7680: Use POST instead of GET when finding versions for mismatches with
- CloudInspectUtil for tests (Ramkumar Aiyengar)
- * SOLR-7665: deprecate the class TransformerWithContext (noble)
- * SOLR-7629: Have RulesTest consider disk space limitations of where the test is
- being run (Christine Poerschke via Ramkumar Aiyengar)
- * SOLR-7499: The "name" parameter in ADDREPLICA Collections API call has be deprecated. One cannot specify
- the core name for a replica (Varun Thacker, noble, Erick Erickson)
- * SOLR-7711: Correct initial capacity for the list that holds the default components for the SearchHandler
- (Christine Poerschke via Varun Thacker)
- * SOLR-7485: Replace shards.info occurrences with ShardParams.SHARDS_INFO
- (Christine Poerschke via Ramkumar Aiyengar)
- * SOLR-7710: Replace async occurrences with CommonAdminParams.ASYNC
- (Christine Poerschke, Ramkumar Aiyengar)
- * SOLR-7712: fixed test to account for aggregate floating point precision loss (hossman)
- * SOLR-7740: Fix typo bug with TestConfigOverlay (Christine Poerschke via Ramkumar Aiyengar)
- * SOLR-7750: Change TestConfig.testDefaults to cover all SolrIndexConfig fields
- (Christine Poerschke via Ramkumar Aiyengar)
- * SOLR-7703: Authentication plugin is now loaded using the ResourceLoader.
- (Avi Digmi via Anshum Gupta)
- * SOLR-7800: JSON Facet API: the avg() facet function now skips missing values
- rather than treating them as a 0 value. The def() function can be used to
- treat missing values as 0 if that is desired.
- Example: facet:{ mean:"avg(def(myfield,0))" }
- * SOLR-7805: Update Kite Morphlines to 1.1.0 (Mark Miller)
- * SOLR-7803: Prevent class loading deadlock in TrieDateField; refactor date
- formatting and parsing out of TrieDateField and move to static utility class
- DateFormatUtil. (Markus Heiden, Uwe Schindler)
- * SOLR-7825: Forbid all usages of log4j and java.util.logging classes in Solr except
- classes which are specific to logging implementations. Remove accidental usage of log4j
- logger from a few places. The default log level for org.apache.zookeeper is changed from
- ERROR to WARN for zkcli.{sh,cmd} only.
- (Oliver Schrenk, Tim Potter, Uwe Schindler, shalin)
- * SOLR-7735: Look for solr.xml in Zookeeper by default in SolrCloud mode. If not found, it will be loaded
- from $SOLR_HOME/solr.xml as before. Sysprop solr.solrxml.location is now gone. (janhoy)
- * SOLR-7227: Ship Solr with the Web application directory exploded into
- server/solr-webapp, solr.war is no longer included in the distribution
- bundles. (Timothy Potter, Uwe Schindler)
- * SOLR-6625: Enable registering interceptors for the calls made using HttpClient and make the
- request object available at the interceptor context ( Ishan Chattopadhyay, Gregory Chanan, noble, Anshum Gupta)
- * SOLR-5022: On Java 7 raise permgen for running tests. (Uwe Schindler)
- * SOLR-7823: TestMiniSolrCloudCluster.testCollectionCreateSearchDelete async collection-creation (sometimes)
- (Christine Poerschke)
- * SOLR-7854: Remove unused ZkStateReader.updateClusterState(false) method. (Scott Blum via shalin)
- * SOLR-7863: Lowercase the CLUSTERPROP command in ZkCLI for consistency, print error for unknown cmd (janhoy)
- * SOLR-7832: bin/post now allows either -url or -c, rather than requiring both. (ehatcher)
- * SOLR-7847: Implement run example logic in Java instead of OS-specific scripts in
- bin/solr and bin\solr.cmd (Timothy Potter)
- * SOLR-7877: TestAuthenticationFramework.testBasics to preserve/restore the original request(Username|Password)
- (Christine Poerschke)
- * SOLR-7900: example/files improvements - added language detection and faceting, added title field, relocated .js files.
- (Esther Quansah and Erik Hatcher)
- ================== 5.2.1 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release
- Versions of Major Components
- ---------------------
- Apache Tika 1.7
- Carrot2 3.9.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.2.10.v20150310
- Detailed Change List
- ----------------------
- Bug Fixes
- ----------------------
- * SOLR-7588: Fix javascript bug introduced by SOLR-7409 that breaks the
- dataimport screen in the admin UI. (Bill Bell via Shawn Heisey)
- * SOLR-7616: Faceting on a numeric field with a unique() subfacet function on another numeric field
- can result in incorrect results or an exception. (yonik)
- * SOLR-7518: New Facet Module should respect shards.tolerant and process all non-failing shards
- instead of throwing an exception. (yonik)
- * SOLR-7574: A request with a json content type but no body caused a null pointer exception (yonik)
- * SOLR-7512: SolrOutputFormat creates an invalid solr.xml in the solr home zip for MapReduceIndexerTool.
- (Mark Miller, Adam McElwee)
- * SOLR-7652: Fix example/files update-script.js to work with Java 7 (ehatcher)
- * SOLR-7638: Fix new (Angular-based) admin UI Cloud pane (Upayavira via ehatcher)
- * SOLR-7655: The DefaultSolrHighlighter since 5.0 was determining if payloads were present in a way
- that was slow, especially when lots of fields were highlighted. It's now fast. (David Smiley)
- * SOLR-7493: Requests aren't distributed evenly if the collection isn't present locally.
- (Jeff Wartes, shalin)
- Other Changes
- ----------------------
- * SOLR-7623: Fix regression from SOLR-7484 that made it impossible to override
- SolrDispatchFilter#execute() and SolrDispatchFilter#sendError(). You can now override these
- functions in HttpSolrCall. (ryan)
- * SOLR-7648: Expose remote IP and Host via the AuthorizationContext to be used by the authorization plugin.
- (Ishan Chattopadhyaya via Anshum Gupta)
- ================== 5.2.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release
- Versions of Major Components
- ---------------------
- Apache Tika 1.7
- Carrot2 3.9.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 9.2.10.v20150310
- Upgrading from Solr 5.1
- -----------------------
- * A bug was introduced in Solr 4.10 that caused index time document boosts to trigger excessive field
- boosts in multivalued fields -- the result being that some field norms might be excessively large.
- This bug has now been fixed, but users of document boosts are strongly encouraged to re-index.
- See SOLR-7335 for more details.
- * The Slice and Replica classes have been changed to use State enums instead of string constants
- to track the respective stats. Advanced users with client code manipulating these objects will
- need to update their code accordingly. See SOLR-7325 and SOLR-7336 for more info.
- * Solr has internally been upgraded to use Jetty 9. See SOLR-4839 for full details, but there are
- a few key details all Solr users should know when upgrading:
- - It is no longer possible to run "java -jar start.jar" from inside the server directory.
- The bin/solr script is the only supported way to run Solr. This is necessary to support
- HTTP and HTTPS modules in Jetty which can be selectively enabled by the bin/solr scripts.
- In case you have a pressing need to run solr the old way, you can run
- "java -jar start.jar --module=http" to get the same behavior as before.
- - The way SSL support is configured has been changed. Before this release,
- the SOLR_SSL_OPTS property configured in solr.in.sh (linux/mac) or solr.in.cmd (windows)
- was used to enable/disable SSL but starting in 5.2.0, new properties named as
- SOLR_SSL_KEY_STORE, SOLR_SSL_KEY_STORE_PASSWORD, SOLR_SSL_TRUST_STORE,
- SOLR_SSL_TRUST_STORE_PASSWORD, SOLR_SSL_NEED_CLIENT_AUTH and SOLR_SSL_WANT_CLIENT_AUTH
- have been introduced. The bin/solr scripts configure the SOLR_SSL_OPTS property
- automatically based on the above new properties.
- You should *not* configure the SOLR_SSL_OPTS property directly inside solr.in.{sh,cmd}.
- - Support for SOLR_SSL_PORT property has been removed. Instead use the regular SOLR_PORT
- property or specify the port while invoking the bin/solr script using the "-p" switch.
- - Furthermore, it is now possible to configure the HTTP client with
- different SSL properties than the ones used for Jetty using the same files.
- - Please refer to the "Enabling SSL" section in the Solr Reference Guide for complete details.
- * Support for pathPrefix has been completely removed from Solr. Since 5.0, Solr no longer officially
- supports being run as a webapp but allowed users to play around with the web.xml to have a path prefix.
- That would no longer be true. See SOLR-7500 for more info.
- * The package structure under org.apache.solr.client.solrj.io has been changed to support
- the Streaming Expression Language (SOLR-7377). Any code written with the 5.1 Streaming API will have to
- be updated to reflect these changes.
- * Merge Policy's "noCFSRatio" is no longer set based on <useCompoundFile> element in the indexConfig section
- of solrconfig.xml. This means that Solr will start using Lucene's default for MP "noCFSRatio", with this
- new default Solr will decide if a segment should use cfs or not based on the size of the segment in relation
- the size of the complete index. For TieredMergePolicy for example (current default), segments will use cfs
- if they are less than 10% of the index, otherwise cfs is disabled. Old values for this setting
- (1.0 for useCompoundFile=true and 0.0 for useCompoundFile=false) as well as any other value can be set
- inside the <mergePolicy> element in solrconfig.xml. <useCompoundFile> will only apply to newly created
- segments. See SOLR-7463.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-6637: Restore a Solr core from a backed up index.
- Restore API Example -
- http://localhost:8983/solr/techproducts/replication?command=restore&name=backup_name
- Restore Status API Example -
- http://localhost:8983/solr/techproducts/replication?command=restorestatus
- (Varun Thacker, noble, shalin)
- * SOLR-7241, SOLR-7263, SOLR-7279, SOLR-7300, SOLR-7396, SOLR-7397, SOLR-7492:
- Admin UI - Refactoring using AngularJS. More functionality moving the Admin
- UI to Angular JS (Upayavira via Erick)
- * SOLR-7372: Limit memory consumed by LRUCache with a new 'maxRamMB' config parameter.
- (yonik, shalin)
- * SOLR-7376: Return raw XML or JSON (in the appropriate writer) using DocumentTransformers.
- ?fl=id,name,json_s:[json],xml_s:[xml] (ryan)
- * SOLR-7422: Optional flatter form for the JSON Facet API via a "type" parameter:
- top_authors : { type:terms, field:author, limit:5 } is equivalent to
- top_authors : { terms : { field:author, limit:5 } }
- (yonik)
- * SOLR-7176: zkcli script can perfrom the CLUSTERPROP command without a running Solr cluster
- (Hrishikesh Gadre, Per Steffensen, Noble Paul)
- * SOLR-7417: JSON Facet API - unique() is now implemented for numeric and date fields.
- (yonik)
- * SOLR-7406: Add a new "facet.range.method" parameter to let users choose how to do range
- faceting between an implementation based on filters (previous algorithm, using
- "facet.range.method=filter") or DocValues ("facet.range.method=dv").
- Input parameters and output of both methods are the same. (Tomás Fernández Löbbe)
- * SOLR-7473: Facet Module (Json Facet API) range faceting now supports the "mincount"
- parameter in range facets to supress buckets less than that count. The default
- for "mincount" remains 0 for range faceting.
- Example: prices:{ type:range, field:price, mincount:1, start:0, end:100, gap:10 }
- (yonik)
- * SOLR-7437: Make HDFS transaction log replication factor configurable. (Mark Miller)
- * SOLR-7477: Multi-select faceting support for the Facet Module via the "excludeTags"
- parameter which disregards any matching tagged filters for that facet. Example:
- & q=shoes
- & fq={!tag=COLOR}color:blue
- & json.facet={ colors:{type:terms, field:color, excludeTags=COLOR} }
- (yonik)
- * SOLR-7231: DIH-TikaEntityprocessor, create lat-lon field from Metadata
- (Tim Allison via Noble Paul)
- * SOLR-6220: Rule Based Replica Assignment during collection, shard creation
- and replica creation (Noble Paul)
- * SOLR-6968: New 'cardinality' option for stats.field, uses HyperLogLog to efficiently
- estimate the cardinality of a field w/bounded RAM. (hossman)
- * SOLR-4392: Make it possible to specify AES encrypted password in dataconfig.xml (Noble Paul)
- * SOLR-7461: stats.field now supports individual local params for 'countDistinct' and 'distinctValues'.
- 'calcdistinct' is still supported as an alias for both options (hossman)
- * SOLR-7522: Facet Module - Implement field/terms faceting over single-valued
- numeric fields. (yonik)
- * SOLR-7275: Authorization framework for Solr. It defines an interface and a mechanism to create,
- load, and use an Authorization plugin. (Noble Paul, Ishan Chattopadhyaya, Anshum Gupta)
- * SOLR-7377: Solr Streaming Expressions (Dennis Gove, Joel Bernstein, Steven Bower)
- * SOLR-7553: Facet Analytics Module: new "hll" function that uses HyperLogLog to calculate
- distributed cardinality. The original "unique" function is still available.
- Example: json.facet={ numProducts : "hll(product_id)" }
- (yonik)
- * SOLR-7546: bin/post (and SimplePostTool in -Dauto=yes mode) now sends rather than skips files
- without a known content type, as "application/octet-stream", provided it still is in the
- allowed filetypes setting. (ehatcher)
- * SOLR-7274: Pluggable authentication module in Solr. This defines an interface and a mechanism to create,
- load, and use an Authentication plugin. (Noble Paul, Ishan Chattopadhyaya, Gregory Chanan, Anshum Gupta)
- * SOLR-7379: (experimental) New spatial RptWithGeometrySpatialField, based on CompositeSpatialStrategy,
- which blends RPT indexes for speed with serialized geometry for accuracy. Includes a Lucene segment based
- in-memory shape cache. (David Smiley)
- * SOLR-7465, SOLR-7610: New file indexing example, under example/files. (Esther Quansah, Erik Hatcher)
- * SOLR-7468: Kerberos authenticaion plugin for Solr. This would allow running a Kerberized Solr.
- (Noble Paul, Ishan Chattopadhyaya, Gregory Chanan, Anshum Gupta)
- Bug Fixes
- ----------------------
- * SOLR-6709: Fix QueryResponse to deal with the "expanded" section when using the XMLResponseParser
- (Varun Thacker, Joel Bernstein)
- * SOLR-7066: autoAddReplicas feature has bug when selecting replacement nodes. (Mark Miller)
- * SOLR-7370: FSHDFSUtils#recoverFileLease tries to recover the lease every one second after
- the first four second wait. (Mark Miller)
- * SOLR-7369: AngularJS UI insufficient URLDecoding in cloud/tree view (janhoy)
- * SOLR-7380: SearchHandler should not try to load runtime components in inform() (Noble Paul)
- * SOLR-7385: The clusterstatus API now returns the config set used to create a collection
- inside a 'configName' key. (Shai Erera, shalin)
- * SOLR-7401: Fixed a NullPointerException when concurrently creating and deleting collections,
- while accessing other collections. (Shai Erera)
- * SOLR-7412: Fixed range.facet.other parameter for distributed requests.
- (Will Miller, Tomás Fernández Löbbe)
- * SOLR-6087: SolrIndexSearcher makes no DelegatingCollector.finish() call when IndexSearcher
- throws an expected exception. (Christine Poerschke via shalin)
- * SOLR-7420: Overseer stats are not reset on loss of ZK connection. (Jessica Cheng, shalin)
- * SOLR-7392: Fix SOLR_JAVA_MEM and SOLR_OPTS customizations in solr.in.sh being ignored
- (Ramkumar Aiyengar, Ere Maijala)
- * SOLR-7426: SolrConfig#getConfigOverlay does not clean up it's resources. (Mark Miller)
- * SOLR-6665: ZkController.publishAndWaitForDownStates can return before all local cores are
- marked as 'down' if multiple replicas with the same core name exist in the cluster.
- (shalin)
- * SOLR-7418: Check and raise a SolrException instead of an NPE when an invalid doc id is sent
- to the MLTQParser. (Anshum Gupta)
- * SOLR-7443: Implemented range faceting over date fields in the new facet module
- (JSON Facet API). (yonik)
- * SOLR-7440: DebugComponent does not return the right requestPurpose for pivot facet refinements.
- (shalin)
- * SOLR-7408: Listeners set by SolrCores on config directories in ZK could be removed if collections
- are created/deleted in paralle against the same config set. (Shai Erera, Anshum Gupta)
- * SOLR-7450: Fix edge case which could cause `bin/solr stop` to hang forever
- (Ramkumar Aiyengar)
- * SOLR-7157: initParams must support tags other than appends, defaults and, invariants (Noble Paul)
- * SOLR-7387: Facet Module - distributed search didn't work when sorting terms
- facet by min, max, avg, or unique functions. (yonik)
- * SOLR-7469: Fix check-licenses to correctly detect if start.jar.sha1 is incorrect (hossman)
- * SOLR-7449: solr/server/etc/jetty-https-ssl.xml hard codes the key store file and password rather
- than pulling them from the sysprops defined in solr/bin/solr.in.{sh,cmd}
- * SOLR-7470: Fix sample data to eliminate file order dependency for successful indexing, also
- fixed SolrCloudExampleTest to help catch this in the future. (hossman)
- * SOLR-7478: UpdateLog#close shuts down it's executor with interrupts before running it's close logic,
- possibly preventing a clean close. (Mark Miller)
- * SOLR-7494: Facet Module - unique() facet function was wildly inaccurate for high cardinality
- fields. (Andy Crossen, yonik)
- * SOLR-7502: start script should not try to create configset for .system collection (Noble Paul)
- * SOLR-7514: SolrClient.getByIds fails with ClassCastException (Tom Farnworth, Ramkumar Aiyengar)
- * SOLR-7531: config API shows a few keys merged together (Noble Paul)
- * SOLR-7542: Schema API: Can't remove single dynamic copy field directive
- (Steve Rowe)
- * SOLR-7472: SortingResponseWriter does not log fl parameters that don't exist. (Joel Bernstein)
- * SOLR-7545: Honour SOLR_HOST parameter with bin/solr{,.cmd}
- (Ishan Chattopadhyaya via Ramkumar Aiyengar)
- * SOLR-7503: Recovery after ZK session expiration should happen in parallel for all cores
- using the thread-pool managed by ZkContainer instead of a single thread.
- (Jessica Cheng Mallet, Timothy Potter, shalin, Mark Miller)
- * SOLR-7335: Fix doc boosts to no longer be multiplied in each field value in multivalued fields that
- are not used in copyFields (Shingo Sasaki via hossman)
- * SOLR-7585: Fix NoSuchElementException in LFUCache resulting from heavy writes
- making concurrent put() calls. (Maciej Zasada via Shawn Heisey)
- * SOLR-7587: Seeding bucket versions from index when the firstSearcher event fires has a race condition
- that leads to an infinite wait on VersionInfo's ReentrantReadWriteLock because the read-lock acquired
- during a commit cannot be upgraded to a write-lock needed to block updates; solution is to move the
- call out of the firstSearcher event path and into the SolrCore constructor. (Timothy Potter)
- * SOLR-7625: Ensure that the max value for seeding version buckets is updated after recovery even if
- the UpdateLog is not replayed. (Timothy Potter)
- * SOLR-7610: Fix VelocityResponseWriter's $resource.locale to accurately report locale in use.
- (ehatcher)
- * SOLR-7614: Distributed pivot facet refinement was broken due to a single correlation counter
- used across multiple requests as if it was private to each request. (yonik)
- Optimizations
- ----------------------
- * SOLR-7324: IndexFetcher does not need to call isIndexStale if full copy is already needed
- (Stephan Lagraulet via Varun Thacker)
- * SOLR-7547: Short circuit SolrDisptachFilter for static content request. Right now it creates
- a new HttpSolrCall object and tries to process it. (Anshum Gupta)
- * SOLR-7333: Make the poll queue time a leader uses when distributing updates to replicas
- configurable and use knowledge that a batch is being processed to poll efficiently.
- (Timothy Potter)
- * SOLR-7332: Initialize the highest value for all version buckets with the max value from
- the index or recent updates to avoid unnecessary lookups to the index to check for reordered
- updates when processing new documents. (Timothy Potter, yonik)
- * SOLR-5855: DefaultSolrHighlighter now re-uses the document's term vectors instance when highlighting
- more than one field. Applies to the standard and FVH highlighters. (David Smiley, Daniel Debray)
- Other Changes
- ----------------------
- * SOLR-6865: Upgrade HttpClient to 4.4.1 (Shawn Heisey)
- * SOLR-7358: TestRestoreCore fails in Windows (Ishan Chattopadhyaya via Varun Thacker)
- * SOLR-7371: Make DocSet implement Accountable to estimate memory usage. (yonik, shalin)
- * SOLR-7381: Improve logging by adding node name in MDC in SolrCloud mode and adding MDC to
- all thread pools. A new MDCAwareThreadPoolExecutor is introduced and usages of
- Executors#newFixedThreadPool, #newSingleThreadExecutor, #newCachedThreadPool as well as
- ThreadPoolExecutor directly is now forbidden in Solr. MDC keys are now exposed in thread
- names automatically so that a thread dump can give hints on what the thread was doing.
- Uncaught exceptions thrown by tasks in the pool are logged along with submitter's stack trace.
- (shalin)
- * SOLR-7384: Fix spurious failures in FullSolrCloudDistribCmdsTest. (shalin)
- * SOLR-6692: Default highlighter changes:
- - hl.maxAnalyzedChars now applies cumulatively on a multi-valied field.
- - fragment ranking on a multi-valued field should be more relevant.
- - hl.usePhraseHighlighter is now toggleable on a per-field basis.
- - Much more extensible (get values from another source; return snippet scores and offsets).
- - When using hl.maxMultiValuedToMatch with hl.preserveMulti, only count matched snippets.
- (David Smiley)
- * SOLR-6886: Removed redundant size check and added missing calls to
- DelegatingCollection.finish inside Grouping code. (Christine Poerschke via shalin)
- * SOLR-7421: RecoveryAfterSoftCommitTest fails frequently on Jenkins due to full index
- replication taking longer than 30 seconds. (Timothy Potter, shalin)
- * SOLR-7081: Add new test case to test if create/delete/re-create collections work.
- (Christine Poerschke via Ramkumar Aiyengar)
- * SOLR-7467: Upgrade t-digest to 3.1 (hossman)
- * SOLR-7471: Stop requiring docValues for interval faceting (Tomás Fernández Löbbe)
- * SOLR-7391: Use a time based expiration cache for one off HDFS FileSystem instances.
- (Mark Miller)
- * SOLR-5213: Log when shard splitting unexpectedly leads to documents going to
- no or multiple shards (Christine Poerschke, Ramkumar Aiyengar)
- * SOLR-7425: Improve MDC based logging format. (Mark Miller)
- * SOLR-4839: Upgrade Jetty to 9.2.10.v20150310 and restlet-jee to 2.3.0
- (Bill Bell, Timothy Potter, Uwe Schindler, Mark Miller, Steve Rowe, Steve Davids, shalin)
- * SOLR-7457: Make DirectoryFactory publishing MBeanInfo extensible.
- (Mike Drob via Mark Miller)
- * SOLR-7325: Slice.getState() now returns a State enum instead of a String. This helps
- clarify the states a Slice can be in, as well comparing the state of a Slice.
- (Shai Erera)
- * SOLR-7336: Added Replica.getState() and removed ZkStateReader state-related constants.
- You should use Replica.State to compare a replica's state. (Shai Erera)
- * SOLR-7487: Fix check-example-lucene-match-version Ant task to check luceneMatchVersion
- in solr/server/solr/configsets instead of example and harden error checking / validation
- logic. (hossman, Timothy Potter)
- * SOLR-7409: When there are multiple dataimport handlers defined, the admin UI
- was listing them in a random order. Now they are sorted in a natural order
- that handles numbers properly. (Jellyfrog via Shawn Heisey)
- * SOLR-7484: Refactor SolrDispatchFilter to extract all Solr specific implementation detail
- to HttpSolrCall and also extract methods from within the current SDF.doFilter(..) logic
- making things easier to manage. HttpSolrCall converts the processing to a 3-step process
- i.e. Construct, Init, and Call so the context of the request would be available after Init
- and before the actual call operation. (Anshum Gupta, Noble Paul)
- * SOLR-6878: Allow symmetric lists of synonyms to be added using the managed synonym REST
- API to support legacy expand=true type mappings; previously the API only allowed adding
- explicit mappings, with this feature you can now add a list and have the mappings
- expanded when the update is applied (Timothy Potter, Vitaliy Zhovtyuk, hossman)
- * SOLR-7102: bin/solr should activate cloud mode if ZK_HOST is set (Timothy Potter)
- * SOLR-7500: Remove pathPrefix from SolrDispatchFilter as Solr no longer runs as a part
- of a bigger webapp. (Anshum Gupta)
- * SOLR-7243: CloudSolrClient was always returning SERVER_ERROR for exceptions,
- even when a more relevant ErrorCode was available, via SolrException. Now
- the actual ErrorCode is used when available.
- (Hrishikesh Gadre via Shawn Heisey)
- * SOLR-7544: CollectionsHandler refactored to be more modular (Noble Paul)
- * SOLR-7532: Removed occurrences of the unused 'commitIntervalLowerBound' property for
- updateHandler elements from Solr configuration. (Marius Grama via shalin)
- * SOLR-7541: Removed CollectionsHandler#createNodeIfNotExists. All calls made to this method now call
- ZkCmdExecutor#ensureExists as they were doing the same thing. Also ZkCmdExecutor#ensureExists now respects the
- CreateMode passed to it. (Varun Thacker)
- * SOLR-6820: Make the number of version buckets used by the UpdateLog configurable as
- increasing beyond the default 256 has been shown to help with high volume indexing
- performance in SolrCloud; helps overcome a limitation where Lucene uses the request
- thread to perform expensive index housekeeping work. (Mark Miller, yonik, Timothy Potter)
- * SOLR-7463: Stop forcing MergePolicy's "NoCFSRatio" based on the IWC "useCompoundFile" configuration
- (Tomás Fernández Löbbe)
- * SOLR-7582: Allow auto-commit to be set with system properties in data_driven_schema_configs and
- enable auto soft-commits for the bin/solr -e cloud example using the Config API.
- (Timothy Potter)
- * SOLR-7183: Fix Locale blacklisting for Minikdc based tests. (Ishan Chattopadhyaya, hossman
- via Anshum Gupta)
- * SOLR-7662: Refactored response writing to consolidate the logic in one place (Noble Paul)
- * SOLR-7110: Added option to optimize JavaBinCodec to minimize string Object creation (Noble Paul)
- ================== 5.1.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release
- Versions of Major Components
- ---------------------
- Apache Tika 1.7
- Carrot2 3.9.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 8.1.10.v20130312
- Upgrading from Solr 5.0
- -----------------------
- * SolrClient query functions now declare themselves as throwing IOException in
- addition to SolrServerException, to bring them in line with the update
- functions.
- * SolrRequest.process() is now final. Subclasses should instead be parameterized
- by their corresponding SolrResponse type, and implement createResponse()
- * The signature of SolrDispatchFilter.createCoreContainer() has changed to take
- (String,Properties) arguments
- * Deprecated the 'lib' option added to create-requesthandler as part of SOLR-6801 in 5.0 release.
- Please use the add-runtimelib command
- * Tika's runtime dependency of 'jhighlight' was removed as the latter was found to
- contain some LGPL-only code. Until that's resolved by Tika, you can download the
- .jar yourself and place it under contrib/extraction/lib.
- * The _text catch-all field in data_driven_schema_configs has been renamed to _text_.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-6909: Extract atomic update handling logic into AtomicUpdateDocumentMerger class
- and enable subclassing. (Steve Davids, yonik)
- * SOLR-6845: Add a “buildOnStartup” option for suggesters. (Tomás Fernández Löbbe)
- * SOLR-6449: Add first class support for Real Time Get in Solrj.
- (Anurag Sharma, Steve Davids via shalin)
- * SOLR-6954: SolrClient now implements Closeable, and shutdown() has been
- deprecated in favour of close(). (Mark Miller, Tomás Fernández Löbbe, Alan
- Woodward)
- * SOLR-4905: Allow fromIndex parameter to JoinQParserPlugin to refer to a single-sharded
- collection that has a replica on all nodes where there is a replica in the to index
- (Jack Lo, Timothy Potter)
- * SOLR-6648: Add support in AnalyzingInfixLookupFactory and BlendedInfixLookupFactory
- for setting 'highlight' and 'allTermsRequired' in the suggester configuration.
- (Boon Low, Varun Thacker via Tomás Fernández Löbbe)
- * SOLR-7083: Support managing all named components in solrconfig such as
- requestHandler, queryParser, queryResponseWriter, valueSourceParser,
- transformer, queryConverter (Noble Paul)
- * SOLR-7005: Spatial 2D heatmap faceting on RPT fields via new facet.heatmap with PNG and
- 2D int array formats. (David Smiley)
- * SOLR-7019: Support changing field key when using interval faceting.
- (Tomás Fernández Löbbe)
- * SOLR-6832: Queries be served locally rather than being forwarded to another replica.
- (Sachin Goyal, Timothy Potter)
- * SOLR-1945: Add support for child docs in DocumentObjectBinder (Noble Paul, Mark Miller)
- * SOLR-7125, SOLR-7158: You can upload and download configurations via CloudSolrClient
- (Alan Woodward, Ishan Chattopadhyaya)
- * SOLR-5507: Admin UI - Refactoring using AngularJS, first part (Upayavira via
- Erick Erickson)
- * SOLR-7164: BBoxField defaults sub fields to not-stored (ryan)
- * SOLR-7155,SOLR-7201: All SolrClient methods now take an optional 'collection' argument
- (Alan Woodward, Shawn Heisey)
- * SOLR-6359: Allow number of logs and records kept by UpdateLog to be configured
- (Ramkumar Aiyengar)
- * SOLR-7189: Allow DIH to extract content from embedded documents via Tika.
- (Tim Allison via shalin)
- * SOLR-6841: Visualize lucene segment information in Admin UI.
- (Alexey Kozhemiakin, Michal Bienkowski, hossman, Shawn Heisey, Varun Thacker via shalin)
- * SOLR-5846: EnumField supports DocValues functionality. (Elran Dvir, shalin)
- * SOLR-4044: CloudSolrClient.connect() throws a more useful exception if the
- cluster is not ready, and can now take an optional timeout argument to wait
- for the cluster. (Alan Woodward, shalin, yonik, Mark Miller, Vitaliy Zhovtyuk)
- * SOLR-7073: Support adding a jar to a collections classpath (Noble Paul)
- * SOLR-7126: Secure loading of runtime external jars (Noble Paul)
- * SOLR-6349: Added support for stats.field localparams to enable/disable individual stats to
- limit the amount of computation done and the amount of data returned.
- eg: stats.field={!min=true max=true}field_name
- (Tomas Fernandez-Lobbe, Xu Zhang, hossman)
- * SOLR-7218: lucene/solr query syntax to give any query clause a constant score.
- General Form: <clause>^=<constant_score>
- Example: (color:blue color:green)^=2.0 text:shoes
- (yonik)
- * SOLR-7214: New Facet module with a JSON API, facet functions, aggregations, and analytics.
- Any facet type can have sub facets, and facets can be sorted by arbitrary aggregation functions.
- Examples:
- json.facet={x:'avg(price)', y:'unique(color)'}
- json.facet={count1:{query:"price:[10 TO 20]"}, count2:{query:"color:blue AND popularity:[0 TO 50]"} }
- json.facet={categories:{terms:{field:cat, sort:"x desc", facet:{x:"avg(price)", y:"sum(price)"}}}}
- (yonik)
- * SOLR-6141: Schema API: Remove fields, dynamic fields, field types and copy
- fields; and replace fields, dynamic fields and field types. (Steve Rowe)
- * SOLR-7217: HTTP POST body is auto-detected when the client is curl and the content
- type is form data (curl's default), allowing users to use curl to send
- JSON or XML without having to specify the content type. (yonik)
- * SOLR-6892: Update processors can now be top-level components and they can be
- specified in request to create a new custom update chain (Noble Paul)
- * SOLR-7216: Solr JSON Request API:
- - HTTP search requests can have a JSON body.
- - JSON request can also be passed via the "json" parameter.
- - Smart merging of multiple JSON parameters: ruery parameters starting with "json."
- will be merged into the JSON request.
- - Legacy query parameters can also be passed in the "params" block of
- the JSON request.
- (yonik)
- * SOLR-7245: Temporary ZK election or connection loss should not stall indexing
- due to leader initiated recovery (Ramkumar Aiyengar)
- * SOLR-6350: StatsComponent now supports Percentiles (Xu Zhang, hossman)
- * SOLR-7306: Percentiles support for the new facet module. Percentiles
- can be calculated for all facet buckets and field faceting can sort
- by percentile values.
- Examples:
- json.facet={ median_age : "percentile(age,50)" }
- json.facet={ salary_percentiles : "percentile(salary,25,50,75)" }
- (yonik)
- * SOLR-7307: EmbeddedSolrServer can now be started up by passing a path to a
- solr home directory, or a NodeConfig object (Alan Woodward, Mike Drob)
- * SOLR-1387: Add facet.contains and facet.contains.ignoreCase options (Tom Winch
- via Alan Woodward)
- * SOLR-7082: Streaming Aggregation for SolrCloud (Joel bernstein, Yonik Seeley)
- * SOLR-7212: Parameter substitution / macro expansion across entire request.
- Substitution can contain further expansions and default values are supported.
- Example: q=price:[ ${low:0} TO ${high} ]&low=100&high=200
- (yonik)
- * SOLR-7226: Make /query/* jmx/* , requestDispatcher/*, <listener> <initParams>
- properties in solrconfig.xml editable (Noble Paul)
- * SOLR-7240: '/' redirects to '/solr/' for convenience (Martijn Koster, hossman)
- * SOLR-5911: Added payload support for term vectors. New "termPayloads" option for fields
- / types in the schema, and "tv.payloads" param for the term vector component.
- (Mike McCandless, David Smiley)
- * SOLR-5132: Added a new collection action MODIFYCOLLECTION (Noble Paul)
- Bug Fixes
- ----------------------
- * SOLR-7046: NullPointerException when group.function uses query() function.
- (Jim Musil via Erick Erickson)
- * SOLR-7072: Multiple mlt.fl does not work. (Constantin Mitocaru, shalin)
- * SOLR-6775: Creating backup snapshot results in null pointer exception.
- (Ryan Hesson, Varun Thacker via shalin)
- * SOLR-5890: Delete silently fails if not sent to shard where document was
- added (Ishan Chattopadhyaya, Noble Paul)
- * SOLR-7101: JmxMonitoredMap can throw an exception in clear when queryNames fails.
- (Mark Miller, Wolfgang Hoschek)
- * SOLR-6214: Snapshots numberToKeep param only keeps n-1 backups.
- (Mathias H., Ramana, Varun Thacker via shalin)
- * SOLR-7084: FreeTextSuggester: Better error message when doing a lookup
- during dictionary build. Used to be nullpointer (janhoy)
- * SOLR-6956: OverseerCollectionProcessor and replicas on the overseer node can sometimes
- operate on stale cluster state due to overseer holding the state update lock for a
- long time. (Mark Miller, shalin)
- * SOLR-7104: Propagate property prefix parameters for ADDREPLICA Collections API call.
- (Varun Thacker via Anshum Gupta)
- * SOLR-7113: Multiple calls to UpdateLog#init is not thread safe with respect to the
- HDFS FileSystem client object usage. (Mark Miller, Vamsee Yarlagadda)
- * SOLR-7128: Two phase distributed search is fetching extra fields in GET_TOP_IDS phase.
- (Pablo Queixalos, shalin)
- * SOLR-7139: Fix SolrContentHandler for TIKA to ignore multiple startDocument events.
- (Chris A. Mattmann, Uwe Schindler)
- * SOLR-7178: OverseerAutoReplicaFailoverThread compares Integer objects using ==
- (shalin)
- * SOLR-7171: BaseDistributedSearchTestCase now clones getSolrHome() for each subclass,
- and consistently uses getSolrXml(). (hossman)
- * SOLR-6657: DocumentDictionaryFactory requires weightField to be mandatory, but it shouldn't
- (Erick Erickson)
- * SOLR-7206: MiniSolrCloudCluster wasn't dealing with SSL mode correctly (Alan
- Woodward)
- * SOLR-4464: DIH Processed documents counter resets to zero after first entity is processed.
- (Dave Cook, Shawn Heisey, Aaron Greenspan, Thomas Champagne via shalin)
- * SOLR-7209: /update/json/docs carry forward fields from previous records (Noble Paul)
- * SOLR-7195: Fixed a bug where the bin/solr shell script would incorrectly
- detect another Solr process listening on the same port number. If the
- requested listen port was 8983, it would match on another Solr using port
- 18983 for any purpose. Also escapes the dot character in all grep commands
- looking for start.jar.
- (Xu Zhang via Shawn Heisey)
- * SOLR-6682: Fix response when using EnumField with StatsComponent
- (Xu Zhang via hossman)
- * SOLR-7109: Indexing threads stuck during network partition can put leader into down state.
- (Mark Miller, Anshum Gupta, Ramkumar Aiyengar, yonik, shalin)
- * SOLR-7092: Stop the HDFS lease recovery retries in HdfsTransactionLog on close and try
- to avoid lease recovery on closed files. (Mark Miller)
- * SOLR-7285: ActionThrottle will not pause if getNanoTime first returns 0.
- (Mark Miller, Gregory Chanan)
- * SOLR-7141: RecoveryStrategy: Raise time that we wait for any updates from the leader before
- they saw the recovery state to have finished. (Mark Miller)
- * SOLR-7248: In legacyCloud=false mode we should check if the core was hosted on the same node before registering it
- (Varun Thacker, Noble Paul, Mark Miller)
- * SOLR-7294: Migrate API fails with 'Invalid status request: notfoundretried 6times' message.
- (Jessica Cheng Mallet, shalin)
- * SOLR-7254: Make an invalid negative start/rows throw a HTTP 400 error (Bad Request) instead
- of causing a 500 error. (Ramkumar Aiyengar, Hrishikesh Gadre, yonik)
- * SOLR-7305: BlendedInfixLookupFactory swallows root IOException when it occurs.
- (Stephan Lagraulet via shalin)
- * SOLR-7293: Fix bug that Solr server does not listen on IPv6 interfaces by default.
- (Uwe Schindler, Sebastian Pesman)
- * SOLR-7298: Fix Collections API calls (SolrJ) to not add name parameter when not needed.
- (Shai Erera, Anshum Gupta)
- * SOLR-7134: Replication can still cause index corruption. (Mark Miller, shalin, Mike Drob)
- * SOLR-7309: Make bin/solr, bin/post work when Solr installation directory contains spaces
- (Ramkumar Aiyengar, Martijn Koster)
- * SOLR-6924: The config API forcefully refreshes all replicas in the collection to ensure all are
- updated (Noble Paul)
- * SOLR-7266: The IgnoreCommitOptimizeUpdateProcessor blocks commit requests from
- replicas needing to recover. (Jessica Cheng Mallet, Timothy Potter)
- * SOLR-7299: bin\solr.cmd doesn't use jetty SSL configuration. (Steve Rowe)
- * SOLR-7334: Admin UI does not show "Num Docs" and "Deleted Docs". (Erick Erickson, Timothy Potter)
- * SOLR-7338, SOLR-6583: A reloaded core will never register itself as active after a ZK session expiration
- (Mark Miller, Timothy Potter)
- * SOLR-7366: Can't index example XML docs into the cloud example using bin/post due to regression in
- ManagedIndexSchema's handling of ResourceLoaderAware objects used by field types (Steve Rowe, Timothy Potter)
- * SOLR-7284: HdfsUpdateLog is using hdfs FileSystem.get without turning off the cache.
- (Mark Miller)
- * SOLR-7286: Using HDFS's FileSystem.newInstance does not guarantee a new instance.
- (Mark Miller)
- * SOLR-7508: SolrParams.toMultiMap() does not handle arrays (Thomas Scheffler , Noble Paul)
- Optimizations
- ----------------------
- * SOLR-7049: Move work done by the LIST Collections API call to the Collections
- Handler (Varun Thacker via Anshum Gupta).
- * SOLR-7116: Distributed facet refinement requests would needlessly compute other types
- of faceting that have already been computed. (David Smiley, Hossman)
- * SOLR-7239: improved performance of min & max in StatsComponent, as well as situations
- where local params disable all stats (hossman)
- * SOLR-7050: realtime get should internally load only fields specified in fl.
- (yonik, Noble Paul)
- Other Changes
- ----------------------
- * SOLR-7014: Collapse identical catch branches in try-catch statements. (shalin)
- * SOLR-6500: Refactor FileFetcher in SnapPuller, add debug logging.
- (Ramkumar Aiyengar via Mark Miller)
- * SOLR-7076: In DIH, TikaEntityProcessor should have support for onError=skip
- (Noble Paul)
- * SOLR-7094: Better error reporting of JSON parse issues when indexing docs
- (Ishan Chattopadhyaya via Timothy Potter)
- * SOLR-7103: Remove unused method params in faceting code. (shalin)
- * SOLR-6311: When performing distributed queries, SearchHandler should use path
- when no qt or shard.qt parameter is specified; fix also resolves SOLR-4479.
- (Steve Molloy, Timothy Potter)
- * SOLR-7112: Fix DeleteInactiveReplicaTest.deleteLiveReplicaTest test failures.
- (shalin)
- * SOLR-6902: Use JUnit rules instead of inheritance with distributed Solr
- tests to allow for multiple tests without the same class.
- (Ramkumar Aiyengar, Erick Erickson, Mike McCandless)
- * SOLR-7032: Clean up test remnants of old-style solr.xml (Erick Erickson)
- * SOLR-7145: SolrRequest is now parametrized by its response type (Alan
- Woodward)
- * SOLR-7142: Fix TestFaceting.testFacets. (Michal Kroliczek via shalin)
- * SOLR-7156: Fix test failures due to resource leaks on windows.
- (Ishan Chattopadhyaya via shalin)
- * SOLR-7147: Introduce new TrackingShardHandlerFactory for monitoring what requests
- are sent to shards during tests. (hossman, shalin)
- * SOLR-7160: Rename ConfigSolr to NodeConfig, and decouple it from xml
- representation (Alan Woodward)
- * SOLR-7166: Encapsulate JettySolrRunner configuration (Alan Woodward)
- * SOLR-7130: Make stale state notification work without failing the requests
- (Noble Paul, shalin)
- * SOLR-7151: SolrClient query methods throw IOException (Alan Woodward)
- * SOLR-7179: JettySolrRunner no longer passes configuration to
- SolrDispatchFilter via system properties, but instead uses a Properties
- object in the servlet context (Alan Woodward)
- * SOLR-6275: Improve accuracy of QTime reporting (Ramkumar Aiyengar)
- * SOLR-7174: DIH should reset TikaEntityProcessor so that it is capable
- of re-use (Alexandre Rafalovitch , Gary Taylor via Noble Paul)
- * SOLR-6804: Untangle SnapPuller and ReplicationHandler (Ramkumar Aiyengar)
- * SOLR-7180: MiniSolrCloudCluster will startup and shutdown its jetties in
- parallel (Alan Woodward, Tomás Fernández Löbbe, Vamsee Yarlagadda)
- * SOLR-7173: Fix ReplicationFactorTest on Windows by adding better retry
- support after seeing no response exceptions. (Ishan Chattopadhyaya via Timothy Potter)
- * SOLR-7246: Speed up BasicZkTest, TestManagedResourceStorage (Ramkumar Aiyengar)
- * SOLR-7258: Forbid MessageFormat.format and MessageFormat single-arg constructor.
- (shalin)
- * SOLR-7162: Remove unused SolrSortField interface. (yonik, Connor Warrington via shalin)
- * SOLR-6414: Update to Hadoop 2.6.0. (Mark Miller)
- * SOLR-6673: MDC based logging of collection, shard, replica, core
- (Ishan Chattopadhyaya , Noble Paul)
- * SOLR-7291: Test indexing on ZK disconnect with ChaosMonkey tests (Ramkumar Aiyengar)
- * SOLR-7203: Remove buggy no-op retry code in HttpSolrClient (Alan Woodward,
- Mark Miller, Greg Solovyev)
- * SOLR-7202: Remove deprecated string action types in Overseer and OverseerCollectionProcessor -
- "deletecollection", "createcollection", "reloadcollection", "removecollection", "removeshard".
- (Varun Thacker, shalin)
- * SOLR-7290: Rename catchall _text field in data_driven_schema_configs
- to _text_ (Steve Rowe)
- * SOLR-7346: Stored XSS in Admin UI Schema-Browser page and Analysis page (Mei Wang via Timothy Potter)
- ================== 5.0.0 ==================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release.
- NOTE: Solr 5.0 only supports creating and removing SolrCloud collections through
- the collections API, unlike previous versions. While not using the
- collections API may still work in 5.0, it is unsupported, not recommended,
- and the behavior will change in a 5.x release.
- Versions of Major Components
- ---------------------
- Apache Tika 1.7
- Carrot2 3.9.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Jetty 8.1.10.v20130312
- Upgrading from Solr 4.x
- ----------------------
- * Apache Solr has no support for Lucene/Solr 3.x and earlier indexes anymore.
- Be sure to run Lucene's IndexUpgrader on the previous 4.10 version if you might
- still have old segments in your index. Alternatively fully optimize your index
- with Solr 4.10 to make sure it consists only of one up-to-date index segment.
- * The "file" attribute of infoStream in solrconfig.xml is removed. Control this
- via your logging configuration (org.apache.solr.update.LoggingInfoStream) instead.
- * UniqFieldsUpdateProcessorFactory no longer supports the <lst named="fields"> init
- param style that was deprecated in Solr 4.5. If you are still using this syntax,
- update your configs to use <arr name="fieldName"> instead. See SOLR-4249 for more
- details.
- * The following legacy numeric and date field types, deprecated in Solr 4.8, are no
- longer supported: BCDIntField, BCDLongField, BCDStrField, IntField, LongField,
- FloatField, DoubleField, SortableIntField, SortableLongField, SortableFloatField,
- SortableDoubleField, and DateField. Convert these types in your schema to the
- corresponding Trie-based field type and then re-index. See SOLR-5936 for more
- information.
- * getAnalyzer() in IndexSchema and FieldType that was deprecated in Solr 4.9 has
- been removed. Use getIndexAnalyzer() instead. See SOLR-6022 for more information.
- * The spellcheck response format has changed, affecting xml and json clients. In
- particular, the "correctlySpelled" and "collations" subsections have been moved outside
- the "suggestions" subsection, and now are directly under "spellcheck".
- See SOLR-3029 for more information.
- * The CollectionsAPI SolrJ calls createCollection(), reloadCollection(),
- deleteCollection(), requestStatus(), createShard(), splitShard(), deleteShard(),
- createAlias() and deleteAlias() which were deprecated in 4.11 have been removed.
- The new usage involves a builder style construction of the call.
- * The OVERSEERSTATUS API returns new key names for operations such as "create"
- for "createcollection", "delete" for "removecollection" and "deleteshard" for
- "removeshard".
- * If you have been using the /update/json/docs to index documents, SOLR-6617 introduces
- backward incompatible change. the key names created are fully qualified paths of keys .
- If you need the old functionality back , please add an extra parameter f=/**
- example: /update/json/docs?f=/**
- * Bugs fixed in several ValueSource functions may result in different behavior in
- situations where some documents do not have values for fields wrapped in other value
- sources. Users who want to preserve the previous behavior may need to wrap fields
- in the "def()" function. Example: changing "fl=sum(fieldA,fieldB)" to
- "fl=sum(def(fieldA,0.0),def(fieldB,0.0))". See LUCENE-5961 for more details.
- * AdminHandlers is deprecated, /admin/* are implicitly defined, /get, /replication and
- handlers are also implicitly registered (refer to SOLR-6792)
- * SolrCore.reload(ConfigSet coreConfig, SolrCore prev) was deprecated in 4.10.3 and
- removed in 5.0. use SolrCore.reload(ConfigSet coreConfig). See SOLR-5864.
- * The "termIndexInterval" option in solrconfig.xml has been a No-Op in the default codec
- since Solr 4.0, and has been removed completely in 5.0. If you get an "Illegal parameter
- 'termIndexInterval'" error when upgrading, you can safely remove this option from your
- configs. If you have a strong need to configure this, you must explicitly configure your
- schema with a custom codec. See SOLR-6560 and for more details.
- * The "checkIntegrityAtMerge" option in solrconfig.xml is now a No-Op and should be removed
- from any solrconfig.xml files -- these integrity checks are now done automatically at a very
- low level during the segment merging process. See SOLR-6834 for more details.
- * SimplePostTool (post.jar) no longer defaults to collection1, making either of core/collection
- name or update URL mandatory. An existing call without an explicit update URL needs to now
- have the core/collection name passed as "-Dc=<collection/core name>" e.g.:
- java -jar -Dc=<collection_name> post.jar *.xml (new call with collection name)
- See SOLR-6852 for more details.
- * Relative paths specified in the solr.xml coreRootDirectory parameter for core
- discovery are now resolved relative to SOLR_HOME, rather than cwd. See
- SOLR-6718.
- * SolrServer and associated classes have been deprecated. Applications using
- SolrJ should use the equivalent SolrClient classes instead.
- * Spatial fields originating from Solr 4 (e.g. SpatialRecursivePrefixTreeFieldType, BBoxField)
- have the 'units' attribute deprecated, now replaced with 'distanceUnits'. If you change it to
- a unit other than 'degrees' (or if you don't specify it, which will default to kilometers if
- geo=true), then be sure to update maxDistErr as it's in those units. If you keep units=degrees
- then it should be backwards compatible but you'll get a deprecation warning on startup. See
- SOLR-6797.
- * The <nrtMode> configuration in solrconfig.xml has been discontinued and should be removed from
- solrconfig.xml. Solr defaults to using NRT searchers regardless of the value in configuration
- and a warning is logged on startup if the solrconfig.xml has <nrtMode> specified.
- * There was an old spatial syntax to specify a circle using Circle(x,y d=...) which should be
- replaced with simply using {!geofilt} (if you can) or BUFFER(POINT(x y),d). Likewise a rect syntax
- comprised of minX minY maxX maxY that should now be replaced with
- ENVELOPE(minX, maxX, maxY, minY).
- * Due to changes in the underlying commons-codec package, users of the BeiderMorseFilterFactory
- will need to rebuild their indexes after upgrading. See LUCENE-6058 for more details.
- * CachedSqlEntityProcessor has been removed, use SqlEntityProcessor with the
- cacheImpl parameter.
- * HttpDataSource has been removed, use URLDataSource instead.
- * LegacyHTMLStripCharFilter has been removed
- * CoreAdminRequest.persist() call has been removed. All changes made via
- CoreAdmin are persistent.
- * SpellCheckResponse.getSuggestions() and getSuggestionFrequencies() have been
- removed, use getAlternatives() and getAlternativeFrequencies() instead.
- * SolrQuery deprecated methods have been removed:
- - setMissing() is now setFacetMissing()
- - getFacetSort() is now getFacetSortString()
- - setFacetSort(boolean) should instead use setFacetSort(String) with
- FacetParams.FACET_SORT_COUNT or FacetParams.FACET_SORT_INDEX
- - setSortField(String, ORDER) should use setSort(SortClause)
- - addSortField(String, ORDER) should use addSort(SortClause)
- - removeSortField(String, ORDER) should use removeSort(SortClause)
- - getSortFields() should use getSorts()
- - set/getQueryType() should use set/getRequestHandler()
- * ClientUtil deprecated date methods have been removed, use DateUtil instead
- * FacetParams.FacetDateOther has been removed, use FacetRangeOther
- * ShardParams.SHARD_KEYS has been removed, use ShardParams._ROUTE_
- * The 'old-style' solr.xml format is no longer supported, and cores must be
- defined using core.properties files. See
- https://cwiki.apache.org/confluence/display/solr/Format+of+solr.xml
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-6103: Added DateRangeField for indexing date ranges, especially multi-valued ones.
- Supports facet.range, DateMath, and is mostly interoperable with TrieDateField.
- Based on LUCENE-5648. (David Smiley)
- * SOLR-6403: TransactionLog replay status logging. (Mark Miller)
- * SOLR-4580: Support for protecting content in ZooKeeper. (Per Steffensen, Mark Miller)
- * SOLR-6365: specify appends, defaults, invariants outside of the request handler.
- (Noble Paul, Erik Hatcher, shalin)
- * SOLR-5097: Schema API: Add REST support for adding dynamic fields to the schema.
- (Steve Rowe)
- * SOLR-5098: Schema API: Add REST support for adding field types to the schema.
- (Timothy Potter)
- * SOLR-5473 : Split clusterstate.json per collection and watch states selectively
- (Noble Paul, Mark Miller, shalin, Jessica Cheng Mallet, Timothy Potter, Anshum Gupta)
- * SOLR-5474 : Support for SOLR-5473 in SolrJ (Timothy Potter, Noble Paul, Mark Miller)
- * SOLR-5810 : Support for SOLR-5473 in solr admin UI (Timothy Potter, Noble Paul)
- * SOLR-6482: Add an onlyIfDown flag for DELETEREPLICA collections API command
- (Erick Erickson)
- * SOLR-6354: stats.field can now be used to generate stats over the numeric results
- of arbitrary functions, ie: stats.field={!func}product(price,popularity)
- (hossman)
- * SOLR-6485: ReplicationHandler should have an option to throttle the speed of
- replication (Varun Thacker, Noble Paul)
- * SOLR-6543: Give HttpSolrClient the ability to send PUT requests (Gregory Chanan)
- * SOLR-5986: Don't allow runaway queries from harming Solr cluster health or search
- performance (Anshum Gupta, Steve Rowe, Robert Muir)
- * SOLR-6565: SolrRequest support for query params (Gregory Chanan)
- * SOLR-6476: Create a bulk mode for schema API (Noble Paul, Steve Rowe)
- * SOLR-6512: Add a collections API call to add/delete arbitrary properties
- to a specific replica. Optionally adding sliceUnique=true will remove
- this property from all other replicas within a particular slice.
- (Erick Erickson)
- * SOLR-6513: Add a collectionsAPI call BALANCESLICEUNIQUE. Allows the even
- distribution of custom replica properties across nodes making up a
- collection, at most one node per slice will have the property.
- * SOLR-6605: Make ShardHandlerFactory maxConnections configurable.
- (Christine Poerschke via shalin)
- * SOLR-6585: RequestHandlers can optionally handle sub paths as well (Noble Paul)
- * SOLR-6617: /update/json/docs path will use fully qualified node names by default
- (Noble Paul)
- * SOLR-4715: Add CloudSolrClient constructors which accept a HttpClient instance.
- (Hardik Upadhyay, Shawn Heisey, shalin)
- * SOLR-5992: add "removeregex" as an atomic update operation
- (Vitaliy Zhovtyuk via Erick Erickson)
- * SOLR-6633: /update/json/docs path can now save the underlying json doc asa string field
- and better support added to the default example (Noble Paul)
- * SOLR-6650: Add optional slow request logging at WARN level
- (Jessica Cheng Mallet via Timothy Potter)
- * SOLR-6655: SimplePostTool now features -Dhost, -Dport, and -Dc (for core/collection)
- properties to allow easier overriding of just the right piece of the Solr URL.
- (ehatcher)
- * SOLR-6248: MoreLikeThis QParser that accepts a document id and returns documents that
- have similar content. It works in standalone/cloud mode and shares logic with the
- Lucene MoreLikeThis class (Anshum Gupta).
- * SOLR-6670: change BALANCESLICEUNIQUE to BALANCESHARDUNIQUE. Also, the parameter
- for ADDREPLICAPROP that used to be sliceUnique is now shardUnique. (Erick Erickson)
- * SOLR-6351: Stats can now be nested under pivot values by adding a 'stats' local param to
- facet.pivot which refers to a 'tag' local param in one or more stats.field params.
- (hossman, Vitaliy Zhovtyuk, Steve Molloy)
- * SOLR-6533: Support editing common solrconfig.xml values (Noble Paul)
- * SOLR-6607: Managing requesthandlers through API (Noble Paul)
- * SOLR-4799: faster join using join="zipper" aka merge join for nested DIH EntityProcessors
- (Mikhail Khludnev via Noble Paul)
- * SOLR-6787: API to manage blobs in Solr (Noble Paul)
- * SOLR-6801: Load RequestHandler from blob store (Noble Paul)
- * SOLR-1632: Support Distributed IDF (Andrzej Bialecki, Mark Miller, Yonik Seeley,
- Robert Muir, Markus Jelsma, Vitaliy Zhovtyuk, Anshum Gupta)
- * SOLR-6729: createNodeSet.shuffle=(true|false) support for /admin/collections?action=CREATE.
- (Christine Poerschke, Ramkumar Aiyengar via Mark Miller)
- * SOLR-6851: Scripts to support installing and running Solr as a service on Linux
- (Timothy Potter, Hossman, Steve Rowe)
- * SOLR-6770: Add/edit param sets and use them in Requests (Noble Paul)
- * SOLR-6879: Have an option to disable autoAddReplicas temporarily for all collections.
- (Varun Thacker via Steve Rowe)
- * SOLR-6435: Add bin/post script to simplify posting content to Solr (Erik Hatcher)
- * SOLR-6761: Ability to ignore commit and/or optimize requests from clients when running in
- SolrCloud mode using the IgnoreCommitOptimizeUpdateProcessorFactory. (Timothy Potter)
- * SOLR-6797: Spatial fields that used to require units=degrees like
- SpatialRecursivePrefixTreeFieldType (RPT) now take distanceUnits=degrees|kilometers|miles
- instead. It is applied to nearly all distance measurements involving the field: maxDistErr,
- distErr, d, geodist, score=distance|area|area2d. score now accepts these units as well. It does
- NOT affect distances embedded in WKT strings like BUFFER(POINT(200 10),0.2)).
- (Ishan Chattopadhyaya, David Smiley)
- * SOLR-6766: Expose HdfsDirectoryFactory Block Cache statistics via JMX.
- (Mike Drob, Mark Miller)
- * SOLR-2035: Add a VelocityResponseWriter $resource tool for locale-specific string lookups.
- (Erik Hatcher)
- * SOLR-6916: Toggle payload support for the default highlighter via hl.payloads. It's auto
- enabled when the index has payloads. (David Smiley)
- * SOLR-6581: Efficient DocValues support and numeric collapse field implementations
- for Collapse and Expand (Joel Bernstein)
- * SOLR-6937: In schemaless mode ,replace spaces and special characters with underscore (Noble Paul)
- * SOLR-5147: Support child documents in DIH
- (Vadim Kirilchuk, Shawn Heisey, Thomas Champagne, Mikhail Khludnev via Noble Paul)
- Bug Fixes
- ----------------------
- * SOLR-4895: An error should be returned when a rollback is attempted in SolrCloud mode.
- (Vamsee Yarlagadda via Mark Miller)
- * SOLR-6424: The hdfs block cache BLOCKCACHE_WRITE_ENABLED is not defaulting to false like it
- should. (Mark Miller)
- * SOLR-6426: SolrZkClient clean can fail due to a race with children nodes. (Mark Miller)
- * SOLR-5966: Admin UI Menu is fixed and doesn't respect smaller viewports.
- (Aman Tandon, steffkes via shalin)
- * SOLR-4406: Fix RawResponseWriter to respect 'base' writer
- (Steve Davids, hossman)
- * SOLR-6297: Fix WordBreakSolrSpellChecker to not lose suggestions in shard/cloud
- environments (James Dyer)
- * SOLR-6467: bin/solr script should direct stdout/stderr when starting in the background
- to the solr-PORT-console.log in the logs directory instead of bin. (Timothy Potter)
- * SOLR-6187: SOLR-6154: facet.mincount ignored in range faceting using distributed search
- NOTE: This does NOT fixed for the (deprecated) facet.date idiom, use facet.range
- instead. (Erick Erickson, Zaccheo Bagnati, Ronald Matamoros, Vamsee Yalargadda)
- * SOLR-6457: LBHttpSolrClient: ArrayIndexOutOfBoundsException risk if counter overflows
- (longkey via Noble Paul)
- * SOLR-6499: Log warning about multiple update request handlers
- (Noble Paul, Andreas Hubold, hossman)
- * SOLR-6507: Fixed several bugs involving stats.field used with local params (hossman)
- * SOLR-6481: CLUSTERSTATUS should check if the node hosting a replica is live when
- reporting replica status (Timothy Potter)
- * SOLR-6484: SolrCLI's healthcheck action needs to check live nodes as part of reporting
- the status of a replica (Timothy Potter)
- * SOLR-6540 Fix NPE from strdist() func when doc value source does not exist in a doc (hossman)
- * SOLR-6624 Spelling mistakes in the Java source (Hrishikesh Gadre)
- * SOLR-6307: Atomic update remove does not work for int array or date array
- (Anurag Sharma , noble)
- * SOLR-6224: Post soft-commit callbacks are called before soft commit actually happens.
- (shalin)
- * SOLR-6591: Overseer can use stale cluster state and lose updates for collections
- with stateFormat > 1. (shalin)
- * SOLR-6631: DistributedQueue spinning on calling zookeeper getChildren()
- (Jessica Cheng Mallet, Mark Miller, Timothy Potter)
- * SOLR-6579: SnapPuller Replication blocks clean shutdown of tomcat
- (Philip Black-Knight via Noble Paul)
- * SOLR-6721: ZkController.ensureReplicaInLeaderInitiatedRecovery puts replica
- in local map before writing to ZK. (shalin)
- * SOLR-6679: Disabled suggester component from techproduct solrconfig.xml since
- it caused long startup times on large indexes even when it wasn't used.
- (yonik, hossman)
- * SOLR-6738: Admin UI - Escape Data on Plugins-View (steffkes)
- * SOLR-3774: Solr adds RequestHandler SolrInfoMBeans twice to the JMX server.
- (Tomás Fernández Löbbe, hossman, Mark Miller)
- * SOLR-6763: Shard leader elections should not persist across session expiry
- (Alan Woodward, Mark Miller)
- * SOLR-3881: Avoid OOMs in LanguageIdentifierUpdateProcessor:
- - Added langid.maxFieldValueChars and langid.maxTotalChars params to limit
- input, by default 10k and 20k chars, respectively.
- - Moved input concatenation to Tika implementation; the langdetect
- implementation instead appends each input piece via the langdetect API.
- (Vitaliy Zhovtyuk, Tomás Fernández Löbbe, Rob Tulloh, Steve Rowe)
- * SOLR-6626: NPE in FieldMutatingUpdateProcessor when indexing a doc with
- null field value (Noble Paul)
- * SOLR-6604: SOLR-6812: Fix NPE with distrib.singlePass=true and expand
- component. Increased test coverage of expand component with docValues.
- (Christine Poerschke, Per Steffensen, shalin)
- * SOLR-6718: Core discovery was walking paths relative to the Jetty working
- directory, rather than SOLR_HOME. (Andreas Hubold, Alan Woodward)
- * SOLR-6864: Support registering searcher listeners in SolrCoreAware.inform(SolrCore)
- method. Existing components rely on this. (Tomás Fernández Löbbe)
- * SOLR-6850: AutoAddReplicas makes a call to wait to see live replicas that times
- out after 30 milliseconds instead of 30 seconds. (Varun Thacker via Mark Miller)
- * SOLR-6397: zkcli script put/putfile should allow overwriting an existing znode's data
- (Timothy Potter)
- * SOLR-6873: Lib relative path is incorrect for techproduct configset
- (Alexandre Rafalovitch via Erick Erickson)
- * SOLR-6899: Change public setter for CollectionAdminRequest.action to protected.
- (Anshum Gupta)
- * SOLR-6779: fix /browse for schemaless example (ehatcher)
- * SOLR-6874: There is a race around SocketProxy binding to it's port the way we setup
- JettySolrRunner and SocketProxy. (Mark Miller, Timothy Potter)
- * SOLR-6735: Make CloneFieldUpdateProcessorFactory null safe (Steve Davids via ehatcher)
- * SOLR-6907: URLEncode documents directory in MorphlineMapperTest to handle spaces etc.
- in file name. (Ramkumar Aiyengar via Erick Erickson)
- * SOLR-6880: Harden ZkStateReader to expect that getCollectionLive may return null
- as it's contract states. (Mark Miller, shalin)
- * SOLR-6643: Fix error reporting & logging of low level JVM Errors that occur when
- loading/reloading a SolrCore (hossman)
- * SOLR-6839: Direct routing with CloudSolrServer will ignore the Overwrite document option.
- (Mark Miller)
- * SOLR-6793: ReplicationHandler does not destroy all of it's created SnapPullers.
- (Mark Miller)
- * SOLR-6946: Document -p port option for the create_core and create_collection actions in
- bin/solr (Timothy Potter)
- * SOLR-6923: AutoAddReplicas also consults live_nodes to see if a state change has happened.
- (Varun Thacker via Anshum Gupta)
- * SOLR-6941: DistributedQueue#containsTaskWithRequestId can fail with NPE. (Mark Miller)
- * SOLR-6764: Field types need to be re-informed after reloading a managed schema from ZK
- (Timothy Potter)
- * SOLR-6931: We should do a limited retry when using HttpClient.
- (Mark Miller, Hrishikesh Gadre, Gregory Chanan)
- * SOLR-7004: Add a missing constructor for CollectionAdminRequest.BalanceShardUnique that
- sets the collection action. (Anshum Gupta)
- * SOLR-6993: install_solr_service.sh won't install on RHEL / CentOS
- (David Anderson via Timothy Potter)
- * SOLR-6928: solr.cmd stop works only in english (john.work, Jan Høydahl, Timothy Potter)
- * SOLR-7011: Delete collection returns before collection is actually removed.
- (Christine Poerschke via shalin)
- * SOLR-6640: Close searchers before rollback and recovery to avoid index corruption.
- (Robert Muir, Varun Thacker, shalin)
- * SOLR-6847: LeaderInitiatedRecoveryThread compares wrong replica's state with lirState.
- (shalin)
- * SOLR-6856: Restore ExtractingRequestHandler's ability to capture all HTML tags when
- parsing (X)HTML. (hossman, Uwe Schindler, ehatcher, Steve Rowe)
- * SOLR-7024: Improved error messages when java is not found by the bin/solr
- shell script, particularly when JAVA_HOME has an invalid location.
- (Shawn Heisey)
- * SOLR-7038: Validate the presence of configset before trying to create a collection.
- (Anshum Gupta, Mark Miller)
- * SOLR-7037: bin/solr start -e techproducts -c fails to start Solr in cloud mode
- (Timothy Potter)
- * SOLR-7016: Fix bin\solr.cmd to work in a directory with spaces in the name.
- (Timothy Potter, Uwe Schindler)
- * SOLR-6969: When opening an HDFSTransactionLog for append we must first attempt to recover
- it's lease to prevent data loss. (Mark Miller, Praneeth Varma, Colin McCabe)
- * SOLR-7067: bin/solr won't run under bash 4.2+. (Steve Rowe)
- * SOLR-7068: Collapse on numeric field breaks when min/max values are negative.
- (Joel Bernstein)
- * SOLR-6780: Fixed a bug in how default/appends/invariants params were affecting the set
- of all "keys" found in the request parameters, resulting in some key=value param pairs
- being duplicated. This was noticeably affecting some areas of the code where iteration
- was done over the set of all params:
- - literal.* in ExtractingRequestHandler
- - facet.* in FacetComponent
- - spellcheck.[dictionary name].* and spellcheck.collateParam.* in SpellCheckComponent
- - olap.* in AnalyticsComponent
- (Alexandre Rafalovitch & hossman)
- * SOLR-6920: A replicated index can end up corrupted when small files end up with the same
- file name and size. (Varun Thacker, Mark Miller)
- * SOLR-7033, SOLR-5961: RecoveryStrategy should not publish any state when
- closed / cancelled and there should always be a pause between recoveries
- even when recoveries are rapidly stopped and started as well as when a
- node attempts to become the leader for a shard.
- (Mark Miller, Maxim Novikov)
- * SOLR-6693: bin\solr.cmd doesn't support 32-bit JRE/JDK running on Windows due to
- parenthesis in JAVA_HOME. (Timothy Potter, Christopher Hewitt, Jan Høydahl)
- * SOLR-12662: Reproducing TestPolicy failures: NPE and NoClassDefFoundError.
- (Steve Rowe)
- Optimizations
- ----------------------
- * SOLR-6603: LBHttpSolrClient - lazily allocate skipped-zombie-servers list.
- (Christine Poerschke via shalin)
- * SOLR-6554: Speed up overseer operations avoiding cluster state reads from
- zookeeper at the start of each loop and instead relying on local state and
- compare-and-set writes. This change also adds batching for consecutive messages
- belonging to the same collection with stateFormat=2. (shalin)
- * SOLR-6680: DefaultSolrHighlighter can sometimes avoid CachingTokenFilter with
- hl.usePhraseHighlighter, and can be more efficient handling data from term vectors.
- (David Smiley)
- * SOLR-6666: Dynamic copy fields are considering all dynamic fields, causing
- a significant performance impact on indexing documents. (Liram Vardi via Erick
- Erickson, Steve Rowe)
- Other Changes
- ----------------------
- * SOLR-4622: Hardcoded SolrCloud defaults for hostContext and hostPort that
- were deprecated in 4.3 have been removed completely. (hossman)
- * SOLR-5936: Removed deprecated non-Trie-based numeric & date field types.
- (Steve Rowe)
- * SOLR-6169: Finish removal of CoreAdminHandler handleAlias action begun in 4.9
- (Alan Woodward)
- * SOLR-6215: TrieDateField should directly extend TrieField instead of
- forwarding to a wrapped TrieField. (Steve Rowe)
- * SOLR-3029: Changes to spellcheck response format (Nalini Kartha via James Dyer)
- * SOLR-3957: Removed RequestHandlerUtils#addExperimentalFormatWarning(), which
- removes "experimental" warning from two places: replication handler details
- command and DataImportHandler responses. (ehatcher)
- * SOLR-6073: Remove helper methods from CollectionsRequest (SolrJ) for CollectionsAPI
- calls and move to a builder design for the same. (Varun Thacker, Anshum Gupta)
- * SOLR-6519: Make DirectoryFactory#create() take LockFactory.
- (Uwe Schindler)
- * SOLR-6400: SolrCloud tests are not properly testing session expiration. (Mark Miller)
- * LUCENE-5650: Tests can no longer write to CWD. Update log dir is now made relative
- to the instance dir if it is not an absolute path. (Ryan Ernst, Dawid Weiss)
- * SOLR-6390: Remove unnecessary checked exception for CloudSolrClient
- constructors, improve javadocs for CloudSolrClient constructors.
- (Steve Davids via Shawn Heisey)
- * LUCENE-5901: Replaced all occurrences of LUCENE_CURRENT with LATEST for luceneMatchVersion.
- (Ryan Ernst)
- * SOLR-6445: Upgrade Noggit to version 0.6 to support more flexible JSON input (Noble Paul, Yonik Seeley)
- * SOLR-6073: Remove helper methods from CollectionsRequest (SolrJ) for CollectionsAPI
- calls and move to a builder design for the same. (Varun Thacker, Anshum Gupta)
- * SOLR-5322: core discovery can fail w/NPE and no explanation if a non-readable directory exists
- (Said Chavkin, Erick Erickson)
- * SOLR-6488, SOLR-6991: Update to Apache Tika 1.7. This adds support for parsing Outlook PST and
- Matlab MAT files. Parsing for NetCDF files was removed because of license issues; if you need
- support for this format, download the parser JAR yourself and add it to contrib/extraction/lib
- folder: http://www.unidata.ucar.edu/software/thredds/current/netcdf-java/
- (Uwe Schindler)
- * SOLR-6115: Cleanup enum/string action types in Overseer, OverseerCollectionProcessor and
- CollectionHandler. (Erick Erickson, shalin)
- * SOLR-6453: Stop throwing an error message from Overseer when node exits (Ramkumar Aiyengar, Noble Paul)
- * SOLR-6550: Provide simple mechanism for passing additional metadata / context about a server-side
- SolrException back to the client-side (Timothy Potter)
- * SOLR-6249: Schema API changes return success before all cores are updated; client application
- can provide the optional updateTimeoutSecs parameter to cause the server handling the
- managed schema update to block until all replicas of the same collection have processed the
- update or until the specified timeout is reached (Timothy Potter)
- * SOLR-6597: SolrIndexConfig parameter in one of the SolrIndexSearcher constructor has been removed.
- It was just passed and never used via that constructor. (Anshum Gupta)
- * SOLR-5852: Add CloudSolrClient helper method to connect to a ZK ensemble. (Varun Thacker, Furkan KAMACI,
- Shawn Heisey, Mark Miller, Erick Erickson via shalin)
- * SOLR-6592: Avoid waiting for the leader to see the down state if that leader is not live.
- (Timothy Potter)
- * SOLR-6641: SystemInfoHandler should include the zkHost the node is using (when running in solrcloud mode)
- (Timothy Potter)
- * SOLR-6295: Fix child filter query creation to never match parent docs in SolrExampleTests.
- (Varun Thacker, Mikhail Khludnev via shalin)
- * SOLR-6578: Update commons-io dependency to the latest 2.4 version
- (Steve Rowe, Shawn Heisey)
- * SOLR-6651: Fix wrong timeout logged in waitForReplicasToComeUp. (shalin)
- * SOLR-6698: Solr is not consistent wrt ZkCredentialsProvider / ZkCredentialProvider.
- References to zkCredentialProvider in System properties or configurations should be
- changed to zkCredentialsProvider. (Gregory Chanan)
- * SOLR-6715: ZkSolrResourceLoader constructors accept a parameter called 'collection'
- but it should be 'configName'. (shalin)
- * SOLR-6697: bin/solr start scripts allow setting SOLR_OPTS in solr.in.* (janhoy)
- * SOLR-6739: Admin UI - Sort list of command line args (steffkes)
- * SOLR-6740: Admin UI - improve Files View (steffkes)
- * SOLR-6570: Run SolrZkClient session watch asynchronously.
- (Ramkumar Aiyengar via Mark Miller)
- * SOLR-6747: Add an optional caching option as a workaround for SOLR-6586.
- (Mark Miller, Gregory Chanan)
- * SOLR-6459: Normalize logging of operations in Overseer and log current queue size.
- (Ramkumar Aiyengar, shalin via Mark Miller)
- * SOLR-6754: ZkController.publish doesn't use the updateLastState parameter.
- (shalin)
- * SOLR-6751: Exceptions thrown in the analysis chain in DirectUpdateHandler2
- should return a BAD_REQUEST status (Alan Woodward)
- * SOLR-6792: deprecate AdminHandlers, Clean up solrconfig.xml of
- unnecessary plugin definitions, implicit registration of /replication,
- /get and /admin/* handlers (Noble Paul)
- * SOLR-5864: Remove previous SolrCore as parameter on reload.
- (Tomás Fernández Löbbe)
- * SOLR-4792: Stop shipping a .war. (Robert Muir, Ramkumar Aiyengar, Mark Miller)
- * SOLR-6799: Update Saxon-HE to 9.6.0-2. (Mark Miller)
- * SOLR-6454: Suppress EOFExceptions in SolrDispatchFilter.
- (Ramkumar Aiyengar via Mark Miller)
- * SOLR-6370: Allow tests to report/fail on many ZK watches being parallelly
- requested on the same data (Ramkumar Aiyengar via Timothy Potter)
- * SOLR-6752: Buffer Cache allocate/lost metrics should be exposed.
- (Mike Drob via Mark Miller)
- * SOLR-6560: Purge termIndexInterval from example/test configs
- (Tom Burton-West, hossman)
- * SOLR-6773: Remove the multicore example as the DIH and cloud examples
- illustrate multicore behavior (hossman, Timothy Potter)
- * SOLR-6834: Warn if checkIntegrityAtMerge is configured. This option is no longer meaningful
- since the checks are done automatically at a very low level in the segment merging.
- This warning will become an error in Solr 6.0. (hossman)
- * SOLR-6833: Examples started with bin/solr -e should use a solr.solr.home directory under
- the example directory instead of server/solr. (Alexandre Rafalovitch, Anshum Gupta, hossman,
- Timothy Potter)
- * SOLR-6826: fieldType capitalization is not consistent with the rest of case-sensitive field names.
- (Alexandre Rafalovitch via Erick Erickson)
- * SOLR-6849: HttpSolrClient.RemoteSolrException reports the URL of the remote
- host where the exception occurred. (Alan Woodward)
- * SOLR-6852: SimplePostTool no longer defaults to collection1 making core/collection/update URL
- mandatory. (Anshum Gupta)
- * SOLR-6861: post.sh from exampledocs directory has been removed as there no longer is a default update
- URL. (Anshum Gupta)
- * SOLR-5922: Add support for adding core properties to SolrJ Collection Admin Request calls.
- (Varun Thacker via Anshum Gupta).
- * SOLR-6523: Provide SolrJ support for specifying stateFormat while creating Collections.
- (Anshum Gupta)
- * SOLR-6881: Add split.key support for SPLITSHARD via SolrJ (Anshum Gupta)
- * SOLR-6883: CLUSTERPROP API switch case does not call break. (Varun Thacker via shalin)
- * SOLR-6882: Misspelled collection API actions in ReplicaMutator exception messages.
- (Steve Rowe via shalin)
- * SOLR-6867: SolrCLI should check for existence before creating a new core/collection,
- more user-friendly error reporting (no stack trace), and the ability to pass a
- directory when using bin/solr to create a core or collection (Timothy Potter)
- * SOLR-6885: Add core name to RecoveryThread name. (Christine Poerschke via shalin)
- * SOLR-6855: bin/solr -e dih launches, but has some path cruft issues preventing some of the
- imports don't work (Hossman, Timothy Potter)
- * SOLR-3711: Truncate long strings in /browse field facets (ehatcher)
- * SOLR-6876: Remove unused legacy scripts.conf (Alexandre Rafalovitch via Erick Erickson)
- * SOLR-6896: Speed up tests by dropping SolrJettyRunner thread max idle time
- (Alan Woodward)
- * SOLR-6448: Add SolrJ support for all current Collection API calls. (Anshum Gupta)
- * Fixed a typo in various solrconfig.xml files. (sdumitriu - pull request #120)
- * SOLR-6895: SolrServer classes are renamed to *SolrClient. The existing
- classes still exist, but are deprecated. (Alan Woodward, Erik Hatcher)
- * SOLR-6483: Refactor some methods in MiniSolrCloudCluster tests (Steve Davids via
- Erick Erickson)
- * SOLR-6906: Fix typo bug in DistributedDebugComponentTest.testCompareWithNonDistributedRequest
- (Ramkumar Aiyengar via Erick Erickson)
- * SOLR-6905: Test pseudo-field retrieval in distributed search.
- (Ramkumar Aiyengar via shalin)
- * SOLR-6897: Nuke non-NRT mode from code and configuration. (Hossman, shalin)
- * SOLR-6830: Update Woodstox to 4.4.1 and StAX to 3.1.4. (ab)
- * SOLR-6918: No need to log exceptions (as warn) generated when creating MBean stats if
- the core is shutting down (Timothy Potter)
- * SOLR-6932: All HttpClient ConnectionManagers and SolrJ clients should always be shutdown
- in tests and regular code. (Mark Miller)
- * SOLR-1723: VelocityResponseWriter improvements (Erik Hatcher)
- * SOLR-6324: Set finite default timeouts for select and update. (Ramkumar Aiyengar via Mark Miller)
- * SOLR-6952: bin/solr create action should copy configset directory instead of reusing
- an existing configset in ZooKeeper by default (Timothy Potter)
- * SOLR-6933: bin/solr should provide a single "create" action that creates a core
- or collection depending on whether Solr is running in standalone or cloud mode
- (Timothy Potter)
- * SOLR-6496: LBHttpSolrClient stops server retries after the timeAllowed threshold is met.
- (Steve Davids, Anshum Gupta)
- * SOLR-6904: Removed deprecated Circle & rect syntax. See upgrading notes. (David Smiley)
- * SOLR-6943: HdfsDirectoryFactory should fall back to system props for most of it's config
- if it is not found in solrconfig.xml. (Mark Miller, Mike Drob)
- * SOLR-6926: "ant example" makes no sense anymore - should be "ant server"
- (Ramkumar Aiyengar, Timothy Potter)
- * SOLR-6982: bin/solr and SolrCLI should support SSL-related Java System Properties
- (Timothy Potter)
- * SOLR-6981: Add a delete action to the bin/solr script to allow deleting of cores /
- collections (with delete collection config directory from ZK) (Timothy Potter)
- * SOLR-6840: Remove support for old-style solr.xml (Erick Erickson, Alan Woodward)
- * SOLR-6976: Remove classes and methods deprecated in 4.x (Alan Woodward, Noble
- Paul, Chris Hostetter)
- * SOLR-6521: CloudSolrClient should synchronize cache cluster state loading
- ( Noble Paul, Jessica Cheng Mallet)
- * SOLR-7018: bin/solr stop should stop if there is only one node running or generate
- an error message prompting the user to be explicit about which of multiple nodes
- to stop using the -p or -all options (Timothy Potter)
- * SOLR-5918: ant clean does not remove ZooKeeper data (Varun Thacker, Steve Rowe)
- * SOLR-7020: 'bin/solr start' should automatically use an SSL-enabled alternate jetty
- configuration file when in SSL mode, eliminating the need for manual jetty.xml edits.
- (Steve Rowe)
- * SOLR-6227: Avoid spurious failures of ChaosMonkeySafeLeaderTest by ensuring there's
- at least one jetty to kill. (shalin)
- ================== 4.10.4 ==================
- Bug Fixes
- ----------------------
- * SOLR-6931: We should do a limited retry when using HttpClient.
- (Mark Miller, Hrishikesh Gadre, Gregory Chanan)
- * SOLR-6780: Fixed a bug in how default/appends/invariants params were affecting the set
- of all "keys" found in the request parameters, resulting in some key=value param pairs
- being duplicated. This was noticeably affecting some areas of the code where iteration
- was done over the set of all params:
- - literal.* in ExtractingRequestHandler
- - facet.* in FacetComponent
- - spellcheck.[dictionary name].* and spellcheck.collateParam.* in SpellCheckComponent
- - olap.* in AnalyticsComponent
- (Alexandre Rafalovitch & hossman)
- * SOLR-6426: SolrZkClient clean can fail due to a race with children nodes. (Mark Miller)
- * SOLR-6457: LBHttpSolrClient: ArrayIndexOutOfBoundsException risk if counter overflows
- (longkey via Noble Paul)
- * SOLR-6481: CLUSTERSTATUS should check if the node hosting a replica is live when
- reporting replica status (Timothy Potter)
- * SOLR-6631: DistributedQueue spinning on calling zookeeper getChildren()
- (Jessica Cheng Mallet, Mark Miller, Timothy Potter)
- * SOLR-6579: SnapPuller Replication blocks clean shutdown of tomcat
- (Philip Black-Knight via Noble Paul)
- * SOLR-6763: Shard leader elections should not persist across session expiry
- (Alan Woodward, Mark Miller)
- * SOLR-3881: Avoid OOMs in LanguageIdentifierUpdateProcessor:
- - Added langid.maxFieldValueChars and langid.maxTotalChars params to limit
- input, by default 10k and 20k chars, respectively.
- - Moved input concatenation to Tika implementation; the langdetect
- implementation instead appends each input piece via the langdetect API.
- (Vitaliy Zhovtyuk, Tomás Fernández Löbbe, Rob Tulloh, Steve Rowe)
- * SOLR-6850: AutoAddReplicas makes a call to wait to see live replicas that times
- out after 30 milliseconds instead of 30 seconds. (Varun Thacker via Mark Miller)
- * SOLR-6839: Direct routing with CloudSolrServer will ignore the Overwrite document option.
- (Mark Miller)
- * SOLR-7139: Fix SolrContentHandler for TIKA to ignore multiple startDocument events.
- (Chris A. Mattmann, Uwe Schindler)
- * SOLR-6941: DistributedQueue#containsTaskWithRequestId can fail with NPE. (Mark Miller)
- * SOLR-7011: Delete collection returns before collection is actually removed.
- (Christine Poerschke via shalin)
- * SOLR-6856: Restore ExtractingRequestHandler's ability to capture all HTML tags when
- parsing (X)HTML. (hossman, Uwe Schindler, ehatcher, Steve Rowe)
- * SOLR-6928: solr.cmd stop works only in english (john.work, Jan Høydahl, Timothy Potter)
- * SOLR-7038: Validate the presence of configset before trying to create a collection.
- (Anshum Gupta, Mark Miller)
- * SOLR-7016: Fix bin\solr.cmd to work in a directory with spaces in the name.
- (Timothy Potter, Uwe Schindler)
- * SOLR-6693: bin\solr.cmd doesn't support 32-bit JRE/JDK running on Windows due to
- parenthesis in JAVA_HOME. (Timothy Potter, Christopher Hewitt, Jan Høydahl)
- * SOLR-7067: bin/solr won't run under bash 4.2+. (Steve Rowe)
- * SOLR-7033, SOLR-5961: RecoveryStrategy should not publish any state when
- closed / cancelled and there should always be a pause between recoveries
- even when recoveries are rapidly stopped and started as well as when a
- node attempts to become the leader for a shard.
- (Mark Miller, Maxim Novikov)
- * SOLR-6847: LeaderInitiatedRecoveryThread compares wrong replica's state with lirState.
- (shalin)
- * SOLR-7128: Two phase distributed search is fetching extra fields in GET_TOP_IDS phase.
- (Pablo Queixalos, shalin)
- Other Changes
- ----------------------
- * SOLR-7147: Introduce new TrackingShardHandlerFactory for monitoring what requests
- are sent to shards during tests. (hossman, shalin)
- ================== 4.10.3 ==================
- Bug Fixes
- ----------------------
- * SOLR-6696: bin/solr start script should not enable autoSoftCommit by default (janhoy)
- * SOLR-6704: TrieDateField type drops schema properties in branch 4.10 (Tomás Fernández Löbbe)
- * SOLR-6085: Suggester crashes when prefixToken is longer than surface form (janhoy)
- * SOLR-6323: ReRankingQParserPlugin cleaner paging and fix bug with fuzzy, range and other queries
- that need to be re-written. (Adair Kovac, Joel Bernstein)
- * SOLR-6684: Fix-up /export JSON. (Joel Bernstein)
- * SOLR-6781: BBoxField didn't support dynamic fields. (David Smiley)
- * SOLR-6784: BBoxField's 'score' mode should have been optional. (David Smiley)
- * SOLR-6510: The collapse QParser would throw a NPE when used on a DocValues field on
- an empty segment/index. (Christine Poerschke, David Smiley)
- * SOLR-2927: Solr does not unregister all mbeans upon exception in constructor
- causing memory leaks. (tom liu, Sharath Babu, Cyrille Roy, shalin)
- * SOLR-6685: ConcurrentModificationException in Overseer Status API. (shalin)
- * SOLR-6706: /update/json/docs throws RuntimeException if a nested structure
- contains a non-leaf float field (Noble Paul, shalin)
- * SOLR-6610: Slow startup of new clusters because ZkController.publishAndWaitForDownStates
- always times out. (Jessica Cheng Mallet, shalin, Noble Paul)
- * SOLR-6662: better validation when parsing command-line options that expect a value
- (Timothy Potter)
- * SOLR-6732: Fix handling of leader-initiated recovery state was String in older versions
- and is now a JSON map, caused backwards compatibility issues when doing rolling upgrades of
- a live cluster while indexing (Timothy Potter)
- * SOLR-6705: Better strategy for dealing with JVM specific options in the start
- scripts; remove -XX:+AggressiveOpts and only set -XX:-UseSuperWord for Java 1.7u40
- to u51. (Uwe Schindler, janhoy, hossman, Timothy Potter)
- * SOLR-6726: better strategy for selecting the JMX RMI port based on SOLR_PORT in bin/solr
- script (Timothy Potter)
- * SOLR-6795: distrib.singlePass returns score even though not asked for.
- (Per Steffensen via shalin)
- * SOLR-6796: distrib.singlePass does not return correct set of fields for multi-fl-parameter
- requests. (Per Steffensen via shalin)
- * SOLR-6776: Transaction log was not flushed at the end of update requests with softCommit
- specified, which could lead to data loss if the server were killed immediately after the
- update finished. (Jeffery Yuan via yonik)
- Other Changes
- ----------------------
- * SOLR-6661: Adjust all example configurations to allow overriding error-prone
- relative paths for solrconfig.xml <lib> references with solr.install.dir
- system property; bin/solr scripts will set it appropriately. (ehatcher)
- * SOLR-6694: Auto-detect JAVA_HOME using the Windows registry if it is not set
- (janhoy, Timothy Potter)
- * SOLR-6653: bin/solr script should return error code >0 when something fails
- (janhoy, Timothy Potter)
- * SOLR-6829: Added getter/setter for lastException in DIH's ContextImpl (ehatcher)
- ================== 4.10.2 ==================
- Bug Fixes
- ----------------------
- * SOLR-6509: Solr start scripts interactive mode doesn't honor -z argument (Timothy Potter)
- * SOLR-6511: Fencepost error in LeaderInitiatedRecoveryThread (Timothy Potter)
- * SOLR-6530: Commits under network partitions can put any node in down state.
- (Ramkumar Aiyengar, Alan Woodward, Mark Miller, shalin)
- * SOLR-6573: QueryElevationComponent now works with localParams in the query (janhoy)
- * SOLR-6524: Collections left in recovery state after node restart because recovery sleep time
- increases exponentially between retries. (Mark Miller, shalin)
- * SOLR-6587: Misleading exception when creating collections in SolrCloud with bad configuration.
- (Tomás Fernández Löbbe)
- * SOLR-6452: StatsComponent's stat 'missing' will work on fields with docValues=true and
- indexed=false (Xu Zhang via Tomás Fernández Löbbe)
- * SOLR-6646: bin/solr start script fails to detect solr on non-default port and then after
- 30s tails wrong log file (janhoy)
- * SOLR-6647: Bad error message when missing resource from ZK when parsing Schema (janhoy)
- * SOLR-6545: Query field list with wild card on dynamic field fails.
- (Burke Webster, Xu Zhang, shalin)
- Other Changes
- ----------------------
- * SOLR-6550: Provide simple mechanism for passing additional metadata / context about a server-side
- SolrException back to the client-side (Timothy Potter)
- * SOLR-6486: solr start script can have a debug flag option; use -a to set arbitrary options
- (Noble Paul, Timothy Potter)
- * SOLR-6549: bin/solr script should support a -s option to set the -Dsolr.solr.home property.
- (Timothy Potter)
- * SOLR-6529: Stop command in the start scripts should only stop the instance that it had started.
- (Varun Thacker, Timothy Potter)
- ================== 4.10.1 ==================
- Bug Fixes
- ----------------------
- * SOLR-6425: If using the new global hdfs block cache option, you can end up
- reading corrupt files on file name reuse. (Mark Miller, Gregory Chanan)
- * SOLR-5814: CoreContainer reports incorrect & misleading path for solrconfig.xml
- when there are loading problems (Pradeep via hossman)
- * SOLR-6024: Fix StatsComponent when using docValues="true" multiValued="true"
- (Vitaliy Zhovtyuk & Tomas Fernandez-Lobbe via hossman)
- * SOLR-6493: Fix fq exclusion via "ex" local param in multivalued stats.field (hossman)
- * SOLR-6447: bin/solr script needs to pass -DnumShards=1 for boostrapping collection1
- when starting Solr in cloud mode. (Timothy Potter)
- * SOLR-6501: Binary Response Writer does not return wildcard fields.
- (Mike Hugo, Constantin Mitocaru, sarowe, shalin)
- Other Changes
- ---------------------
- * SOLR-6503: Removed support for parsing netcdf files in Solr Cell because
- of license issues. If you need support for this format, download the parser
- JAR yourself (version 4.2) and add it to contrib/extraction/lib folder:
- http://www.unidata.ucar.edu/software/thredds/current/netcdf-java/
- (Uwe Schindler)
- ================== 4.10.0 =================
- Consult the LUCENE_CHANGES.txt file for additional, low level, changes in this release
- Versions of Major Components
- ---------------------
- Apache Tika 1.5 (with upgraded Apache POI 3.10.1)
- Carrot2 3.9.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Upgrading from Solr 4.9
- ----------------------
- * In Solr 3.6, all primitive field types were changed to omit norms by default when the
- schema version is 1.5 or greater (SOLR-3140), but TrieDateField's default was mistakenly
- not changed. As of Solr 4.10, TrieDateField omits norms by default (see SOLR-6211).
- * Creating a SolrCore via CoreContainer.create() no longer requires an
- additional call to CoreContainer.register() to make it available to clients
- (see SOLR-6170).
- * CoreContainer.remove() has been removed. You should now use CoreContainer.unload() to
- delete a SolrCore (see SOLR-6232).
- * solr.xml parsing has been improved to better account for the expected data types of
- various options. As part of this fix, additional error checking has also been added to
- provide errors in the event of duplicated options, or unknown option names that may
- indicate a typo. Users who have modified their solr.xml in the past and now upgrade may
- get errors on startup if they have typos or unexpected options specified in their solr.xml
- file. (See SOLR-5746 for more information.)
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-6196: The overseerstatus collection API instruments amILeader and ZK state update calls.
- (shalin)
- * SOLR-6069: The 'clusterstatus' API should return 'roles' information. (shalin)
- * SOLR-6044: The 'clusterstatus' API should return live_nodes as well. (shalin)
- * SOLR-5768: Add a distrib.singlePass parameter to make EXECUTE_QUERY phase fetch all fields
- and skip GET_FIELDS. (Gregg Donovan, shalin)
- * SOLR-6183: New spatial BBoxField for indexing rectangles with search support for most predicates.
- It includes extra score relevancy modes in addition to distance: score=overlapRatio|area|area2D.
- (David Smiley, Ryan McKinley)
- * SOLR-6232: You can now unload/delete cores that have failed to initialize (Alan Woodward)
- * SOLR-2245: Improvements to the MailEntityProcessor:
- - Support for server-side date filtering if using GMail; requires new
- dependency on the Sun Gmail Java mail extensions
- - Support for using the last_index_time from the previous run as the
- value for the fetchMailsSince filter.
- (Peter Sturge, Timothy Potter)
- * SOLR-6258: Added onRollback event handler hook to Data Import Handler (DIH).
- (ehatcher)
- * SOLR-6263: Add DIH handler name to variable resolver as ${dih.handlerName}. (ehatcher)
- * SOLR-6216: Better faceting for multiple intervals on DV fields (Tomas Fernandez-Lobbe
- via Erick Erickson)
- * SOLR-6267: Let user override Interval Faceting key with LocalParams (Tomas Fernandez_Lobbe
- via Erick Erickson)
- * SOLR-6020: Auto-generate a unique key in schema-less example if data does not have an id field.
- The UUIDUpdateProcessor was improved to not require a field name in configuration and generate
- a UUID into the unique Key field.
- (Vitaliy Zhovtyuk, hossman, Steve Rowe, Erik Hatcher, shalin)
- * SOLR-6294: SOLR-6437: Remove the restriction of adding json by only wrapping it in an array in a
- new path /update/json/docs (Noble Paul , hossman, Yonik Seeley, Steve Rowe)
- * SOLR-6302: UpdateRequestHandlers are registered implicitly /update ,
- /update/json, /update/csv , /update/json/docs (Noble Paul)
- * SOLR-6318: New "terms" QParser for efficiently filtering documents by a list of values. For
- many values, it's more appropriate than a boolean query. (David Smiley)
- * SOLR-6283: Add support for Interval Faceting in SolrJ. (Tomás Fernández Löbbe)
- * SOLR-6304 : JsonLoader should be able to flatten an input JSON to multiple docs (Noble Paul)
- * SOLR-2894: Distributed query support for facet.pivot (Dan Cooper, Erik Hatcher, Chris Russell,
- Andrew Muldowney, Brett Lucey, Mark Miller, hossman)
- * SOLR-5656: Add autoAddReplicas feature for shared file systems. (Mark Miller, Gregory Chanan)
- * SOLR-5244: Exporting Full Sorted Result Sets (Erik Hatcher, Joel Bernstein)
- * SOLR-3617: bin/solr and bin/solr.cmd scripts for starting, stopping, and running Solr examples
- (Timothy Potter)
- * SOLR-6233: Provide basic command line tools for checking Solr status and health.
- (Timothy Potter)
- Bug Fixes
- ----------------------
- * SOLR-6095 : SolrCloud cluster can end up without an overseer with overseer roles (Noble Paul, Shalin Mangar)
- * SOLR-6165: DataImportHandler should write BigInteger and BigDecimal values as strings.
- (Anand Sengamalai via shalin)
- * SOLR-6189: Avoid publishing the state as down if the node is not live when determining
- if a replica should be in leader-initiated recovery. (Timothy Potter)
- * SOLR-6197: The MIGRATE collection API doesn't work when legacyCloud=false is set
- in cluster properties. (shalin)
- * SOLR-6206: The migrate collection API fails on retry if temp collection already exists.
- (shalin)
- * SOLR-6072: The 'deletereplica' API should remove the data and instance directory by default.
- (shalin)
- * SOLR-6211: TrieDateField doesn't default to omitNorms=true. (Michael Ryan, Steve Rowe)
- * SOLR-6159: A ZooKeeper session expiry during setup can keep LeaderElector from joining elections.
- (Steven Bower, shalin)
- * SOLR-6223: SearchComponents may throw NPE when using shards.tolerant and there is a failure
- in the 'GET_FIELDS/GET_HIGHLIGHTS/GET_DEBUG' phase. (Tomás Fernández Löbbe via shalin)
- * SOLR-6180: Callers of ManagedIndexSchema mutators should hold the schemaUpdateLock.
- (Gregory Chanan via Steve Rowe)
- * SOLR-6229: Make SuggestComponent return 400 instead of 500 for bad dictionary selected in request.
- (Tomás Fernández Löbbe via shalin)
- * SOLR-6235: Leader initiated recovery should use coreNodeName instead of coreName to avoid marking
- all replicas having common core name as down. (shalin)
- * SOLR-6208: JettySolrRunner QueuedThreadPool's configuration code is never executed. (dweiss via shalin)
- * SOLR-6245: Socket and Connection configuration are ignored in HttpSolrServer when passing in HttpClient.
- (Patanachai Tangchaisin, shalin)
- * SOLR-6137: Schemaless concurrency improvements:
- - Fixed an NPE when reloading a managed schema with no dynamic copy fields
- - Moved parsing and schema fields addition to after the distributed phase
- - AddSchemaFieldsUpdateProcessor now uses a fixed schema rather than always
- retrieving the latest, and holds the schema update lock through the entire
- schema swap-out process
- (Gregory Chanan via Steve Rowe)
- * SOLR-6136: ConcurrentUpdateSolrServer includes a Spin Lock (Brandon Chapman, Timothy Potter)
- * SOLR-6257: More than two "!"-s in a doc ID throws an
- ArrayIndexOutOfBoundsException when using the composite id router.
- (Steve Rowe)
- * SOLR-5746: Bugs in solr.xml parsing have been fixed to more correctly deal with the various
- datatypes of options people can specify, additional error handling of duplicated/unidentified
- options has also been added. (Maciej Zasada, hossman)
- * SOLR-5847: Fixed data import abort button in admin UI. (ehatcher)
- * SOLR-6264: Distributed commit and optimize are executed serially across all
- replicas. (Mark Miller, Timothy Potter)
- * SOLR-6163: Correctly decode special characters in managed stopwords and synonym endpoints.
- (Vitaliy Zhovtyuk, Timo Schmidt via Timothy Potter)
- * SOLR-6336: DistributedQueue can easily create too many ZooKeeper Watches.
- (Ramkumar Aiyengar via Mark Miller)
- * SOLR-6347: DELETEREPLICA throws a NPE while removing the last Replica in a Custom
- sharded collection. (Anshum Gupta)
- * SOLR-6062: Fix undesirable edismax query parser effect (introduced in SOLR-2058) in how phrase queries
- generated from pf, pf2, and pf3 are merged into the main query. (Michael Dodsworth via ehatcher)
- * SOLR-6372: HdfsDirectoryFactory should use supplied Configuration for communicating with secure kerberos.
- (Gregory Chanan via Mark Miller)
- * SOLR-6284: Fix NPE in OCP when non-existent sliceId is used for a
- deleteShard request (Ramkumar Aiyengar via Anshum Gupta)
- * SOLR-6380: Added missing context info to log message if IOException occurs in processing tlog
- (Steven Bower via hossman)
- * SOLR-6383: RegexTransformer returns no results after replaceAll if regex does not match a value.
- (Alexander Kingson, shalin)
- * SOLR-6387: Add better error messages throughout Solr and supply a work around for
- Java bug #8047340 to SystemInfoHandler: On Turkish default locale, some JVMs fail
- to fork on MacOSX, BSD, AIX, and Solaris platforms. (hossman, Uwe Schindler)
- * SOLR-6338: coreRootDirectory requires trailing slash, or SolrCloud cores are created in wrong location.
- (Primož Skale via Erick Erickson)
- * SOLR-6314: Facet counts duplicated in the response if specified more than once on the request.
- (Vamsee Yarlagadda, Erick Erickson)
- * SOLR-6378: Fixed example/example-DIH/ issues with "tika" and "solr" configurations, and tidied up README.txt
- (Daniel Shchyokin via ehatcher)
- * SOLR-6393: TransactionLog replay performance on HDFS is very poor. (Mark Miller)
- * SOLR-6268: HdfsUpdateLog has a race condition that can expose a closed HDFS FileSystem instance and should
- close its FileSystem instance if either inherited close method is called. (Mark Miller)
- * SOLR-6089: When using the HDFS block cache, when a file is deleted, its underlying data entries in the
- block cache are not removed, which is a problem with the global block cache option.
- (Mark Miller, Patrick Hunt)
- * SOLR-6402: OverseerCollectionProcessor should not exit for ZooKeeper ConnectionLoss.
- (Jessica Cheng via Mark Miller)
- * SOLR-6405: ZooKeeper calls can easily not be retried enough on ConnectionLoss.
- (Jessica Cheng, Mark Miller)
- * SOLR-6410: Ensure all Lookup instances are closed via CloseHook
- (hossman, Areek Zillur, Ryan Ernst, Dawid Weiss)
- Optimizations
- ---------------------
- * LUCENE-5803: Solr's schema now uses DelegatingAnalyzerWrapper. This uses less heap
- for cached TokenStreamComponents because it caches per FieldType not per Field, so
- indexes with many fields of same type just use one TokenStream per thread.
- (Shay Banon, Uwe Schindler, Robert Muir)
- * SOLR-6259: Reduce CPU usage by avoiding repeated costly calls to Document.getField inside
- DocumentBuilder.toDocument for use-cases with large number of fields and copyFields.
- (Steven Bower via shalin)
- * SOLR-5968: BinaryResponseWriter fetches unnecessary stored fields when only pseudo-fields
- are requested. (Gregg Donovan via shalin)
- * SOLR-6261: Run ZooKeeper watch event callbacks in parallel to the ZooKeeper
- event thread. (Ramkumar Aiyengar via Mark Miller)
- Other Changes
- ---------------------
- * SOLR-6173: Fixed wrong failure message in TestDistributedSearch. (shalin)
- * SOLR-5902: Corecontainer level mbeans are not exposed (noble)
- * SOLR-6194: Allow access to DataImporter and DIHConfiguration from DataImportHandler.
- (Aaron LaBella via shalin)
- * SOLR-6170: CoreContainer.preRegisterInZk() and CoreContainer.register() commands
- are merged into CoreContainer.create(). (Alan Woodward)
- * SOLR-6171: Remove unused SolrCores coreNameToOrig map (Alan Woodward)
- * SOLR-5596: Set system property zookeeper.forceSync=no for Solr test cases. (shalin)
- * SOLR-2853: Add a unit test for the case when "spellcheck.maxCollationTries=0" (James Dyer)
- * SOLR-6240: Removed unused coreName parameter in ZkStateReader.getReplicaProps. (shalin)
- * SOLR-6241: Harden the HttpPartitionTest. (shalin)
- * SOLR-6228: Fixed bug in TestReplicationHandler.doTestIndexAndConfigReplication. (shalin)
- * SOLR-6120: On Windows, when the war is not extracted, the zkcli.bat script
- will print a helpful message indicating that the war must be unzipped instead
- of a java error about a missing class. (shalin, Shawn Heisey)
- * SOLR-6179: Better strategy for handling empty managed data to avoid spurious
- warning messages in the logs. (Timothy Potter)
- * SOLR-6232: CoreContainer.remove() replaced with CoreContainer.unload(). A call to
- unload will also close the core.
- * SOLR-3893: DIH should not depend on mail.jar,activation.jar (Timothy Potter, Steve Rowe)
- * SOLR-6252: A couple of small improvements to UnInvertedField class.
- (Vamsee Yarlagadda, Gregory Chanan, Mark Miller)
- * SOLR-3345: BaseDistributedSearchTestCase should always ignore QTime.
- (Vamsee Yarlagadda, Benson Margulies via Mark Miller)
- * SOLR-6270: Increased timeouts for MultiThreadedOCPTest. (shalin)
- * SOLR-6274: UpdateShardHandler should log the params used to configure its
- HttpClient. (Ramkumar Aiyengar via Mark Miller)
- * SOLR-6194: Opened up "public" access to DataSource, DocBuilder, and EntityProcessorWrapper
- in DIH. (Aaron LaBella via ehatcher)
- * SOLR-6269: Renamed "rollback" to "error" in DIH internals, including renaming onRollback
- to onError introduced in SOLR-6258. (ehatcher)
- * SOLR-3622: When using DIH in SolrCloud-mode, rollback will no longer be called when
- an error occurs. (ehatcher)
- * SOLR-6231: Increased timeouts and hardened the RollingRestartTest. (Noble Paul, shalin)
- * SOLR-6290: Harden and speed up CollectionsAPIAsyncDistributedZkTest. (Mark Miller, shalin)
- * SOLR-6281: Made PostingsSolrHighlighter more configurable via subclass extension. (David Smiley)
- * SOLR-6309: Increase timeouts for AsyncMigrateRouteKeyTest. (shalin)
- * SOLR-2168: Added support for facet.missing in /browse field and pivot faceting. (ehatcher)
- * SOLR-4702: Added support for multiple spellcheck collations to /browse UI. (ehatcher)
- * SOLR-5664: Added support for multi-valued field highlighting in /browse UI. (ehatcher)
- * SOLR-6313: Improve SolrCloud cloud-dev scripts. (Mark Miller, Vamsee Yarlagadda)
- * SOLR-6360: Remove bogus "Content-Charset" header in HttpSolrServer. (Michael Ryan,
- Uwe Schindler)
- * SOLR-6362: Fix bug in TestSqlEntityProcessorDelta. (James Dyer)
- * SOLR-6388: Force upgrade of Apache POI dependency in Solr Cell to version
- 3.10.1 to fix CVE-2014-3529 and CVE-2014-3574. (Uwe Schindler)
- * SOLR-6391: Improve message for CREATECOLLECTION failure due to missing
- numShards (Anshum Gupta)
- ================== 4.9.1 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.5 (with upgraded Apache POI 3.10.1)
- Carrot2 3.9.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Detailed Change List
- ----------------------
- Other Changes
- ---------------------
- * SOLR-6503: Removed support for parsing netcdf files in Solr Cell because
- of license issues. If you need support for this format, download the parser
- JAR yourself (version 4.2) and add it to contrib/extraction/lib folder:
- http://www.unidata.ucar.edu/software/thredds/current/netcdf-java/
- (Uwe Schindler)
- * SOLR-6388: Force upgrade of Apache POI dependency in Solr Cell to version
- 3.10.1 to fix CVE-2014-3529 and CVE-2014-3574. (Uwe Schindler)
- ================== 4.9.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.5
- Carrot2 3.9.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Upgrading from Solr 4.8
- ----------------------
- * Support for DiskDocValuesFormat (ie: fieldTypes configured with docValuesFormat="Disk")
- has been removed due to poor performance. If you have an existing fieldTypes using
- DiskDocValuesFormat please modify your schema.xml to remove the 'docValuesFormat'
- attribute, and optimize your index to rewrite it into the default codec, prior to
- upgrading to 4.9. See LUCENE-5761 for more details.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-5999: Add checkIntegrityAtMerge support to solrconfig.xml.
- (Varun Thacker via Ryan Ernst)
- * SOLR-6043: Add ability to set http headers in solr response
- (Tomás Fernández Löbbe via Ryan Ernst)
- * SOLR-5973: Pluggable Ranking Collectors and Merge Strategies
- (Joel Bernstein)
- * SOLR-6108: Add support for 'addreplica' Collection API in SolrJ. (shalin)
- * SOLR-5468: Allow a client application to request the minium achieved
- replication factor for an update request (single or batch) by sending
- an optional parameter "min_rf". (Timothy Potter)
- * SOLR-6088: Add query re-ranking with the ReRankingQParserPlugin
- (Joel Bernstein)
- * SOLR-5285: Added a new [child ...] DocTransformer for optionally including
- Block-Join descendant documents inline in the results of a search. This works
- independent of whether the search itself is a block-join related query and is
- supported by he xml, json, and javabin response formats.
- (Varun Thacker via hossman)
- * SOLR-6150: Add new AnalyticsQuery to support pluggable analytics
- (Joel Bernstein)
- * SOLR-6125: Allow SolrIndexWriter to close without waiting for merges
- (Christine Poerschke via Alan Woodward)
- * SOLR-6064: DebugComponent track output should be returned as a JSON
- object rather than a list (Christine Poerschke, Alan Woodward)
- Bug Fixes
- ----------------------
- * SOLR-5956: Use coreDescriptor.getInstanceDir() instead of getRawInstanceDir()
- in the SnapShooter to avoid problems when solr.solr.home is a symbolic link.
- (Timothy Potter)
- * SOLR-6002: Fix a couple of ugly issues around SolrIndexWriter close and
- rollback as well as how SolrIndexWriter manages its ref counted directory
- instance. (Mark Miller, Gregory Chanan)
- * SOLR-6015: Better way to handle managed synonyms when ignoreCase=true
- (Timothy Potter)
- * SOLR-6104: The 'addreplica' Collection API does not support 'async' parameter.
- (shalin)
- * SOLR-6101: Shard splitting doesn't work when legacyCloud=false is set in
- cluster properties. (shalin)
- * SOLR-6111: The 'deleteshard' collection API should be able to delete a shard
- in 'construction' state. (shalin)
- * SOLR-6118: 'expand.sort' didn't support function queries. (David Smiley)
- * SOLR-6120: zkcli.sh should expand solr.war automatically instead of throwing
- ClassNotFoundException. (sebastian badea, shalin)
- * SOLR-6149: Specifying the query value without any index value does not work in
- Analysis browser. (Aman Tandon, shalin)
- * SOLR-6145: Fix Schema API optimistic concurrency by moving it out of
- ManagedIndexSchema.add(Copy)Fields() into the consumers of those methods:
- CopyFieldCollectionResource, FieldCollectionResource, FieldResource,
- and AddSchemaFieldsUpdateProcessorFactory.
- (Gregory Chanan, Alexey Serba, Steve Rowe)
- * SOLR-6146: Incorrect configuration such as wrong chroot in zk server address can
- cause CloudSolrServer to leak resources. (Jessica Cheng, Varun Thacker, shalin)
- * SOLR-6158: Relative configSetBase directories were resolved relative to the
- container CWD, rather than solr.home. (Simon Endele, Alan Woodward)
- * SOLR-5426: Fixed a bug in ReverseWildCardFilter that could cause
- InvalidTokenOffsetsException when highlighting. (Uwe Schindler, Arun Kumar, via hossman)
- * SOLR-6175: DebugComponent throws NPE on shard exceptions when using shards.tolerant.
- (Tomás Fernández Löbbe via shalin)
- * SOLR-6129: DateFormatTransformer doesn't resolve dateTimeFormat. (Aaron LaBella via shalin)
- * SOLR-6164: Copy Fields Schema additions are not distributed to other nodes.
- (Gregory Chanan via Steve Rowe)
- * SOLR-6160: An error was sometimes possible if a distributed search included grouping
- with group.facet, faceting on facet.field and either facet.range or facet.query.
- (David Smiley)
- * SOLR-6182: Data stored by the RestManager could not be reloaded after core restart, causing
- the core to fail to load; cast the data loaded from storage to the correct data type.
- (Timothy Potter)
- Other Changes
- ---------------------
- * SOLR-5980: AbstractFullDistribZkTestBase#compareResults always returns false
- for shouldFail. (Mark Miller, Gregory Chanan)
- * SOLR-5987: Add "collection" to UpdateParams. (Mark Miller, Greg Solovyev)
- * SOLR-3862: Add remove" as update option for atomically removing a value
- from a multivalued field (Jim Musli, Steven Bower, Alaknantha via Erick Erickson)
- * SOLR-5974: Remove ShardDoc.score and use parent's ScoreDoc.score.
- (Tomás Fernández Löbbe via Ryan Ernst)
- * SOLR-6025: Replace mentions of CommonsHttpSolrServer with HttpSolrServer and
- StreamingUpdateSolrServer with ConcurrentUpdateSolrServer. (Ahmet Arslan via shalin)
- * SOLR-6013: Fix method visibility of Evaluator, refactor DateFormatEvaluator for
- extensibility. (Aaron LaBella via shalin)
- * SOLR-6022: Deprecate getAnalyzer() in IndexField and FieldType, and add getIndexAnalyzer().
- (Ryan Ernst)
- * SOLR-3671: Fix DIHWriter interface usage so users may implement writers that output
- documents to a location external to Solr (ex. a NoSql db). (Roman Chyla via James Dyer)
- * SOLR-5340: Add support for named snapshots (Varun Thacker via Noble Paul)
- * SOLR-5495: Recovery strategy for leader partitioned from replica case. Hardening
- recovery scenarios after the leader receives an error trying to forward an
- update request to a replica. (Timothy Potter)
- * SOLR-6116: Refactor DocRouter.getDocRouter to accept routerName as a String. (shalin)
- * SOLR-6026: REQUESTSTATUS Collection API now also checks for submitted tasks which are
- yet to begin execution.
- * SOLR-6067: Refactor duplicate Collector code in SolrIndexSearcher
- (Christine Poerschke via hossman)
- * SOLR-5940: post.jar reports back detailed error in case of error responses.
- (Sameer Maggon, shalin, Uwe Schindler)
- * SOLR-6161: SolrDispatchFilter should throw java.lang.Error back even if wrapped in
- another exception. (Miklos Christine via shalin)
- * SOLR-6153: ReplicationHandler backup response format should contain backup name.
- (Varun Thacker via shalin)
- * SOLR-6169: Remove broken handleAlias action in CoreAdminHandler (Alan
- Woodward)
- * SOLR-6128: Removed deprecated analysis factories and fieldTypes from the example
- schema.xml (hossman)
- * SOLR-5868: HttpClient should be configured to use ALLOW_ALL_HOSTNAME hostname
- verifier to simplify SSL setup. (Steve Davids via Mark Miller)
- Optimizations
- ----------------------
- * SOLR-5681: Make the processing of Collection API calls multi-threaded.
- (Anshum Gupta, shalin, Noble Paul)
- Build
- ---------------------
- * SOLR-6006: Separate test and compile scope dependencies in the Solrj and
- Solr contrib ivy.xml files, so that the derived Maven dependencies get
- filled out properly in the corresponding POMs. (Steven Scott, Steve Rowe)
- * SOLR-6130: Added com.uwyn:jhighlight dependency to, and removed asm:asm
- dependency from the extraction contrib - dependencies weren't fully
- upgraded with the Tika 1.4->1.5 upgrade (SOLR-5763). (Steve Rowe)
- ================== 4.8.1 ==================
- Bug Fixes
- ----------------------
- * SOLR-5904: ElectionContext can cancel an election when it should not if there
- was an exception while trying to register as the leader.
- (Mark Miller, Alan Woodward)
- * SOLR-5993: ZkController can warn about shard leader conflict even after the conflict
- is resolved. (Gregory Chanan via shalin)
- * SOLR-6017: Fix SimpleQParser to use query analyzer
- (Ryan Ernst)
- * SOLR-6029: CollapsingQParserPlugin throws ArrayIndexOutOfBoundsException
- if elevated doc has been deleted from a segment. (Greg Harris, Joel Bernstein)
- * SOLR-6030: Use System.nanoTime() instead of currentTimeInMills() in LRUCache.warm.
- (Tomás Fernández Löbbe via shalin)
- * SOLR-6037: Fixed incorrect max/sum/stddev for Date fields in StatsComponent
- (Brett Lucey, hossman)
- * SOLR-6023: FieldAnalysisRequestHandler throws NPE if no parameters are supplied.
- (shalin)
- * SOLR-5090: SpellCheckComponent sometimes throws NPE if
- "spellcheck.alternativeTermCount" is set to zero (James Dyer).
- * SOLR-6039: fixed debug output when no results in response
- (Tomás Fernández Löbbe, hossman)
- * SOLR-6035: CloudSolrServer directUpdate routing should use getCoreUrl.
- (Marvin Justice, Joel Bernstein)
- ================== 4.8.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.5
- Carrot2 3.9.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.6
- Upgrading from Solr 4.7
- ----------------------
- * In previous versions of Solr, Terms that exceeded Lucene's MAX_TERM_LENGTH were
- silently ignored when indexing documents. Beginning with Solr 4.8, a document
- an error will be generated when attempting to index a document with a term
- that is too large. If you wish to continue to have large terms ignored,
- use "solr.LengthFilterFactory" in all of your Analyzers. See LUCENE-5472 for
- more details.
- * Solr 4.8 requires Java 7 or greater, Java 8 is verified to be
- compatible and may bring some performance improvements. When using
- Oracle Java 7 or OpenJDK 7, be sure to not use the GA build 147 or
- update versions u40, u45 and u51! We recommend using u55 or later.
- An overview of known JVM bugs can be found on
- http://wiki.apache.org/lucene-java/JavaBugs
- * ZooKeeper is upgraded from 3.4.5 to 3.4.6.
- * <fields> and <types> tags have been deprecated. There is no longer any reason to
- keep them in the schema file, they may be safely removed. This allows intermixing of
- <fieldType>, <field> and <copyField> definitions if desired. Currently, these tags
- are supported so either style may be implemented. TBD is whether they'll be
- deprecated formally for 5.0
- Detailed Change List
- ----------------------
- System Requirements
- ----------------------
- * LUCENE-4747, LUCENE-5514: Move to Java 7 as minimum Java version.
- (Robert Muir, Uwe Schindler)
- New Features
- ----------------------
- * SOLR-5130: Implement addReplica Collections API (Noble Paul)
- * SOLR-5183: JSON updates now support nested child documents using a
- "_childDocument_" object key. (Varun Thacker, hossman)
- * SOLR-5714: You can now use one pool of memory for for the HDFS block cache
- that all collections share. (Mark Miller, Gregory Chanan)
- * SOLR-5720: Add ExpandComponent to expand results collapsed by the
- CollapsingQParserPlugin. (Joel Bernstein)
- * SOLR-3177: Enable tagging and excluding filters in StatsComponent via the
- localParams syntax. (Mathias H., Nikolai Luthman, Vitaliy Zhovtyuk, shalin)
- * SOLR-1604: Wildcards, ORs etc inside Phrase Queries. (Ahmet Arslan via Erick Erickson)
- * SOLR-5477: Async execution of OverseerCollectionProcessor(CollectionsAPI)
- tasks. (Anshum Gupta)
- * SOLR-5865: Provide a MiniSolrCloudCluster to enable easier testing.
- (Greg Chanan via Mark Miller)
- * SOLR-5860: Use leaderConflictResolveWait in WaitForState during recovery/startup,
- improve logging and force refresh cluster state every 15 seconds.
- (Timothy Potter via shalin)
- * SOLR-5749: A new Overseer status collection API exposes overseer queue sizes, timing
- statistics, success and error counts and last N failures per operation. (shalin)
- * SOLR-5858: Add a hl.qparser parameter to allow you to define a queryparser
- for hl.q highlight queries. If no queryparser is defined, Solr will use
- the overall query's defType. (Alan Woodward)
- * SOLR-4478: Allow cores to use configuration from a configsets directory
- outside their instance directory. (Alan Woodward, Erick Erickson)
- * SOLR-5466: A new List collections and cluster status API which clients can use
- to read collection and shard information instead of reading data directly from ZooKeeper.
- (Dave Seltzer, Varun Thacker, Vitaliy Zhovtyuk, Erick Erickson, shalin)
- * SOLR-5795: New DocExpirationUpdateProcessorFactory supports computing an expiration
- date for documents from the "TTL" expression, as well as automatically deleting expired
- documents on a periodic basis. (hossman)
- * SOLR-5829: Allow ExpandComponent to accept query and filter query parameters
- (Joel Bernstein)
- * SOLR-5653: Create a RestManager to provide REST API endpoints for
- reconfigurable plugins. (Tim Potter, Steve Rowe)
- * SOLR-5655: Create a stopword filter factory that is (re)configurable,
- and capable of reporting its configuration, via REST API.
- (Tim Potter via Steve Rowe)
- * SOLR-5654: Create a synonym filter factory that is (re)configurable, and
- capable of reporting its configuration, via REST API.
- (Tim Potter via Steve Rowe)
- * SOLR-5960: Add support for basic authentication in post.jar tool, e.g.:
- java -Durl="http://username:password@hostname:8983/solr/update" -jar post.jar sample.xml
- (Sameer Maggon via Uwe Schindler)
- * SOLR-4864: RegexReplaceProcessorFactory should support pattern capture group
- substitution in replacement string.
- (Sunil Srinivasan, Jack Krupansky via Steve Rowe)
- Bug Fixes
- ----------------------
- * SOLR-5858, SOLR-4812: edismax and dismax query parsers can be used for parsing
- highlight queries. (Alan Woodward, Tien Nguyen Manh)
- * SOLR-5893: On restarting overseer designate , move itself to front of the queue (Noble Paul)
- * SOLR-5915: Attempts to specify the parserImpl for
- solr.PreAnalyzedField fieldtype failed. (Mike McCandless)
- * SOLR-5943: SolrCmdDistributor does not distribute the openSearcher parameter.
- (ludovic Boutros via shalin)
- * SOLR-5954: Slower DataImportHandler process caused by not reusing jdbc
- connections. (Mark Miller, Paco Garcia, Raja Nagendra Kumar)
- * SOLR-5897: Upgraded to jQuery 1.7.2, Solr was previously using 1.4.3, the file was
- mistakenly named 1.7.2 (steffkes)
- Optimizations
- ----------------------
- * SOLR-1880: Distributed Search skips GET_FIELDS stage if EXECUTE_QUERY
- stage gets all fields. Requests with fl=id or fl=id,score are now single-pass.
- (Shawn Smith, Vitaliy Zhovtyuk, shalin)
- * SOLR-5783: Requests to open a new searcher will now reuse the current registered
- searcher (w/o additional warming) if possible in situations where the underlying
- index has not changed. This reduces overhead in situations such as deletes that
- do not modify the index, and/or redundant commits. (hossman)
- * SOLR-5884: When recovery is cancelled, any call to the leader to wait to see
- the replica in the right state for recovery should be aborted. (Mark Miller)
- Other Changes
- ---------------------
- * SOLR-5909: Upgrade Carrot2 clustering dependency to 3.9.0. (Dawid Weiss)
- * SOLR-5764: Fix recently added tests to not use absolute paths to load test-files,
- use SolrTestCaseJ4.getFile() and getResource() instead; fix morphlines/map-reduce
- to not duplicate test resources and fix dependencies among them.
- (Uwe Schindler)
- * SOLR-5765: Update to SLF4J 1.7.6. (Mark Miller)
- * SOLR-5609: If legacy mode is disabled don't let cores create slices/replicas/collections .
- All operations should be performed through collection API (Noble Paul)
- * SOLR-5613: Upgrade to commons-codec 1.9 for better BeiderMorseFilter performance.
- (Thomas Champagne, Shawn Heisey via shalin)
- * SOLR-5771: Add SolrTestCaseJ4.SuppressSSL annotation to disable SSL (instead of static boolean).
- (Robert Muir)
- * SOLR-5799: When registering as the leader, if an existing ephemeral
- registration exists, wait a short time to see if it goes away.
- (Mark Miller)
- * LUCENE-5472: IndexWriter.addDocument will now throw an IllegalArgumentException
- if a Term to be indexed exceeds IndexWriter.MAX_TERM_LENGTH. To recreate previous
- behavior of silently ignoring these terms, use LengthFilter in your Analyzer.
- (hossman, Mike McCandless, Varun Thacker)
- * SOLR-5825: Separate http request creating and execution in SolrJ
- (Steven Bower via Erick Erickson)
- * SOLR-5837: Add hashCode/equals to SolrDocument, SolrInputDocument
- and SolrInputField for testing purposes. (Varun Thacker, Noble Paul,
- Mark Miller)
- * SOLR-5853: The createCollection methods in the test framework now reports
- result of operation in the returned CollectionAdminResponse (janhoy)
- * SOLR-5838: Relative SolrHome Path Bug At AbstractFullDistribZkTestBase.
- (Furkan KAMACI via shalin)
- * SOLR-5763: Upgrade to Tika 1.5 (Vitaliy Zhovtyuk via Steve Rowe)
- * SOLR-5881: Upgrade ZooKeeper to 3.4.6 (Shawn Heisey)
- * SOLR-5883: Many tests do not shutdown SolrServer.
- (Tomás Fernández Löbbe via Mark Miller)
- * SOLR-5898: Update to latest Kite Morphlines release: Version 0.12.1.
- (Mark Miller)
- * SOLR-5228: Don't require <field> or <dynamicField> be inside of <fields> -- or
- that <fieldType> be inside of <types>. (Erick Erickson)
- * SOLR-5903: SolrCore implements Closeable, cut over to using try-with-resources
- where possible. (Alan Woodward)
- * SOLR-5914: Cleanup and fix Solr's test cleanup code.
- (Mark Miller, Uwe Schindler)
- * SOLR-5936: Deprecate non-Trie-based numeric & date field types. (Steve Rowe)
- * SOLR-5934: LBHttpSolrServer exception handling improvement and small test
- improvements. (Gregory Chanan via Mark Miller)
- * SOLR-5773: CollapsingQParserPlugin should make elevated documents the
- group head. (David Boychuck, Joel Bernstein)
- * SOLR-5937: Modernize the DIH example config sets. (Steve Rowe)
- ================== 4.7.2 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.4
- Carrot2 3.8.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Detailed Change List
- ----------------------
- Bug Fixes
- ----------------------
- * SOLR-5951: Fixed SolrDispatchFilter to throw useful exception on startup if
- SLF4j logging jars are missing. (Uwe Schindler, Hossman, Shawn Heisey)
- * SOLR-5950: Maven config: make the org.slf4j:slf4j-api dependency transitive
- (i.e., not optional) in all modules in which it's a dependency, including
- solrj, except for the WAR, where it will remain optional.
- (Uwe Schindler, Steve Rowe)
- ================== 4.7.1 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.4
- Carrot2 3.8.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Detailed Change List
- ----------------------
- Bug Fixes
- ----------------------
- * SOLR-5647: The lib paths in example-schemaless will now load correctly.
- (Paul Westin via Shawn Heisey)
- * SOLR-5770: All attempts to match a SolrCore with its state in clusterstate.json
- should be done with the CoreNodeName. (Steve Davids via Mark Miller)
- * SOLR-5875: QueryComponent.mergeIds() unmarshals all docs' sort field values once
- per doc instead of once per shard.
- (Alexey Serba, hoss, Martin de Vries via Steve Rowe)
- * SOLR-5800: Admin UI - Analysis form doesn't render results correctly when a
- CharFilter is used. (steffkes)
- * SOLR-5870: Admin UI - Reload on Core Admin doesn't show errors (steffkes)
- * SOLR-5867: OverseerCollectionProcessor isn't properly generating https urls in some
- cases. (Steve Davids via shalin)
- * SOLR-5866: UpdateShardHandler needs to use the system default scheme registry to
- properly handle https via javax.net.ssl.* properties. (Steve Davids via shalin)
- * SOLR-5782: The full MapReduceIndexer help text does not display when using --help.
- (Mark Miller, Wolfgang Hoschek)
- * SOLR-5824: Merge up Solr MapReduce contrib code to latest external changes.
- Includes a few minor bug fixes.
- (Mark Miller)
- * SOLR-5818: distrib search with custom comparator does not quite work correctly
- (Ryan Ernst)
- * SOLR-5895: JavaBinLoader hides IOExceptions. (Mike Sokolov via shalin)
- * SOLR-5861: Recovery should not set onlyIfLeaderActive=true for slice in 'recovery'
- state. (shalin)
- * SOLR-5423: CSV output doesn't include function field
- (Arun Kumar, hossman, Steve Rowe)
- * SOLR-5550: shards.info is not returned by a short circuited distributed query.
- (Timothy Potter, shalin)
- * SOLR-5777: Fix ordering of field values in JSON updates where
- field name key is repeated (hossman)
- * SOLR-5734: We should use System.nanoTime rather than System.currentTimeMillis
- when calculating elapsed time. (Mark Miller, Ramkumar Aiyengar)
- * SOLR-5760: ConcurrentUpdateSolrServer has a blockUntilFinished call when
- streamDeletes is true that should be tucked into the if statement below it.
- (Mark Miller, Gregory Chanan)
- * SOLR-5761: HttpSolrServer has a few fields that can be set via setters but
- are not volatile. (Mark Miller, Gregory Chanan)
- * SOLR-5907: The hdfs write cache can cause a reader to see a corrupted state.
- It now defaults to off, and if you were using solr.hdfs.blockcache.write.enabled
- explicitly, you should set it to false.
- (Mark Miller)
- * SOLR-5811: The Overseer will retry work items until success, which is a serious
- problem if you hit a bad work item. (Mark Miller)
- * SOLR-5796: Increase how long we are willing to wait for a core to see the ZK
- advertised leader in its local state. (Timothy Potter, Mark Miller)
- * SOLR-5834: Overseer threads are only being interrupted and not closed.
- (hossman, Mark Miller)
- * SOLR-5839: ZookeeperInfoServlet does not trim path properly.
- (Furkan KAMACI via Mark Miller)
- * SOLR-5874: Unsafe cast in CloudSolrServer's RouteException. Change
- RouteException to handle Throwable rather than Exception.
- (Mark Miller, David Arthur)
- * SOLR-5899: CloudSolrServer's RouteResponse and RouteException should be
- publicly accessible. (Mark Miller, shalin)
- * SOLR-5905: CollapsingQParserPlugin throws a NPE if required 'field' param is missing.
- (Spyros Kapnissis via shalin)
- * SOLR-5906: Collection create API ignores property.instanceDir parameter.
- (Varun Thacker, shalin)
- * SOLR-5920: Distributed sort on DateField, BoolField and BCD{Int,Long,Str}Field
- returns string cast exception (Eric Bus, AJ Lemke, hossman, Steve Rowe)
- Other Changes
- ---------------------
- * SOLR-5796: Make how long we are willing to wait for a core to see the ZK
- advertised leader in its local state configurable.
- (Timothy Potter via Mark Miller)
- ================== 4.7.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.4
- Carrot2 3.8.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Upgrading from Solr 4.6.0
- ----------------------
- * CloudSolrServer and LBHttpSolrServer no longer declare MalformedURLException
- as thrown from their constructors.
- * Due to a bug in previous versions the default value of the 'discountOverlap' property
- of DefaultSimilarity was not being set appropriately if you were using the implicit
- DefaultSimilarityFactory instead of explicitly configuring it. To preserve
- consistent behavior for people who upgrade, the implicit behavior is now contingent
- on the <luceneMatchVersion/> -- discountOverlap=false for 4.6 and below,
- discountOverlap=true for 4.7 and above. See SOLR-5561 for more information.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-5308: SOLR-5601: SOLR-5710: A new 'migrate' collection API to split all
- documents with a route key into another collection (shalin)
- * SOLR-5441: Expose number of transaction log files and their size via JMX.
- (Rafał Kuć via shalin)
- * SOLR-5320: Added support for tri-level compositeId routing.
- (Anshum Gupta via shalin)
- * SOLR-5458: Admin UI - Added a new "Files" conf directory browser/file viewer.
- (steffkes)
- * SOLR-5447, SOLR-5490: Add a QParserPlugin for Lucene's SimpleQueryParser.
- (Jack Conradson via shalin)
- * SOLR-5208: Support for the setting of core.properties key/values at create-time on
- Collections API (Erick Erickson)
- * SOLR-5428: SOLR-5690: New 'stats.calcdistinct' parameter in StatsComponent returns
- set of distinct values and their count. This can also be specified per field
- e.g. 'f.field.stats.calcdistinct'. (Elran Dvir via shalin)
- * SOLR-5378, SOLR-5528: A new SuggestComponent that fully utilizes the Lucene suggester
- module and adds pluggable dictionaries, payloads and better distributed support.
- This is intended to eventually replace the Suggester support through the
- SpellCheckComponent. (Areek Zillur, Varun Thacker via shalin)
- * SOLR-5492: Return the replica that actually served the query in shards.info
- response. (shalin)
- * SOLR-5506: Support docValues in CollationField and ICUCollationField.
- (Robert Muir)
- * SOLR-5023: Add support for deleteInstanceDir to be passed from SolrJ for Core
- Unload action. (Lyubov Romanchuk, shalin)
- * SOLR-1871: The 'map' function query accepts a ValueSource as target and
- default value. (Chris Harris, shalin)
- * SOLR-5556: Allow class of CollectionsHandler and InfoHandler to be specified
- in solr.xml. (Gregory Chanan, Alan Woodward)
- * SOLR-5581: Give ZkCLI the ability to get files. (Gregory Chanan via Mark Miller)
- * SOLR-5536: Add ValueSource collapse criteria to CollapsingQParsingPlugin (Joel Bernstein)
- * SOLR-5541: Allow QueryElevationComponent to accept elevateIds and excludeIds
- as http parameters (Joel Bernstein)
- * SOLR-5463: new 'cursorMark' request param for deep paging of sorted result sets
- (sarowe, hossman)
- * SOLR-5529: Add support for queries to use multiple suggesters.
- (Areek Zillur, Erick Erickson, via Robert Muir)
- * SOLR-1301: Add a Solr contrib that allows for building Solr indexes via
- Hadoop's MapReduce. (Matt Revelle, Alexander Kanarsky, Steve Rowe,
- Mark Miller, Greg Bowyer, Jason Rutherglen, Kris Jirapinyo, Jason Venner ,
- Andrzej Bialecki, Patrick Hunt, Wolfgang Hoschek, Roman Shaposhnik,
- Eric Wong)
- * SOLR-5631: Add support for Lucene's FreeTextSuggester.
- (Areek Zillur via Robert Muir)
- * SOLR-5695: Add support for Lucene's BlendedInfixSuggester.
- (Areek Zillur)
- * SOLR-5476: Overseer Role for nodes (Noble Paul)
- * SOLR-5594: Allow FieldTypes to specify custom PrefixQuery behavior
- (Anshum Gupta via hossman)
- * LUCENE-5395: Upgrade to Spatial4j 0.4. Various new options are now exposed
- automatically for an RPT field type. See Spatial4j CHANGES & javadocs.
- https://github.com/spatial4j/spatial4j/blob/master/CHANGES.md (David Smiley)
- * SOLR-5670: allow _version_ to use DocValues. (Per Steffensen via yonik)
- * SOLR-5535: Set "partialResults" header for shards that error out if
- shards.tolerant is specified. (Steve Davids via shalin)
- * SOLR-5610: Support cluster-wide properties with an API called CLUSTERPROP (Noble Paul)
- * SOLR-5623: Better diagnosis of RuntimeExceptions in analysis
- (Benson Margulies)
- * SOLR-5530: Added a NoOpResponseParser for SolrJ which puts the entire raw
- response into an entry in the NamedList.
- (Upayavira, Vitaliy Zhovtyuk via shalin)
- * SOLR-5682: Make the admin InfoHandler more pluggable / derivable.
- (Greg Chanan via Mark Miller)
- * SOLR-5672: Add logParamsList parameter to support reduced logging.
- (Christine Poerschke via Mark Miller)
- * SOLR-3854: SSL support for SolrCloud. (Sami Siren, hossman, Steve Davids,
- Alexey Serba, Mark Miller)
- Bug Fixes
- ----------------------
- * SOLR-5438: DebugComponent throws NPE when used with grouping.
- (Tomás Fernández Löbbe via shalin)
- * SOLR-4612: Admin UI - Analysis Screen contains empty table-columns (steffkes)
- * SOLR-5451: SyncStrategy closes its http connection manager before the
- executor that uses it in its close method. (Mark Miller)
- * SOLR-5460: SolrDispatchFilter#sendError can get a SolrCore that it does not
- close. (Mark Miller)
- * SOLR-5461: Request proxying should only set con.setDoOutput(true) if the
- request is a post. (Mark Miller)
- * SOLR-5481: SolrCmdDistributor should not let the http client do its own
- retries. (Mark Miller)
- * LUCENE-5347: Fixed Solr's Zookeeper Client to copy files to Zookeeper using
- binary transfer. Previously data was read with default encoding and stored
- in zookeeper as UTF-8. This bug was found after upgrading to forbidden-apis
- 1.4. (Uwe Schindler)
- * SOLR-4376: DataImportHandler uses wrong date format for last_index_time if
- a delta-import is run first before any full-imports.
- (Sebastien Lorber, Arcadius Ahouansou via shalin)
- * SOLR-5494: CoreContainer#remove throws NPE rather than returning null when
- a SolrCore does not exist in core discovery mode. (Mark Miller)
- * SOLR-5354: Distributed sort is broken with CUSTOM FieldType.
- (Steve Rowe, hossman, Robert Muir, Jessica Cheng)
- * SOLR-5515: NPE when getting stats on date field with empty result on
- SolrCloud. (Alexander Sagen, shalin)
- * SOLR-5204: StatsComponent and SpellCheckComponent do not support the
- shards.tolerant=true parameter. (Anca Kopetz, shalin)
- * SOLR-5527: DIH logs spurious warning for special commands. (shalin)
- * SOLR-5524: Exception when using Query Function inside Scale Function.
- (Trey Grainger, yonik)
- * SOLR-5562: ConcurrentUpdateSolrServer constructor ignores supplied httpclient.
- (Kyle Halliday via Mark Miller)
- * SOLR-5567: ZkController getHostAddress duplicates url prefix.
- (Kyle Halliday, Alexey Serba, shalin)
- * SOLR-4992: Solr eats OutOfMemoryError exceptions in many cases.
- (Mark Miller, Daniel Collins)
- * LUCENE-5399, SOLR-5354 sort wouldn't work correctly with
- distributed searching for some field types such as legacy numeric
- types (Rob Muir, Mike McCandless)
- * SOLR-5643: ConcurrentUpdateSolrServer will sometimes not spawn a new Runner
- thread even though there are updates in the queue. (Mark Miller)
- * SOLR-5650: When a replica becomes a leader, only peer sync with other replicas
- that last published an ACTIVE state. (Mark Miller)
- * SOLR-5657: When a SolrCore starts on HDFS, it should gracefully handle HDFS
- being in safe mode. (Mark Miller)
- * SOLR-5663: example-DIH uses non-existing column for mapping (case-sensitive)
- (steffkes)
- * SOLR-5666: Using the hdfs write cache can result in appearance of corrupted
- index. (Mark Miller)
- * SOLR-5230: Call DelegatingCollector.finish() during grouping.
- (Joel Bernstein, ehatcher)
- * SOLR-5679: Shard splitting fails with ClassCastException on collections
- upgraded from 4.5 and earlier versions. (Brett Hoerner, shalin)
- * SOLR-5673: HTTPSolrServer doesn't set own property correctly in
- setFollowRedirects. (Frank Wesemann via shalin)
- * SOLR-5676: SolrCloud updates rejected if talking to secure ZooKeeper.
- (Greg Chanan via Mark Miller)
- * SOLR-5634: SolrJ GroupCommand.getNGroups returns null if group.format=simple
- and group.ngroups=true. (Artem Lukanin via shalin)
- * SOLR-5667: Performance problem when not using hdfs block cache. (Mark Miller)
- * SOLR-5526: Fixed NPE that could arise when explicitly configuring some built
- in QParserPlugins (Nikolay Khitrin, Vitaliy Zhovtyuk, hossman)
- * SOLR-5598: LanguageIdentifierUpdateProcessor ignores all but the first value
- of multiValued string fields. (Andreas Hubold, Vitaliy Zhovtyuk via shalin)
- * SOLR-5593: Replicas should accept the last updates from a leader that has just
- lost its connection to ZooKeeper. (Christine Poerschke via Mark Miller)
- * SOLR-5678: SolrZkClient should throw a SolrException when connect times out
- rather than a RuntimeException. (Karl Wright, Anshum Gupta, Mark Miller)
- * SOLR-4072: Error message is incorrect for linkconfig in ZkCLI.
- (Vamsee Yarlagadda, Adam Hahn, via Mark Miller)
- * SOLR-5691: Sharing non thread safe WeakHashMap across thread can cause
- problems. (Bojan Smid, Mark Miller)
- * SOLR-5693: Running on HDFS does work correctly with NRT search. (Mark Miller)
- * SOLR-5644: SplitShard does not handle not finding a shard leader well.
- (Mark Miller, Anshum Gupta via shalin)
- * SOLR-5704: coreRootDirectory was not respected when creating new cores
- via CoreAdminHandler (Jesse Sipprell, Alan Woodward)
- * SOLR-5709: Highlighting grouped duplicate docs from different shards with
- group.limit > 1 throws ArrayIndexOutOfBoundsException. (Steve Rowe)
- * SOLR-5561: Fix implicit DefaultSimilarityFactory initialization in IndexSchema
- to properly specify discountOverlap option.
- (Isaac Hebsh, Ahmet Arslan, Vitaliy Zhovtyuk, hossman)
- * SOLR-5689: On reconnect, ZkController cancels election on first context rather
- than latest. (Gregory Chanan, Mark Miller via shalin)
- * SOLR-5649: Clean up some minor ConnectionManager issues.
- (Mark Miller, Gregory Chanan)
- * SOLR-5365: Fix bug with compressed files in ExtractingRequestHandler by
- upgrading commons-compress to 1.7 (Jan Høydahl, hossman)
- * SOLR-5675: cloud-scripts/zkcli.bat: quote option log4j
- (Günther Ruck via steffkes
- * SOLR-5721: ConnectionManager can become stuck in likeExpired.
- (Gregory Chanan via Mark Miller)
- * SOLR-5731: In ConnectionManager, we should catch and only log exceptions
- from BeforeReconnect. (Mark Miller)
- * SOLR-5718: Make LBHttpSolrServer zombie checks non-distrib and non-scoring.
- (Christine Poerschke via Mark Miller)
- * SOLR-5727: LBHttpSolrServer should only retry on Connection exceptions when
- sending updates. Affects CloudSolrServer. (Mark Miller)
- * SOLR-5739: Sub-shards created by shard splitting have their update log set
- to buffering mode on restarts. (Günther Ruck, shalin)
- * SOLR-5741: UpdateShardHandler was not correctly setting max total connections
- on the HttpClient. (Shawn Heisey)
- * SOLR-5620: ZKStateReader.aliases should be volatile to ensure all threads see
- the latest aliases. (Ramkumar Aiyengar via Mark Miller)
- * SOLR-5448: ShowFileRequestHandler treats everything as Directory, when in
- Cloud-Mode. (Erick Erickson, steffkes)
- Optimizations
- ----------------------
- * SOLR-5436: Eliminate the 1500ms wait in overseer loop as well as
- polling the ZK distributed queue. (Noble Paul, Mark Miller)
- * SOLR-5189: Solr 4.x Web UI Log Viewer does not display 'date' column from
- logs (steffkes)
- * SOLR-5512: Optimize DocValuesFacets. (Robert Muir)
- * SOLR-2960: fix DIH XPathEntityProcessor to add the correct number of "null"
- placeholders for multi-valued fields (Michael Watts via James Dyer)
- * SOLR-5214: Reduce memory usage for shard splitting by merging segments one
- at a time. (Christine Poerschke via shalin)
- * SOLR-4227: Wrap XML RequestWriter's OutputStreamWriter in a BufferedWriter
- to avoid frequent converter invocations. (Conrad Herrmann, shalin)
- * SOLR-5624: Enable QueryResultCache for CollapsingQParserPlugin.
- (David Boychuck, Joel Bernstein)
- * LUCENE-5440: DocSet decoupled from OpenBitSet. DocSetBase moved to use
- FixedBitSet instead of OpenBitSet. As a result BitDocSet now only works
- with FixedBitSet. (Shai Erera)
- Other Changes
- ---------------------
- * SOLR-5399: Add distributed request tracking information to DebugComponent
- (Tomás Fernández Löbbe via Ryan Ernst)
- * SOLR-5421: Remove double set of distrib.from param in processAdd method of
- DistributedUpdateProcessor. (Anshum Gupta via shalin)
- * SOLR-5404: The example config references deprecated classes.
- (Uwe Schindler, Rafał Kuć via Mark Miller)
- * SOLR-5487: Replication factor error message doesn't match constraint.
- (Patrick Hunt via shalin)
- * SOLR-5499: Log a warning if /get is not registered when using SolrCloud.
- (Daniel Collins via shalin)
- * SOLR-5517: Return HTTP error on POST requests with no Content-Type.
- (Ryan Ernst, Uwe Schindler)
- * SOLR-5502: Added a test for tri-level compositeId routing with documents
- having a "/" in a document id. (Anshum Gupta via Mark Miller)
- * SOLR-5533: Improve out of the box support for running Solr on hdfs with
- SolrCloud. (Mark Miller)
- * SOLR-5548: Give DistributedSearchTestCase / JettySolrRunner the ability to
- specify extra filters. (Greg Chanan via Mark Miller)
- * SOLR-5555: LBHttpSolrServer and CloudSolrServer constructors don't need to
- declare MalformedURLExceptions (Sushil Bajracharya, Alan Woodward)
- * SOLR-5565: Raise default ZooKeeper session timeout to 30 seconds from 15
- seconds. (Mark Miller)
- * SOLR-5574: CoreContainer shutdown publishes all nodes as down and waits to
- see that and then again publishes all nodes as down. (Mark Miller)
- * SOLR-5590: Upgrade HttpClient/HttpComponents to 4.3.x.
- (Karl Wright via Shawn Heisey)
- * SOLR-2794: change the default of hl.phraseLimit to 5000.
- (Michael Della Bitta via Robert Muir, Koji, zarni - pull request #11)
- * SOLR-5632: Improve response message for reloading a non-existent core.
- (Anshum Gupta via Mark Miller)
- * SOLR-5633: HttpShardHandlerFactory should make its http client available to subclasses.
- (Ryan Ernst)
- * SOLR-5684: Shutdown SolrServer clients created in BasicDistributedZk2Test and
- BasicDistributedZkTest. (Tomás Fernández Löbbe via shalin)
- * SOLR-5629: SolrIndexSearcher.name should include core name.
- (Shikhar Bhushan via shalin)
- * SOLR-5702: Log config name found for collection at info level.
- (Christine Poerschke via Mark Miller)
- * SOLR-5659: Add test for compositeId ending with an '!'.
- (Markus Jelsma, Anshum Gupta via shalin)
- * SOLR-5700: Improve error handling of remote queries (proxied requests).
- (Greg Chanan, Steve Davids via Mark Miller)
- * SOLR-5585: Raise Collections API timeout to 3 minutes from one minute.
- (Mark Miller)
- * SOLR-5257: Improved error/warn messages when Update XML contains unexpected XML nodes
- (Vitaliy Zhovtyuk, hossman)
- ================== 4.6.1 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.4
- Carrot2 3.8.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Detailed Change List
- ----------------------
- Bug Fixes
- ----------------------
- * SOLR-5408: CollapsingQParserPlugin scores incorrectly when multiple sort criteria are used
- (Brandon Chapman, Joel Bernstein)
- * SOLR-5416: CollapsingQParserPlugin breaks Tag/Exclude Faceting (David Boychuck, Joel Bernstein)
- * SOLR-5442: Python client cannot parse proxied response when served by Tomcat.
- (Patrick Hunt, Gregory Chanan, Vamsee Yarlagadda, Romain Rigaux, Mark Miller)
- * SOLR-5445: Proxied responses should propagate all headers rather than the
- first one for each key. (Patrick Hunt, Mark Miller)
- * SOLR-5479: SolrCmdDistributor retry logic stops if a leader for the request
- cannot be found in 1 second. (Mark Miller)
- * SOLR-5532: SolrJ Content-Type validation is too strict for some
- webcontainers / proxies. (Jakob Furrer, hossman, Shawn Heisey, Uwe Schindler,
- Mark Miller)
- * SOLR-5547: Creating a collection alias using SolrJ's CollectionAdminRequest
- sets the alias name and the collections to alias to the same value.
- (Aaron Schram, Mark Miller)
- * SOLR-5577: Likely ZooKeeper expiration should not slow down updates a given
- amount, but instead cut off updates after a given time.
- (Mark Miller, Christine Poerschke, Ramkumar Aiyengar)
- * SOLR-5580: NPE when creating a core with both explicit shard and coreNodeName.
- (YouPeng Yang, Mark Miller)
- * SOLR-5552: Leader recovery process can select the wrong leader if all replicas
- for a shard are down and trying to recover as well as lose updates that should
- have been recovered. (Timothy Potter, Mark Miller)
- * SOLR-5569 A replica should not try and recover from a leader until it has
- published that it is ACTIVE. (Mark Miller)
- * SOLR-5568 A SolrCore cannot decide to be the leader just because the cluster
- state says no other SolrCore's are active. (Mark Miller)
- * SOLR-5496: We should share an http connection manager across non search
- HttpClients and ensure all http connection managers get shutdown.
- (Mark Miller)
- * SOLR-5583: ConcurrentUpdateSolrServer#blockUntilFinished may wait forever if
- the executor service is shutdown. (Mark Miller)
- * SOLR-5586: All ZkCmdExecutor's should be initialized with the zk client
- timeout. (Mark Miller)
- * SOLR-5587: ElectionContext implementations should use
- ZkCmdExecutor#ensureExists to ensure their election paths are properly
- created. (Mark Miller)
- * SOLR-5540: HdfsLockFactory should explicitly create the lock parent directory if
- necessary. (Mark Miller)
- * SOLR-4709: The core reload after replication if config files have changed
- can fail due to a race condition. (Mark Miller, Hossman)
- * SOLR-5503: Retry 'forward to leader' requests less aggressively - rather
- than on IOException and status 500, ConnectException. (Mark Miller)
- * SOLR-5588: PeerSync doesn't count all connect failures as success.
- (Mark Miller)
- * SOLR-5564: hl.maxAlternateFieldLength should apply to original field when
- fallback is attempted (janhoy)
- * SOLR-5608: Don't allow a closed SolrCore to publish state to ZooKeeper.
- (Mark Miller, Shawn Heisey)
- * SOLR-5615: Deadlock while trying to recover after a ZK session expiration.
- (Ramkumar Aiyengar, Mark Miller)
- * SOLR-5543: Core swaps resulted in duplicate core entries in solr.xml when
- using solr.xml persistence. (Bill Bell, Alan Woodward)
- * SOLR-5618: Fix false cache hits in queryResultCache when hashCodes are equal
- and duplicate filter queries exist in one of the requests (hossman)
- * SOLR-4260: ConcurrentUpdateSolrServer#blockUntilFinished can return before
- all previously added updates have finished. This could cause distributed
- updates meant for replicas to be lost. (Markus Jelsma, Timothy Potter,
- Joel Bernstein, Mark Miller)
- * SOLR-5645: A SolrCore reload via the CoreContainer will try and register in
- zk again with the new SolrCore. (Mark Miller)
- * SOLR-5636: SolrRequestParsers does some xpath lookups on every request, which
- can cause concurrency issues. (Mark Miller)
- * SOLR-5658: commitWithin and overwrite are not being distributed to replicas
- now that SolrCloud uses javabin to distribute updates.
- (Mark Miller, Varun Thacker, Elodie Sannier, shalin)
- Optimizations
- ----------------------
- * SOLR-5576: Improve concurrency when registering and waiting for all
- SolrCore's to register a DOWN state. (Christine Poerschke via Mark Miller)
- ================== 4.6.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.4
- Carrot2 3.8.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Upgrading from Solr 4.5.0
- ----------------------
- * If you are using methods from FieldMutatingUpdateProcessorFactory for getting
- configuration information (oneOrMany or getBooleanArg), those methods have
- been moved to NamedList and renamed to removeConfigArgs and removeBooleanArg,
- respectively. The original methods are deprecated, to be removed in 5.0.
- See SOLR-5264.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-5167: Add support for AnalyzingInfixSuggester (AnalyzingInfixLookupFactory).
- (Areek Zillur, Varun Thacker via Robert Muir)
- * SOLR-5246: Shard splitting now supports collections configured with router.field.
- (shalin)
- * SOLR-5274: Allow JettySolrRunner SSL config to be specified via a constructor.
- (Mark Miller)
- * SOLR-5300: Shards can be split by specifying arbitrary number of hash ranges
- within the shard's hash range. (shalin)
- * SOLR-5226: Add Lucene index heap usage to the Solr admin UI.
- (Areek Zillur via Robert Muir)
- * SOLR-5324: Make sub shard replica recovery and shard state switch asynchronous.
- (Yago Riveiro, shalin)
- * SOLR-5338: Split shards by a route key using split.key parameter. (shalin)
- * SOLR-5353: Enhance CoreAdmin api to split a route key's documents from an index
- and leave behind all other documents. (shalin)
- * SOLR-5027: CollapsingQParserPlugin for high performance field collapsing on high cardinality fields.
- (Joel Bernstein)
- * SOLR-5395: Added a RunAlways marker interface for UpdateRequestProcessorFactory
- implementations indicating that they should not be removed in later stages
- of distributed updates (usually signalled by the update.distrib parameter)
- (yonik)
- * SOLR-5310: Add a collection admin command to remove a replica (noble)
- * SOLR-5311: Avoid registering replicas which are removed (noble)
- * SOLR-5406: CloudSolrServer failed to propagate request parameters
- along with delete updates. (yonik)
- * SOLR-5374: Support user configured doc-centric versioning rules
- via the optional DocBasedVersionConstraintsProcessorFactory
- update processor (Hossman, yonik)
- * SOLR-5392: Extend solrj apis to cover collection management.
- (Roman Shaposhnik via Mark Miller)
- * SOLR-5084: new field type EnumField. (Elran Dvir via Erick Erickson)
- * SOLR-5464: Add option to ConcurrentSolrServer to stream pure delete
- requests. (Mark Miller)
- Bug Fixes
- ----------------------
- * SOLR-5216: Document updates to SolrCloud can cause a distributed deadlock.
- (Mark Miller)
- * SOLR-5367: Unmarshalling delete by id commands with JavaBin can lead to class cast
- exception. (Mark Miller)
- * SOLR-5359: ZooKeeper client is not closed when it fails to connect to an ensemble.
- (Mark Miller, Klaus Herrmann)
- * SOLR-5042: MoreLikeThisComponent was using the rows/count value in place of
- flags, which caused a number of very strange issues, including NPEs and
- ignoring requests for the results to include the score.
- (Anshum Gupta, Mark Miller, Shawn Heisey)
- * SOLR-5371: Solr should consistently call SolrServer#shutdown (Mark Miller)
- * SOLR-5363: Solr doesn't start up properly with Log4J2 (Petar Tahchiev via Alan
- Woodward)
- * SOLR-5380: Using cloudSolrServer.setDefaultCollection(collectionId) does not
- work as intended for an alias spanning more than 1 collection.
- (Thomas Egense, Shawn Heisey, Mark Miller)
- * SOLR-5418: Background merge after field removed from solr.xml causes error.
- (Reported on user's list, Robert M's patch via Erick Erickson)
- * SOLR-5318: Creating a core via the admin API doesn't respect transient property
- (Olivier Soyez via Erick Erickson)
- * SOLR-5388: Creating a new core via the HTTP API that results in a transient being
- unloaded results in a " Too many close [count:-1]" error.
- (Olivier Soyez via Erick Erickson)
- * SOLR-5453: Raise recovery socket read timeouts. (Mark Miller)
- * SOLR-5397: Replication can fail silently in some cases. (Mark Miller)
- * SOLR-5465: SolrCmdDistributor retry logic has a concurrency race bug.
- (Mark Miller)
- * SOLR-5452: Do not attempt to proxy internal update requests. (Mark Miller)
- Optimizations
- ----------------------
- * SOLR-5232: SolrCloud should distribute updates via streaming rather than buffering.
- (Mark Miller)
- * SOLR-5223: SolrCloud should use the JavaBin binary format for communication by default.
- (Mark Miller)
- * SOLR-5370: Requests to recover when an update fails should be done in
- background threads. (Mark Miller)
- * LUCENE-5300,LUCENE-5304: Specialized faceting for fields which are declared as
- multi-valued in the schema but are actually single-valued. (Adrien Grand)
- Security
- ----------------------
- * SOLR-4882: SolrResourceLoader was restricted to only allow access to resource
- files below the instance dir. The reason for this is security related: Some
- Solr components allow to pass in resource paths via REST parameters
- (e.g. XSL stylesheets, velocity templates,...) and load them via resource
- loader. For backwards compatibility, this security feature can be disabled
- by a new system property: solr.allow.unsafe.resourceloading=true
- (Uwe Schindler)
- Other Changes
- ----------------------
- * SOLR-5237: Add indexHeapUsageBytes to LukeRequestHandler, indicating how much
- heap memory is being used by the underlying Lucene index structures.
- (Areek Zillur via Robert Muir)
- * SOLR-5241: Fix SimplePostToolTest performance problem - implicit DNS lookups
- (hossman)
- * SOLR-5273: Update HttpComponents to 4.2.5 and 4.2.6. (Mark Miller)
- * SOLR-5264: Move methods for getting config information from
- FieldMutatingUpdateProcessorFactory to NamedList. (Shawn Heisey)
- * SOLR-5319: Remove unused and incorrect router name from Collection ZK nodes.
- (Jessica Cheng via shalin)
- * SOLR-5321: Remove unnecessary code in Overseer.updateState method which tries to
- use router name from message where none is ever sent. (shalin)
- * SOLR-5401: SolrResourceLoader logs a warning if a deprecated (factory) class
- is used in schema or config. (Uwe Schindler)
- * SOLR-3397: Warn if master or slave replication is enabled in SolrCloud mode. (Erick
- Erickson)
- ================== 4.5.1 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.4
- Carrot2 3.8.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Detailed Change List
- ----------------------
- Bug Fixes
- ----------------------
- * SOLR-4590: Collections API should return a nice error when not in SolrCloud mode.
- (Anshum Gupta, Mark Miller)
- * SOLR-5295: The CREATESHARD collection API creates maxShardsPerNode number of
- replicas if replicationFactor is not specified. (Brett Hoerner, shalin)
- * SOLR-5296: Creating a collection with implicit router adds shard ranges
- to each shard. (shalin)
- * SOLR-5263: Fix CloudSolrServer URL cache update race. (Jessica Cheng, Mark Miller)
- * SOLR-5297: Admin UI - Threads Screen missing Icon (steffkes)
- * SOLR-5301: DELETEALIAS command prints CREATEALIAS in logs (janhoy)
- * SOLR-5255: Remove unnecessary call to fetch and watch live nodes in ZkStateReader
- cluster watcher. (Jessica Cheng via shalin)
- * SOLR-5305: Admin UI - Reloading System-Information on Dashboard does not work
- anymore (steffkes)
- * SOLR-5314: Shard split action should use soft commits instead of hard commits
- to make sub shard data visible. (Kalle Aaltonen, shalin)
- * SOLR-5327: SOLR-4915, "The root cause should be returned to the user when a SolrCore create
- call fails", was reverted. (Mark Miller)
- * SOLR-5317: SolrCore persistence bugs if defining SolrCores in solr.xml.
- (Mark Miller, Yago Riveiro)
- * SOLR-5306: Extra collection creation parameters like collection.configName are
- not being respected. (Mark Miller, Liang Tianyu, Nathan Neulinger)
- * SOLR-5325: ZooKeeper connection loss can cause the Overseer to stop processing
- commands. (Christine Poerschke, Mark Miller, Jessica Cheng)
- * SOLR-4327: HttpSolrServer can leak connections on errors. (Karl Wright, Mark Miller)
- * SOLR-5349: CloudSolrServer - ZK timeout arguments passed to ZkStateReader are flipped.
- (Ricardo Merizalde via shalin)
- * SOLR-5330: facet.method=fcs on single values fields could sometimes result
- in incorrect facet labels. (Michael Froh, yonik)
- Other Changes
- ----------------------
- * SOLR-5323: Disable ClusteringComponent by default in collection1 example.
- The solr.clustering.enabled system property needs to be set to 'true'
- to enable the clustering contrib (reverts SOLR-4708). (Dawid Weiss)
- ================== 4.5.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.4
- Carrot2 3.8.0
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Upgrading from Solr 4.4.0
- ----------------------
- * XML configuration parsing is now more strict about situations where a single
- setting is allowed but multiple values are found. In the past, one value
- would be chosen arbitrarily and silently. Starting with 4.5, configuration
- parsing will fail with an error in situations like this. If you see error
- messages such as "solrconfig.xml contains more than one value for config path:
- XXXXX" or "Found Z configuration sections when at most 1 is allowed matching
- expression: XXXXX" check your solrconfig.xml file for multiple occurrences of
- XXXXX and delete the ones that you do not wish to use. See SOLR-4953 &
- SOLR-5108 for more details.
- * In the past, schema.xml parsing would silently ignore "default" or "required"
- options specified on <dynamicField/> declarations. Beginning with 4.5, attempting
- to do configured these on a dynamic field will cause an init error. If you
- encounter one of these errors when upgrading an existing schema.xml, you can
- safely remove these attributes, regardless of their value, from your config and
- Solr will continue to behave exactly as it did in previous versions. See
- SOLR-5227 for more details.
- * The UniqFieldsUpdateProcessorFactory has been improved to support all of the
- FieldMutatingUpdateProcessorFactory selector options. The <lst named="fields">
- init param option is now deprecated and should be replaced with the more standard
- <arr name="fieldName">. See SOLR-4249 for more details.
- * UpdateRequestExt has been removed as part of SOLR-4816. You should use UpdateRequest
- instead.
- * CloudSolrServer can now use multiple threads to add documents by default. This is a
- small change in runtime semantics when using the bulk add method - you will still
- end up with the same exception on a failure, but some documents beyond the one that
- failed may have made it in. To get the old, single threaded behavior, set parallel updates
- to false on the CloudSolrServer instance.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-5219: Rewritten selection of the default search and document clustering
- algorithms. (Dawid Weiss)
- * SOLR-5202: Support easier overrides of Carrot2 clustering attributes via
- XML data sets exported from the Workbench. (Dawid Weiss)
- * SOLR-5126: Update Carrot2 clustering to version 3.8.0, update Morfologik
- to version 1.7.1 (Dawid Weiss)
- * SOLR-2345: Enhanced geodist() to work with an RPT field, provided that the
- field is referenced via 'sfield' and the query point is constant.
- (David Smiley)
- * SOLR-5082: The encoding of URL-encoded query parameters can be changed with
- the "ie" (input encoding) parameter, e.g. "select?q=m%FCller&ie=ISO-8859-1".
- The default is UTF-8. To change the encoding of POSTed content, use the
- "Content-Type" HTTP header. (Uwe Schindler, Shawn Heisey)
- * SOLR-4221: Custom sharding (Noble Paul)
- * SOLR-4808: Persist and use router,replicationFactor and maxShardsPerNode at Collection
- and Shard level (Noble Paul, Shalin Mangar)
- * SOLR-5006: CREATESHARD command for 'implicit' shards (Noble Paul)
- * SOLR-5017: Allow sharding based on the value of a field (Noble Paul)
- * SOLR-4222: create custom sharded collection via collections API (Noble Paul)
- * SOLR-4718: Allow solr.xml to be stored in ZooKeeper. (Mark Miller, Erick Erickson)
- * SOLR-5156: Enhance ZkCLI to allow uploading of arbitrary files to ZK. (Erick Erickson)
- * SOLR-5165: Single-valued docValues fields no longer require a default value.
- Additionally they work with sortMissingFirst, sortMissingLast, facet.missing,
- exists() in function queries, etc. (Robert Muir)
- * SOLR-5182: Add NoOpRegenerator, a regenerator for custom per-segment caches
- where items are preserved across commits. (Robert Muir)
- * SOLR-4249: UniqFieldsUpdateProcessorFactory now extends
- FieldMutatingUpdateProcessorFactory and supports all of its selector options. Use
- of the "fields" init param is now deprecated in favor of "fieldName" (hossman)
- * SOLR-2548: Allow multiple threads to be specified for faceting. When threading, one
- can specify facet.threads to parallelize loading the uninverted fields. In at least
- one extreme case this reduced warmup time from 20 seconds to 3 seconds. (Janne Majaranta,
- Gun Akkor via Erick Erickson, David Smiley)
- * SOLR-4816: CloudSolrServer can now route updates locally and no longer relies on inter-node
- update forwarding. (Joel Bernstein, Shikhar Bhushan, Stephen Riesenberg, Mark Miller)
- * SOLR-3249: Allow CloudSolrServer and SolrCmdDistributor to use JavaBin. (Mark Miller)
- Bug Fixes
- ----------------------
- * SOLR-3633: web UI reports an error if CoreAdminHandler says there are no
- SolrCores (steffkes)
- * SOLR-4489: SpellCheckComponent can throw StringIndexOutOfBoundsException
- when generating collations involving multiple word-break corrections.
- (James Dyer)
- * SOLR-5087 - CoreAdminHandler.handleMergeAction generating NullPointerException
- (Patrick Hunt via Erick Erickson)
- * SOLR-5107: Fixed NPE when using numTerms=0 in LukeRequestHandler
- (Ahmet Arslan, hossman)
- * SOLR-4679, SOLR-4908, SOLR-5124: Text extracted from HTML or PDF files
- using Solr Cell was missing ignorable whitespace, which is inserted by
- TIKA for convenience to support plain text extraction without using the
- HTML elements. This bug resulted in glued words. (hossman, Uwe Schindler)
- * SOLR-5121: zkcli usage help for makepath doesn't match actual command.
- (Daniel Collins via Mark Miller)
- * SOLR-5119: Managed schema problems after adding fields via Schema Rest API.
- (Nils Kübler, Steve Rowe)
- * SOLR-5133: HdfsUpdateLog can fail to close a FileSystem instance if init
- is called more than once. (Mark Miller)
- * SOLR-5135: Harden Collection API deletion of /collections/$collection
- ZooKeeper node. (Mark Miller)
- * SOLR-4764: When using NRT, just init the first reader from IndexWriter.
- (Robert Muir, Mark Miller)
- * SOLR-5122: Fixed bug in spellcheck.collateMaxCollectDocs. Eliminates risk
- of divide by zero, and makes estimated hit counts meaningful in non-optimized
- indexes. (hossman)
- * SOLR-3936: Fixed QueryElevationComponent sorting when used with Grouping
- (Michael Garski via hossman)
- * SOLR-5171: SOLR Admin gui works in IE9, breaks in IE10. (Joseph L Howard via
- steffkes)
- * SOLR-5174: Admin UI - Query View doesn't highlight (json) Result if it
- contains HTML Tags (steffkes)
- * SOLR-4817 Solr should not fall back to the back compat built in solr.xml in SolrCloud
- mode (Erick Erickson)
- * SOLR-5112: Show full message in Admin UI Logging View (Matthew Keeney via
- steffkes)
- * SOLR-5190: SolrEntityProcessor substitutes variables only once in child entities
- (Harsh Chawla, shalin)
- * SOLR-3852: Fixed ZookeeperInfoServlet so that the SolrCloud Admin UI pages will
- work even if ZK contains nodes with data which are not utf8 text. (hossman)
- * SOLR-5206: Fixed OpenExchangeRatesOrgProvider to use refreshInterval correctly
- (Catalin, hossman)
- * SOLR-5215: Fix possibility of deadlock in ZooKeeper ConnectionManager.
- (Mark Miller, Ricardo Merizalde)
- * SOLR-4909: Use DirectoryReader.openIfChanged in non-NRT mode.
- (Michael Garski via Robert Muir)
- * SOLR-5227: Correctly fail schema initialization if a dynamicField is configured to
- be required, or have a default value. (hossman)
- * SOLR-5231: Fixed a bug with the behavior of BoolField that caused documents w/o
- a value for the field to act as if the value were true in functions if no other
- documents in the same index segment had a value of true.
- (Robert Muir, hossman, yonik)
- * SOLR-5233: The "deleteshard" collections API doesn't wait for cluster state to update,
- can fail if some nodes of the deleted shard were down and had incorrect logging.
- (Christine Poerschke, shalin)
- * SOLR-5150: HdfsIndexInput may not fully read requested bytes. (Mark Miller, Patrick Hunt)
- * SOLR-5240: All solr cores will now be loaded in parallel (as opposed to a fixed number)
- in zookeeper mode to avoid deadlocks due to replicas waiting for other replicas
- to come up. (yonik)
- * SOLR-5243: Killing a shard in one collection can result in leader election in a different
- collection if they share the same coreNodeName. (yonik, Mark Miller)
- * SOLR-5281: IndexSchema log message was printing '[null]' instead of
- '[<core name>]' (Jun Ohtani via Steve Rowe)
- * SOLR-5279: Implicit properties don't seem to exist on core RELOAD
- (elyograg, hossman, Steve Rowe)
- * SOLR-5291: Solrj does not propagate the root cause to the user for many errors.
- (Mark Miller)
- Optimizations
- ----------------------
- * SOLR-5044: Admin UI - Note on Core-Admin about directories while creating
- core (steffkes)
- * SOLR-5134: Have HdfsIndexOutput extend BufferedIndexOutput.
- (Mark Miller, Uwe Schindler)
- * SOLR-5057: QueryResultCache should not related with the order of fq's list (Feihong Huang via Erick Erickson)
- * SOLR-4816: CloudSolrServer now uses multiple threads to send updates by default.
- (Joel Bernstein via Mark Miller)
- * SOLR-3530: Better error messages / Content-Type validation in SolrJ. (Mark Miller, hossman)
- Other Changes
- ----------------------
- * SOLR-4708: Enable ClusteringComponent by default in collection1 example.
- The solr.clustering.enabled system property is set to 'true' by default.
- (ehatcher, Dawid Weiss)
- * SOLR-4914, SOLR-5162: Factor out core list persistence and discovery into a
- new CoresLocator interface. (Alan Woodward, Shawn Heisey)
- * SOLR-5056: Improve type safety of ConfigSolr class. (Alan Woodward)
- * SOLR-4951: Better randomization of MergePolicy in Solr tests (hossman)
- * SOLR-4953, SOLR-5108: Make XML Configuration parsing fail if an xpath matches
- multiple nodes when only a single value or plugin instance is expected.
- (hossman)
- * The routing parameter "shard.keys" is deprecated as part of SOLR-5017 .The new parameter name is '_route_' .
- The old parameter should continue to work for another release (Noble Paul)
- * SOLR-5173: Solr-core's Maven configuration includes test-only Hadoop
- dependencies as indirect compile-time dependencies.
- (Chris Collins, Steve Rowe)
- ================== 4.4.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.4
- Carrot2 3.6.2
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Upgrading from Solr 4.3.0
- ----------------------
- * TieredMergePolicy and the various subtypes of LogMergePolicy no longer have
- an explicit "setUseCompoundFile" method. Instead the behavior of new
- segments is determined by the IndexWriter configuration, and the MergePolicy
- is only consulted to determine if merge segments should use the compound
- file format (based on the value of "setNoCFSRatio"). If you have explicitly
- configured one of these classes using <mergePolicy> and include an init arg
- like this...
- <bool name="useCompoundFile">true</bool>
- ...this will now be treated as if you specified...
- <useCompoundFile>true</useCompoundFile>
- ...directly on the <indexConfig> (overriding any value already set using that
- syntax) and a warning will be logged to updated your configuration. Users
- with an explicitly declared <mergePolicy> are encouraged to review the
- current javadocs for their MergePolicy subclass and review their configured
- options carefully. See SOLR-4941, SOLR-4934 and LUCENE-5038 for more
- information.
- * SOLR-4778: The signature of LogWatcher.registerListener has changed, from
- (ListenerConfig, CoreContainer) to (ListenerConfig). Users implementing their
- own LogWatcher classes will need to change their code accordingly.
- * LUCENE-5063: ByteField and ShortField have been deprecated and will be removed
- in 5.0. If you are still using these field types, you should migrate your
- fields to TrieIntField.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-3251: Dynamically add fields to schema. (Steve Rowe, Robert Muir, yonik)
- * SOLR-4761, SOLR-4976: Add option to plugin a merged segment warmer into solrconfig.xml.
- Info about segments warmed in the background is available via infostream.
- (Mark Miller, Ryan Ernst, Mike McCandless, Robert Muir)
- * SOLR-3240: Add "spellcheck.collateMaxCollectDocs" option so that when testing
- potential Collations against the index, SpellCheckComponent will only collect
- n documents, thereby estimating the hit-count. This is a performance optimization
- in cases where exact hit-counts are unnecessary. Also, when "collateExtendedResults"
- is false, this optimization is always made (James Dyer).
- * SOLR-4785: New MaxScoreQParserPlugin returning max() instead of sum() of terms (janhoy)
- * SOLR-4234: Add support for binary files in ZooKeeper. (Eric Pugh via Mark Miller)
- * SOLR-4048: Add findRecursive method to NamedList. (Shawn Heisey)
- * SOLR-4228: SolrJ's SolrPing object has new methods for ping, enable, and
- disable. (Shawn Heisey, hossman, Steve Rowe)
- * SOLR-4893: Extend FieldMutatingUpdateProcessor.ConfigurableFieldNameSelector
- to enable checking whether a field matches any schema field. To select field
- names that don't match any fields or dynamic fields in the schema, add
- <bool name="fieldNameMatchesSchemaField">false</bool> to an update
- processor's configuration in solrconfig.xml. (Steve Rowe, hossman)
- * SOLR-4921: Admin UI now supports adding documents to Solr (gsingers, steffkes)
- * SOLR-4916: Add support to write and read Solr index files and transaction log
- files to and from HDFS. (phunt, Mark Miller, Gregory Chanan)
- * SOLR-4892: Add FieldMutatingUpdateProcessorFactory subclasses
- Parse{Date,Integer,Long,Float,Double,Boolean}UpdateProcessorFactory. These
- factories have a default selector that matches all fields that either don’t
- match any schema field, or are in the schema with the corresponding
- typeClass. If they see a value that is not a CharSequence, or can't parse
- the value, they leave it as is. For multi-valued fields, these processors
- will not convert any values unless all are first successfully parsed, or
- already are instances of the target class. Ordering the processors, e.g.
- [Boolean, Long, Double, Date] will allow e.g. values ["2", "5", "8.6"] to
- be left alone by the Boolean and Long processors, but then converted by the
- Double processor. (Steve Rowe, hossman)
- * SOLR-4972: Add PUT command to ZkCli tool. (Roman Shaposhnik via Mark Miller)
- * SOLR-4973: Adding getter method for defaultCollection on CloudSolrServer.
- (Furkan KAMACI via Mark Miller)
- * SOLR-4897: Add solr/example/example-schemaless/, an example config set
- for schemaless mode. (Steve Rowe)
- * SOLR-4655: Add option to have Overseer assign generic node names so that
- new addresses can host shards without naming confusion. (Mark Miller, Anshum Gupta)
- * SOLR-4977: Add option to send IndexWriter's infostream to the logging system.
- (Ryan Ernst via Robert Muir)
- * SOLR-4693: A "deleteshard" collections API that unloads all replicas of a given
- shard and then removes it from the cluster state. It will remove only those shards
- which are INACTIVE or have no range (created for custom sharding).
- (Anshum Gupta, shalin)
- * SOLR-5003: CSV Update Handler supports optionally adding the line number/row id to
- a document (gsingers)
- * SOLR-5010: Add support for creating copy fields to the Schema REST API (gsingers)
- * SOLR-4991: Register QParserPlugins as SolrInfoMBeans (ehatcher)
- * SOLR-4943: Add a new system wide info admin handler that exposes the system info
- that could previously only be retrieved using a SolrCore. (Mark Miller)
- * SOLR-3076: Block joins. Documents and their sub-documents must be indexed
- as a block.
- {!parent which=<allParents>}<someChildren> takes in a query that matches child
- documents and results in matches on their parents.
- {!child of=<allParents>}<someParents> takes in a query that matches some parent
- documents and results in matches on their children.
- (Mikhail Khludnev, Vadim Kirilchuk, Alan Woodward, Tom Burton-West, Mike McCandless,
- hossman, yonik)
- Bug Fixes
- ----------------------
- * SOLR-4333: edismax parser to not double-escape colons if already escaped by
- the client application (James Dyer, Robert J. van der Boon)
- * SOLR-4776: Solrj doesn't return "between" count in range facets
- (Philip K. Warren via shalin)
- * SOLR-4616: HitRatio on caches is now exposed over JMX MBeans as a float.
- (Greg Bowyer)
- * SOLR-4803: Fixed core discovery mode (ie: new style solr.xml) to treat
- 'collection1' as the default core name. (hossman)
- * SOLR-4790: Throw an error if a core has the same name as another core, both old and
- new style solr.xml
- * SOLR-4842: Fix facet.field local params from affecting other facet.field's.
- (ehatcher, hossman)
- * SOLR-4814: If a SolrCore cannot be created it should remove any information it
- published about itself from ZooKeeper. (Mark Miller)
- * SOLR-4863: Removed non-existent attribute sourceId from dynamic JMX stats
- to fix AttributeNotFoundException (suganuma, hossman via shalin)
- * SOLR-4891: JsonLoader should preserve field value types from the JSON content stream.
- (Steve Rowe)
- * SOLR-4805: SolrCore#reload should not call preRegister and publish a DOWN state to
- ZooKeeper. (Mark Miller, Jared Rodriguez)
- * SOLR-4899: When reconnecting after ZooKeeper expiration, we need to be willing to wait
- forever, not just for 30 seconds. (Mark Miller)
- * SOLR-4920: JdbcDataSource incorrectly suppresses exceptions when retrieving a connection from
- a JNDI context and falls back to trying to use DriverManager to obtain a connection. Additionally,
- if a SQLException is thrown while initializing a connection, such as in setAutoCommit(), the
- connection will not be closed. (Chris Eldredge via shalin)
- * SOLR-4915: The root cause should be returned to the user when a SolrCore create call fails.
- (Mark Miller)
- * SOLR-4925 : Collection create throws NPE when 'numShards' param is missing (Noble Paul)
- * SOLR-4910: persisting solr.xml is broken. More stringent testing of persistence fixed
- up a number of issues and several bugs with persistence. Among them are
- - don't persisting implicit properties
- - should persist zkHost in the <solr> tag (user's list)
- - reloading a core that has transient="true" returned an error. reload should load
- a transient core if it's not yet loaded.
- - No longer persisting loadOnStartup or transient core properties if they were not
- specified in the original solr.xml
- - Testing flushed out the fact that you couldn't swap a core marked transient=true
- loadOnStartup=false because it hadn't been loaded yet.
- - SOLR-4862, CREATE fails to persist schema, config, and dataDir
- - SOLR-4363, not persisting coreLoadThreads in <solr> tag
- - SOLR-3900, logWatcher properties not persisted
- - SOLR-4850, cores defined as loadOnStartup=true, transient=false can't be searched
- (Erick Erickson)
- * SOLR-4923: Commits to non leaders as part of a request that also contain updates
- can execute out of order. (hossman, Ricardo Merizalde, Mark Miller)
- * SOLR-4932: persisting solr.xml saves some parameters it shouldn't when they weren't
- defined in the original. Benign since the default values are saved, but still incorrect.
- (Erick Erickson, thanks Shawn Heisey for helping test!)
- * SOLR-4934, SOLR-4941: Fix handling of <mergePolicy> init arg
- "useCompoundFile" needed after changes in LUCENE-5038 (hossman)
- * SOLR-4456: Admin UI: Displays dashboard even if Solr is down (steffkes)
- * SOLR-4949: UI Analysis page dropping characters from input box (steffkes)
- * SOLR-4960: Fix race conditions in shutdown of CoreContainer
- and getCore that could cause a request to attempt to use a core that
- has shut down. (yonik)
- * SOLR-4926: Fixed rare replication bug that normally only manifested when
- using compound file format. (yonik, Mark Miller)
- * SOLR-4974: Outgrowth of SOLR-4960 that includes transient cores and pending cores
- (Erick Erickson)
- * SOLR-3369: shards.tolerant=true is broken for group queries
- (Russell Black, Martijn van Groningen, Jabouille jean Charles, Ryan McKinley via shalin)
- * SOLR-4452: Hunspell stemmer should not merge duplicate dictionary entries (janhoy)
- * SOLR-5000: ManagedIndexSchema doesn't persist uniqueKey tag after calling addFields
- method. (Jun Ohtani, Steve Rowe)
- * SOLR-4982: Creating a core while referencing system properties looks like it loses files
- Actually, instanceDir, config, dataDir and schema are not dereferenced properly
- when creating cores that reference sys vars (e.g. &dataDir=${dir}). In the dataDir
- case in particular this leads to the index being put in a directory literally named
- ${dir} but on restart the sysvar will be properly dereferenced.
- * SOLR-4788: Multiple Entities DIH delta import: dataimporter.[entityName].last_index_time
- is empty. (chakming wong, James Dyer via shalin)
- * SOLR-4978: Time is stripped from datetime column when imported into Solr date field
- if convertType=true. (Bill Au, shalin)
- * SOLR-5019: spurious ConcurrentModificationException when spell check component
- was in use with filters. (yonik)
- * SOLR-5018: The Overseer should avoid publishing the state for collections that do not
- exist under the /collections zk node. (Mark Miller)
- * SOLR-5028,SOLR-5029: ShardHandlerFactory was not being created properly when
- using new-style solr.xml, and was not being persisted properly when using
- old-style. (Tomás Fernández Löbbe, Ryan Ernst, Alan Woodward)
- * SOLR-4997: The splitshard api doesn't call commit on new sub shards before
- switching shard states. Multiple bugs related to sub shard recovery and
- replication are also fixed. (shalin)
- * SOLR-5034: A facet.query that parses or analyzes down to a null Query would
- throw a NPE. Fixed. (David Smiley)
- * SOLR-5039: Admin/Schema Browser displays -1 for term counts for multiValued fields.
- * SOLR-5037: The CSV loader now accepts field names that are not in the schema.
- (gsingers, ehatcher, Steve Rowe)
- * SOLR-4791: solr.xml sharedLib does not work in 4.3.0 (Ryan Ernst, Jan Høydahl via
- Erick Erickson)
- Optimizations
- ----------------------
- * SOLR-4923: Commit to all nodes in a collection in parallel rather than locally and
- then to all other nodes. (hossman, Ricardo Merizalde, Mark Miller)
- * SOLR-3838: Admin UI - Multiple filter queries are not supported in Query UI (steffkes)
- * SOLR-4719 : Admin UI - Default to wt=json on Query-Screen (steffkes)
- * SOLR-4611: Admin UI - Analysis-Urls with empty parameters create empty result table
- (steffkes)
- * SOLR-4955: Admin UI - Show address bar on top for Schema + Config (steffkes)
- * SOLR-4412: New parameter langid.lcmap to map detected language code to be placed
- in "language" field (janhoy)
- * SOLR-4815: Admin-UI - DIH: Let "commit" be checked by default (steffkes)
- * SOLR-5002: optimize numDocs(Query,DocSet) when filterCache is null (Robert Muir)
- * SOLR-5012: optimize search with filter when filterCache is null (Robert Muir)
- Other Changes
- ----------------------
- * SOLR-4737: Update Guava to 14.0.1 (Mark Miller)
- * SOLR-2079: Add option to pass HttpServletRequest in the SolrQueryRequest context map.
- (Tomás Fernández Löbbe via Robert Muir)
- * SOLR-4738: Update Jetty to 8.1.10.v20130312 (Mark Miller, Robert Muir)
- * SOLR-4749: Clean up and refactor CoreContainer code around solr.xml and SolrCore
- management. (Mark Miller)
- * SOLR-4547: Move logging of filenames on commit from INFO to DEBUG.
- (Shawn Heisey, hossman)
- * SOLR-4757: Change the example to use the new solr.xml format and core
- discovery by directory structure. (Mark Miller)
- * SOLR-4759: Velocity (/browse) template cosmetic cleanup.
- (Mark Bennett, ehatcher)
- * SOLR-4778: LogWatcher init code moved out of CoreContainer (Alan Woodward)
- * SOLR-4784: Make class LuceneQParser public (janhoy)
- * SOLR-4448: Allow the solr internal load balancer to be more easily pluggable.
- (Philip Hoy via Robert Muir)
- * SOLR-4224: Refactor JavaBinCodec input stream definition to enhance reuse.
- (phunt via Mark Miller)
- * SOLR-4931: SolrDeletionPolicy onInit and onCommit methods changed to override
- exact signatures (with generics) from IndexDeletionPolicy (shalin)
- * SOLR-4942: test improvements to randomize use of compound files (hossman)
- * SOLR-4966: CSS, JS and other files in webapp without license (uschindler,
- steffkes)
- * SOLR-4986: Upgrade to Tika 1.4 (Markus Jelsma via janhoy)
- * SOLR-4948, SOLR-5009: Tidied up CoreContainer construction logic.
- (Alan Woodward, Uwe Schindler, Steve Rowe)
- * LUCENE-5107: Properties files by Solr are now written in UTF-8 encoding,
- Unicode is no longer escaped. Reading of legacy properties files with
- \u escapes is still possible. (Uwe Schindler, Robert Muir)
- ================== 4.3.1 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.3
- Carrot2 3.6.2
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Detailed Change List
- ----------------------
- Bug Fixes
- ----------------------
- * SOLR-4795: Sub shard leader should not accept any updates from parent after
- it goes active (shalin)
- * SOLR-4798: shard splitting does not respect the router for the collection
- when executing the index split. One effect of this is that documents
- may be placed in the wrong shard when the default compositeId router
- is used in conjunction with IDs containing "!". (yonik)
- * SOLR-4797: Shard splitting creates sub shards which have the wrong hash
- range in cluster state. This happens when numShards is not a power of two
- and router is compositeId. (shalin)
- * SOLR-4806: Shard splitting does not abort if WaitForState times out (shalin)
- * SOLR-4807: The zkcli script now works with log4j. The zkcli.bat script
- was broken on Windows in 4.3.0, now it works. (Shawn Heisey)
- * SOLR-4813: Fix SynonymFilterFactory to allow init parameters for
- tokenizer factory used when parsing synonyms file. (Shingo Sasaki, hossman)
- * SOLR-4829: Fix transaction log leaks (a failure to clean up some old logs)
- on a shard leader, or when unexpected exceptions are thrown during log
- recovery. (Steven Bower, Mark Miller, yonik)
- * SOLR-4751: Fix replication problem of files in sub directory of conf directory.
- (Minoru Osuka via Koji)
- * SOLR-4741: Deleting a collection should set DELETE_DATA_DIR to true.
- (Mark Miller)
- * SOLR-4752: There are some minor bugs in the Collections API parameter
- validation. (Mark Miller)
- * SOLR-4563: RSS DIH-example not working (janhoy)
- * SOLR-4796: zkcli.sh should honor JAVA_HOME (Roman Shaposhnik via Mark Miller)
- * SOLR-4734: Leader election fails with an NPE if there is no UpdateLog.
- (Mark Miller, Alexander Eibner)
- * SOLR-4868: Setting the log level for the log4j root category results in
- adding a new category, the empty string. (Shawn Heisey)
- * SOLR-4855: DistributedUpdateProcessor doesn't check for peer sync requests (shalin)
- * SOLR-4867: Admin UI - setting loglevel on root throws RangeError (steffkes)
- * SOLR-4870: RecentUpdates.update() does not increment numUpdates loop counter
- (Alexey Kudinov via shalin)
- * SOLR-4877, LUCENE-5023: Removed SolrIndexSearcher#getDocSetNC()'s special
- case for handling TermQuery to prevent NullPointerException if reader does
- not have fields. (Bao Yang Yang, Uwe Schindler)
- * SOLR-4881: Fix DocumentAnalysisRequestHandler to correctly use
- EmptyEntityResolver to prevent loading of external entities like
- UpdateRequestHandler does. (Hossman, Uwe Schindler)
- * SOLR-4858: SolrCore reloading was broken when the UpdateLog
- was enabled. (Hossman, Anshum Gupta, Alexey Serba, Mark Miller, yonik)
- * SOLR-4853: Fixed SolrJettyTestBase so it may be reused by end users
- (hossman)
- * SOLR-4744: Update failure on sub shard is not propagated to clients by parent
- shard (Anshum Gupta, yonik, shalin)
- Other Changes
- ----------------------
- * SOLR-4760: Include core name in logs when loading schema.
- (Shawn Heisey)
- ================== 4.3.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.3
- Carrot2 3.6.2
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Upgrading from Solr 4.2.0
- ----------------------
- * In the schema REST API, the output path for copyFields and dynamicFields
- has been changed from all lowercase "copyfields" and "dynamicfields" to
- camelCase "copyFields" and "dynamicFields", respectively, to align with all
- other schema REST API outputs, which use camelCase. The URL format remains
- the same: all resource names are lowercase. See SOLR-4623 for details.
- * Slf4j/logging jars are no longer included in the Solr webapp. All logging
- jars are now in example/lib/ext. Changing logging impls is now as easy as
- updating the jars in this folder with those necessary for the logging impl
- you would like. If you are using another webapp container, these jars will
- need to go in the corresponding location for that container.
- In conjunction, the dist-excl-slf4j and dist-war-excl-slf4 build targets
- have been removed since they are redundant. See the Slf4j documentation,
- SOLR-3706, and SOLR-4651 for more details.
- * The hardcoded SolrCloud defaults for 'hostContext="solr"' and
- 'hostPort="8983"' have been deprecated and will be removed in Solr 5.0.
- Existing solr.xml files that do not have these options explicitly specified
- should be updated accordingly. See SOLR-4622 for more details.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-4648 PreAnalyzedUpdateProcessorFactory allows using the functionality
- of PreAnalyzedField with other field types. See javadoc for details and
- examples. (Andrzej Bialecki)
- * SOLR-4623: Provide REST API read access to all elements of the live schema.
- Add a REST API request to return the entire live schema, in JSON, XML, and
- schema.xml formats. Move REST API methods from package org.apache.solr.rest
- to org.apache.solr.rest.schema, and rename base functionality REST API
- classes to remove the current schema focus, to prepare for other non-schema
- REST APIs. Change output path for copyFields and dynamicFields from
- "copyfields" and "dynamicfields" (all lowercase) to "copyFields" and
- "dynamicFields", respectively, to align with all other REST API outputs, which
- use camelCase.
- (Steve Rowe)
- * SOLR-4658: In preparation for REST API requests that can modify the schema,
- a "managed schema" is introduced.
- Add '<schemaFactory class="ManagedSchemaFactory" mutable="true"/>' to solrconfig.xml
- in order to use it, and to enable schema modifications via REST API requests.
- (Steve Rowe, Robert Muir)
- * SOLR-4656: Added two new highlight parameters, hl.maxMultiValuedToMatch and
- hl.maxMultiValuedToExamine. maxMultiValuedToMatch stops looking for snippets after
- finding the specified number of matches, no matter how far into the multivalued field
- you've gone. maxMultiValuedToExamine stops looking for matches after the specified
- number of multiValued entries have been examined. If both are specified, the limit
- hit first stops the loop. Also this patch cuts down on the copying of the document
- entries during highlighting. These optimizations are probably unnoticeable unless
- there are a large number of entries in the multiValued field. Conspicuously, this will
- prevent the "best" match from being found if it appears later in the MV list than the
- cutoff specified by either of these params. (Erick Erickson)
- * SOLR-4675: Improve PostingsSolrHighlighter to support per-field/query-time overrides
- and add additional configuration parameters. See the javadocs for more details and
- examples. (Robert Muir)
- * SOLR-3755: A new collections api to add additional shards dynamically by splitting
- existing shards. (yonik, Anshum Gupta, shalin)
- * SOLR-4530: DIH: Provide configuration to use Tika's IdentityHtmlMapper
- (Alexandre Rafalovitch via shalin)
- * SOLR-4662: Discover SolrCores by directory structure rather than defining them
- in solr.xml. Also, change the format of solr.xml to be closer to that of solrconfig.xml.
- This version of Solr will ship the example in the old style, but you can manually
- try the new style. Solr 4.4 will ship with the new style, and Solr 5.0 will remove
- support for the old style. (Erick Erickson, Mark Miller)
- Additional Work:
- - SOLR-4347: Ensure that newly-created cores via Admin handler are persisted in solr.xml
- (Erick Erickson)
- - SOLR-1905: Cores created by the admin request handler should be persisted to solr.xml.
- Also fixed a problem whereby properties like solr.solr.datadir would be persisted
- to solr.xml. Also, cores that didn't happen to be loaded were not persisted.
- (Erick Erickson)
- * SOLR-4717/SOLR-1351: SimpleFacets now work with localParams allowing faceting on the
- same field multiple ways (ryan, Uri Boness)
- * SOLR-4671: CSVResponseWriter now supports pseudo fields. (ryan, nihed mbarek)
- * SOLR-4358: HttpSolrServer sends the stream name and exposes 'useMultiPartPost'
- (Karl Wright via ryan)
- Bug Fixes
- ----------------------
- * SOLR-4543: setting shardHandlerFactory in solr.xml/solr.properties does not work.
- (Ryan Ernst, Robert Muir via Erick Erickson)
- * SOLR-4634: Fix scripting engine tests to work with Java 8's "Nashorn" Javascript
- implementation. (Uwe Schindler)
- * SOLR-4636: If opening a reader fails for some reason when opening a SolrIndexSearcher,
- a Directory can be left unreleased. (Mark Miller)
- * SOLR-4405: Admin UI - admin-extra files are not rendered into the core-menu (steffkes)
- * SOLR-3956: Fixed group.facet=true to work with negative facet.limit
- (Chris van der Merwe, hossman)
- * SOLR-4650: copyField doesn't work with source globs that don't match any
- explicit or dynamic fields. This regression was introduced in Solr 4.2.
- (Daniel Collins, Steve Rowe)
- * SOLR-4641: Schema now throws exception on illegal field parameters. (Robert Muir)
- * SOLR-3758: Fixed SpellCheckComponent to work consistently with distributed grouping
- (James Dyer)
- * SOLR-4652: Fix broken behavior with shared libraries in resource loader for
- solr.xml plugins. (Ryan Ernst, Robert Muir, Uwe Schindler)
- * SOLR-4664: ZkStateReader should update aliases on construction.
- (Mark Miller, Elodie Sannier)
- * SOLR-4682: CoreAdminRequest.mergeIndexes can not merge multiple cores or indexDirs.
- (Jason.D.Cao via shalin)
- * SOLR-4581: When faceting on numeric fields in Solr 4.2, negative values (constraints)
- were sorted incorrectly. (Alexander Buhr, shalin, yonik)
- * SOLR-4699: The System admin handler should not assume a file system based data directory
- location. (Mark Miller)
- * SOLR-4695: Fix core admin SPLIT action to be useful with non-cloud setups (shalin)
- * SOLR-4680: Correct example spellcheck configuration's queryAnalyzerFieldType and
- use "text" field instead of narrower "name" field (ehatcher, Mark Bennett)
- * SOLR-4702: Fix example /browse "Did you mean?" suggestion feature. (ehatcher, Mark Bennett)
- * SOLR-4710: You cannot delete a collection fully from ZooKeeper unless all nodes are up and
- functioning correctly. (Mark Miller)
- * SOLR-4487: SolrExceptions thrown by HttpSolrServer will now contain the
- proper HTTP status code returned by the remote server, even if that status
- code is not something Solr itself returned -- eg: from the Servlet Container,
- or an intermediate HTTP Proxy (hossman)
- * SOLR-4661: Admin UI Replication details now correctly displays the current
- replicable generation/version of the master. (hossman)
- * SOLR-4716,SOLR-4584: SolrCloud request proxying does not work on Tomcat and
- perhaps other non Jetty containers. (Po Rui, Yago Riveiro via Mark Miller)
- * SOLR-4746: Distributed grouping used a NamedList instead of a SimpleOrderedMap
- for the top level group commands, causing output formatting differences
- compared to non-distributed grouping. (yonik)
- * SOLR-4705: Fixed bug causing NPE when querying a single replica in SolrCloud
- using the shards param (Raintung Li, hossman)
- * SOLR-4729: LukeRequestHandler: Using a dynamic copyField source that is
- not also a dynamic field triggers error message 'undefined field: "(glob)"'.
- (Adam Hahn, hossman, Steve Rowe)
- Optimizations
- ----------------------
- Other Changes
- ----------------------
- * SOLR-4653: Solr configuration should log inaccessible/ non-existent relative paths in lib
- dir=... (Dawid Weiss)
- * SOLR-4317: SolrTestCaseJ4: Can't avoid "collection1" convention (Tricia Jenkins, via Erick Erickson)
- * SOLR-4571: SolrZkClient#setData should return Stat object. (Mark Miller)
- * SOLR-4603: CachingDirectoryFactory should use an IdentityHashMap for
- byDirectoryCache. (Mark Miller)
- * SOLR-4544: Refactor HttpShardHandlerFactory so load-balancing logic can be customized.
- (Ryan Ernst via Robert Muir)
- * SOLR-4607: Use noggit 0.5 release jar rather than a forked copy. (Yonik Seeley, Robert Muir)
- * SOLR-3706: Ship setup to log with log4j. (ryan, Mark Miller)
- * SOLR-4651: Remove dist-excl-slf4j build target. (Shawn Heisey)
- * SOLR-4622: The hardcoded SolrCloud defaults for 'hostContext="solr"' and
- 'hostPort="8983"' have been deprecated and will be removed in Solr 5.0.
- Existing solr.xml files that do not have these options explicitly specified
- should be updated accordingly. (hossman)
- * SOLR-4672: Requests attempting to use SolrCores which had init failures
- (that would be reported by CoreAdmin STATUS requests) now result in 500
- error responses with the details about the init failure, instead of 404
- error responses. (hossman)
- * SOLR-4730: Make the wiki link more prominent in the release documentation.
- (Uri Laserson via Robert Muir)
- ================== 4.2.1 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.3
- Carrot2 3.6.2
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Detailed Change List
- ----------------------
- Bug Fixes
- ----------------------
- * SOLR-4567: copyField source glob matching explicit field(s) stopped working
- in Solr 4.2. (Alexandre Rafalovitch, Steve Rowe)
- * SOLR-4475: Fix various places that still assume File based paths even when
- not using a file based DirectoryFactory. (Mark Miller)
- * SOLR-4551: CachingDirectoryFactory needs to create CacheEntry's with the
- fullpath not path. (Mark Miller)
- * SOLR-4555: When forceNew is used with CachingDirectoryFactory#get, the old
- CacheValue should give up its path as it will be used by a new Directory
- instance. (Mark Miller)
- * SOLR-4578: CoreAdminHandler#handleCreateAction gets a SolrCore and does not
- close it in SolrCloud mode when a core with the same name already exists.
- (Mark Miller)
- * SOLR-4574: The Collections API will silently return success on an unknown
- ACTION parameter. (Mark Miller)
- * SOLR-4576: Collections API validation errors should cause an exception on
- clients and otherwise act as validation errors with the Core Admin API.
- (Mark Miller)
- * SOLR-4577: The collections API should return responses (success or failure)
- for each node it attempts to work with. (Mark Miller)
- * SOLR-4568: The lastPublished state check before becoming a leader is not
- working correctly. (Mark Miller)
- * SOLR-4570: Even if an explicit shard id is used, ZkController#preRegister
- should still wait to see the shard id in its current ClusterState.
- (Mark Miller)
- * SOLR-4585: The Collections API validates numShards with < 0 but should use
- <= 0. (Mark Miller)
- * SOLR-4592: DefaultSolrCoreState#doRecovery needs to check the CoreContainer
- shutdown flag inside the recoveryLock sync block. (Mark Miller)
- * SOLR-4595: CachingDirectoryFactory#close can throw a concurrent
- modification exception. (Mark Miller)
- * SOLR-4573: Accessing Admin UI files in SolrCloud mode logs warnings.
- (Mark Miller, Phil John)
- * SOLR-4594: StandardDirectoryFactory#remove accesses byDirectoryCache
- without a lock. (Mark Miller)
- * SOLR-4597: CachingDirectoryFactory#remove should not attempt to empty/remove
- the index right away but flag for removal after close. (Mark Miller)
- * SOLR-4598: The Core Admin unload command's option 'deleteDataDir', should use
- the DirectoryFactory API to remove the data dir. (Mark Miller)
- * SOLR-4599: CachingDirectoryFactory calls close(Directory) on forceNew if the
- Directory has a refCnt of 0, but it should call closeDirectory(CacheValue).
- (Mark Miller)
- * SOLR-4602: ZkController#unregister should cancel its election participation
- before asking the Overseer to delete the SolrCore information. (Mark Miller)
- * SOLR-4601: A Collection that is only partially created and then deleted will
- leave pre allocated shard information in ZooKeeper. (Mark Miller)
- * SOLR-4604: UpdateLog#init is over called on SolrCore#reload. (Mark Miller)
- * SOLR-4605: Rollback does not work correctly. (Mark S, Mark Miller)
- * SOLR-4609: The Collections API should only send the reload command to ACTIVE
- cores. (Mark Miller)
- * SOLR-4297: Atomic update request containing null=true sets all subsequent
- fields to null (Ben Pennell, Rob, shalin)
- * SOLR-4371: Admin UI - Analysis Screen shows empty result (steffkes)
- * SOLR-4318: NPE encountered with querying with wildcards on a field that uses
- the DefaultAnalyzer (i.e. no analysis chain defined). (Erick Erickson)
- * SOLR-4361: DataImportHandler would throw UnsupportedOperationException if
- handler-level parameters were specified containing periods in the name
- (James Dyer)
- * SOLR-4538: Date Math expressions were being truncated to 32 characters
- when used in field:value queries in the lucene QParser. (hossman, yonik)
- * SOLR-4617: SolrCore#reload needs to pass the deletion policy to the next
- SolrCore through its constructor rather than setting a field after.
- (Mark Miller)
- * SOLR-4589: Fixed CPU spikes and poor performance in lazy field loading
- of multivalued fields. (hossman)
- * SOLR-4608: Update Log replay and PeerSync replay should use the default
- processor chain to update the index. (Ludovic Boutros, yonik)
- * SOLR-4625: The solr (lucene syntax) query parser lost top-level boost
- values and top-level phrase slops on queries produced by nested
- sub-parsers. (yonik)
- * SOLR-4624: CachingDirectoryFactory does not need to support forceNew any
- longer and it appears to be causing a missing close directory bug. forceNew
- is no longer respected and will be removed in 4.3. (Mark Miller)
- * SOLR-3819: Grouped faceting (group.facet=true) did not respect filter
- exclusions. (Petter Remen, yonik)
- * SOLR-4637: Replication can sometimes wait until shutdown or core unload until
- removing some tmp directories. (Mark Miller)
- * SOLR-4638: DefaultSolrCoreState#getIndexWriter(null) is a way to avoid
- creating the IndexWriter earlier than necessary, but it's not
- implemented quite right. (Mark Miller)
- * SOLR-4640: CachingDirectoryFactory can fail to close directories in some race
- conditions. (Mark Miller)
- * SOLR-4642: QueryResultKey is not calculating the correct hashCode for filters.
- (Joel Bernstein via Mark Miller)
- Optimizations
- ----------------------
- * SOLR-4569: waitForReplicasToComeUp should bail right away if it doesn't see the
- expected slice in the clusterstate rather than waiting. (Mark Miller)
- * SOLR-4311: Admin UI - Optimize Caching Behaviour (steffkes)
- Other Changes
- ----------------------
- * SOLR-4537: Clean up schema information REST API. (Steve Rowe)
- * SOLR-4596: DistributedQueue should ensure its full path exists in the constructor.
- (Mark Miller)
- ================== 4.2.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.3
- Carrot2 3.6.2
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Upgrading from Solr 4.1.0
- ----------------------
- (No upgrade instructions yet)
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-4043: Add ability to get success/failure responses from Collections API.
- (Raintung Li, Mark Miller)
- * SOLR-2827: RegexpBoost Update Processor (janhoy)
- * SOLR-4370: Allow configuring commitWithin to do hard commits.
- (Mark Miller, Senthuran Sivananthan)
- * SOLR-4451: SolrJ, and SolrCloud internals, now use SystemDefaultHttpClient
- under the covers -- allowing many HTTP connection related properties to be
- controlled via 'standard' java system properties. (hossman)
- * SOLR-3855, SOLR-4490: Doc values support. (Adrien Grand, Robert Muir)
- * SOLR-4417: Reopen the IndexWriter on SolrCore reload. (Mark Miller)
- * SOLR-4477: Add support for queries (match-only) against docvalues fields.
- (Robert Muir)
- * SOLR-4488: Return slave replication details for a master if the master has
- also acted like a slave. (Mark Miller)
- * SOLR-4498: Add list command to ZkCLI that prints out the contents of
- ZooKeeper. (Roman Shaposhnik via Mark Miller)
- * SOLR-4481: SwitchQParserPlugin registered by default as 'switch' using
- syntax: {!switch case=XXX case.foo=YYY case.bar=ZZZ default=QQQ}foo
- (hossman)
- * SOLR-4078: Allow custom naming of SolrCloud nodes so that a new host:port
- combination can take over for a previous shard. (Mark Miller)
- * SOLR-4210: Requests to a Collection that does not exist on the receiving node
- should be proxied to a suitable node. (Mark Miller, Po Rui, yonik)
- * SOLR-1365: New SweetSpotSimilarityFactory allows customizable TF/IDF based
- Similarity when you know the optimal "Sweet Spot" of values for the field
- length and TF scoring factors. (hossman)
- * SOLR-4138: CurrencyField fields can now be used in a ValueSources to
- get the "raw" value (using the default number of fractional digits) in
- the default currency of the field type. There is also a new
- currency(field,[CODE]) function for generating a ValueSource of the
- "natural" value, converted to an optionally specified currency to
- override the default for the field type.
- (hossman)
- * SOLR-4503: Add REST API methods, via Restlet integration, for reading schema
- elements, at /schema/fields/, /schema/dynamicfields/, /schema/fieldtypes/,
- and /schema/copyfields/. (Steve Rowe)
- Bug Fixes
- ----------------------
- * SOLR-2850: Do not refine facets when minCount == 1
- (Matt Smith, lundgren via Adrien Grand)
- * SOLR-4309: /browse: Improve JQuery autosuggest behavior (janhoy)
- * SOLR-4330: group.sort is ignored when using group.truncate and ex/tag
- local params together (koji)
- * SOLR-4321: Collections API will sometimes use a node more than once, even
- when more unused nodes are available.
- (Eric Falcao, Brett Hoerner, Mark Miller)
- * SOLR-4345 : Solr Admin UI doesn't work in IE 10 (steffkes)
- * SOLR-4349 : Admin UI - Query Interface does not work in IE
- (steffkes)
- * SOLR-4359: The RecentUpdates#update method should treat a problem reading the
- next record the same as a problem parsing the record - log the exception and
- break. (Mark Miller)
- * SOLR-4225: Term info page under schema browser shows incorrect count of terms
- (steffkes)
- * SOLR-3926: Solr should support better way of finding active sorts (Eirik Lygre via
- Erick Erickson)
- * SOLR-4342: Fix DataImportHandler stats to be a proper Map (hossman)
- * SOLR-3967: langid.enforceSchema option checks source field instead of target field (janhoy)
- * SOLR-4380: Replicate after startup option would not replicate until the
- IndexWriter was lazily opened. (Mark Miller, Gregg Donovan)
- * SOLR-4400: Deadlock can occur in a rare race between committing and
- closing a SolrIndexWriter. (Erick Erickson, Mark Miller)
- * SOLR-3655: A restarted node can briefly appear live and active before it really
- is in some cases. (Mark Miller)
- * SOLR-4426: NRTCachingDirectoryFactory does not initialize maxCachedMB and maxMergeSizeMB
- if <directoryFactory> is not present in solrconfig.xml (Jack Krupansky via shalin)
- * SOLR-4463: Fix SolrCoreState reference counting. (Mark Miller)
- * SOLR-4459: The Replication 'index move' rather than copy optimization doesn't
- kick in when using NRTCachingDirectory or the rate limiting feature.
- (Mark Miller)
- * SOLR-4421,SOLR-4165: On CoreContainer shutdown, all SolrCores should publish their
- state as DOWN. (Mark Miller, Markus Jelsma)
- * SOLR-4467: Ephemeral directory implementations may not recover correctly
- because the code to clear the tlog files on startup is off. (Mark Miller)
- * SOLR-4413: Fix SolrCore#getIndexDir() to return the current index directory.
- (Gregg Donovan, Mark Miller)
- * SOLR-4469: A new IndexWriter must be opened on SolrCore reload when the index
- directory has changed and the previous SolrCore's state should not be
- propagated. (Mark Miller, Gregg Donovan)
- * SOLR-4471: Replication occurs even when a slave is already up to date.
- (Mark Miller, Andre Charton)
- * SOLR-4484: ReplicationHandler#loadReplicationProperties still uses Files
- rather than the Directory to try and read the replication properties files.
- (Mark Miller)
- * SOLR-4352: /browse pagination now supports and preserves sort context
- (Eric Spiegelberg, Erik Hatcher)
- * LUCENE-4796, SOLR-4373: Fix concurrency issue in NamedSPILoader and
- AnalysisSPILoader when doing concurrent core loads in multicore
- Solr configs. (Uwe Schindler, Hossman)
- * SOLR-4504: Fixed CurrencyField range queries to correctly exclude
- documents w/o values (hossman)
- * SOLR-4480: A trailing + or - caused the edismax parser to throw
- an exception. (Fiona Tay, Jan Høydahl, yonik)
- * SOLR-4507: The Cloud tab does not show up in the Admin UI if you
- set zkHost in solr.xml. (Alfonso Presa, Mark Miller)
- * SOLR-4505: Possible deadlock around SolrCoreState update lock.
- (Erick Erickson, Mark Miller)
- * SOLR-4511: When a new index is replicated into place, we need
- to update the most recent replicatable index point without
- doing a commit. This is important for repeater use cases, as
- well as when nodes may switch master/slave roles.
- (Mark Miller, Raúl Grande)
- * SOLR-4515: CurrencyField's OpenExchangeRatesOrgProvider now requires
- a ratesFileLocation init param, since the previous global default
- no longer works (hossman)
- * SOLR-4518: Improved CurrencyField error messages when attempting to
- use a Currency that is not supported by the current JVM. (hossman)
- * SOLR-3798: Fix copyField implementation in IndexSchema to handle
- dynamic field references that aren't string-equal to the name of
- the referenced dynamic field. (Steve Rowe)
- * SOLR-4497: Collection Aliasing. (Mark Miller)
- Optimizations
- ----------------------
- * SOLR-4339: Admin UI - Display Field-Flags on Schema-Browser
- (steffkes)
- * SOLR-4340: Admin UI - Analysis's Button Spinner goes wild
- (steffkes)
- * SOLR-4341: Admin UI - Plugins/Stats Page contains loooong
- Values which result in horizontal Scrollbar (steffkes)
- * SOLR-3915: Color Legend for Cloud UI (steffkes)
- * SOLR-4306: Utilize indexInfo=false when gathering core names in UI
- (steffkes)
- * SOLR-4284: Admin UI - make core list scrollable separate from the rest of
- the UI (steffkes)
- * SOLR-4364: Admin UI - Locale based number formatting (steffkes)
- * SOLR-4521: Stop using the 'force' option for recovery replication. This
- will keep some less common unnecessary replications from happening.
- (Mark Miller, Simon Scofield)
- * SOLR-4529: Improve Admin UI Dashboard legibility (Felix Buenemann via
- steffkes)
- * SOLR-4526: Admin UI depends on optional system info (Felix Buenemann via
- steffkes)
- Other Changes
- ----------------------
- * SOLR-4259: Carrot2 dependency should be declared on the mini version, not the core.
- (Dawid Weiss).
- * SOLR-4348: Make the lock type configurable by system property by default.
- (Mark Miller)
- * SOLR-4353: Renamed example jetty context file to reduce confusion (hossman)
- * SOLR-4384: Make post.jar report timing information (Upayavira via janhoy)
- * SOLR-4415: Add 'state' to shards (default to 'active') and read/write them to
- ZooKeeper (Anshum Gupta via shalin)
- * SOLR-4394: Tests and example configs demonstrating SSL with both server
- and client certs (hossman)
- * SOLR-3060: SurroundQParserPlugin highlighting tests
- (Ahmet Arslan via hossman)
- * SOLR-2470: Added more tests for VelocityResponseWriter
- * SOLR-4471: Improve and clean up TestReplicationHandler.
- (Amit Nithian via Mark Miller)
- * SOLR-3843: Include lucene codecs jar and enable per-field postings and docvalues
- support in the schema.xml (Robert Muir, Steve Rowe)
- * SOLR-4511: Add new test for 'repeater' replication node. (Mark Miller)
- * SOLR-4458: Sort directions (asc, desc) are now case insensitive
- (Shawn Heisey via hossman)
- * SOLR-2996: A bare * without a field specification is treated as *:*
- by the lucene and edismax query parsers.
- (hossman, Jan Høydahl, Alan Woodward, yonik)
- * SOLR-4416: Upgrade to Tika 1.3. (Markus Jelsma via Mark Miller)
- * SOLR-4200: Reduce INFO level logging from CachingDirectoryFactory
- (Shawn Heisey via hossman)
- ================== 4.1.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.2
- Carrot2 3.6.2
- Velocity 1.7 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.4.5
- Upgrading from Solr 4.0.0
- ----------------------
- Custom java parsing plugins need to migrate from throwing the internal
- ParseException to throwing SyntaxError.
- BaseDistributedSearchTestCase now randomizes the servlet context it uses when
- creating Jetty instances. Subclasses that assume a hard coded context of
- "/solr" should either be fixed to use the "String context" variable, or should
- take advantage of the new BaseDistributedSearchTestCase(String) constructor
- to explicitly specify a fixed servlet context path. See SOLR-4136 for details.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-2255: Enhanced pivot faceting to use local-params in the same way that
- regular field value faceting can. This means support for excluding a filter
- query, using a different output key, and specifying 'threads' to do
- facet.method=fcs concurrently. PivotFacetHelper now extends SimpleFacet and
- the getFacetImplementation() extension hook was removed. (dsmiley)
- * SOLR-3897: A highlighter parameter "hl.preserveMulti" to return all of the
- values of a multiValued field in their original order when highlighting.
- (Joel Bernstein via yonik)
- * SOLR-3929: Support configuring IndexWriter max thread count in solrconfig.
- (phunt via Mark Miller)
- * SOLR-3906: Add support for AnalyzingSuggester (LUCENE-3842), where the
- underlying analyzed form used for suggestions is separate from the returned
- text. (Robert Muir)
- * SOLR-3985: ExternalFileField caches can be reloaded on firstSearcher/
- newSearcher events using the ExternalFileFieldReloader (Alan Woodward)
- * SOLR-3911: Make Directory and DirectoryFactory first class so that the majority
- of Solr's features work with any custom implementations. (Mark Miller)
- Additional Work:
- - SOLR-4032: Files larger than an internal buffer size fail to replicate.
- (Mark Miller, Markus Jelsma)
- - SOLR-4033: Consistently use the solrconfig.xml lockType everywhere.
- (Mark Miller, Markus Jelsma)
- - SOLR-4144: Replication using too much RAM. (yonik, Markus Jelsma)
- - SOLR-4187: NPE on Directory release (Mark Miller, Markus Jelsma)
- * SOLR-4051: Add <propertyWriter /> element to DIH's data-config.xml file,
- allowing the user to specify the location, filename and Locale for
- the "data-config.properties" file. Alternatively, users can specify their
- own property writer implementation for greater control. This new configuration
- element is optional, and defaults mimic prior behavior. The one exception is
- that the "root" locale is default. Previously it was the machine's default locale.
- (James Dyer)
- * SOLR-4084: Add FuzzyLookupFactory, which is like AnalyzingSuggester except that
- it can tolerate typos in the input. (Areek Zillur via Robert Muir)
- * SOLR-4088: New and improved auto host detection strategy for SolrCloud.
- (Raintung Li via Mark Miller)
- * SOLR-3970: SystemInfoHandler now exposes more details about the
- JRE/VM/Java version in use. (hossman)
- * SOLR-4101: Add support for storing term offsets in the index via a
- 'storeOffsetsWithPositions' flag on field definitions in the schema.
- (Tom Winch, Alan Woodward)
- * SOLR-4093: Solr QParsers may now be directly invoked in the lucene
- query syntax without the _query_ magic field hack.
- Example: foo AND {!term f=myfield v=$qq}
- (yonik)
- * SOLR-4087: Add MAX_DOC_FREQ option to MoreLikeThis.
- (Andrew Janowczyk via Mark Miller)
- * SOLR-4114: Allow creating more than one shard per instance with the
- Collection API. (Per Steffensen, Mark Miller)
- * SOLR-3531: Allowing configuring maxMergeSizeMB and maxCachedMB when
- using NRTCachingDirectoryFactory. (Andy Laird via Mark Miller)
- * SOLR-4118: Fix replicationFactor to align with industry usage.
- replicationFactor now means the total number of copies
- of a document stored in the collection (or the total number of
- physical indexes for a single logical slice of the collection).
- For example if replicationFactor=3 then for a given shard there
- will be a total of 3 replicas (one of which will normally be
- designated as the leader.) (yonik)
- * SOLR-4124: You should be able to set the update log directory with the
- CoreAdmin API the same way as the data directory. (Mark Miller)
- * SOLR-4028: When using ZK chroot, it would be nice if Solr would create the
- initial path when it doesn't exist. (Tomás Fernández Löbbe via Mark Miller)
- * SOLR-3948: Calculate/display deleted documents in admin interface.
- (Shawn Heisey via Mark Miller)
- * SOLR-4030: Allow rate limiting Directory IO based on the IO context.
- (Mark Miller, Radim Kolar)
- * SOLR-4166: LBHttpSolrServer ignores ResponseParser passed in constructor.
- (Steve Molloy via Mark Miller)
- * SOLR-4140: Allow access to the collections API through CloudSolrServer
- without referencing an existing collection. (Per Steffensen via Mark Miller)
- * SOLR-788: Distributed search support for MLT.
- (Matthew Woytowitz, Mike Anderson, Jamie Johnson, Mark Miller)
- * SOLR-4120: Collection API: Support for specifying a list of Solr addresses to
- spread a new collection across. (Per Steffensen via Mark Miller)
- * SOLR-4110: Configurable Content-Type headers for PHPResponseWriters and
- PHPSerializedResponseWriter. (Dominik Siebel via Mark Miller)
- * SOLR-1028: The ability to specify "transient" and "loadOnStartup" as a new properties of
- <core> tags in solr.xml. Can specify "transientCacheSize" in the <cores> tag. Together
- these allow cores to be loaded only when needed and only transientCacheSize transient
- cores will be loaded at a time, the rest aged out on an LRU basis.
- * SOLR-4246: When update.distrib is set to skip update processors before
- the distributed update processor, always include the log update processor
- so forwarded updates will still be logged. (yonik)
- * SOLR-4230: The new Solr 4 spatial fields now work with the {!geofilt} and
- {!bbox} query parsers. The score local-param works too. (David Smiley)
- * SOLR-1972: Add extra statistics to RequestHandlers - 5 & 15-minute reqs/sec
- rolling averages; median, 75th, 95th, 99th, 99.9th percentile request times
- (Alan Woodward, Shawn Heisey, Adrien Grand, Uwe Schindler)
- * SOLR-4271: Add support for PostingsHighlighter. (Robert Muir)
- * SOLR-4255: The new Solr 4 spatial fields now have a 'filter' boolean local-param
- that can be set to false to not filter. It's useful when there is already a spatial
- filter query but you also need to sort or boost by distance. (David Smiley)
- * SOLR-4265, SOLR-4283: Solr now parses request parameters (in URL or sent with POST
- using content-type application/x-www-form-urlencoded) in its dispatcher code. It no
- longer relies on special configuration settings in Tomcat or other web containers
- to enable UTF-8 encoding, which is mandatory for correct Solr behaviour. Query
- strings passed in via the URL need to be properly-%-escaped, UTF-8 encoded
- bytes, otherwise Solr refuses to handle the request. The maximum length of
- x-www-form-urlencoded POST parameters can now be configured through the
- requestDispatcher/requestParsers/@formdataUploadLimitInKB setting in
- solrconfig.xml (defaults to 2 MiB). Solr now works out of the box with
- e.g. Tomcat, JBoss,... (Uwe Schindler, Dawid Weiss, Alex Rocher)
- * SOLR-2201: DIH's "formatDate" function now supports a timezone as an optional
- fourth parameter (James Dyer, Mark Waddle)
- * SOLR-4302: New parameter 'indexInfo' (defaults to true) in CoreAdmin STATUS
- command can be used to omit index specific information (Shahar Davidson via shalin)
- * SOLR-2592: Collection specific document routing. The "compositeId"
- router is the default for collections with hash based routing (i.e. when
- numShards=N is specified on collection creation). Documents with ids sharing
- the same domain (prefix) will be routed to the same shard, allowing for
- efficient querying.
- Example:
- The following two documents will be indexed to the same shard
- since they share the same domain "customerB!".
- <code>
- {"id" : "customerB!doc1" [...] }
- {"id" : "customerB!doc2" [...] }
- </code>
- At query time, one can specify a "shard.keys" parameter that lists what
- shards the query should cover.
- http://.../query?q=my_query&shard.keys=customerB!
- Collections that do not specify numShards at collection creation time
- use custom sharding and default to the "implicit" router. Document updates
- received by a shard will be indexed to that shard, unless a "_shard_" parameter
- or document field names a different shard.
- (Michael Garski, Dan Rosher, yonik)
- Optimizations
- ----------------------
- * SOLR-3788: Admin Cores UI should redirect to newly created core details
- (steffkes)
- * SOLR-3895: XML and XSLT UpdateRequestHandler should not try to resolve
- external entities. This improves speed of loading e.g. XSL-transformed
- XHTML documents. (Martin Herfurt, uschindler, hossman)
- * SOLR-3614: Fix XML parsing in XPathEntityProcessor to correctly expand
- named entities, but ignore external entities. (uschindler, hossman)
- * SOLR-3734: Improve Schema-Browser Handling for CopyField using
- dynamicField's (steffkes)
- * SOLR-3941: The "commitOnLeader" part of distributed recovery can use
- openSearcher=false. (Tomás Fernández Löbbe via Mark Miller)
- * SOLR-4063: Allow CoreContainer to load multiple SolrCores in parallel rather
- than just serially. (Mark Miller)
- * SOLR-4199: When doing zk retries due to connection loss, rather than just
- retrying for 2 minutes, retry in proportion to the session timeout.
- (Mark Miller)
- * SOLR-4262: Replication Icon on Dashboard does not reflect Master-/Slave-
- State (steffkes)
- * SOLR-4264: Missing Error-Screen on UI's Cloud-Page (steffkes)
- * SOLR-4261: Percentage Infos on Dashboard have a fixed width (steffkes)
- * SOLR-3851: create a new core/delete an existing core should also update
- the main/left list of cores on the admin UI (steffkes)
- * SOLR-3840: XML query response display is unreadable in Solr Admin Query UI
- (steffkes)
- * SOLR-3982: Admin UI: Various Dataimport Improvements (steffkes)
- * SOLR-4296: Admin UI: Improve Dataimport Auto-Refresh (steffkes)
- * SOLR-3458: Allow multiple Items to stay open on Plugins-Page (steffkes)
- Bug Fixes
- ----------------------
- * SOLR-4288: Improve logging for FileDataSource (basePath, relative
- resources). (Dawid Weiss)
- * SOLR-4007: Morfologik dictionaries not available in Solr field type
- due to class loader lookup problems. (Lance Norskog, Dawid Weiss)
- * SOLR-3560: Handle different types of Exception Messages for Logging UI
- (steffkes)
- * SOLR-3637: Commit Status at Core-Admin UI is always false (steffkes)
- * SOLR-3917: Partial State on Schema-Browser UI is not defined for Dynamic
- Fields & Types (steffkes)
- * SOLR-3939: Consider a sync attempt from leader to replica that fails due
- to 404 a success. (Mark Miller, Joel Bernstein)
- * SOLR-3940: Rejoining the leader election incorrectly triggers the code path
- for a fresh cluster start rather than fail over. (Mark Miller)
- * SOLR-3961: Fixed error using LimitTokenCountFilterFactory
- (Jack Krupansky, hossman)
- * SOLR-3933: Distributed commits are not guaranteed to be ordered within a
- request. (Mark Miller)
- * SOLR-3939: An empty or just replicated index cannot become the leader of a
- shard after a leader goes down. (Joel Bernstein, yonik, Mark Miller)
- * SOLR-3971: A collection that is created with numShards=1 turns into a
- numShards=2 collection after starting up a second core and not specifying
- numShards. (Mark Miller)
- * SOLR-3988: Fixed SolrTestCaseJ4.adoc(SolrInputDocument) to respect
- field and document boosts (hossman)
- * SOLR-3981: Fixed bug that resulted in document boosts being compounded in
- <copyField/> destination fields. (hossman)
- * SOLR-3920: Fix server list caching in CloudSolrServer when using more than one
- collection list with the same instance. (Grzegorz Sobczyk, Mark Miller)
- * SOLR-3938: prepareCommit command omits commitData causing a failure to trigger
- replication to slaves. (yonik)
- * SOLR-3992: QuerySenderListener doesn't populate document cache.
- (Shotaro Kamio, yonik)
- * SOLR-3995: Recovery may never finish on SolrCore shutdown if the last reference to
- a SolrCore is closed by the recovery process. (Mark Miller)
- * SOLR-3998: Atomic update on uniqueKey field itself causes duplicate document.
- (Eric Spencer, yonik)
- * SOLR-4001: In CachingDirectoryFactory#close, if there are still refs for a
- Directory outstanding, we need to wait for them to be released before closing.
- (Mark Miller)
- * SOLR-4005: If CoreContainer fails to register a created core, it should close it.
- (Mark Miller)
- * SOLR-4009: OverseerCollectionProcessor is not resilient to many error conditions
- and can stop running on errors. (Raintung Li, milesli, Mark Miller)
- * SOLR-4019: Log stack traces for 503/Service Unavailable SolrException if not
- thrown by PingRequestHandler. Do not log exceptions if a user tries to view a
- hidden file using ShowFileRequestHandler. (Tomás Fernández Löbbe via James Dyer)
- * SOLR-3589: Edismax parser does not honor mm parameter if analyzer splits a token.
- (Tom Burton-West, Robert Muir)
- * SOLR-4031: Upgrade to Jetty 8.1.7 to fix a bug where in very rare occasions
- the content of two concurrent requests get mixed up. (Per Steffensen, yonik)
- * SOLR-4060: ReplicationHandler can try and do a snappull and open a new IndexWriter
- after shutdown has already occurred, leaving an IndexWriter that is not closed.
- (Mark Miller)
- * SOLR-4055: Fix a thread safety issue with the Collections API that could
- cause actions to be targeted at the wrong SolrCores.
- (Raintung Li, Per Steffensen via Mark Miller)
- * SOLR-3993: If multiple SolrCore's for a shard coexist on a node, on cluster
- restart, leader election would stall until timeout, waiting to see all of
- the replicas come up. (Mark Miller, Alexey Kudinov)
- * SOLR-2045: Databases that require a commit to be issued before closing the
- connection on a non-read-only database leak connections. Also expanded the
- SqlEntityProcessor test to sometimes use Derby as well as HSQLDB (Derby is
- one db affected by this bug). (Fenlor Sebastia, James Dyer)
- * SOLR-4064: When there is an unexpected exception while trying to run the new
- leader process, the SolrCore will not correctly rejoin the election.
- (Po Rui via Mark Miller)
- * SOLR-3989: SolrZkClient constructor dropped exception cause when throwing
- a new RuntimeException. (Colin Bartolome, yonik)
- * SOLR-4036: field aliases in fl should not cause properties of target field
- to be used. (Martin Koch, yonik)
- * SOLR-4003: The SolrZKClient clean method should not try and clear zk paths
- that start with /zookeeper, as this can fail and stop the removal of
- further nodes. (Mark Miller)
- * SOLR-4076: SolrQueryParser should run fuzzy terms through
- MultiTermAwareComponents to ensure that (for example) a fuzzy query of
- foobar~2 is equivalent to FooBar~2 on a field that includes lowercasing.
- (yonik)
- * SOLR-4081: QueryParsing.toString, used during debugQuery=true, did not
- correctly handle ExtendedQueries such as WrappedQuery
- (used when cache=false), spatial queries, and frange queries.
- (Eirik Lygre, yonik)
- * SOLR-3959: Ensure the internal comma separator of poly fields is escaped
- for CSVResponseWriter. (Areek Zillur via Robert Muir)
- * SOLR-4075: A logical shard that has had all of its SolrCores unloaded should
- be removed from the cluster state. (Mark Miller, Gilles Comeau)
- * SOLR-4034: Check if a collection already exists before trying to create a
- new one. (Po Rui, Mark Miller)
- * SOLR-4097: Race can cause NPE in logging line on first cluster state update.
- (Mark Miller)
- * SOLR-4099: Allow the collection api work queue to make forward progress even
- when its watcher is not fired for some reason. (Raintung Li via Mark Miller)
- * SOLR-3960: Fixed a bug where Distributed Grouping ignored PostFilters
- (Nathan Visagan, hossman)
- * SOLR-3842: DIH would not populate multivalued fields if the column name
- derives from a resolved variable (James Dyer)
- * SOLR-4117: Retrieving the size of the index may use the wrong index dir if
- you are replicating.
- (Mark Miller, Markus Jelsma)
- * SOLR-2890: Fixed a bug that prevented omitNorms and omitTermFreqAndPositions
- options from being respected in some <fieldType/> declarations (hossman)
- * SOLR-4159: When we are starting a shard from rest, a potential leader should
- not consider its last published state when deciding if it can be the new
- leader. (Mark Miller)
- * SOLR-4158: When a core is registering in ZooKeeper it may not wait long
- enough to find the leader due to how long the potential leader waits to see
- replicas. (Mark Miller, Alain Rogister)
- * SOLR-4162: ZkCli usage examples are not correct because the zkhost parameter
- is not present and it is mandatory for all commands.
- (Tomás Fernández Löbbe via Mark Miller)
- * SOLR-4071: Validate that name is pass to Collections API create, and behave the
- same way as on startup when collection.configName is not explicitly passed.
- (Po Rui, Mark Miller)
- * SOLR-4127: Added explicit error message if users attempt Atomic document
- updates with either updateLog or DistribUpdateProcessor. (hossman)
- * SOLR-4136: Fix SolrCloud behavior when using "hostContext" containing "_"
- or"/" characters. This fix also makes SolrCloud more accepting of
- hostContext values with leading/trailing slashes. (hossman)
- * SOLR-4168: Ensure we are using the absolute latest index dir when getting
- list of files for replication. (Mark Miller)
- * SOLR-4171: CachingDirectoryFactory should not return any directories after it
- has been closed. (Mark Miller)
- * SOLR-4102: Fix UI javascript error if canonical hostname can not be resolved
- (steffkes via hossman)
- * SOLR-4178: ReplicationHandler should abort any current pulls and wait for
- its executor to stop during core close. (Mark Miller)
- * SOLR-3918: Fixed the 'dist-war-excl-slf4j' ant target to exclude all
- slf4j jars, so that the resulting war is usable as is provided the servlet
- container includes the correct slf4j api and impl jars.
- (Shawn Heisey, hossman)
- * SOLR-4198: OverseerCollectionProcessor should implement ClosableThread.
- (Mark Miller)
- * SOLR-4213: Directories that are not shutdown until DirectoryFactory#close
- do not have close listeners called on them. (Mark Miller)
- * SOLR-4134: Standard (XML) request writer cannot "set" multiple values into
- multivalued field with partial updates. (Luis Cappa Banda, Will Butler, shalin)
- * SOLR-3972: Fix ShowFileRequestHandler to not log a warning in the
- (expected) situation of a file not found. (hossman)
- * SOLR-4133: Cannot "set" field to null with partial updates when using the
- standard RequestWriter. (Will Butler, shalin)
- * SOLR-4223: "maxFormContentSize" in jetty.xml is not picked up by jetty 8
- so set it via solr webapp context file. (shalin)
- * SOLR-4175:SearchComponent chain can't contain two components of the
- same class and use debugQuery. (Tomás Fernández Löbbe via ehatcher)
- * SOLR-4244: When coming back from session expiration we should not wait for
- the leader to see us in the down state if we are the node that must become
- the leader. (Mark Miller)
- * SOLR-4245: When a core is registering with ZooKeeper, the timeout to find the
- leader in the cluster state is 30 seconds rather than leaderVoteWait + extra
- time. (Mark Miller)
- * SOLR-4238: Fix jetty example requestLog config (jm via hossman)
- * SOLR-4251: Fix SynonymFilterFactory when an optional tokenizerFactory is supplied.
- (Chris Bleakley via rmuir)
- * SOLR-4253: Misleading resource loading warning from Carrot2 clustering
- component fixed (Stanisław Osiński)
- * SOLR-4257: PeerSync updates and Log Replay updates should not wait for
- a ZooKeeper connection in order to proceed. (yonik)
- * SOLR-4045: SOLR admin page returns HTTP 404 on core names containing
- a '.' (dot) (steffkes)
- * SOLR-4176: analysis ui: javascript not properly handling URL decoding
- of input (steffkes)
- * SOLR-4079: Long core names break web gui appearance and functionality
- (steffkes)
- * SOLR-4263: Incorrect Link from Schema-Browser to Query From for Top-Terms
- (steffkes)
- * SOLR-3829: Admin UI Logging events broken if schema.xml defines a catch-all
- dynamicField with type ignored (steffkes)
- * SOLR-4275: Fix TrieTokenizer to no longer throw StringIndexOutOfBoundsException
- in admin UI / AnalysisRequestHandler when you enter no number to tokenize.
- (Uwe Schindler)
- * SOLR-4279: Wrong exception message if _version_ field is multivalued (shalin)
- * SOLR-4170: The 'backup' ReplicationHandler command can sometimes use a stale
- index directory rather than the current one. (Mark Miller, Marcin Rzewucki)
- * SOLR-3876: Solr Admin UI is completely dysfunctional on IE 9 (steffkes)
- * SOLR-4112: Fixed DataImportHandler ZKAwarePropertiesWriter implementation so
- import works fine with SolrCloud clusters (Deniz Durmus, James Dyer,
- Erick Erickson, shalin)
- * SOLR-4291: Harden the Overseer work queue thread loop. (Mark Miller)
- * SOLR-3820: Solr Admin Query form is missing some edismax request parameters
- (steffkes)
- * SOLR-4217: post.jar no longer ignores -Dparams when -Durl is used.
- (Alexandre Rafalovitch, ehatcher)
- * SOLR-4303: On replication, if the generation of the master is lower than the
- slave we need to force a full copy of the index. (Mark Miller, Gregg Donovan)
- * SOLR-4266: HttpSolrServer does not release connection properly on exception
- when no response parser is used. (Steve Molloy via Mark Miller)
- * SOLR-2298: Updated JavaDoc for SolrDocument.addField and SolrInputDocument.addField
- to have more information on name and value parameters. (Siva Natarajan)
- Other Changes
- ----------------------
- * SOLR-4106: Javac/ ivy path warnings with morfologik fixed by
- upgrading to Morfologik 1.5.5 (Robert Muir, Dawid Weiss)
- * SOLR-3899: SolrCore should not log at warning level when the index directory
- changes - it's an info event. (Tobias Bergman, Mark Miller)
- * SOLR-3861: Refactor SolrCoreState so that it's managed by SolrCore.
- (Mark Miller, hossman)
- * SOLR-3966: Eliminate superfluous warning from LanguageIdentifierUpdateProcessor
- (Markus Jelsma via hossman)
- * SOLR-3932: SolrCmdDistributorTest either takes 3 seconds or 3 minutes.
- (yonik, Mark Miller)
- * SOLR-3856: New tests for SqlEntityProcessor/CachedSqlEntityProcessor
- (James Dyer)
- * SOLR-4067: ZkStateReader#getLeaderProps should not return props for a leader
- that it does not think is live. (Mark Miller)
- * SOLR-4086: DIH refactor of VariableResolver and Evaluator. VariableResolver
- and each built-in Evaluator are separate concrete classes. DateFormatEvaluator
- now defaults with the ROOT Locale. However, users may specify a different
- Locale using an optional new third parameter. (James Dyer)
- * SOLR-3602: Update ZooKeeper to 3.4.5 (Mark Miller)
- * SOLR-4095: DIH NumberFormatTransformer & DateFormatTransformer default to the
- ROOT Locale if none is specified. These previously used the machine's default.
- (James Dyer)
- * SOLR-4096: DIH FileDataSource & FieldReaderDataSource default to UTF-8 encoding
- if none is specified. These previously used the machine's default.
- (James Dyer)
- * SOLR-1916: DIH to not use Lucene-forbidden Java APIs
- (default encoding, locale, etc.) (James Dyer, Robert Muir)
- * SOLR-4111: SpellCheckCollatorTest#testContextSensitiveCollate to test against
- both DirectSolrSpellChecker & IndexBasedSpellChecker
- (Tomás Fernández Löbbe via James Dyer)
- * SOLR-2141: Better test coverage for Evaluators (James Dyer)
- * SOLR-4119: Update Guava to 13.0.1 (Mark Miller)
- * SOLR-4074: Raise default ramBufferSizeMB to 100 from 32.
- (yonik, Mark Miller)
- * SOLR-4062: The update log location in solrconfig.xml should default to
- ${solr.ulog.dir} rather than ${solr.data.dir:} (Mark Miller)
- * SOLR-4155: Upgrade Jetty to 8.1.8. (Robert Muir)
- * SOLR-2986: Add MoreLikeThis to warning about features that require uniqueKey.
- Also, change the warning to warn log level. (Shawn Heisey via Mark Miller)
- * SOLR-4163: README improvements (Shawn Heisey via hossman)
- * SOLR-4248: "ant eclipse" should declare .svn directories as derived.
- (Shawn Heisey via Mark Miller)
- * SOLR-3279: Upgrade Carrot2 to 3.6.2 (Stanisław Osiński)
- * SOLR-4254: Harden the 'leader requests replica to recover' code path.
- (Mark Miller, yonik)
- * SOLR-4226: Extract fl parsing code out of ReturnFields constructor.
- (Ryan Ernst via Robert Muir)
- * SOLR-4208: ExtendedDismaxQParserPlugin has been refactored to make
- subclassing easier. (Tomás Fernández Löbbe, hossman)
- * SOLR-3735: Relocate the example mime-to-extension mapping, and
- upgrade Velocity Engine to 1.7 (ehatcher)
- * SOLR-4287: Removed "apache-" prefix from Solr distribution and artifact
- filenames. (Ryan Ernst, Robert Muir, Steve Rowe)
- * SOLR-4016: Deduplication does not work with atomic/partial updates so
- disallow atomic update requests which change signature generating fields.
- (Joel Nothman, yonik, shalin)
- * SOLR-4308: Remove the problematic and now unnecessary log4j-over-slf4j.
- (Mark Miller)
- ================== 4.0.0 ==================
- Versions of Major Components
- ---------------------
- Apache Tika 1.2
- Carrot2 3.5.0
- Velocity 1.6.4 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.3.6
- Upgrading from Solr 4.0.0-BETA
- ----------------------
- In order to better support distributed search mode, the TermVectorComponent's
- response format has been changed so that if the schema defines a
- uniqueKeyField, then that field value is used as the "key" for each document in
- its response section, instead of the internal lucene doc id. Users w/o a
- uniqueKeyField will continue to see the same response format. See SOLR-3229
- for more details.
- If you are using SolrCloud's distributed update request capabilities and a non
- string type id field, you must re-index.
- Upgrading from Solr 4.0.0-ALPHA
- ----------------------
- Solr is now much more strict about requiring that the uniqueKeyField feature
- (if used) must refer to a field which is not multiValued. If you upgrade from
- an earlier version of Solr and see an error that your uniqueKeyField "can not
- be configured to be multivalued" please add 'multiValued="false"' to the
- <field /> declaration for your uniqueKeyField. See SOLR-3682 for more details.
- In addition, please review the notes above about upgrading from 4.0.0-BETA
- Upgrading from Solr 3.6
- ----------------------
- * The Lucene index format has changed and as a result, once you upgrade,
- previous versions of Solr will no longer be able to read your indices.
- In a master/slave configuration, all searchers/slaves should be upgraded
- before the master. If the master were to be updated first, the older
- searchers would not be able to read the new index format.
- * Setting abortOnConfigurationError=false is no longer supported
- (since it has never worked properly). Solr will now warn you if
- you attempt to set this configuration option at all. (see SOLR-1846)
- * The default logic for the 'mm' param of the 'dismax' QParser has
- been changed. If no 'mm' param is specified (either in the query,
- or as a default in solrconfig.xml) then the effective value of the
- 'q.op' param (either in the query or as a default in solrconfig.xml
- or from the 'defaultOperator' option in schema.xml) is used to
- influence the behavior. If q.op is effectively "AND" then mm=100%.
- If q.op is effectively "OR" then mm=0%. Users who wish to force the
- legacy behavior should set a default value for the 'mm' param in
- their solrconfig.xml file.
- * The VelocityResponseWriter is no longer built into the core. Its JAR and
- dependencies now need to be added (via <lib> or solr/home lib inclusion),
- and it needs to be registered in solrconfig.xml like this:
- <queryResponseWriter name="velocity" class="solr.VelocityResponseWriter"/>
- * The update request parameter to choose Update Request Processor Chain is
- renamed from "update.processor" to "update.chain". The old parameter was
- deprecated but still working since Solr3.2, but is now removed
- entirely.
- * The <indexDefaults> and <mainIndex> sections of solrconfig.xml are discontinued
- and replaced with the <indexConfig> section. There are also better defaults.
- When migrating, if you don't know what your old settings mean, simply delete
- both <indexDefaults> and <mainIndex> sections. If you have customizations,
- put them in <indexConfig> section - with same syntax as before.
- * Two of the SolrServer subclasses in SolrJ were renamed/replaced.
- CommonsHttpSolrServer is now HttpSolrServer, and
- StreamingUpdateSolrServer is now ConcurrentUpdateSolrServer.
- * The PingRequestHandler no longer looks for a <healthcheck/> option in the
- (legacy) <admin> section of solrconfig.xml. Users who wish to take
- advantage of this feature should configure a "healthcheckFile" init param
- directly on the PingRequestHandler. As part of this change, relative file
- paths have been fixed to be resolved against the data dir. See the example
- solrconfig.xml and SOLR-1258 for more details.
- * Due to low level changes to support SolrCloud, the uniqueKey field can no
- longer be populated via <copyField/> or <field default=...> in the
- schema.xml. Users wishing to have Solr automatically generate a uniqueKey
- value when adding documents should instead use an instance of
- solr.UUIDUpdateProcessorFactory in their update processor chain. See
- SOLR-2796 for more details.
- In addition, please review the notes above about upgrading from 4.0.0-BETA, and 4.0.0-ALPHA
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-3670: New CountFieldValuesUpdateProcessorFactory makes it easy to index
- the number of values in another field for later use at query time. (hossman)
- * SOLR-2768: new "mod(x,y)" function for computing the modulus of two value
- sources. (hossman)
- * SOLR-3238: Numerous small improvements to the Admin UI (steffkes)
- * SOLR-3597: seems like a lot of wasted whitespace at the top of the admin screens
- (steffkes)
- * SOLR-3304: Added Solr adapters for Lucene 4's new spatial module. With
- SpatialRecursivePrefixTreeFieldType ("location_rpt" in example schema), it is
- possible to index a variable number of points per document (and sort on them),
- index not just points but any Spatial4j supported shape such as polygons, and
- to query on these shapes too. Polygons requires adding JTS to the classpath.
- (David Smiley)
- * SOLR-3825: Added optional capability to log what ids are in a response
- (Scott Stults via gsingers)
- * SOLR-3821: Added 'df' to the UI Query form (steffkes)
- * SOLR-3822: Added hover titles to the edismax params on the UI Query form
- (steffkes)
- Optimizations
- ----------------------
- * SOLR-3715: improve concurrency of the transaction log by removing
- synchronization around log record serialization. (yonik)
- * SOLR-3807: Currently during recovery we pause for a number of seconds after
- waiting for the leader to see a recovering state so that any previous updates
- will have finished before our commit on the leader - we don't need this wait
- for peersync. (Mark Miller)
- * SOLR-3837: When a leader is elected and asks replicas to sync back to him and
- that fails, we should ask those nodes to recovery asynchronously rather than
- synchronously. (Mark Miller)
- * SOLR-3709: Cache the url list created from the ClusterState in CloudSolrServer
- on each request. (Mark Miller)
- Bug Fixes
- ----------------------
- * SOLR-3685: Solr Cloud sometimes skipped peersync attempt and replicated instead due
- to tlog flags not being cleared when no updates were buffered during a previous
- replication. (Markus Jelsma, Mark Miller, yonik)
- * SOLR-3229: Fixed TermVectorComponent to work with distributed search
- (Hang Xie, hossman)
- * SOLR-3725: Fixed package-local-src-tgz target to not bring in unnecessary jars
- and binary contents. (Michael Dodsworth via rmuir)
- * SOLR-3649: Fixed bug in JavabinLoader that caused deleteById(List<String> ids)
- to not work in SolrJ (siren)
- * SOLR-3730: Rollback is not implemented quite right and can cause corner case fails in
- SolrCloud tests. (rmuir, Mark Miller)
- * SOLR-2981: Fixed StatsComponent to no longer return duplicated information
- when requesting multiple stats.facet fields.
- (Roman Kliewer via hossman)
- * SOLR-3743: Fixed issues with atomic updates and optimistic concurrency in
- conjunction with stored copyField targets by making real-time get never
- return copyField targets. (yonik)
- * SOLR-3746: Proper error reporting if updateLog is configured w/o necessary
- "_version_" field in schema.xml (hossman)
- * SOLR-3745: Proper error reporting if SolrCloud mode is used w/o
- necessary "_version_" field in schema.xml (hossman)
- * SOLR-3770: Overseer may lose updates to cluster state (siren)
- * SOLR-3721: Fix bug that could theoretically allow multiple recoveries to run
- briefly at the same time if the recovery thread join call was interrupted.
- (Per Steffensen, Mark Miller)
- * SOLR-3782: A leader going down while updates are coming in can cause shard
- inconsistency. (Mark Miller)
- * SOLR-3611: We do not show ZooKeeper data in the UI for a node that has children.
- (Mark Miller)
- * SOLR-3789: Fix bug in SnapPuller that caused "internal" compression to fail.
- (siren)
- * SOLR-3790: ConcurrentModificationException could be thrown when using hl.fl=*.
- Fixed in r1231606. (yonik, koji)
- * SOLR-3668: DataImport : Specifying Custom Parameters (steffkes)
- * SOLR-3793: UnInvertedField faceting cached big terms in the filter
- cache that ignored deletions, leading to duplicate documents in search
- later when a filter of the same term was specified.
- (Günter Hipler, hossman, yonik)
- * SOLR-3679: Core Admin UI gives no feedback if "Add Core" fails (steffkes, hossman)
- * SOLR-3795: Fixed LukeRequestHandler response to correctly return field name
- strings in copyDests and copySources arrays (hossman)
- * SOLR-3699: Fixed some Directory leaks when there were errors during SolrCore
- or SolrIndexWriter initialization. (hossman)
- * SOLR-3518: Include final 'hits' in log information when aggregating a
- distributed request (Markus Jelsma via hossman)
- * SOLR-3628: SolrInputField and SolrInputDocument are now consistently backed
- by Collections passed in to setValue/setField, and defensively copy values
- from Collections passed to addValue/addField
- (Tom Switzer via hossman)
- * SOLR-3595: CurrencyField now generates an appropriate error on schema init
- if it is configured as multiValued - this has never been properly supported,
- but previously failed silently in odd ways. (hossman)
- * SOLR-3823: Fix 'bq' parsing in edismax. Please note that this required
- reverting the negative boost support added by SOLR-3278 (hossman)
- * SOLR-3827: Fix shareSchema=true in solr.xml
- (Tomás Fernández Löbbe via hossman)
- * SOLR-3809: Fixed config file replication when subdirectories are used
- (Emmanuel Espina via hossman)
- * SOLR-3828: Fixed QueryElevationComponent so that using 'markExcludes' does
- not modify the result set or ranking of 'excluded' documents relative to
- not using elevation at all. (Alexey Serba via hossman)
- * SOLR-3569: Fixed debug output on distributed requests when there are no
- results found. (David Bowen via hossman)
- * SOLR-3811: Query Form using wrong values for dismax, edismax (steffkes)
- * SOLR-3779: DataImportHandler's LineEntityProcessor when used in conjunction
- with FileListEntityProcessor would only process the first file.
- (Ahmet Arslan via James Dyer)
- * SOLR-3791: CachedSqlEntityProcessor would throw a NullPointerException when
- a query returns a row with a NULL key. (Steffen Moelter via James Dyer)
- * SOLR-3833: When a election is started because a leader went down, the new
- leader candidate should decline if the last state they published was not
- active. (yonik, Mark Miller)
- * SOLR-3836: When doing peer sync, we should only count sync attempts that
- cannot reach the given host as success when the candidate leader is
- syncing with the replicas - not when replicas are syncing to the leader.
- (Mark Miller)
- * SOLR-3835: In our leader election algorithm, if on connection loss we found
- we did not create our election node, we should retry, not throw an exception.
- (Mark Miller)
- * SOLR-3834: A new leader on cluster startup should also run the leader sync
- process in case there was a bad cluster shutdown. (Mark Miller)
- * SOLR-3772: On cluster startup, we should wait until we see all registered
- replicas before running the leader process - or if they all do not come up,
- N amount of time. (Mark Miller)
- * SOLR-3756: If we are elected the leader of a shard, but we fail to publish
- this for any reason, we should clean up and re trigger a leader election.
- (Mark Miller)
- * SOLR-3812: ConnectionLoss during recovery can cause lost updates, leading to
- shard inconsistency. (Mark Miller)
- * SOLR-3813: When a new leader syncs, we need to ask all shards to sync back,
- not just those that are active. (Mark Miller)
- * SOLR-3641: CoreContainer is not persisting roles core attribute.
- (hossman, Mark Miller)
- * SOLR-3527: SolrCmdDistributor drops some of the important commit attributes
- (maxOptimizeSegments, softCommit, expungeDeletes) when sending a commit to
- replicas. (Andy Laird, Tomás Fernández Löbbe, Mark Miller)
- * SOLR-3844: SolrCore reload can fail because it tries to remove the index
- write lock while already holding it. (Mark Miller)
- * SOLR-3831: Atomic updates do not distribute correctly to other nodes.
- (Jim Musil, Mark Miller)
- * SOLR-3465: Replication causes two searcher warmups.
- (Michael Garski, Mark Miller)
- * SOLR-3645: /terms should default to distrib=false. (Nick Cotton, Mark Miller)
- * SOLR-3759: Various fixes to the example-DIH configs (Ahmet Arslan, hossman)
- * SOLR-3777: Dataimport-UI does not send unchecked checkboxes (Glenn MacStravic
- via steffkes)
- * SOLR-3850: DataImportHandler "cacheKey" parameter was incorrectly renamed "cachePk"
- (James Dyer)
- * SOLR-3087: Fixed DOMUtil so that code doing attribute validation will
- automatically ignore nodes in the reserved "xml" prefix - in particular this
- fixes some bugs related to xinclude and fieldTypes.
- (Amit Nithian, hossman)
- * SOLR-3783: Fixed Pivot Faceting to work with facet.missing=true (hossman)
- * SOLR-3869: A PeerSync attempt to its replicas by a candidate leader should
- not fail on o.a.http.conn.ConnectTimeoutException. (Mark Miller)
- * SOLR-3875: Fixed index boosts on multi-valued fields when docBoost is used
- (hossman)
- * SOLR-3878: Exception when using open-ended range query with CurrencyField (janhoy)
- * SOLR-3891: CacheValue in CachingDirectoryFactory cannot be used outside of
- solr.core package. (phunt via Mark Miller)
- * SOLR-3892: Inconsistent locking when accessing cache in CachingDirectoryFactory
- from RAMDirectoryFactory and MockDirectoryFactory. (phunt via Mark Miller)
- * SOLR-3883: Distributed indexing forwards non-applicable request params.
- (Dan Sutton, Per Steffensen, yonik, Mark Miller)
- * SOLR-3903: Fixed MissingFormatArgumentException in ConcurrentUpdateSolrServer
- (hossman)
- * SOLR-3916: Fixed whitespace bug in parsing the fl param (hossman)
- Other Changes
- ----------------------
- * SOLR-3690: Fixed binary release packages to include dependencies needed for
- the solr-test-framework (hossman)
- * SOLR-2857: The /update/json and /update/csv URLs were restored to aid
- in the migration of existing clients. (yonik)
- * SOLR-3691: SimplePostTool: Mode for crawling/posting web pages
- See http://wiki.apache.org/solr/ExtractingRequestHandler for examples (janhoy)
- * SOLR-3707: Upgrade Solr to Tika 1.2 (janhoy)
- * SOLR-2747: Updated changes2html.pl to handle Solr's CHANGES.txt; added
- target 'changes-to-html' to solr/build.xml.
- (Steve Rowe, Robert Muir)
- * SOLR-3752: When a leader goes down, have the Overseer clear the leader state
- in cluster.json (Mark Miller)
- * SOLR-3751: Add defensive checks for SolrCloud updates and requests that ensure
- the local state matches what we can tell the request expected. (Mark Miller)
- * SOLR-3773: Hash based on the external String id rather than the indexed
- representation for distributed updates. (Michael Garski, yonik, Mark Miller)
- * SOLR-3780: Maven build: Make solrj tests run separately from solr-core.
- (Steve Rowe)
- * SOLR-3772: Optionally, on cluster startup, we can wait until we see all registered
- replicas before running the leader process - or if they all do not come up,
- N amount of time. (Jan Høydahl, Per Steffensen, Mark Miller)
- * SOLR-3750: Optionally, on session expiration, we can explicitly wait some time before
- running the leader sync process so that we are sure every node participates.
- (Per Steffensen, Mark Miller)
- * SOLR-3824: Velocity: Error messages from search not displayed (janhoy)
- * SOLR-3826: Test framework improvements for specifying coreName on initCore
- (Amit Nithian, hossman)
- * SOLR-3749: Allow default UpdateLog syncLevel to be configured by
- solrconfig.xml (Raintung Li, Mark Miller)
- * SOLR-3845: Rename numReplicas to replicationFactor in Collections API.
- (yonik, Mark Miller)
- * SOLR-3815: SolrCloud - Add properties such as "range" to shards, which changes
- the clusterstate.json and puts the shard replicas under "replicas". (yonik)
- * SOLR-3871: SyncStrategy should use an executor for the threads it creates to
- request recoveries. (Mark Miller)
- * SOLR-3870: SyncStrategy should have a close so it can abort earlier on
- shutdown. (Mark Miller)
- ================== 4.0.0-BETA ===================
- Versions of Major Components
- ---------------------
- Apache Tika 1.1
- Carrot2 3.5.0
- Velocity 1.6.4 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.3.6
- Upgrading from Solr 4.0.0-ALPHA
- ----------------------
- Solr is now much more strict about requiring that the uniqueKeyField feature
- (if used) must refer to a field which is not multiValued. If you upgrade from
- an earlier version of Solr and see an error that your uniqueKeyField "can not
- be configured to be multivalued" please add 'multiValued="false"' to the
- <field /> declaration for your uniqueKeyField. See SOLR-3682 for more details.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * LUCENE-4201: Added JapaneseIterationMarkCharFilterFactory to normalize Japanese
- iteration marks. (Robert Muir, Christian Moen)
- * SOLR-1856: In Solr Cell, literals should override Tika-parsed values.
- Patch adds a param "literalsOverride" which defaults to true, but can be set
- to "false" to let Tika-parsed values be appended to literal values (Chris Harris, janhoy)
- * SOLR-3488: Added a Collection management API for SolrCloud.
- (Tommaso Teofili, Sami Siren, yonik, Mark Miller)
- * SOLR-3559: Full deleteByQuery support with SolrCloud distributed indexing.
- All replicas of a shard will be consistent, even if updates arrive in a
- different order on different replicas. (yonik)
- * SOLR-1929: Index encrypted documents with ExtractingUpdateRequestHandler.
- By supplying resource.password=<mypw> or specifying an external file with regular
- expressions matching file names, Solr will decrypt and index PDFs and DOCX formats.
- (janhoy, Yiannis Pericleous)
- * SOLR-3562: Add options to remove instance dir or data dir on core unload.
- (Mark Miller, Per Steffensen)
- * SOLR-2702: The default directory factory was changed to NRTCachingDirectoryFactory
- which wraps the StandardDirectoryFactory and caches small files for improved
- Near Real-time (NRT) performance. (Mark Miller, yonik)
- * SOLR-2616: Include a sample java util logging configuration file.
- (David Smiley, Mark Miller)
- * SOLR-3460: Add cloud-scripts directory and a zkcli.sh|bat tool for easy scripting
- and interaction with ZooKeeper. (Mark Miller)
- * SOLR-1725: StatelessScriptUpdateProcessorFactory allows users to implement
- the full ScriptUpdateProcessor API using any scripting language with a
- javax.script.ScriptEngineFactory
- (Uri Boness, ehatcher, Simon Rosenthal, hossman)
- * SOLR-139: Change to updateable documents to create the document if it doesn't
- already exist. To assert that the document must exist, use the optimistic
- concurrency feature by specifying a _version_ of 1. (yonik)
- * LUCENE-2510, LUCENE-4044: Migrated Solr's Tokenizer-, TokenFilter-, and
- CharFilterFactories to the lucene-analysis module. To add new analysis
- modules to Solr (like ICU, SmartChinese, Morfologik,...), just drop in
- the JAR files from Lucene's binary distribution into your Solr instance's
- lib folder. The factories are automatically made available with SPI.
- (Chris Male, Robert Muir, Uwe Schindler)
- * SOLR-3634, SOLR-3635: CoreContainer and CoreAdminHandler will now remember
- and report back information about failures to initialize SolrCores. These
- failures will be accessible from the web UI and CoreAdminHandler STATUS
- command until they are "reset" by creating/renaming a SolrCore with the
- same name. (hossman, steffkes)
- * SOLR-1280: Added commented-out example of the new script update processor
- to the example configuration. See http://wiki.apache.org/solr/ScriptUpdateProcessor (ehatcher)
- * SOLR-3672: SimplePostTool: Improvements for posting files
- Support for auto mode, recursive and wildcards (janhoy)
- Optimizations
- ----------------------
- * SOLR-3708: Add hashCode to ClusterState so that structures built based on the
- ClusterState can be easily cached. (Mark Miller)
- * SOLR-3709: Cache the url list created from the ClusterState in CloudSolrServer on each
- request. (Mark Miller, yonik)
- * SOLR-3710: Change CloudSolrServer so that update requests are only sent to leaders by
- default. (Mark Miller)
- Bug Fixes
- ----------------------
- * SOLR-3582: Our ZooKeeper watchers respond to session events as if they are change events,
- creating undesirable side effects. (Trym R. Møller, Mark Miller)
- * SOLR-3467: ExtendedDismax escaping is missing several reserved characters
- (Michael Dodsworth via janhoy)
- * SOLR-3587: After reloading a SolrCore, the original Analyzer is still used rather than a new
- one. (Alexey Serba, yonik, rmuir, Mark Miller)
- * LUCENE-4185: Fix a bug where CharFilters were wrongly being applied twice. (Michael Froh, rmuir)
- * SOLR-3610: After reloading a core, indexing would fail on any newly added fields to the schema. (Brent Mills, rmuir)
- * SOLR-3377: edismax fails to correctly parse a fielded query wrapped by parens.
- This regression was introduced in 3.6. (Bernd Fehling, Jan Høydahl, yonik)
- * SOLR-3621: Fix rare concurrency issue when opening a new IndexWriter for replication or rollback.
- (Mark Miller)
- * SOLR-1781: Replication index directories not always cleaned up.
- (Markus Jelsma, Terje Sten Bjerkseth, Mark Miller)
- * SOLR-3639: Update ZooKeeper to 3.3.6 for a variety of bug fixes. (Mark Miller)
- * SOLR-3629: Typo in solr.xml persistence when overriding the solrconfig.xml
- file name using the "config" attribute prevented the override file from being
- used. (Ryan Zezeski, hossman)
- * SOLR-3642: Correct broken check for multivalued fields in stats.facet
- (Yandong Yao, hossman)
- * SOLR-3660: Velocity: Link to admin page broken (janhoy)
- * SOLR-3658: Adding thousands of docs with one UpdateProcessorChain instance can briefly create
- spikes of threads in the thousands. (yonik, Mark Miller)
- * SOLR-3656: A core reload now always uses the same dataDir. (Mark Miller, yonik)
- * SOLR-3662: Core reload bugs: a reload always obtained a non-NRT searcher, which
- could go back in time with respect to the previous core's NRT searcher. Versioning
- did not work correctly across a core reload, and update handler synchronization
- was changed to synchronize on core state since more than on update handler
- can coexist for a single index during a reload. (yonik)
- * SOLR-3663: There are a couple of bugs in the sync process when a leader goes down and a
- new leader is elected. (Mark Miller)
- * SOLR-3623: Fixed inconsistent treatment of third-party dependencies for
- solr contribs analysis-extras & uima (hossman)
- * SOLR-3652: Fixed range faceting to error instead of looping infinitely
- when 'gap' is zero -- or effectively zero due to floating point arithmetic
- underflow. (hossman)
- * SOLR-3648: Fixed VelocityResponseWriter template loading in SolrCloud mode.
- For the example configuration, this means /browse now works with SolrCloud.
- (janhoy, ehatcher)
- * SOLR-3677: Fixed misleading error message in web ui to distinguish between
- no SolrCores loaded vs. no /admin/ handler available.
- (hossman, steffkes)
- * SOLR-3428: SolrCmdDistributor flushAdds/flushDeletes can cause repeated
- adds/deletes to be sent (Mark Miller, Per Steffensen)
- * SOLR-3647: DistributedQueue should use our Solr zk client rather than the std zk
- client. ZooKeeper expiration can be permanent otherwise. (Mark Miller)
- Other Changes
- ----------------------
- * SOLR-3524: Make discarding punctuation configurable in JapaneseTokenizerFactory.
- The default is to discard punctuation, but this is overridable as an expert option.
- (Kazuaki Hiraga, Jun Ohtani via Christian Moen)
- * SOLR-1770: Move the default core instance directory into a collection1 folder.
- (Mark Miller)
- * SOLR-3355: Add shard and collection to SolrCore statistics. (Michael Garski, Mark Miller)
- * SOLR-3575: solr.xml should default to persist=true (Mark Miller)
- * SOLR-3563: Unloading all cores in a SolrCloud collection will now cause the removal of
- that collection's meta data from ZooKeeper. (Mark Miller, Per Steffensen)
- * SOLR-3599: Add zkClientTimeout to solr.xml so that it's obvious how to change it and so
- that you can change it with a system property. (Mark Miller)
- * SOLR-3609: Change Solr's expanded webapp directory to be at a consistent path called
- solr-webapp rather than a temporary directory. (Mark Miller)
- * SOLR-3600: Raise the default zkClientTimeout from 10 seconds to 15 seconds. (Mark Miller)
- * SOLR-3215: Clone SolrInputDocument when distrib indexing so that update processors after
- the distrib update process do not process the document twice. (Mark Miller)
- * SOLR-3683: Improved error handling if an <analyzer> contains both an
- explicit class attribute, as well as nested factories. (hossman)
- * SOLR-3682: Fail to parse schema.xml if uniqueKeyField is multivalued (hossman)
- * SOLR-2115: DIH no longer requires the "config" parameter to be specified in solrconfig.xml.
- Instead, the configuration is loaded and parsed with every import. This allows the use of
- a different configuration with each import, and makes correcting configuration errors simpler.
- Also, the configuration itself can be passed using the "dataConfig" parameter rather than
- using a file (this previously worked in debug mode only). When configuration errors are
- encountered, the error message is returned in XML format. (James Dyer)
- * SOLR-3439: Make SolrCell easier to use out of the box. Also improves "/browse" to display
- rich-text documents correctly, along with facets for author and content_type.
- With the new "content" field, highlighting of body is supported. See also SOLR-3672 for
- easier posting of a whole directory structure. (Jack Krupansky, janhoy)
- * SOLR-3579: SolrCloud view should default to the graph view rather than tree view.
- (steffkes, Mark Miller)
- ================== 4.0.0-ALPHA ==================
- More information about this release, including any errata related to the
- release notes, upgrade instructions, or other changes may be found online at:
- https://wiki.apache.org/solr/Solr4.0
- Versions of Major Components
- ---------------------
- Apache Tika 1.1
- Carrot2 3.5.0
- Velocity 1.6.4 and Velocity Tools 2.0
- Apache UIMA 2.3.1
- Apache ZooKeeper 3.3.4
- Upgrading from Solr 3.6-dev
- ----------------------
- * The Lucene index format has changed and as a result, once you upgrade,
- previous versions of Solr will no longer be able to read your indices.
- In a master/slave configuration, all searchers/slaves should be upgraded
- before the master. If the master were to be updated first, the older
- searchers would not be able to read the new index format.
- * Setting abortOnConfigurationError=false is no longer supported
- (since it has never worked properly). Solr will now warn you if
- you attempt to set this configuration option at all. (see SOLR-1846)
- * The default logic for the 'mm' param of the 'dismax' QParser has
- been changed. If no 'mm' param is specified (either in the query,
- or as a default in solrconfig.xml) then the effective value of the
- 'q.op' param (either in the query or as a default in solrconfig.xml
- or from the 'defaultOperator' option in schema.xml) is used to
- influence the behavior. If q.op is effectively "AND" then mm=100%.
- If q.op is effectively "OR" then mm=0%. Users who wish to force the
- legacy behavior should set a default value for the 'mm' param in
- their solrconfig.xml file.
- * The VelocityResponseWriter is no longer built into the core. Its JAR and
- dependencies now need to be added (via <lib> or solr/home lib inclusion),
- and it needs to be registered in solrconfig.xml like this:
- <queryResponseWriter name="velocity" class="solr.VelocityResponseWriter"/>
- * The update request parameter to choose Update Request Processor Chain is
- renamed from "update.processor" to "update.chain". The old parameter was
- deprecated but still working since Solr3.2, but is now removed
- entirely.
- * The <indexDefaults> and <mainIndex> sections of solrconfig.xml are discontinued
- and replaced with the <indexConfig> section. There are also better defaults.
- When migrating, if you don't know what your old settings mean, simply delete
- both <indexDefaults> and <mainIndex> sections. If you have customizations,
- put them in <indexConfig> section - with same syntax as before.
- * Two of the SolrServer subclasses in SolrJ were renamed/replaced.
- CommonsHttpSolrServer is now HttpSolrServer, and
- StreamingUpdateSolrServer is now ConcurrentUpdateSolrServer.
- * The PingRequestHandler no longer looks for a <healthcheck/> option in the
- (legacy) <admin> section of solrconfig.xml. Users who wish to take
- advantage of this feature should configure a "healthcheckFile" init param
- directly on the PingRequestHandler. As part of this change, relative file
- paths have been fixed to be resolved against the data dir. See the example
- solrconfig.xml and SOLR-1258 for more details.
- * Due to low level changes to support SolrCloud, the uniqueKey field can no
- longer be populated via <copyField/> or <field default=...> in the
- schema.xml. Users wishing to have Solr automatically generate a uniqueKey
- value when adding documents should instead use an instance of
- solr.UUIDUpdateProcessorFactory in their update processor chain. See
- SOLR-2796 for more details.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-3272: Solr filter factory for MorfologikFilter (Polish lemmatisation).
- (Rafał Kuć via Dawid Weiss, Steven Rowe, Uwe Schindler).
- * SOLR-571: The autowarmCount for LRUCaches (LRUCache and FastLRUCache) now
- supports "percentages" which get evaluated relative the current size of
- the cache when warming happens.
- (Tomás Fernández Löbbe and hossman)
- * SOLR-1932: New relevancy function queries: termfreq, tf, docfreq, idf
- norm, maxdoc, numdocs. (yonik)
- * SOLR-1665: Add debug component options for timings, results and query info only (gsingers, hossman, yonik)
- * SOLR-2112: Solrj API now supports streaming results. (ryan)
- * SOLR-792: Adding PivotFacetComponent for Hierarchical faceting
- (ehatcher, Jeremy Hinegardner, Thibaut Lassalle, ryan)
- * LUCENE-2507, SOLR-2571, SOLR-2576: Added DirectSolrSpellChecker, which uses Lucene's
- DirectSpellChecker to retrieve correction candidates directly from the term dictionary using
- levenshtein automata. (James Dyer, rmuir)
- * SOLR-1873, SOLR-2358: SolrCloud - added shared/central config and core/shard management via zookeeper,
- built-in load balancing, and distributed indexing.
- (Jamie Johnson, Sami Siren, Ted Dunning, yonik, Mark Miller)
- Additional Work:
- - SOLR-2324: SolrCloud solr.xml parameters are not persisted by CoreContainer.
- (Massimo Schiavon, Mark Miller)
- - SOLR-2287: Allow users to query by multiple, compatible collections with SolrCloud.
- (Soheb Mahmood, Alex Cowell, Mark Miller)
- - SOLR-2622: ShowFileRequestHandler does not work in SolrCloud mode.
- (Stefan Matheis, Mark Miller)
- - SOLR-3108: Error in SolrCloud's replica lookup code when replica's are hosted in same Solr instance.
- (Bruno Dumon, Sami Siren, Mark Miller)
- - SOLR-3080: Remove shard info from zookeeper when SolrCore is explicitly unloaded.
- (yonik, Mark Miller, siren)
- - SOLR-3437: Recovery issues a spurious commit to the cluster. (Trym R. Møller via Mark Miller)
- - SOLR-2822: Skip update processors already run on other nodes (hossman)
- * SOLR-1566: Transforming documents in the ResponseWriters. This will allow
- for more complex results in responses and open the door for function queries
- as results.
- (ryan with patches from grant, noble, cmale, yonik, Jan Høydahl,
- Arul Kalaipandian, Luca Cavanna, hossman)
- - SOLR-2037: Thanks to SOLR-1566, documents boosted by the QueryElevationComponent
- can be marked as boosted. (gsingers, ryan, yonik)
- * SOLR-2396: Add CollationField, which is much more efficient than
- the Solr 3.x CollationKeyFilterFactory, and also supports
- Locale-sensitive range queries. (rmuir)
- * SOLR-2338: Add support for using <similarity/> in a schema's fieldType,
- for customizing scoring on a per-field basis. (hossman, yonik, rmuir)
- * SOLR-2335: New 'field("...")' function syntax for referring to complex
- field names (containing whitespace or special characters) in functions.
- * SOLR-2383: /browse improvements: generalize range and date facet display
- (Jan Høydahl via yonik)
- * SOLR-2272: Pseudo-join queries / filters. Examples:
- - To restrict to the set of parents with at least one blue-eyed child:
- fq={!join from=parent to=name}eyes:blue
- - To restrict to the set of children with at least one blue-eyed parent:
- fq={!join from=name to=parent}eyes:blue
- (yonik)
- * SOLR-1942: Added the ability to select postings format per fieldType in schema.xml
- as well as support custom Codecs in solrconfig.xml.
- (simonw via rmuir)
- * SOLR-2136: Boolean type added to function queries, along with
- new functions exists(), if(), and(), or(), xor(), not(), def(),
- and true and false constants. (yonik)
- * SOLR-2491: Add support for using spellcheck collation in conjunction
- with grouping. Note that the number of hits returned for collations
- is the number of ungrouped hits. (James Dyer via rmuir)
- * SOLR-1298: Return FunctionQuery as pseudo field. The solr 'fl' param
- now supports functions. For example: fl=id,sum(x,y) -- NOTE: only
- functions with fast random access are recommended. (yonik, ryan)
- * SOLR-705: Optionally return shard info with each document in distributed
- search. Use fl=id,[shard] to return the shard url. (ryan)
- * SOLR-2417: Add explain info directly to return documents using
- ?fl=id,[explain] (ryan)
- * SOLR-2533: Converted ValueSource.ValueSourceSortField over to new rewriteable Lucene
- SortFields. ValueSourceSortField instances must be rewritten before they can be used.
- This is done by SolrIndexSearcher when necessary. (Chris Male).
- * SOLR-2193, SOLR-2565: You may now specify a 'soft' commit when committing. This will
- use Lucene's NRT feature to avoid guaranteeing documents are on stable storage in exchange
- for faster reopen times. There is also a new 'soft' autocommit tracker that can be
- configured. (Mark Miller, Robert Muir)
- * SOLR-2399: Updated Solr Admin interface. New look and feel with per core administration
- and many new options. (Stefan Matheis via ryan)
- * SOLR-1032: CSV handler now supports "literal.field_name=value" parameters.
- (Simon Rosenthal, ehatcher)
- * SOLR-2656: realtime-get, efficiently retrieves the latest stored fields for specified
- documents, even if they are not yet searchable (i.e. without reopening a searcher)
- (yonik)
- * SOLR-2703: Added support for Lucene's "surround" query parser. (Simon Rosenthal, ehatcher)
- * SOLR-2754: Added factories for several ranking algorithms:
- - BM25SimilarityFactory: Okapi BM25
- - DFRSimilarityFactory: Divergence from Randomness models
- - IBSimilarityFactory: Information-based models
- - LMDirichletSimilarity: LM with Dirichlet smoothing
- - LMJelinekMercerSimilarity: LM with Jelinek-Mercer smoothing
- (David Mark Nemeskey, Robert Muir)
- * SOLR-2134 Trie* fields should support sortMissingLast=true, and deprecate Sortable* Field Types
- (Ryan McKinley, Mike McCandless, Uwe Schindler, Erick Erickson)
- * SOLR-2438 added MultiTermAwareComponent to the various classes to allow automatic lowercasing
- for multiterm queries (wildcards, regex, prefix, range, etc). You can now optionally specify a
- "multiterm" analyzer in our schema.xml, but Solr should "do the right thing" if you don't
- specify <analyzer type="multiterm"> (Pete Sturge Erick Erickson, Mentoring from Seeley and Muir)
- * SOLR-2481: Add support for commitWithin in DataImportHandler (Sami Siren via yonik)
- * SOLR-2992: Add support for IndexWriter.prepareCommit() via prepareCommit=true
- on update URLs. (yonik)
- * SOLR-2906: Added LFU cache options to Solr. (Shawn Heisey via Erick Erickson)
- * SOLR-3069: Ability to add openSearcher=false to not open a searcher when doing
- a hard commit. commitWithin now only invokes a softCommit. (yonik)
- * SOLR-2802: New FieldMutatingUpdateProcessor and Factory to simplify the
- development of UpdateProcessors that modify field values of documents as
- they are indexed. Also includes several useful new implementations:
- - RemoveBlankFieldUpdateProcessorFactory
- - TrimFieldUpdateProcessorFactory
- - HTMLStripFieldUpdateProcessorFactory
- - RegexReplaceProcessorFactory
- - FieldLengthUpdateProcessorFactory
- - ConcatFieldUpdateProcessorFactory
- - FirstFieldValueUpdateProcessorFactory
- - LastFieldValueUpdateProcessorFactory
- - MinFieldValueUpdateProcessorFactory
- - MaxFieldValueUpdateProcessorFactory
- - TruncateFieldUpdateProcessorFactory
- - IgnoreFieldUpdateProcessorFactory
- (hossman, janhoy)
- * SOLR-3120: Optional post filtering for spatial queries bbox and geofilt
- for LatLonType. (yonik)
- * SOLR-2459: Expose LogLevel selection with a RequestHandler rather then servlet
- (Stefan Matheis, Upayavira, ryan)
- * SOLR-3134: Include shard info in distributed response when shards.info=true
- (Russell Black, ryan)
- * SOLR-2898: Support grouped faceting. (Martijn van Groningen)
- Additional Work:
- - SOLR-3406: Extended grouped faceting support to facet.query and facet.range parameters.
- (David Boychuck, Martijn van Groningen)
- * SOLR-2949: QueryElevationComponent is now supported with distributed search.
- (Mark Miller, yonik)
- * SOLR-3221: Added the ability to directly configure aspects of the concurrency
- and thread-pooling used within distributed search in solr. This allows for finer
- grained controlled and can be tuned by end users to target their own specific
- requirements. This builds on the work of the HttpCommComponent and uses the same configuration
- block to configure the thread pool. The default configuration has
- the same behaviour as solr 3.5, favouring throughput over latency. More
- information can be found on the wiki (http://wiki.apache.org/solr/SolrConfigXml) (Greg Bowyer)
- * SOLR-3278: Negative boost support to the Extended Dismax Query Parser Boost Query (bq).
- (James Dyer)
- * SOLR-3255: OpenExchangeRates.Org Exchange Rate Provider for CurrencyField (janhoy)
- * SOLR-3358: Logging events are captured and available from the /admin/logging
- request handler. (ryan)
- * SOLR-1535: PreAnalyzedField type provides a functionality to index (and optionally store)
- field content that was already processed and split into tokens using some external processing
- chain. Serialization format is pluggable, and defaults to JSON. (ab)
- * SOLR-3363: Consolidated Exceptions in Analysis Factories so they only throw
- InitializationExceptions (Chris Male)
- * SOLR-2690: New support for a "TZ" request param which overrides the TimeZone
- used when rounding Dates in DateMath expressions for the entire request
- (all date range queries and date faceting is affected). The default TZ
- is still UTC. (David Schlotfeldt, hossman)
- * SOLR-3402: Analysis Factories are now configured with their Lucene Version
- throw setLuceneMatchVersion, rather than through the Map passed to init.
- Parsing and simple error checking for the Version is now done inside
- the code that creates the Analysis Factories. (Chris Male)
- * SOLR-3178: Optimistic locking. If a _version_ is provided with an update
- that does not match the version in the index, an HTTP 409 error (Conflict)
- will result. (Per Steffensen, yonik)
- * SOLR-139: Updateable documents. JSON Example:
- {"id":"mydoc", "f1":{"set":10}, "f2":{"add":20}} will result in field "f1"
- being set to 10, "f2" having an additional value of 20 added, and all
- other existing fields unchanged. All source fields must be stored for
- this feature to work correctly. (Ryan McKinley, Erik Hatcher, yonik)
- * SOLR-2857: Support XML,CSV,JSON, and javabin in a single RequestHandler and
- choose the correct ContentStreamLoader based on Content-Type header. This
- also deprecates the existing [Xml,JSON,CSV,Binary,Xslt]UpdateRequestHandler.
- (ryan)
- * SOLR-2585: Context-Sensitive Spelling Suggestions & Collations. This adds support
- for the "spellcheck.alternativeTermCount" & "spellcheck.maxResultsForSuggest"
- parameters, letting users receive suggestions even when all the queried terms
- exist in the dictionary. This differs from "spellcheck.onlyMorePopular" in
- that the suggestions need not consist entirely of terms with a greater document
- frequency than the queried terms. (James Dyer)
- * SOLR-2058: Edismax query parser to allow "phrase slop" to be specified per-field
- on the pf/pf2/pf3 parameters using optional "FieldName~slop^boost" syntax. The
- prior "FieldName^boost" syntax is still accepted. In such cases the value on the
- "ps" parameter serves as the default slop. (Ron Mayer via James Dyer)
- * SOLR-3495: New UpdateProcessors have been added to create default values for
- configured fields. These works similarly to the <field default="..."/>
- option in schema.xml, but are applied in the UpdateProcessorChain, so they
- may be used prior to other UpdateProcessors, or to generate a uniqueKey field
- value when using the DistributedUpdateProcessor (ie: SolrCloud)
- TimestampUpdateProcessorFactory
- UUIDUpdateProcessorFactory
- DefaultValueUpdateProcessorFactory
- (hossman)
- * SOLR-2993: Add WordBreakSolrSpellChecker to offer suggestions by combining adjacent
- query terms and/or breaking terms into multiple words. This spellchecker can be
- configured with a traditional checker (ie: DirectSolrSpellChecker). The results
- are combined and collations can contain a mix of corrections from both spellcheckers.
- (James Dyer)
- * SOLR-3508: Simplify JSON update format for deletes as well as allow
- version specification for optimistic locking. Examples:
- - {"delete":"myid"}
- - {"delete":["id1","id2","id3"]}
- - {"delete":{"id":"myid", "_version_":123456789}}
- (yonik)
- * SOLR-3211: Allow parameter overrides in conjunction with "spellcheck.maxCollationTries".
- To do so, use parameters starting with "spellcheck.collateParam." For instance, to
- override the "mm" parameter, specify "spellcheck.collateParam.mm". This is helpful
- in cases where testing spellcheck collations for result counts should use different
- parameters from the main query (James Dyer)
- * SOLR-2599: CloneFieldUpdateProcessorFactory provides similar functionality
- to schema.xml's <copyField/> declaration but as an update processor that can
- be combined with other processors in any order. (Jan Høydahl & hossman)
- * SOLR-3351: eDismax: ps2 and ps3 params (janhoy)
- * SOLR-3542: Add WeightedFragListBuilder for FVH and set it to default fragListBuilder
- in example solrconfig.xml. (Sebastian Lutze, koji)
- * SOLR-2396: Add ICUCollationField to contrib/analysis-extras, which is much
- more efficient than the Solr 3.x ICUCollationKeyFilterFactory, and also
- supports Locale-sensitive range queries. (rmuir)
- Optimizations
- ----------------------
- * SOLR-1875: Per-segment field faceting for single valued string fields.
- Enable with facet.method=fcs, control the number of threads used with
- the "threads" local param on the facet.field param. This algorithm will
- only be faster in the presence of rapid index changes. (yonik)
- * SOLR-1904: When facet.enum.cache.minDf > 0 and the base doc set is a
- SortedIntSet, convert to HashDocSet for better performance. (yonik)
- * SOLR-2092: Speed up single-valued and multi-valued "fc" faceting. Typical
- improvement is 5%, but can be much greater (up to 10x faster) when facet.offset
- is very large (deep paging). (yonik)
- * SOLR-2193, SOLR-2565: The default Solr update handler has been improved so
- that it uses fewer locks, keeps the IndexWriter open rather than closing it
- on each commit (ie commits no longer wait for background merges to complete),
- works with SolrCore to provide faster 'soft' commits, and has an improved API
- that requires less instanceof special casing. (Mark Miller, Robert Muir)
- Additional Work:
- - SOLR-2697: commit and autocommit operations don't reset
- DirectUpdateHandler2.numDocsPending stats attribute.
- (Alexey Serba, Mark Miller)
- * SOLR-2950: The QueryElevationComponent now avoids using the FieldCache and looking up
- every document id (gsingers, yonik)
- Bug Fixes
- ----------------------
- * SOLR-3139: Make ConcurrentUpdateSolrServer send UpdateRequest.getParams()
- as HTTP request params (siren)
- * SOLR-3165: Cannot use DIH in Solrcloud + Zookeeper (Alexey Serba,
- Mark Miller, siren)
- * SOLR-3068: Occasional NPE in ThreadDumpHandler (siren)
- * SOLR-2762: FSTLookup could return duplicate results or one results less
- than requested. (David Smiley, Dawid Weiss)
- * SOLR-2741: Bugs in facet range display in trunk (janhoy)
- * SOLR-1908: Fixed SignatureUpdateProcessor to fail to initialize on
- invalid config. Specifically: a signatureField that does not exist,
- or overwriteDupes=true with a signatureField that is not indexed.
- (hossman)
- * SOLR-1824: IndexSchema will now fail to initialize if there is a
- problem initializing one of the fields or field types. (hossman)
- * SOLR-1928: TermsComponent didn't correctly break ties for non-text
- fields sorted by count. (yonik)
- * SOLR-2107: MoreLikeThisHandler doesn't work with alternate qparsers. (yonik)
- * SOLR-2108: Fixed false positives when using wildcard queries on fields with reversed
- wildcard support. For example, a query of *zemog* would match documents that contain
- 'gomez'. (Landon Kuhn via Robert Muir)
- * SOLR-1962: SolrCore#initIndex should not use a mix of indexPath and newIndexPath (Mark Miller)
- * SOLR-2275: fix DisMax 'mm' parsing to be tolerant of whitespace
- (Erick Erickson via hossman)
- * SOLR-2193, SOLR-2565, SOLR-2651: SolrCores now properly share IndexWriters across SolrCore reloads.
- (Mark Miller, Robert Muir)
- Additional Work:
- - SOLR-2705: On reload, IndexWriterProvider holds onto the initial SolrCore it was created with.
- (Yury Kats, Mark Miller)
- * SOLR-2682: Remove addException() in SimpleFacet. FacetComponent no longer catches and embeds
- exceptions occurred during facet processing, it throws HTTP 400 or 500 exceptions instead. (koji)
- * SOLR-2654: Directorys used by a SolrCore are now closed when they are no longer used.
- (Mark Miller)
- * SOLR-2854: Now load URL content stream data (via stream.url) when called for during request handling,
- rather than loading URL content streams automatically regardless of use.
- (David Smiley and Ryan McKinley via ehatcher)
- * SOLR-2829: Fix problem with false-positives due to incorrect
- equals methods. (Yonik Seeley, Hossman, Erick Erickson.
- Marc Tinnemeyer caught the bug)
- * SOLR-2848: Removed 'instanceof AbstractLuceneSpellChecker' hacks from distributed spellchecking code,
- and added a merge() method to SolrSpellChecker instead. Previously if you extended SolrSpellChecker
- your spellchecker would not work in distributed fashion. (James Dyer via rmuir)
- * SOLR-2509: StringIndexOutOfBoundsException in the spellchecker collate when the term contains
- a hyphen. (Thomas Gambier caught the bug, Steffen Godskesen did the patch, via Erick Erickson)
- * SOLR-1730: Made it clearer when a core failed to load as well as better logging when the
- QueryElevationComponent fails to properly initialize (gsingers)
- * SOLR-1520: QueryElevationComponent now supports non-string ids (gsingers)
- * SOLR-3037: When using binary format in solrj the codec screws up parameters
- (Sami Siren, Jörg Maier via yonik)
- * SOLR-3062: A join in the main query was not respecting any filters pushed
- down to it via acceptDocs since LUCENE-1536. (Mike Hugo, yonik)
- * SOLR-3214: If you use multiple fl entries rather than a comma separated list, all but the first
- entry can be ignored if you are using distributed search. (Tomás Fernández Löbbe via Mark Miller)
- * SOLR-3352: eDismax: pf2 should kick in for a query with 2 terms (janhoy)
- * SOLR-3361: ReplicationHandler "maxNumberOfBackups" doesn't work if backups are triggered on commit
- (James Dyer, Tomás Fernández Löbbe)
- * SOLR-2605: fixed tracking of the 'defaultCoreName' in CoreContainer so that
- CoreAdminHandler could return consistent information regardless of whether
- there is a a default core name or not. (steffkes, hossman)
- * SOLR-3370: fixed CSVResponseWriter to respect globs in the 'fl' param
- (Keith Fligg via hossman)
- * SOLR-3436: Group count incorrect when not all shards are queried in the second
- pass. (Francois Perron, Martijn van Groningen)
- * SOLR-3454: Exception when using result grouping with main=true and using
- wt=javabin. (Ludovic Boutros, Martijn van Groningen)
- * SOLR-3446: Better errors when PatternTokenizerFactory is configured with
- an invalid pattern, and include the 'name' whenever possible in plugin init
- error messages. (hossman)
- * LUCENE-4075: Cleaner path usage in TestXPathEntityProcessor
- (Greg Bowyer via hossman)
- * SOLR-2923: IllegalArgumentException when using useFilterForSortedQuery on an
- empty index. (Adrien Grand via Mark Miller)
- * SOLR-2352: Fixed TermVectorComponent so that it will not fail if the fl
- param contains globs or psuedo-fields (hossman)
- * SOLR-3541: add missing solrj dependencies to binary packages.
- (Thijs Vonk via siren)
- * SOLR-3522: fixed parsing of the 'literal()' function (hossman)
- * SOLR-3548: Fixed a bug in the cachability of queries using the {!join}
- parser or the strdist() function, as well as some minor improvements to
- the hashCode implementation of {!bbox} and {!geofilt} queries.
- (hossman)
- * SOLR-3470: contrib/clustering: custom Carrot2 tokenizer and stemmer factories
- are respected now (Stanislaw Osinski, Dawid Weiss)
- * SOLR-3430: Added a new DIH test against a real SQL database. Fixed problems
- revealed by this new test related to the expanded cache support added to
- 3.6/SOLR-2382 (James Dyer)
- * SOLR-1958: When using the MailEntityProcessor, import would fail if
- fetchMailsSince was not specified. (Max Lynch via James Dyer)
- * SOLR-4289: Admin UI - JVM memory bar - dark grey "used" width is too small
- (steffkes, elyograg)
- Other Changes
- ----------------------
- * SOLR-1846: Eliminate support for the abortOnConfigurationError
- option. It has never worked very well, and in recent versions of
- Solr hasn't worked at all. (hossman)
- * SOLR-1889: The default logic for the 'mm' param of DismaxQParser and
- ExtendedDismaxQParser has been changed to be determined based on the
- effective value of the 'q.op' param (hossman)
- * SOLR-1946: Misc improvements to the SystemInfoHandler: /admin/system
- (hossman)
- * SOLR-2289: Tweak spatial coords for example docs so they are a bit
- more spread out (Erick Erickson via hossman)
- * SOLR-2288: Small tweaks to eliminate compiler warnings. primarily
- using Generics where applicable in method/object declarations, and
- adding @SuppressWarnings("unchecked") when appropriate (hossman)
- * SOLR-2375: Suggester Lookup implementations now store trie data
- and load it back on init. This means that large tries don't have to be
- rebuilt on every commit or core reload. (ab)
- * SOLR-2413: Support for returning multi-valued fields w/o <arr> tag
- in the XMLResponseWriter was removed. XMLResponseWriter only
- no longer work with values less then 2.2 (ryan)
- * SOLR-2423: FieldType argument changed from String to Object
- Conversion from SolrInputDocument > Object > Fieldable is now managed
- by FieldType rather then DocumentBuilder. (ryan)
- * SOLR-2461: QuerySenderListener and AbstractSolrEventListener are
- now public (hossman)
- * LUCENE-2995: Moved some spellchecker and suggest APIs to modules/suggest:
- HighFrequencyDictionary, SortedIterator, TermFreqIterator, and the
- suggester APIs and implementations. (rmuir)
- * SOLR-2576: Remove deprecated SpellingResult.add(Token, int).
- (James Dyer via rmuir)
- * LUCENE-3232: Moved MutableValue classes to new 'common' module. (Chris Male)
- * LUCENE-2883: FunctionQuery, DocValues (and its impls), ValueSource (and its
- impls) and BoostedQuery have been consolidated into the queries module. They
- can now be found at o.a.l.queries.function.
- * SOLR-2027: FacetField.getValues() now returns an empty list if there are no
- values, instead of null (Chris Male)
- * SOLR-1825: SolrQuery.addFacetQuery now enables facets automatically, like
- addFacetField (Chris Male)
- * SOLR-2663: FieldTypePluginLoader has been refactored out of IndexSchema
- and made public. (hossman)
- * SOLR-2331,SOLR-2691: Refactor CoreContainer's SolrXML serialization code and improve testing
- (Yury Kats, hossman, Mark Miller)
- * SOLR-2698: Enhance CoreAdmin STATUS command to return index size.
- (Yury Kats, hossman, Mark Miller)
- * SOLR-2654: The same Directory instance is now always used across a SolrCore so that
- it's easier to add other DirectoryFactory's without static caching hacks.
- (Mark Miller)
- * LUCENE-3286: 'luke' ant target has been disabled due to incompatibilities with XML
- queryparser location (Chris Male)
- * SOLR-1897: The data dir from the core descriptor should override the data dir from
- the solrconfig.xml rather than the other way round. (Mark Miller)
- * SOLR-2756: Maven configuration: Excluded transitive stax:stax-api dependency
- from org.codehaus.woodstox:wstx-asl dependency. (David Smiley via Steve Rowe)
- * SOLR-2588: Moved VelocityResponseWriter back to contrib module in order to
- remove it as a mandatory core dependency. (ehatcher)
- * SOLR-2862: More explicit lexical resources location logged if Carrot2 clustering
- extension is used. Fixed solr. impl. of IResource and IResourceLookup. (Dawid Weiss)
- * SOLR-1123: Changed JSONResponseWriter to now use application/json as its Content-Type
- by default. However the Content-Type can be overwritten and is set to text/plain in
- the example configuration. (Uri Boness, Chris Male)
- * SOLR-2607: Removed deprecated client/ruby directory, which included solr-ruby and flare.
- (ehatcher)
- * SOLR-3032: logOnce from SolrException logOnce and all the supporting
- structure is gone. abortOnConfigurationError is also gone as it is no longer referenced.
- Errors should be caught and logged at the top-most level or logged and NOT propagated up the
- chain. (Erick Erickson)
- * SOLR-2105: Remove support for deprecated "update.processor" (since 3.2), in favor of
- "update.chain" (janhoy)
- * SOLR-3005: Default QueryResponseWriters are now initialized via init() with an empty
- NamedList. (Gasol Wu, Chris Male)
- * SOLR-2607: Removed obsolete client/ folder (ehatcher, Eric Pugh, janhoy)
- * SOLR-3202, SOLR-3244: Dropping Support for JSP. New Admin UI is all client side
- (ryan, Aliaksandr Zhuhrou, Uwe Schindler)
- * SOLR-3159: Upgrade example and tests to run with Jetty 8 (ryan)
- * SOLR-3254: Upgrade Solr to Tika 1.1 (janhoy)
- * SOLR-3329: Dropped getSourceID() from SolrInfoMBean and using
- getClass().getPackage().getSpecificationVersion() for Version. (ryan)
- * SOLR-3302: Upgraded SLF4j to version 1.6.4 (hossman)
- * SOLR-3322: Add more context to IndexReaderFactory.newReader (ab)
- * SOLR-3343: Moved FastWriter, FileUtils, RegexFileFilter, RTimer and SystemIdResolver
- from org.apache.solr.common to org.apache.solr.util (Chris Male)
- * SOLR-3357: ResourceLoader.newInstance now accepts a Class representation of the expected
- instance type (Chris Male)
- * SOLR-3388: HTTP caching is now disabled by default for RequestUpdateHandlers. (ryan)
- * SOLR-3309: web.xml now specifies metadata-complete=true (which requires
- Servlet 2.5) to prevent servlet containers from scanning class annotations
- on startup. This allows for faster startup times on some servlet containers.
- (Bill Bell, hossman)
- * SOLR-1893: Refactored some common code from LRUCache and FastLRUCache into
- SolrCacheBase (Tomás Fernández Löbbe via hossman)
- * SOLR-3403: Deprecated Analysis Factories now log their own deprecation messages.
- No logging support is provided by Factory parent classes. (Chris Male)
- * SOLR-1258: PingRequestHandler is now directly configured with a
- "healthcheckFile" instead of looking for the legacy
- <admin><healthcheck/></admin> syntax. Filenames specified as relative
- paths have been fixed so that they are resolved against the data dir
- instead of the CWD of the java process. (hossman)
- * SOLR-3083: JMX beans now report Numbers as numeric values rather then String
- (Tagged Siteops, Greg Bowyer via ryan)
- * SOLR-2796: Due to low level changes to support SolrCloud, the uniqueKey
- field can no longer be populated via <copyField/> or <field default=...>
- in the schema.xml.
- * SOLR-3534: The Dismax and eDismax query parsers will fall back on the 'df' parameter
- when 'qf' is absent. And if neither is present nor the schema default search field
- then an exception will be thrown now. (dsmiley)
- * SOLR-3262: The "threads" feature of DIH is removed (deprecated in Solr 3.6)
- (James Dyer)
- * SOLR-3422: Refactored DIH internal data classes. All entities in
- data-config.xml must have a name (James Dyer)
- Documentation
- ----------------------
- * SOLR-2232: Improved README info on solr.solr.home in examples
- (Eric Pugh and hossman)
- ================== 3.6.2 ==================
- Bug Fixes
- ----------------------
- * SOLR-3790: ConcurrentModificationException could be thrown when using hl.fl=*.
- (yonik, koji)
- * SOLR-3589: Edismax parser does not honor mm parameter if analyzer splits a token.
- (Tom Burton-West, Robert Muir)
- ================== 3.6.1 ==================
- More information about this release, including any errata related to the
- release notes, upgrade instructions, or other changes may be found online at:
- https://wiki.apache.org/solr/Solr3.6.1
- Bug Fixes
- * LUCENE-3969: Throw IAE on bad arguments that could cause confusing errors in
- PatternTokenizer. CommonGrams populates PositionLengthAttribute correctly.
- (Uwe Schindler, Mike McCandless, Robert Muir)
- * SOLR-3361: ReplicationHandler "maxNumberOfBackups" doesn't work if backups are triggered on commit
- (James Dyer, Tomás Fernández Löbbe)
- * SOLR-3375: Fix charset problems with HttpSolrServer (Roger Håkansson, yonik, siren)
- * SOLR-3436: Group count incorrect when not all shards are queried in the second
- pass. (Francois Perron, Martijn van Groningen)
- * SOLR-3454: Exception when using result grouping with main=true and using
- wt=javabin. (Ludovic Boutros, Martijn van Groningen)
- * SOLR-3489: Config file replication less error prone (Jochen Just via janhoy)
- * SOLR-3477: SOLR does not start up when no cores are defined (Tomás Fernández Löbbe via tommaso)
- * SOLR-3470: contrib/clustering: custom Carrot2 tokenizer and stemmer factories
- are respected now (Stanislaw Osinski, Dawid Weiss)
- * SOLR-3360: More DIH bug fixes for the deprecated "threads" parameter.
- (Mikhail Khludnev, Claudio R, via James Dyer)
- * SOLR-3430: Added a new DIH test against a real SQL database. Fixed problems
- revealed by this new test related to the expanded cache support added to
- 3.6/SOLR-2382 (James Dyer)
- * SOLR-3336: SolrEntityProcessor substitutes most variables at query time.
- (Michael Kroh, Lance Norskog, via Martijn van Groningen)
- ================== 3.6.0 ==================
- More information about this release, including any errata related to the
- release notes, upgrade instructions, or other changes may be found online at:
- https://wiki.apache.org/solr/Solr3.6
- Upgrading from Solr 3.5
- ----------------------
- * SOLR-2983: As a consequence of moving the code which sets a MergePolicy from SolrIndexWriter to SolrIndexConfig,
- (custom) MergePolicies should now have an empty constructor; thus an IndexWriter should not be passed as constructor
- parameter but instead set using the setIndexWriter() method.
- * As doGet() methods in SimplePostTool was changed to static, the client applications of this
- class need to be recompiled.
- * In Solr version 3.5 and earlier, HTMLStripCharFilter had known bugs in the
- character offsets it provided, triggering e.g. exceptions in highlighting.
- HTMLStripCharFilter has been re-implemented, addressing this and other
- issues. See the entry for LUCENE-3690 in the Bug Fixes section below for a
- detailed list of changes. For people who depend on the behavior of
- HTMLStripCharFilter in Solr version 3.5 and earlier: the old implementation
- (bugs and all) is preserved as LegacyHTMLStripCharFilter.
- * As of Solr 3.6, the <indexDefaults> and <mainIndex> sections of solrconfig.xml are deprecated
- and replaced with a new <indexConfig> section. Read more in SOLR-1052 below.
- * SOLR-3040: The DIH's admin UI (dataimport.jsp) now requires DIH request handlers to start with
- a '/'. (dsmiley)
- * SOLR-3161: <requestDispatcher handleSelect="false"> is now the default. An existing config will
- probably work as-is because handleSelect was explicitly enabled in default configs. HandleSelect
- makes /select work as well as enables the 'qt' parameter. Instead, consider explicitly
- configuring /select as is done in the example solrconfig.xml, and register your other search
- handlers with a leading '/' which is a recommended practice. (David Smiley, Erik Hatcher)
- * SOLR-3161: Don't use the 'qt' parameter with a leading '/'. It probably won't work in 4.0
- and it's now limited in 3.6 to SearchHandler subclasses that aren't lazy-loaded.
- * SOLR-2724: Specifying <defaultSearchField> and <solrQueryParser defaultOperator="..."/> in
- schema.xml is now considered deprecated. Instead you are encouraged to specify these via the "df"
- and "q.op" parameters in your request handler definition. (David Smiley)
- * Bugs found and fixed in the SignatureUpdateProcessor that previously caused
- some documents to produce the same signature even when the configured fields
- contained distinct (non-String) values. Users of SignatureUpdateProcessor
- are strongly advised that they should re-index as document signatures may
- have now changed. (see SOLR-3200 & SOLR-3226 for details)
- New Features
- ----------------------
- * SOLR-2020: Add Java client that uses Apache Http Components http client (4.x).
- (Chantal Ackermann, Ryan McKinley, Yonik Seeley, siren)
- * SOLR-2854: Now load URL content stream data (via stream.url) when called for during request handling,
- rather than loading URL content streams automatically regardless of use.
- (David Smiley and Ryan McKinley via ehatcher)
- * SOLR-2904: BinaryUpdateRequestHandler should be able to accept multiple update requests from
- a stream (shalin)
- * SOLR-1565: StreamingUpdateSolrServer supports RequestWriter API and therefore, javabin update
- format (shalin)
- * SOLR-2438 added MultiTermAwareComponent to the various classes to allow automatic lowercasing
- for multiterm queries (wildcards, regex, prefix, range, etc). You can now optionally specify a
- "multiterm" analyzer in our schema.xml, but Solr should "do the right thing" if you don't
- specify <fieldType="multiterm"> (Pete Sturge Erick Erickson, Mentoring from Seeley and Muir)
- * SOLR-2919: Added support for localized range queries when the analysis chain uses
- CollationKeyFilter or ICUCollationKeyFilter. (Michael Sokolov, rmuir)
- * SOLR-2982: Added BeiderMorseFilterFactory for Beider-Morse (BMPM) phonetic encoder. Upgrades
- commons-codec to version 1.6 (Brooke Schreier Ganz, rmuir)
- * SOLR-1843: A new "rootName" attribute is now available when
- configuring <jmx/> in solrconfig.xml. If this attribute is set,
- Solr will use it as the root name for all MBeans Solr exposes via
- JMX. The default root name is "solr" followed by the core name.
- (Constantijn Visinescu, hossman)
- * SOLR-2906: Added LFU cache options to Solr. (Shawn Heisey via Erick Erickson)
- * SOLR-3036: Ability to specify overwrite=false on the URL for XML updates.
- (Sami Siren via yonik)
- * SOLR-2603: Add the encoding function for alternate fields in highlighting.
- (Massimo Schiavon, koji)
- * SOLR-1729: Evaluation of NOW for date math is done only once per request for
- consistency, and is also propagated to shards in distributed search.
- Adding a parameter NOW=<time_in_ms> to the request will override the
- current time. (Peter Sturge, yonik, Simon Willnauer)
- * SOLR-1709: Distributed support for Date and Numeric Range Faceting
- (Peter Sturge, David Smiley, hossman, Simon Willnauer)
- * SOLR-3054, LUCENE-3671: Add TypeTokenFilterFactory that creates TypeTokenFilter
- that filters tokens based on their TypeAttribute. (Tommaso Teofili via
- Uwe Schindler)
- * LUCENE-3305, SOLR-3056: Added Kuromoji morphological analyzer for Japanese.
- See the 'text_ja' fieldtype in the example to get started.
- (Christian Moen, Masaru Hasegawa via Robert Muir)
- * SOLR-1860: StopFilterFactory, CommonGramsFilterFactory, and
- CommonGramsQueryFilterFactory can optionally read stopwords in Snowball
- format (specify format="snowball"). (Robert Muir)
- * SOLR-3105: ElisionFilterFactory optionally allows the parameter
- ignoreCase (default=false). (Robert Muir)
- * LUCENE-3714: Add WFSTLookupFactory, a suggester that uses a weighted FST
- for more fine-grained suggestions. (Mike McCandless, Dawid Weiss, Robert Muir)
- * SOLR-3143: Add SuggestQueryConverter, a QueryConverter intended for
- auto-suggesters. (Robert Muir)
- * SOLR-3033: ReplicationHandler's backup command now supports a 'maxNumberOfBackups'
- init param that can be used to delete all but the most recent N backups. (Torsten Krah, James Dyer)
- * SOLR-2202: Currency FieldType, whith support for currencies and exchange rates
- (Greg Fodor & Andrew Morrison via janhoy, rmuir, Uwe Schindler)
- * SOLR-3026: eDismax: Locking down which fields can be explicitly queried (user fields aka uf)
- (janhoy, hossmann, Tomás Fernández Löbbe)
- * SOLR-2826: URLClassify Update Processor (janhoy)
- * SOLR-2764: Create a NorwegianLightStemmer and NorwegianMinimalStemmer (janhoy)
- * SOLR-3221: Added the ability to directly configure aspects of the concurrency
- and thread-pooling used within distributed search in solr. This allows for finer
- grained controlled and can be tuned by end users to target their own specific
- requirements. This builds on the work of the HttpCommComponent and uses the same configuration
- block to configure the thread pool. The default configuration has
- the same behaviour as solr 3.5, favouring throughput over latency. More
- information can be found on the wiki (http://wiki.apache.org/solr/SolrConfigXml) (Greg Bowyer)
- * SOLR-2001: The query component will substitute an empty query that matches
- no documents if the query parser returns null. This also prevents an
- exception from being thrown by the default parser if "q" is missing. (yonik)
- - SOLR-435: if q is "" then it's also acceptable. (dsmiley, hoss)
- * SOLR-2919: Added parametric tailoring options to ICUCollationKeyFilterFactory.
- These can be used to customize range query/sort behavior, for example to
- support numeric collation, ignore punctuation/whitespace, ignore accents but
- not case, control whether upper/lowercase values are sorted first, etc. (rmuir)
- * SOLR-2346: Add a chance to set content encoding explicitly via content type
- of stream for extracting request handler. This is convenient when Tika's
- auto detector cannot detect encoding, especially the text file is too short
- to detect encoding. (koji)
- * SOLR-1499: Added SolrEntityProcessor that imports data from another Solr core
- or instance based on a specified query.
- (Lance Norskog, Erik Hatcher, Pulkit Singhal, Ahmet Arslan, Luca Cavanna,
- Martijn van Groningen)
- * SOLR-3190: Minor improvements to SolrEntityProcessor. Add more consistency
- between solr parameters and parameters used in SolrEntityProcessor and
- ability to specify a custom HttpClient instance.
- (Luca Cavanna via Martijn van Groningen)
- * SOLR-2382: Added pluggable cache support to DIH so that any Entity can be
- made cache-able by adding the "cacheImpl" parameter. Include
- "SortedMapBackedCache" to provide in-memory caching (as previously this was
- the only option when using CachedSqlEntityProcessor). Users can provide
- their own implementations of DIHCache for other caching strategies.
- Deprecate CachedSqlEntityProcessor in favor of specifing "cacheImpl" with
- SqlEntityProcessor. Make SolrWriter implement DIHWriter and allow the
- possibility of pluggable Writers (DIH writing to something other than Solr).
- (James Dyer, Noble Paul)
- Optimizations
- ----------------------
- * SOLR-1931: Speedup for LukeRequestHandler and admin/schema browser. New parameter
- reportDocCount defaults to 'false'. Old behavior still possible by specifying this as 'true'
- (Erick Erickson)
- * SOLR-3012: Move System.getProperty("type") in postData() to main() and add type argument so that
- the client applications of SimplePostTool can set content type via method argument. (koji)
- * SOLR-2888: FSTSuggester refactoring: internal storage is now UTF-8,
- external sorting (on disk) prevents OOMs even with large data sets
- (the bottleneck is now FST construction), code cleanups and API cleanups.
- (Dawid Weiss, Robert Muir)
- Bug Fixes
- ----------------------
- * SOLR-3187 SystemInfoHandler leaks filehandles (siren)
- * LUCENE-3820: Fixed invalid position indexes by reimplementing PatternReplaceCharFilter.
- This change also drops real support for boundary characters -- all input is prebuffered
- for pattern matching. (Dawid Weiss)
- * SOLR-3068: Fixed NPE in ThreadDumpHandler (siren)
- * SOLR-2912: Fixed File descriptor leak in ShowFileRequestHandler (Michael Ryan, shalin)
- * SOLR-2819: Improved speed of parsing hex entities in HTMLStripCharFilter
- (Bernhard Berger, hossman)
- * SOLR-2509: StringIndexOutOfBoundsException in the spellchecker collate when the term contains
- a hyphen. (Thomas Gambier caught the bug, Steffen Godskesen did the patch, via Erick Erickson)
- * SOLR-2955: Fixed IllegalStateException when querying with group.sort=score desc in sharded
- environment. (Steffen Elberg Godskesen, Martijn van Groningen)
- * SOLR-2956: Fixed inconsistencies in the flags (and flag key) reported by
- the LukeRequestHandler (hossman)
- * SOLR-1730: Made it clearer when a core failed to load as well as better logging when the
- QueryElevationComponent fails to properly initialize (gsingers)
- * SOLR-1520: QueryElevationComponent now supports non-string ids (gsingers)
- * SOLR-3024: Fixed JSONTestUtil.matchObj, in previous releases it was not
- respecting the 'delta' arg (David Smiley via hossman)
- * SOLR-2542: Fixed DIH Context variables which were broken for all scopes other
- then SCOPE_ENTITY (Linbin Chen & Frank Wesemann via hossman)
- * SOLR-3042: Fixed Maven Jetty plugin configuration.
- (David Smiley via Steve Rowe)
- * SOLR-2970: CSV ResponseWriter returns fields defined as stored=false in schema (janhoy)
- * LUCENE-3690, LUCENE-2208, SOLR-882, SOLR-42: Re-implemented
- HTMLStripCharFilter as a JFlex-generated scanner and moved it to
- lucene/contrib/analyzers/common/. See below for a list of bug fixes and
- other changes. To get the same behavior as HTMLStripCharFilter in Solr
- version 3.5 and earlier (including the bugs), use LegacyHTMLStripCharFilter,
- which is the previous implementation.
- Behavior changes from the previous version:
- - Known offset bugs are fixed.
- - The "Mark invalid" exceptions reported in SOLR-1283 are no longer
- triggered (the bug is still present in LegacyHTMLStripCharFilter).
- - The character entity "'" is now always properly decoded.
- - More cases of <script> tags are now properly stripped.
- - CDATA sections are now handled properly.
- - Valid tag name characters now include the supplementary Unicode characters
- from Unicode character classes [:ID_Start:] and [:ID_Continue:].
- - Uppercase character entities """, "©", ">", "<", "®",
- and "&" are now recognized and handled as if they were in lowercase.
- - The REPLACEMENT CHARACTER U+FFFD is now used to replace numeric character
- entities for unpaired UTF-16 low and high surrogates (in the range
- [U+D800-U+DFFF]).
- - Properly paired numeric character entities for UTF-16 surrogates are now
- converted to the corresponding code units.
- - Opening tags with unbalanced quotation marks are now properly stripped.
- - Literal "<" and ">" characters in opening tags, regardless of whether they
- appear inside quotation marks, now inhibit recognition (and stripping) of
- the tags. The only exception to this is for values of event-handler
- attributes, e.g. "onClick", "onLoad", "onSelect".
- - A newline '\n' is substituted instead of a space for stripped HTML markup.
- - Nothing is substituted for opening and closing inline tags - they are
- simply removed. The list of inline tags is (case insensitively): <a>,
- <abbr>, <acronym>, <b>, <basefont>, <bdo>, <big>, <cite>, <code>, <dfn>,
- <em>, <font>, <i>, <img>, <input>, <kbd>, <label>, <q>, <s>, <samp>,
- <select>, <small>, <span>, <strike>, <strong>, <sub>, <sup>, <textarea>,
- <tt>, <u>, and <var>.
- - HTMLStripCharFilterFactory now handles HTMLStripCharFilter's "escapedTags"
- feature: opening and closing tags with the given names, including any
- attributes and their values, are left intact in the output.
- (Steve Rowe)
- * LUCENE-3717: Fixed offset bugs in TrimFilter, WordDelimiterFilter, and
- HyphenatedWordsFilter where they would create invalid offsets in
- some situations, leading to problems in highlighting. (Robert Muir)
- * SOLR-2280: commitWithin ignored for a delete query (Juan Grande via janhoy)
- * SOLR-3073: Fixed 'Invalid UUID string' error when having an UUID field as
- the unique key and executing a distributed grouping request. (Devon Krisman, Martijn van Groningen)
- * SOLR-3084: Fixed initialization error when using
- <queryResponseWriter default="true" ... /> (Bernd Fehling and hossman)
- * SOLR-3109: Fixed numerous redundant shard requests when using distributed grouping.
- (rblack via Martijn van Groningen)
- * SOLR-3052: Fixed typo in distributed grouping parameters.
- (Martijn van Groningen, Grant Ingersoll)
- * SOLR-2909: Add support for ResourceLoaderAware tokenizerFactories in synonym
- filter factories. (Tom Klonikowski, Jun Ohtani via Koji Sekiguchi)
- * SOLR-3168: ReplicationHandler "numberToKeep" & "maxNumberOfBackups" parameters
- would keep only 1 backup, even if more than 1 was specified (Neil Hooey, James Dyer)
- * SOLR-3009: hitGrouped.vm isn't shipped with 3.x (ehatcher, janhoy)
- * SOLR-3195: timeAllowed is ignored for grouping queries
- (Russell Black via Martijn van Groningen)
- * SOLR-2124: Do not log stack traces for "Service Disabled" / 503 Exceptions (PingRequestHandler, etc)
- (James Dyer, others)
- * SOLR-3260: DataImportHandler: ScriptTransformer gives better error messages when
- problems arise on initialization (no Script Engine, invalid script, etc). (James Dyer)
- * SOLR-2959: edismax now respects the magic fields '_val_' and '_query_'
- (Michael Watts, hossman)
- * SOLR-3074: fix SolrPluginUtils.docListToSolrDocumentList to respect the
- list of fields specified. This fix also deprecates
- DocumentBuilder.loadStoredFields which is not used anywhere in Solr,
- and was fundamentally broken/bizarre.
- (hossman, Ahmet Arslan)
- * SOLR-2291: fix JSONWriter to respect field list when writing SolrDocuments
- (Ahmet Arslan via hossman)
- * SOLR-3264: Fix CoreContainer and SolrResourceLoader logging to be more
- clear about when SolrCores are being created, and stop misleading people
- about SolrCore instanceDir's being the "Solr Home Dir" (hossman)
- * SOLR-3046: Fix whitespace typo in DIH response "Time taken" (hossman)
- * SOLR-3261: Fix edismax to respect query operators when literal colons
- are used in query string. (Juan Grande via hossman)
- * SOLR-3226: Fix SignatureUpdateProcessor to no longer ignore non-String
- field values (Spyros Kapnissis, hossman)
- * SOLR-3200: Fix SignatureUpdateProcessor "all fields" mode to use all
- fields of each document instead of the fields specified by the first
- document indexed (Spyros Kapnissis via hossman)
- * SOLR-3316: Distributed grouping failed when rows parameter was set to 0 and
- sometimes returned a wrong hit count as matches. (Cody Young, Martijn van Groningen)
- * SOLR-3107: contrib/langid: When using the LangDetect implementation of
- langid, set the random seed to 0, so that the same document is detected as
- the same language with the same probability every time.
- (Christian Moen via rmuir)
- * SOLR-2937: Configuring the number of contextual snippets used for
- search results clustering. The hl.snippets parameter is now respected
- by the clustering plugin, can be overridden by carrot.summarySnippets
- if needed (Stanislaw Osinski).
- * SOLR-2938: Clustering on multiple fields. The carrot.title and
- carrot.snippet can now take comma- or space-separated lists of
- field names to cluster (Stanislaw Osinski).
- * SOLR-2939: Clustering of multilingual search results. The document's
- language field be passed in the carrot.lang parameter, the carrot.lcmap
- parameter enables mapping of language codes to ISO 639 (Stanislaw Osinski).
- * SOLR-2940: Passing values for custom Carrot2 fields to Clustering component.
- The custom field mapping are defined using the carrot.custom parameter
- (Stanislaw Osinski).
- * SOLR-2941: NullPointerException on clustering component initialization
- when schema does not have a unique key field (Stanislaw Osinski).
- * SOLR-2942: ClassCastException when passing non-textual fields to
- clustering component (Stanislaw Osinski).
- Other Changes
- ----------------------
- * SOLR-2922: Upgrade commons-io and commons-lang to 2.1 and 2.6, respectively. (koji)
- * SOLR-2920: Refactor frequent conditional use of DefaultSolrParams and
- AppendedSolrParams into factory methods.
- (David Smiley via hossman)
- * SOLR-3032: Deprecate logOnce from SolrException logOnce and all the supporting
- structure will disappear in 4.0. Errors should be caught and logged at the
- top-most level or logged and NOT propagated up the chain. (Erick Erickson)
- * SOLR-2718: Add ability to lazy load response writers, defined with startup="lazy".
- (ehatcher)
- * SOLR-2901: Upgrade Solr to Tika 1.0 (janhoy)
- * SOLR-3059: Example XSL stylesheet for indexing query result XML (janhoy)
- * SOLR-3097, SOLR-3105: Add analysis configurations for different languages to
- the example. (Christian Moen, Robert Muir)
- * SOLR-3005: Default QueryResponseWriters are now initialized via init() with an empty
- NamedList. (Gasol Wu, Chris Male)
- * SOLR-3140: Upgrade schema version to 1.5, where omitNorms defaults to "true" for all
- primitive (non-analyzed) field types such as int, float, date, bool, string.. (janhoy)
- * SOLR-3077: Better error messages when attempting to use "blank" field names
- (Antony Stubbs via hossman)
- * SOLR-2712: expecting fl=score to return all fields is now deprecated.
- In solr 4.0, this will only return the score. (ryan)
- * SOLR-3156: Check for Lucene directory locks at startup. In previous versions
- this check was only performed during modifying (e.g. adding and deleting
- documents) the index. (Luca Cavanna via Martijn van Groningen)
- * SOLR-1052: Deprecated <indexDefaults> and <mainIndex> in solrconfig.xml
- From now, all settings go in the new <indexConfig> tag, and some defaults are
- changed: useCompoundFile=false, ramBufferSizeMB=32, lockType=native, so that
- the effect of NOT specifying <indexConfig> at all gives same result as the
- example config used to give in 3.5 (janhoy, gsingers)
- * SOLR-3294: In contrib/clustering/lib/, replaced the manually retrowoven
- Java 1.5-compatible carrot2-core-3.5.0.jar (which is not publicly available,
- except from the Solr Subversion repository), with newly released Java
- 1.5-compatible carrot2-core-3.5.0.1.jar (hosted on the Maven Central
- repository). Also updated dependencies jackson-core-asl and
- jackson-mapper-asl (both v1.5.2 -> v1.7.4). (Dawid Weiss, Steve Rowe)
- * SOLR-3295: netcdf jar is excluded from the binary release (and disabled in
- ivy.xml) because it requires java 6. If you want to parse this content with
- extracting request handler and are willing to use java 6, just add the jar.
- (rmuir)
- * SOLR-3142: DIH Imports no longer default optimize to true, instead false.
- If you want to force all segments to be merged into one, you can specify
- this parameter yourself. NOTE: this can be very expensive operation and
- usually does not make sense for delta-imports. (Robert Muir)
- Build
- ----------------------
- * SOLR-2487: Add build target to package war without slf4j jars (janhoy)
- * SOLR-3112: Fix tests not to write to src/test-files (Luca Cavanna via Robert Muir)
- * LUCENE-3753: Restructure the Solr build system. (Steve Rowe)
- * SOLR-3204: The packaged pre-release artifact of Commons CSV used the original
- package name (org.apache.commons.csv). This created a compatibility issue as
- the Apache Commons team works toward an official release of Commons CSV.
- The source of Commons CSV was added under a separate package name to the
- Solr source code. (Uwe Schindler, Chris Male, Emmanuel Bourg)
- * LUCENE-3930: Changed build system to use Apache Ivy for retrival of 3rd
- party JAR files. Please review README.txt for instructions.
- (Robert Muir, Chris Male, Uwe Schindler, Steven Rowe, Hossman)
- ================== 3.5.0 ==================
- New Features
- ----------------------
- * SOLR-2749: Add boundary scanners for FastVectorHighlighter. <boundaryScanner/>
- can be specified with a name in solrconfig.xml, and use hl.boundaryScanner=name
- parameter to specify the named <boundaryScanner/>. (koji)
- * SOLR-2066,SOLR-2776: Added support for distributed grouping.
- (Martijn van Groningen, Jasper van Veghel, Matt Beaumont)
- * SOLR-2769: Added factory for the new Hunspell stemmer capable of doing stemming
- for 99 languages (janhoy, cmale)
- * SOLR-1979: New contrib "langid". Adds language identification capabilities as an
- Update Processor, using Tika's LanguageIdentifier or Cybozu language-detection
- library (janhoy, Tommaso Teofili, gsingers)
- * SOLR-2818: Added before/after count response parsing support for range facets in
- SolrJ. (Bernhard Frauendienst via Martijn van Groningen)
- * SOLR-2276: Add support for cologne phonetic to PhoneticFilterFactory.
- (Marc Pompl via rmuir)
- * SOLR-1926: Add hl.q parameter. (koji)
- * SOLR-2881: Numeric types now support sortMissingFirst/Last. This includes Trie and date types
- (Ryan McKinley, Mike McCandless, Uwe Schindler, Erick Erickson)
- * SOLR-1023: StatsComponent now supports date fields and string fields.
- (Chris Male, Mark Holland, Gunnlaugur Thor Briem, Ryan McKinley)
- * SOLR-2578: ReplicationHandler's backup command now supports a 'numberToKeep'
- request param that can be used to delete all but the most recent N backups.
- (James Dyer via hossman)
- * SOLR-2839: Add alternative implementation to contrib/langid supporting 53
- languages, based on http://code.google.com/p/language-detection/ (rmuir)
- Optimizations
- ----------------------
- * SOLR-2742: SolrJ: Provide commitWithinMs as optional parameter for all add() methods,
- making the feature more conveniently accessible for developers (janhoy)
- Bug Fixes
- ----------------------
- * SOLR-2748: The CommitTracker used for commitWith or autoCommit by maxTime
- could commit too frequently and could block adds until a new searcher was
- registered. (yonik)
- * SOLR-2726: Fixed NullPointerException when using spellcheck.q with Suggester.
- (Bernd Fehling, valentin via rmuir)
- * SOLR-2772: Fixed Date parsing/formatting of years 0001-1000 (hossman)
- * SOLR-2763: Extracting update request handler throws exception and returns 400
- when zero-length file posted using multipart form post (janhoy)
- * SOLR-2780: Fixed issue where multi select facets didn't respect group.truncate parameter.
- (Martijn van Groningen, Ramzi Alqrainy)
- * SOLR-2793: In rare cases (most likely during shutdown), a SolrIndexSearcher can be left
- open if the executor rejects a task. (Mark Miller)
- * SOLR-2791: Replication: abortfetch command is broken if replication was started
- by fetchindex command instead of a regular poll (Yury Kats via shalin)
- * SOLR-2861: Fix extremely rare race condition on commit that can result
- in a NPE (yonik)
- * SOLR-2813: Fix HTTP error codes returned when requests contain strings that
- can not be parsed as numbers for Trie fields. (Jeff Crump and hossman)
- * SOLR-2902: List of collations are wrong parsed in SpellCheckResponse causing
- a wrong number of collation results in the response.
- (Bastiaan Verhoef, James Dyer via Simon Willnauer)
- * SOLR-2875: Fix the incorrect url in DIH example tika-data-config.xml
- (Shinichiro Abe via koji)
- Other Changes
- ----------------------
- * SOLR-2750: Make both "update.chain" and the deprecated "update.param" work
- consistently everywhere; see also SOLR-2105. (Mark Miller, janhoy)
- * LUCENE-3410: Deprecated the WordDelimiterFilter constructors accepting multiple
- ints masquerading as booleans. Preferred constructor now accepts a single int
- bitfield (Chris Male)
- * SOLR-2758: Moved ConcurrentLRUCache from o.a.s.common.util package in the solrj
- module to the o.a.s.util package in the Solr core module.
- (David Smiley via Steve Rowe)
- * SOLR-2766: Package individual javadoc sites for solrj and test-framework.
- (Steve Rowe, Mike McCandless)
- * SOLR-2771: Solr modules' tests should not depend on solr-core test classes;
- move BufferingRequestProcessor from solr-core tests to test-framework so that
- the Solr Cell module can use it. (janhoy, Steve Rowe)
- * LUCENE-3457: Upgrade commons-compress to 1.2 (Doron Cohen)
- * SOLR-2757: min() and max() functions now support an arbitrary number of
- ValueSources (Bill Bell via hossman)
- * SOLR-2372: Upgrade Solr to Tika 0.10 (janhoy)
- * SOLR-2792: Allow case insensitive Hunspell stemming (janhoy, rmuir)
- * SOLR-2862: More explicit lexical resources location logged if Carrot2 clustering
- extension is used. Fixed solr. impl. of IResource and IResourceLookup. (Dawid Weiss)
- * SOLR-2849: Fix dependencies in Maven POMs. (David Smiley via Steve Rowe)
- * SOLR-2591: Remove commitLockTimeout option from solrconfig.xml (Luca Cavanna via Martijn van Groningen)
- * SOLR-2746: Upgraded UIMA dependencies from *-2.3.1-SNAPSHOT.jar to *-2.3.1.jar.
- ================== 3.4.0 ==================
- Upgrading from Solr 3.3
- ----------------------
- * The Lucene index format has changed and as a result, once you upgrade,
- previous versions of Solr will no longer be able to read your indices.
- In a master/slave configuration, all searchers/slaves should be upgraded
- before the master. If the master were to be updated first, the older
- searchers would not be able to read the new index format.
- * Previous versions of Solr silently allow and ignore some contradictory
- properties specified in schema.xml. For example:
- - indexed="false" omitNorms="false"
- - indexed="false" omitTermFreqAndPositions="false"
- Field property validation has now been fixed, to ensure that
- contradictions like these now generate error messages. If users
- have existing schemas that generate one of these new "conflicting
- 'false' field options for non-indexed field" error messages the
- conflicting "omit*" properties can safely be removed, or changed to
- "true" for consistent behavior with previous Solr versions. This
- situation has now been fixed to cause an error on startup when these
- contradictory options. See SOLR-2669.
- * FacetComponent no longer catches and embeds exceptions occurred during facet
- processing, it throws HTTP 400 or 500 exceptions instead.
- New Features
- ----------------------
- * SOLR-2540: CommitWithin as an Update Request parameter
- You can now specify &commitWithin=N (ms) on the update request (janhoy)
- * SOLR-2458: post.jar enhanced to handle JSON, CSV and <optimize> (janhoy)
- * LUCENE-3234: add a new parameter hl.phraseLimit for FastVectorHighlighter speed up.
- (Mike Sokolov via koji)
- * SOLR-2429: Ability to add cache=false to queries and query filters to avoid
- using the filterCache or queryCache. A cost may also be specified and is used
- to order the evaluation of non-cached filters from least to greatest cost .
- For very expensive query filters (cost >= 100) if the query implements
- the PostFilter interface, it will be used to obtain a Collector that is
- checked only for documents that match the main query and all other filters.
- The "frange" query now implements the PostFilter interface. (yonik)
- * SOLR-2630: Added new XsltUpdateRequestHandler that works like
- XmlUpdateRequestHandler but allows to transform the POSTed XML document
- using XSLT. This allows to POST arbitrary XML documents to the update
- handler, as long as you also provide a XSL to transform them to a valid
- Solr input document. (Upayavira, Uwe Schindler)
- * SOLR-2615: Log individual updates (adds and deletes) at the FINE level
- before adding to the index. Fix a null pointer exception in logging
- when there was no unique key. (David Smiley via yonik)
- * LUCENE-2048: Added omitPositions to the schema, so you can omit position
- information while still indexing term frequencies. (rmuir)
- * SOLR-2584: add UniqFieldsUpdateProcessor that removes duplicate values in the
- specified fields. (Elmer Garduno, koji)
- * SOLR-2670: Added NIOFSDirectoryFactory (yonik)
- * SOLR-2523: Added support in SolrJ to easily interact with range facets.
- The range facet response can be parsed and is retrievable from the
- QueryResponse class. The SolrQuery class has convenient methods for using
- range facets. (Martijn van Groningen)
- * SOLR-2637: Added support for group result parsing in SolrJ.
- (Tao Cheng, Martijn van Groningen)
- * SOLR-2665: Added post group faceting. Facet counts are based on the most
- relevant document of each group matching the query. This feature has the
- same impact on the StatsComponent. (Martijn van Groningen)
- * SOLR-2675: CoreAdminHandler now allows arbitrary properties to be
- specified when CREATEing a new SolrCore using property.* request
- params. (Yury Kats, hossman)
- * SOLR-2714: JSON update format - "null" field values are now dropped
- instead of causing an exception. (Trygve Laugstøl, yonik)
- Optimizations
- ----------------------
- * LUCENE-3233: Improved memory usage, build time, and performance of
- SynonymFilterFactory. (Mike McCandless, Robert Muir)
- Bug Fixes
- ----------------------
- * SOLR-2625: TermVectorComponent throws NPE if TF-IDF option is used without DF
- option. (Daniel Erenrich, Simon Willnauer)
- * SOLR-2631: PingRequestHandler should not allow to ping itself using "qt"
- param to prevent infinite loop. (Edoardo Tosca, Uwe Schindler)
- * SOLR-2636: Fix explain functionality for negative queries. (Tom Hill via yonik)
- * SOLR-2538: Range Faceting on long/double fields could overflow if values
- bigger then the max int/float were used.
- (Erbi Hanka, hossman)
- * SOLR-2230: CommonsHttpSolrServer.addFile could not be used to send
- multiple files in a single request.
- (Stephan Günther, hossman)
- * SOLR-2541: PluginInfos was not correctly parsing <long/> tags when
- initializing plugins
- (Frank Wesemann, hossman)
- * SOLR-2623: Solr JMX MBeans do not survive core reloads (Alexey Serba, shalin)
- * Fixed grouping bug when start is bigger than rows and format is simple that zero documents are returned even
- if there are documents to display. (Martijn van Groningen, Nikhil Chhaochharia)
- * SOLR-2564: Fixed ArrayIndexOutOfBoundsException when using simple format and
- start > 0 (Martijn van Groningen, Matteo Melli)
- * SOLR-2642: Fixed sorting by function when using grouping. (Thomas Heigl, Martijn van Groningen)
- * SOLR-2535: REGRESSION: in Solr 3.x and trunk the admin/file handler
- fails to show directory listings (David Smiley, Peter Wolanin via Erick Erickson)
- * SOLR-2545: ExternalFileField file parsing would fail if any key
- contained an "=" character. It now only looks for the last "=" delimiter
- prior to the float value.
- (Markus Jelsma, hossman)
- * SOLR-2662: When Solr is configured to have no queryResultCache, the
- "start" parameter was not honored and the documents returned were
- 0 through start+offset. (Markus Jelsma, yonik)
- * SOLR-2669: Fix backwards validation of field properties in
- SchemaField.calcProps (hossman)
- * SOLR-2676: Add "welcome-file-list" to solr.war so admin UI works correctly
- in servlet containers such as WebSphere that do not use a default list
- (Jay R. Jaeger, hossman)
- * SOLR-2606: Fixed sort parsing of fields containing punctuation that
- failed due to sort by function changes introduced in SOLR-1297
- (Mitsu Hadeishi, hossman)
- * SOLR-2706: contrib/clustering: The carrot.lexicalResourcesDir parameter
- now works with absolute directories (Stanislaw Osinski)
- * SOLR-2692: contrib/clustering: Typo in param name fixed: "carrot.fragzise"
- changed to "carrot.fragSize" (Stanislaw Osinski).
- * SOLR-2644: When using DIH with threads=2 the default logging is set too high
- (Bill Bell via shalin)
- * SOLR-2492: DIH does not commit if only deletes are processed
- (James Dyer via shalin)
- * SOLR-2186: DataImportHandler's multi-threaded option throws NPE
- (Lance Norskog, Frank Wesemann, shalin)
- * SOLR-2655: DIH multi threaded mode does not resolve attributes correctly
- (Frank Wesemann, shalin)
- * SOLR-2695: DIH: Documents are collected in unsynchronized list in
- multi-threaded debug mode (Michael McCandless, shalin)
- * SOLR-2668: DIH multithreaded mode does not rollback on errors from
- EntityProcessor (Frank Wesemann, shalin)
- Other Changes
- ----------------------
- * SOLR-2629: Eliminate deprecation warnings in some JSPs.
- (Bernd Fehling, hossman)
- * SOLR-2743: Remove commons logging from contrib/extraction. (koji)
- Build
- ----------------------
- * SOLR-2452,SOLR-2653,LUCENE-3323,SOLR-2659,LUCENE-3329,SOLR-2666:
- Rewrote the Solr build system:
- - Integrated more fully with the Lucene build system: generalized the
- Lucene build system and eliminated duplication.
- - Converted all Solr contribs to the Lucene/Solr conventional src/ layout:
- java/, resources/, test/, and test-files/<contrib-name>.
- - Created a new Solr-internal module named "core" by moving the java/,
- test/, and test-files/ directories from solr/src/ to solr/core/src/.
- - Merged solr/src/webapp/src/ into solr/core/src/java/.
- - Eliminated solr/src/ by moving all its directories up one level;
- renamed solr/src/site/ to solr/site-src/ because solr/site/ already
- exists.
- - Merged solr/src/common/ into solr/solrj/src/java/.
- - Moved o.a.s.client.solrj.* and o.a.s.common.* tests from
- solr/src/test/ to solr/solrj/src/test/.
- - Made the solrj tests not depend on the solr core tests by moving
- some classes from solr/src/test/ to solr/test-framework/src/java/.
- - Each internal module (core/, solrj/, test-framework/, and webapp/)
- now has its own build.xml, from which it is possible to run
- module-specific targets. solr/build.xml delegates all build
- tasks (via <ant dir="internal-module-dir"> calls) to these
- modules' build.xml files.
- (Steve Rowe, Robert Muir)
- * LUCENE-3406: Add ant target 'package-local-src-tgz' to Lucene and Solr
- to package sources from the local working copy.
- (Seung-Yeoul Yang via Steve Rowe)
- Documentation
- ----------------------
- ================== 3.3.0 ==================
- Upgrading from Solr 3.2.0
- ----------------------
- * SolrCore's CloseHook API has been changed in a backward-incompatible way. It
- has been changed from an interface to an abstract class. Any custom
- components which use the SolrCore.addCloseHook method will need to
- be modified accordingly. To migrate, put your old CloseHook#close impl into
- CloseHook#preClose.
- New Features
- ----------------------
- * SOLR-2378: A new, automaton-based, implementation of suggest (autocomplete)
- component, offering an order of magnitude smaller memory consumption
- compared to ternary trees and jaspell and very fast lookups at runtime.
- (Dawid Weiss)
- * SOLR-2400: Field- and DocumentAnalysisRequestHandler now provide a position
- history for each token, so you can follow the token through all analysis stages.
- The output contains a separate int[] attribute containing all positions from
- previous Tokenizers/TokenFilters (called "positionHistory").
- (Uwe Schindler)
- * SOLR-2524: (SOLR-236, SOLR-237, SOLR-1773, SOLR-1311) Grouping / Field collapsing
- using the Lucene grouping contrib. The search result can be grouped by field and query.
- (Martijn van Groningen, Emmanuel Keller, Shalin Shekhar Mangar, Koji Sekiguchi,
- Iván de Prado, Ryan McKinley, Marc Sturlese, Peter Karich, Bojan Smid,
- Charles Hornberger, Dieter Grad, Dmitry Lihachev, Doug Steigerwald,
- Karsten Sperling, Michael Gundlach, Oleg Gnatovskiy, Thomas Traeger,
- Harish Agarwal, yonik, Michael McCandless, Bill Bell)
- * SOLR-1331 -- Added a srcCore parameter to CoreAdminHandler's mergeindexes action
- to merge one or more cores' indexes to a target core (shalin)
- * SOLR-2610 -- Add an option to delete index through CoreAdmin UNLOAD action (shalin)
- * SOLR-2480: Add ignoreTikaException flag to the extraction request handler so
- that users can ignore TikaException but index meta data.
- (Shinichiro Abe, koji)
- * SOLR-2582: Use uniqueKey for error log in UIMAUpdateRequestProcessor.
- (Tommaso Teofili via koji)
- Optimizations
- ----------------------
- * SOLR-2567: Solr now defaults to TieredMergePolicy. See http://s.apache.org/merging
- for more information. (rmuir)
- Bug Fixes
- ----------------------
- * SOLR-2519: Improve text_* fieldTypes in example schema.xml: improve
- cross-language defaults for text_general; break out separate
- English-specific fieldTypes (Jan Høydahl, hossman, Robert Muir,
- yonik, Mike McCandless)
- * SOLR-2462: Fix extremely high memory usage problems with spellcheck.collate.
- Separately, an additional spellcheck.maxCollationEvaluations (default=10000)
- parameter is added to avoid excessive CPU time in extreme cases (e.g. long
- queries with many misspelled words). (James Dyer via rmuir)
- * SOLR-2579: UIMAUpdateRequestProcessor ignore error fails if text.length() < 100.
- (Elmer Garduno via koji)
- * SOLR-2581: UIMAToSolrMapper wrongly instantiates Type with reflection.
- (Tommaso Teofili via koji)
- * SOLR-2551: Check dataimport.properties for write access (if delta-import is
- supported in DIH configuration) before starting an import (C S, shalin)
- Other Changes
- ----------------------
- * SOLR-2571: Add a commented out example of the spellchecker's thresholdTokenFrequency
- parameter to the example solrconfig.xml, and also add a unit test for this feature.
- (James Dyer via rmuir)
- * SOLR-2576: Deprecate SpellingResult.add(Token token, int docFreq), please use
- SpellingResult.addFrequency(Token token, int docFreq) instead.
- (James Dyer via rmuir)
- * SOLR-2574: Upgrade slf4j to v1.6.1 (shalin)
- * LUCENE-3204: The maven-ant-tasks jar is now included in the source tree;
- users of the generate-maven-artifacts target no longer have to manually
- place this jar in the Ant classpath. NOTE: when Ant looks for the
- maven-ant-tasks jar, it looks first in its pre-existing classpath, so
- any copies it finds will be used instead of the copy included in the
- Lucene/Solr source tree. For this reason, it is recommeded to remove
- any copies of the maven-ant-tasks jar in the Ant classpath, e.g. under
- ~/.ant/lib/ or under the Ant installation's lib/ directory. (Steve Rowe)
- * SOLR-2611: Fix typos in the example configuration (Eric Pugh via rmuir)
- ================== 3.2.0 ==================
- Versions of Major Components
- ---------------------
- Apache Lucene trunk
- Apache Tika 0.8
- Carrot2 3.4.2
- Upgrading from Solr 3.1
- ----------------------
- * The updateRequestProcessorChain for a RequestHandler is now defined
- with update.chain rather than update.processor. The latter still works,
- but has been deprecated.
- * <uimaConfig/> just beneath <config> ... </config> is no longer supported.
- It should move to UIMAUpdateRequestProcessorFactory setting.
- See contrib/uima/README.txt for more details. (SOLR-2436)
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-2496: Add ability to specify overwrite and commitWithin as request
- parameters (e.g. specified in the URL) when using the JSON update format,
- and added a simplified format for specifying multiple documents.
- Example: [{"id":"doc1"},{"id":"doc2"}]
- (yonik)
- * SOLR-2113: Add TermQParserPlugin, registered as "term". This is useful
- when generating filter queries from terms returned from field faceting or
- the terms component. Example: fq={!term f=weight}1.5 (hossman, yonik)
- * SOLR-1915: DebugComponent now supports using a NamedList to model
- Explanation objects in its responses instead of
- Explanation.toString (hossman)
- * SOLR-2448: Search results clustering updates: bisecting k-means
- clustering algorithm added, loading of Carrot2 stop words from
- <solr.home>/conf/carrot2 (SOLR-2449), using Solr's stopwords.txt
- for clustering (SOLR-2450), output of cluster scores (SOLR-2505)
- (Stanislaw Osinski, Dawid Weiss).
- * SOLR-2503: extend UIMAUpdateRequestProcessorFactory mapping function to
- map feature value to dynamicField. (koji)
- * SOLR-2512: add ignoreErrors flag to UIMAUpdateRequestProcessorFactory so
- that users can ignore exceptions in AE. (Tommaso Teofili, koji)
- Optimizations
- ----------------------
- Bug Fixes
- ----------------------
- * SOLR-2445: Change the default qt to blank in form.jsp, because there is no "standard"
- request handler unless you have it in your solrconfig.xml explicitly. (koji)
- * SOLR-2455: Prevent double submit of forms in admin interface.
- (Jeffrey Chang via uschindler)
- * SOLR-2464: Fix potential slowness in QueryValueSource (the query() function) when
- the query is very sparse and may not match any documents in a segment. (yonik)
- * SOLR-2469: When using java replication with replicateAfter=startup, the first
- commit point on server startup is never removed. (yonik)
- * SOLR-2466: SolrJ's CommonsHttpSolrServer would retry requests on failure, regardless
- of the configured maxRetries, due to HttpClient having its own retry mechanism
- by default. The retryCount of HttpClient is now set to 0, and SolrJ does
- the retry. (yonik)
- * SOLR-2409: edismax parser - treat the text of a fielded query as a literal if the
- fieldname does not exist. For example Mission: Impossible should not search on
- the "Mission" field unless it's a valid field in the schema. (Ryan McKinley, yonik)
- * SOLR-2403: facet.sort=index reported incorrect results for distributed search
- in a number of scenarios when facet.mincount>0. This patch also adds some
- performance/algorithmic improvements when (facet.sort=count && facet.mincount=1
- && facet.limit=-1) and when (facet.sort=index && facet.mincount>0) (yonik)
- * SOLR-2333: The "rename" core admin action does not persist the new name to solr.xml
- (Rasmus Hahn, Paul R. Brown via Mark Miller)
- * SOLR-2390: Performance of usePhraseHighlighter is terrible on very large Documents,
- regardless of hl.maxDocCharsToAnalyze. (Mark Miller)
- * SOLR-2474: The helper TokenStreams in analysis.jsp and AnalysisRequestHandlerBase
- did not clear all attributes so they displayed incorrect attribute values for tokens
- in later filter stages. (uschindler, rmuir, yonik)
- * SOLR-2467: Fix <analyzer class="..." /> initialization so any errors
- are logged properly. (hossman)
- * SOLR-2493: SolrQueryParser was fixed to not parse the SolrConfig DOM tree on each
- instantiation which is a huge slowdown. (Stephane Bailliez via uschindler)
- * SOLR-2495: The JSON parser could hang on corrupted input and could fail
- to detect numbers that were too large to fit in a long. (yonik)
- * SOLR-2520: Make JSON response format escape \u2029 as well as \u2028
- in strings since those characters are not valid in javascript strings
- (although they are valid in JSON strings). (yonik)
- * SOLR-2536: Add ReloadCacheRequestHandler to fix ExternalFileField bug (if reopenReaders
- set to true and no index segments have been changed, commit cannot trigger reload
- external file). (koji)
- * SOLR-2539: VectorValueSource.floatVal incorrectly used byteVal on sub-sources.
- (Tom Liu via yonik)
- * SOLR-2554: RandomSortField didn't work when used in a function query. (yonik)
- Other Changes
- ----------------------
- * SOLR-2061: Pull base tests out into a new Solr Test Framework module,
- and publish binary, javadoc, and source test-framework jars.
- (Drew Farris, Robert Muir, Steve Rowe)
- * SOLR-2105: Rename RequestHandler param 'update.processor' to 'update.chain'.
- (Jan Høydahl via Mark Miller)
- * SOLR-2485: Deprecate BaseResponseWriter, GenericBinaryResponseWriter, and
- GenericTextResponseWriter. These classes will be removed in 4.0. (ryan)
- * SOLR-2451: Enhance assertJQ to allow individual tests to specify the
- tolerance delta used in numeric equalities. This allows for slight
- variance in asserting score comparisons in unit tests.
- (David Smiley, Chris Hostetter)
- * SOLR-2528: Remove default="true" from HtmlEncoder in example solrconfig.xml,
- because html encoding confuses non-ascii users. (koji)
- * SOLR-2387: add mock annotators for improved testing in contrib/uima,
- (Tommaso Teofili via rmuir)
- * SOLR-2436: move uimaConfig to under the uima's update processor in
- solrconfig.xml. (Tommaso Teofili, koji)
- Build
- ----------------------
- * LUCENE-3006: Building javadocs will fail on warnings by default. Override with -Dfailonjavadocwarning=false (sarowe, gsingers)
- Documentation
- ----------------------
- ================== 3.1.0 ==================
- Versions of Major Components
- ---------------------
- Apache Lucene 3.1.0
- Apache Tika 0.8
- Carrot2 3.4.2
- Velocity 1.6.1 and Velocity Tools 2.0-beta3
- Apache UIMA 2.3.1-SNAPSHOT
- Upgrading from Solr 1.4
- ----------------------
- * The Lucene index format has changed and as a result, once you upgrade,
- previous versions of Solr will no longer be able to read your indices.
- In a master/slave configuration, all searchers/slaves should be upgraded
- before the master. If the master were to be updated first, the older
- searchers would not be able to read the new index format.
- * The Solr JavaBin format has changed as of Solr 3.1. If you are using the
- JavaBin format, you will need to upgrade your SolrJ client. (SOLR-2034)
- * The experimental ALIAS command has been removed (SOLR-1637)
- * Using solr.xml is recommended for single cores also (SOLR-1621)
- * Old syntax of <highlighting> configuration in solrconfig.xml
- is deprecated (SOLR-1696)
- * The deprecated HTMLStripReader, HTMLStripWhitespaceTokenizerFactory and
- HTMLStripStandardTokenizerFactory were removed. To strip HTML tags,
- HTMLStripCharFilter should be used instead, and it works with any
- Tokenizer of your choice. (SOLR-1657)
- * Field compression is no longer supported. Fields that were formerly
- compressed will be uncompressed as index segments are merged. For
- shorter fields, this may actually be an improvement, as the compression
- used was not very good for short text. Some indexes may get larger though.
- * SOLR-1845: The TermsComponent response format was changed so that the
- "terms" container is a map instead of a named list. This affects
- response formats like JSON, but not XML. (yonik)
- * SOLR-1876: All Analyzers and TokenStreams are now final to enforce
- the decorator pattern. (rmuir, uschindler)
- * LUCENE-2608: Added the ability to specify the accuracy on a per request basis.
- It is recommended that implementations of SolrSpellChecker should change over to the new SolrSpellChecker
- methods using the new SpellingOptions class, but are not required to. While this change is
- backward compatible, the trunk version of Solr has already dropped support for all but the SpellingOptions method. (gsingers)
- * readercycle script was removed. (SOLR-2046)
- * In previous releases, sorting or evaluating function queries on
- fields that were "multiValued" (either by explicit declaration in
- schema.xml or by implict behavior because the "version" attribute on
- the schema was less then 1.2) did not generally work, but it would
- sometimes silently act as if it succeeded and order the docs
- arbitrarily. Solr will now fail on any attempt to sort, or apply a
- function to, multi-valued fields
- * The DataImportHandler jars are no longer included in the solr
- WAR and should be added in Solr's lib directory, or referenced
- via the <lib> directive in solrconfig.xml.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- * SOLR-1302: Added several new distance based functions, including
- Great Circle (haversine), Manhattan, Euclidean and String (using the
- StringDistance methods in the Lucene spellchecker).
- Also added geohash(), deg() and rad() convenience functions.
- See http://wiki.apache.org/solr/FunctionQuery. (gsingers)
- * SOLR-1553: New dismax parser implementation (accessible as "edismax")
- that supports full lucene syntax, improved reserved char escaping,
- fielded queries, improved proximity boosting, and improved stopword
- handling. Note: status is experimental for now. (yonik)
- * SOLR-1574: Add many new functions from java Math (e.g. sin, cos) (yonik)
- * SOLR-1569: Allow functions to take in literal strings by modifying the
- FunctionQParser and adding LiteralValueSource (gsingers)
- * SOLR-1571: Added unicode collation support though Lucene's CollationKeyFilter
- (Robert Muir via shalin)
- * SOLR-785: Distributed Search support for SpellCheckComponent
- (Matthew Woytowitz, shalin)
- * SOLR-1625: Add regexp support for TermsComponent (Uri Boness via noble)
- * SOLR-1297: Add sort by Function capability (gsingers, yonik)
- * SOLR-1139: Add TermsComponent Query and Response Support in SolrJ (Matt Weber via shalin)
- * SOLR-1177: Distributed Search support for TermsComponent (Matt Weber via shalin)
- * SOLR-1621, SOLR-1722: Allow current single core deployments to be specified by solr.xml (Mark Miller , noble)
- * SOLR-1532: Allow StreamingUpdateSolrServer to use a provided HttpClient (Gabriele Renzi via shalin)
- * SOLR-1653: Add PatternReplaceCharFilter (koji)
- * SOLR-1131: FieldTypes can now output multiple Fields per Type and still be searched. This can be handy for hiding the details of a particular
- implementation such as in the spatial case. (Chris Mattmann, shalin, noble, gsingers, yonik)
- * SOLR-1586: Add support for Geohash and Spatial Tile FieldType (Chris Mattmann, gsingers)
- * SOLR-1697: PluginInfo should load plugins w/o class attribute also (noble)
- * SOLR-1268: Incorporate FastVectorHighlighter (koji)
- * SOLR-1750: SolrInfoMBeanHandler added for simpler programmatic access
- to info currently available from registry.jsp and stats.jsp
- (ehatcher, hossman)
- * SOLR-1815: SolrJ now preserves the order of facet queries. (yonik)
- * SOLR-1677: Add support for choosing the Lucene Version for Lucene components within
- Solr. (Uwe Schindler, Mark Miller)
- * SOLR-1379: Add RAMDirectoryFactory for non-persistent in memory index storage.
- (Alex Baranov via yonik)
- * SOLR-1857: Synced Solr analysis with Lucene 3.1. Added KeywordMarkerFilterFactory
- and StemmerOverrideFilterFactory, which can be used to tune stemming algorithms.
- Added factories for Bulgarian, Czech, Hindi, Turkish, and Wikipedia analysis. Improved the
- performance of SnowballPorterFilterFactory. (rmuir)
- * SOLR-1657: Converted remaining TokenStreams to the Attributes-based API. All Solr
- TokenFilters now support custom Attributes, and some have improved performance:
- especially WordDelimiterFilter and CommonGramsFilter. (rmuir, cmale, uschindler)
- * SOLR-1740: ShingleFilterFactory supports the "minShingleSize" and "tokenSeparator"
- parameters for controlling the minimum shingle size produced by the filter, and
- the separator string that it uses, respectively. (Steven Rowe via rmuir)
- * SOLR-744: ShingleFilterFactory supports the "outputUnigramsIfNoShingles"
- parameter, to output unigrams if the number of input tokens is fewer than
- minShingleSize, and no shingles can be generated.
- (Chris Harris via Steven Rowe)
- * SOLR-1923: PhoneticFilterFactory now has support for the
- Caverphone algorithm. (rmuir)
- * SOLR-1957: The VelocityResponseWriter contrib moved to core.
- Example search UI now available at http://localhost:8983/solr/browse
- (ehatcher)
- * SOLR-1974: Add LimitTokenCountFilterFactory. (koji)
- * SOLR-1966: QueryElevationComponent can now return just the included results in the elevation file (gsingers, yonik)
- * SOLR-1556: TermVectorComponent now supports per field overrides. Also, it now throws an error
- if passed in fields do not exist and warnings
- if fields that do not have term vector options (termVectors, offsets, positions)
- that align with the schema declaration. It also
- will now return warnings about (gsingers)
- * SOLR-1985: FastVectorHighlighter: add wrapper class for Lucene's SingleFragListBuilder (koji)
- * SOLR-1984: Add HyphenationCompoundWordTokenFilterFactory. (PB via rmuir)
- * SOLR-397: Date Faceting now supports a "facet.date.include" param
- for specifying when the upper & lower end points of computed date
- ranges should be included in the range. Legal values are: "all",
- "lower", "upper", "edge", and "outer". For backwards compatibility
- the default value is the set: [lower,upper,edge], so that all ranges
- between start and end are inclusive of their endpoints, but the
- "before" and "after" ranges are not.
- * SOLR-945: JSON update handler that accepts add, delete, commit
- commands in JSON format. (Ryan McKinley, yonik)
- * SOLR-2015: Add a boolean attribute autoGeneratePhraseQueries to TextField.
- autoGeneratePhraseQueries="true" (the default) causes the query parser to
- generate phrase queries if multiple tokens are generated from a single
- non-quoted analysis string. For example WordDelimiterFilter splitting text:pdp-11
- will cause the parser to generate text:"pdp 11" rather than (text:PDP OR text:11).
- Note that autoGeneratePhraseQueries="true" tends to not work well for non whitespace
- delimited languages. (yonik)
- * SOLR-1925: Add CSVResponseWriter (use wt=csv) that returns the list of documents
- in CSV format. (Chris Mattmann, yonik)
- * SOLR-1240: "Range Faceting" has been added. This is a generalization
- of the existing "Date Faceting" logic so that it now supports any
- all stock numeric field types that support range queries in addition
- to dates. facet.date is now deprecated in favor of this generalized mechanism.
- (Gijs Kunze, hossman)
- * SOLR-2021: Add SolrEncoder plugin to Highlighter. (koji)
- * SOLR-2030: Make FastVectorHighlighter use of SolrEncoder. (koji)
- * SOLR-2053: Add support for custom comparators in Solr spellchecker, per LUCENE-2479 (gsingers)
- * SOLR-2049: Add hl.multiValuedSeparatorChar for FastVectorHighlighter, per LUCENE-2603. (koji)
- * SOLR-2059: Add "types" attribute to WordDelimiterFilterFactory, which
- allows you to customize how WordDelimiterFilter tokenizes text with
- a configuration file. (Peter Karich, rmuir)
- * SOLR-2099: Add ability to throttle rsync based replication using rsync option --bwlimit.
- (Brandon Evans via koji)
- * SOLR-1316: Create autosuggest component.
- (Ankul Garg, Jason Rutherglen, Shalin Shekhar Mangar, Grant Ingersoll, Robert Muir, ab)
- * SOLR-1568: Added "native" filtering support for PointType, GeohashField. Added LatLonType with filtering support too. See
- http://wiki.apache.org/solr/SpatialSearch and the example. Refactored some items in Lucene spatial.
- Removed SpatialTileField as the underlying CartesianTier is broken beyond repair and is going to be moved. (gsingers)
- * SOLR-2128: Full parameter substitution for function queries.
- Example: q=add($v1,$v2)&v1=mul(popularity,5)&v2=20.0
- (yonik)
- * SOLR-2133: Function query parser can now parse multiple comma separated
- value sources. It also now fails if there is extra unexpected text
- after parsing the functions, instead of silently ignoring it.
- This allows expressions like q=dist(2,vector(1,2),$pt)&pt=3,4 (yonik)
- * SOLR-2157: Suggester should return alpha-sorted results when onlyMorePopular=false (ab)
- * SOLR-2010: Added ability to verify that spell checking collations have
- actual results in the index. (James Dyer via gsingers)
- * SOLR-2188: Added "maxTokenLength" argument to the factories for ClassicTokenizer,
- StandardTokenizer, and UAX29URLEmailTokenizer. (Steven Rowe)
- * SOLR-2129: Added a Solr module for dynamic metadata extraction/indexing with Apache UIMA.
- See contrib/uima/README.txt for more information. (Tommaso Teofili via rmuir)
- * SOLR-2325: Allow tagging and exclusion of main query for faceting. (yonik)
- * SOLR-2263: Add ability for RawResponseWriter to stream binary files as well as
- text files. (Eric Pugh via yonik)
- * SOLR-860: Add debug output for MoreLikeThis. (koji)
- * SOLR-1057: Add PathHierarchyTokenizerFactory. (ryan, koji)
- * SOLR-1804: Re-enabled clustering component on trunk, updated to latest
- version of Carrot2. No more LGPL run-time dependencies. This release of
- C2 also does not have a specific Lucene dependency.
- (Stanislaw Osinski, gsingers)
- * SOLR-2282: Add distributed search support for search result clustering.
- (Brad Giaccio, Dawid Weiss, Stanislaw Osinski, rmuir, koji)
- * SOLR-2210: Add icu-based tokenizer and filters to contrib/analysis-extras (rmuir)
- * SOLR-1336: Add SmartChinese (word segmentation for Simplified Chinese)
- tokenizer and filters to contrib/analysis-extras (rmuir)
- * SOLR-2211,LUCENE-2763: Added UAX29URLEmailTokenizerFactory, which implements
- UAX#29, a unicode algorithm with good results for most languages, as well as
- URL and E-mail tokenization according to the relevant RFCs.
- (Tom Burton-West via rmuir)
- * SOLR-2237: Added StempelPolishStemFilterFactory to contrib/analysis-extras (rmuir)
- * SOLR-1525: allow DIH to refer to core properties (noble)
- * SOLR-1547: DIH TemplateTransformer copy objects more intelligently when the
- template is a single variable (noble)
- * SOLR-1627: DIH VariableResolver should be fetched just in time (noble)
- * SOLR-1583: DIH Create DataSources that return InputStream (noble)
- * SOLR-1358: Integration of Tika and DataImportHandler (Akshay Ukey, noble)
- * SOLR-1654: TikaEntityProcessor example added DIHExample
- (Akshay Ukey via noble)
- * SOLR-1678: Move onError handling to DIH framework (noble)
- * SOLR-1352: Multi-threaded implementation of DIH (noble)
- * SOLR-1721: Add explicit option to run DataImportHandler in synchronous mode
- (Alexey Serba via noble)
- * SOLR-1737: Added FieldStreamDataSource (noble)
- Optimizations
- ----------------------
- * SOLR-1679: Don't build up string messages in SolrCore.execute unless they
- are necessary for the current log level.
- (Fuad Efendi and hossman)
- * SOLR-1874: Optimize PatternReplaceFilter for better performance. (rmuir, uschindler)
- * SOLR-1968: speed up initial filter cache population for facet.method=enum and
- also big terms for multi-valued facet.method=fc. The resulting speedup
- for the first facet request is anywhere from 30% to 32x, depending on how many
- terms are in the field and how many documents match per term. (yonik)
- * SOLR-2089: Speed up UnInvertedField faceting (facet.method=fc for
- multi-valued fields) when facet.limit is both high, and a high enough
- percentage of the number of unique terms in the field. Extreme cases
- yield speedups over 3x. (yonik)
- * SOLR-2046: add common functions to scripts-util. (koji)
- * SOLR-1684: Switch clustering component to use the
- SolrIndexSearcher.doc(int, Set<String>) method b/c it can use the document
- cache (gsingers)
- * SOLR-2200: Improve the performance of DataImportHandler for large
- delta-import updates. (Mark Waddle via rmuir)
- Bug Fixes
- ----------------------
- * SOLR-1769: Solr 1.4 Replication - Repeater throwing NullPointerException (Jörgen Rydenius via noble)
- * SOLR-1432: Make the new ValueSource.getValues(context,reader) delegate
- to the original ValueSource.getValues(reader) so custom sources
- will work. (yonik)
- * SOLR-1572: FastLRUCache correctly implemented the LRU policy only
- for the first 2B accesses. (yonik)
- * SOLR-1582: copyField was ignored for BinaryField types (gsingers)
- * SOLR-1563: Binary fields, including trie-based numeric fields, caused null
- pointer exceptions in the luke request handler. (yonik)
- * SOLR-1577: The example solrconfig.xml defaulted to a solr data dir
- relative to the current working directory, even if a different solr home
- was being used. The new behavior changes the default to a zero length
- string, which is treated the same as if no dataDir had been specified,
- hence the "data" directory under the solr home will be used. (yonik)
- * SOLR-1584: SolrJ - SolrQuery.setIncludeScore() incorrectly added
- fl=score to the parameter list instead of appending score to the
- existing field list. (yonik)
- * SOLR-1580: Solr Configuration ignores 'mergeFactor' parameter, always
- uses Lucene default. (Lance Norskog via Mark Miller)
- * SOLR-1593: ReverseWildcardFilter didn't work for surrogate pairs
- (i.e. code points outside of the BMP), resulting in incorrect
- matching. This change requires reindexing for any content with
- such characters. (Robert Muir, yonik)
- * SOLR-1596: A rollback operation followed by the shutdown of Solr
- or the close of a core resulted in a warning:
- "SEVERE: SolrIndexWriter was not closed prior to finalize()" although
- there were no other consequences. (yonik)
- * SOLR-1595: StreamingUpdateSolrServer used the platform default character
- set when streaming updates, rather than using UTF-8 as the HTTP headers
- indicated, leading to an encoding mismatch. (hossman, yonik)
- * SOLR-1587: A distributed search request with fl=score, didn't match
- the behavior of a non-distributed request since it only returned
- the id,score fields instead of all fields in addition to score. (yonik)
- * SOLR-1601: Schema browser does not indicate presence of charFilter. (koji)
- * SOLR-1615: Backslash escaping did not work in quoted strings
- for local param arguments. (Wojtek Piaseczny, yonik)
- * SOLR-1628: log contains incorrect number of adds and deletes.
- (Thijs Vonk via yonik)
- * SOLR-343: Date faceting now respects facet.mincount limiting
- (Uri Boness, Raiko Eckstein via hossman)
- * SOLR-1624: Highlighter only highlights values from the first field value
- in a multivalued field when term positions (term vectors) are stored.
- (Chris Harris via yonik)
- * SOLR-1635: Fixed error message when numeric values can't be parsed by
- DOMUtils - notably for plugin init params in solrconfig.xml.
- (hossman)
- * SOLR-1651: Fixed Incorrect dataimport handler package name in SolrResourceLoader
- (Akshay Ukey via shalin)
- * SOLR-1660: CapitalizationFilter crashes if you use the maxWordCountOption
- (Robert Muir via shalin)
- * SOLR-1667: PatternTokenizer does not reset attributes such as positionIncrementGap
- (Robert Muir via shalin)
- * SOLR-1711: SolrJ - StreamingUpdateSolrServer had a race condition that
- could halt the streaming of documents. The original patch to fix this
- (never officially released) introduced another hanging bug due to
- connections not being released.
- (Attila Babo, Erik Hetzner, Johannes Tuchscherer via yonik)
- * SOLR-1748, SOLR-1747, SOLR-1746, SOLR-1745, SOLR-1744: Streams and Readers
- retrieved from ContentStreams are not closed in various places, resulting
- in file descriptor leaks.
- (Christoff Brill, Mark Miller)
- * SOLR-1753: StatsComponent throws NPE when getting statistics for facets in distributed search
- (Janne Majaranta via koji)
- * SOLR-1736:In the slave , If 'mov'ing file does not succeed , copy the file (noble)
- * SOLR-1579: Fixes to XML escaping in stats.jsp
- (David Bowen and hossman)
- * SOLR-1777: fieldTypes with sortMissingLast=true or sortMissingFirst=true can
- result in incorrectly sorted results. (yonik)
- * SOLR-1798: Small memory leak (~100 bytes) in fastLRUCache for every
- commit. (yonik)
- * SOLR-1823: Fixed XMLResponseWriter (via XMLWriter) so it no longer throws
- a ClassCastException when a Map containing a non-String key is used.
- (Frank Wesemann, hossman)
- * SOLR-1797: fix ConcurrentModificationException and potential memory
- leaks in ResourceLoader. (yonik)
- * SOLR-1850: change KeepWordFilter so a new word set is not created for
- each instance (John Wang via yonik)
- * SOLR-1706: fixed WordDelimiterFilter for certain combinations of options
- where it would output incorrect tokens. (Robert Muir, Chris Male)
- * SOLR-1936: The JSON response format needed to escape unicode code point
- U+2028 - 'LINE SEPARATOR' (Robert Hofstra, yonik)
- * SOLR-1914: Change the JSON response format to output float/double
- values of NaN,Infinity,-Infinity as strings. (yonik)
- * SOLR-1948: PatternTokenizerFactory should use parent's args (koji)
- * SOLR-1870: Indexing documents using the 'javabin' format no longer
- fails with a ClassCastException whenSolrInputDocuments contain field
- values which are Collections or other classes that implement
- Iterable. (noble, hossman)
- * SOLR-1981: Solr will now fail correctly if solr.xml attempts to
- specify multiple cores that have the same name (hossman)
- * SOLR-1791: Fix messed up core names on admin gui (yonik via koji)
- * SOLR-1995: Change date format from "hour in am/pm" to "hour in day"
- in CoreContainer and SnapShooter. (Hayato Ito, koji)
- * SOLR-2008: avoid possible RejectedExecutionException w/autoCommit
- by making SolreCore close the UpdateHandler before closing the
- SearchExecutor. (NarasimhaRaju, hossman)
- * SOLR-2036: Avoid expensive fieldCache ram estimation for the
- admin stats page. (yonik)
- * SOLR-2047: ReplicationHandler should accept bool type for enable flag. (koji)
- * SOLR-1630: Fix spell checking collation issue related to token positions (rmuir, gsingers)
- * SOLR-2100: The replication handler backup command didn't save the commit
- point and hence could fail when a newer commit caused the older commit point
- to be removed before it was finished being copied. This did not affect
- normal master/slave replication. (Peter Sturge via yonik)
- * SOLR-2114: Fixed parsing error in hsin function. The function signature has changed slightly. (gsingers)
- * SOLR-2083: SpellCheckComponent misreports suggestions when distributed (James Dyer via gsingers)
- * SOLR-2111: Change exception handling in distributed faceting to work more
- like non-distributed faceting, change facet_counts/exception from a String
- to a List<String> to enable listing all exceptions that happened, and
- prevent an exception in one facet command from affecting another
- facet command. (yonik)
- * SOLR-2110: Remove the restriction on names for local params
- substitution/dereferencing. Properly encode local params in
- distributed faceting. (yonik)
- * SOLR-2135: Fix behavior of ConcurrentLRUCache when asking for
- getLatestAccessedItems(0) or getOldestAccessedItems(0).
- (David Smiley via hossman)
- * SOLR-2148: Highlighter doesn't support q.alt. (koji)
- * SOLR-2180: It was possible for EmbeddedSolrServer to leave searchers
- open if a request threw an exception. (yonik)
- * SOLR-2173: Suggester should always rebuild Lookup data if Lookup.load fails. (ab)
- * SOLR-2081: BaseResponseWriter.isStreamingDocs causes
- SingleResponseWriter.end to be called 2x
- (Chris A. Mattmann via hossman)
- * SOLR-2219: The init() method of every SolrRequestHandler was being
- called twice. (ambikeshwar singh and hossman)
- * SOLR-2285: duplicate SolrEventListeners no longer created (hossman)
- * SOLR-1993: fix String cast assumption in JavaBinCodec - specific
- addresses "commitWithin" option on Update requests.
- (noble, hossman, and Maxim Valyanskiy)
- * SOLR-2261: fix velocity template layout.vm that referred to an older
- version of jquery. (Eric Pugh via rmuir)
- * SOLR-2307: fix bug in PHPSerializedResponseWriter (wt=phps) when
- dealing with SolrDocumentList objects -- ie: sharded queries.
- (Antonio Verni via hossman)
- * SOLR-2127: Fixed serialization of default core and indentation of solr.xml when serializing.
- (Ephraim Ofir, Mark Miller)
- * SOLR-2320: Fixed ReplicationHandler detail reporting for masters
- (hossman)
- * SOLR-482: Provide more exception handling in CSVLoader (gsingers)
- * SOLR-1283: HTMLStripCharFilter sometimes threw a "Mark Invalid" exception.
- (Julien Coloos, hossman, yonik)
- * SOLR-2085: Improve SolrJ behavior when FacetComponent comes before
- QueryComponent (Tomas Salfischberger via hossman)
- * SOLR-1940: Fix SolrDispatchFilter behavior when Content-Type is
- unknown (Lance Norskog and hossman)
- * SOLR-1983: snappuller fails when modifiedConfFiles is not empty and
- full copy of index is needed. (Alexander Kanarsky via yonik)
- * SOLR-2156: SnapPuller fails to clean Old Index Directories on Full Copy
- (Jayendra Patil via yonik)
- * SOLR-96: Fix XML parsing in XMLUpdateRequestHandler and
- DocumentAnalysisRequestHandler to respect charset from XML file and only
- use HTTP header's "Content-Type" as a "hint". (uschindler)
- * SOLR-2339: Fix sorting to explicitly generate an error if you
- attempt to sort on a multiValued field. (hossman)
- * SOLR-2348: Fix field types to explicitly generate an error if you
- attempt to get a ValueSource for a multiValued field. (hossman)
- * SOLR-2380: Distributed faceting could miss values when facet.sort=index
- and when facet.offset was greater than 0. (yonik)
- * SOLR-1656: XIncludes and other HREFs in XML files loaded by ResourceLoader
- are fixed to be resolved using the URI standard (RFC 2396). The system
- identifier is no longer a plain filename with path, it gets initialized
- using a custom URI scheme "solrres:". This scheme is resolved using a
- EntityResolver that utilizes ResourceLoader
- (org.apache.solr.common.util.SystemIdResolver). This makes all relative
- pathes in Solr's config files behave like expected. This change
- introduces some backwards breaks in the API: Some config classes
- (Config, SolrConfig, IndexSchema) were changed to take
- org.xml.sax.InputSource instead of InputStream. There may also be some
- backwards breaks in existing config files, it is recommended to check
- your config files / XSLTs and replace all XIncludes/HREFs that were
- hacked to use absolute paths to use relative ones. (uschindler)
- * SOLR-309: Fix FieldType so setting an analyzer on a FieldType that
- doesn't expect it will generate an error. Practically speaking this
- means that Solr will now correctly generate an error on
- initialization if the schema.xml contains an analyzer configuration
- for a fieldType that does not use TextField. (hossman)
- * SOLR-2192: StreamingUpdateSolrServer.blockUntilFinished was not
- thread safe and could throw an exception. (yonik)
- * SOLR-1692: Fix bug in clustering component relating to carrot.produceSummary
- option (gsingers)
- * SOLR-1756: The date.format setting for extraction request handler causes
- ClassCastException when enabled and the config code that parses this setting
- does not properly use the same iterator instance.
- (Christoph Brill, Mark Miller)
- * SOLR-1638: Fixed NullPointerException during DIH import if uniqueKey is not
- specified in schema (Akshay Ukey via shalin)
- * SOLR-1639: Fixed misleading error message when dataimport.properties is not
- writable (shalin)
- * SOLR-1598: DIH: Reader used in PlainTextEntityProcessor is not explicitly
- closed (Sascha Szott via noble)
- * SOLR-1759: DIH: $skipDoc was not working correctly
- (Gian Marco Tagliani via noble)
- * SOLR-1762: DIH: DateFormatTransformer does not work correctly with
- non-default locale dates (tommy chheng via noble)
- * SOLR-1757: DIH multithreading sometimes throws NPE (noble)
- * SOLR-1766: DIH with threads enabled doesn't respond to the abort command
- (Michael Henson via noble)
- * SOLR-1767: dataimporter.functions.escapeSql() does not escape backslash
- character (Sean Timm via noble)
- * SOLR-1811: formatDate should use the current NOW value always
- (Sean Timm via noble)
- * SOLR-1794: Dataimport of CLOB fields fails when getCharacterStream() is
- defined in a superclass. (Gunnar Gauslaa Bergem via rmuir)
- * SOLR-2057: DataImportHandler never calls UpdateRequestProcessor.finish()
- (Drew Farris via koji)
- * SOLR-1973: Empty fields in XML update messages confuse DataImportHandler.
- (koji)
- * SOLR-2221: Use StrUtils.parseBool() to get values of boolean options in DIH.
- true/on/yes (for TRUE) and false/off/no (for FALSE) can be used for
- sub-options (debug, verbose, synchronous, commit, clean, optimize) for
- full/delta-import commands. (koji)
- * SOLR-2310: DIH: getTimeElapsedSince() returns incorrect hour value when
- the elapse is over 60 hours (tom liu via koji)
- * SOLR-2252: DIH: When a child entity in nested entities is rootEntity="true",
- delta-import doesn't work. (koji)
- * SOLR-2330: solrconfig.xml files in example-DIH are broken. (Matt Parker, koji)
- * SOLR-1191: resolve DataImportHandler deltaQuery column against pk when pk
- has a prefix (e.g. pk="book.id" deltaQuery="select id from ..."). More
- useful error reporting when no match found (previously failed with a
- NullPointerException in log and no clear user feedback). (gthb via yonik)
- * SOLR-2116: Fix TikaConfig classloader bug in TikaEntityProcessor
- (Martijn van Groningen via hossman)
- Other Changes
- ----------------------
- * SOLR-1602: Refactor SOLR package structure to include o.a.solr.response
- and move QueryResponseWriters in there
- (Chris A. Mattmann, ryan, hoss)
- * SOLR-1516: Addition of an abstract BaseResponseWriter class to simplify the
- development of QueryResponseWriter implementations.
- (Chris A. Mattmann via noble)
- * SOLR-1592: Refactor XMLWriter startTag to allow arbitrary attributes to be written
- (Chris A. Mattmann via noble)
- * SOLR-1561: Added Lucene 2.9.1 spatial contrib jar to lib. (gsingers)
- * SOLR-1570: Log warnings if uniqueKey is multi-valued or not stored (hossman, shalin)
- * SOLR-1558: QueryElevationComponent only works if the uniqueKey field is
- implemented using StrField. In previous versions of Solr no warning or
- error would be generated if you attempted to use QueryElevationComponent,
- it would just fail in unexpected ways. This has been changed so that it
- will fail with a clear error message on initialization. (hossman)
- * SOLR-1611: Added Lucene 2.9.1 collation contrib jar to lib (shalin)
- * SOLR-1608: Extract base class from TestDistributedSearch to make
- it easy to write test cases for other distributed components. (shalin)
- * Upgraded to Lucene 2.9-dev r888785 (shalin)
- * SOLR-1610: Generify SolrCache (Jason Rutherglen via shalin)
- * SOLR-1637: Remove ALIAS command
- * SOLR-1662: Added Javadocs in BufferedTokenStream and fixed incorrect cloning
- in TestBufferedTokenStream (Robert Muir, Uwe Schindler via shalin)
- * SOLR-1674: Improve analysis tests and cut over to new TokenStream API.
- (Robert Muir via Mark Miller)
- * SOLR-1661: Remove adminCore from CoreContainer . removed deprecated methods setAdminCore(), getAdminCore() (noble)
- * SOLR-1704: Google collections moved from clustering to core (noble)
- * SOLR-1268: Add Lucene 2.9-dev r888785 FastVectorHighlighter contrib jar to lib. (koji)
- * SOLR-1538: Reordering of object allocations in ConcurrentLRUCache to eliminate
- (an extremely small) potential for deadlock.
- (gabriele renzi via hossman)
- * SOLR-1588: Removed some very old dead code.
- (Chris A. Mattmann via hossman)
- * SOLR-1696 : Deprecate old <highlighting> syntax and move configuration to HighlightComponent (noble)
- * SOLR-1727: SolrEventListener should extend NamedListInitializedPlugin (noble)
- * SOLR-1771: Improved error message when StringIndex cannot be initialized
- for a function query (hossman)
- * SOLR-1695: Improved error messages when adding a document that does not
- contain exactly one value for the uniqueKey field (hossman)
- * SOLR-1776: DismaxQParser and ExtendedDismaxQParser now use the schema.xml
- "defaultSearchField" as the default value for the "qf" param instead of failing
- with an error when "qf" is not specified. (hossman)
- * SOLR-1851: luceneAutoCommit no longer has any effect - it has been remove (Mark Miller)
- * SOLR-1865: SolrResourceLoader.getLines ignores Byte Order Markers (BOMs) at the
- beginning of input files, these are often created by editors such as Windows
- Notepad. (rmuir, hossman)
- * SOLR-1938: ElisionFilterFactory will use a default set of French contractions
- if you do not supply a custom articles file. (rmuir)
- * SOLR-2003: SolrResourceLoader will report any encoding errors, rather than
- silently using replacement characters for invalid inputs (blargy via rmuir)
- * SOLR-1804: Google collections updated to Google Guava (which is a superset of collections and contains bug fixes) (gsingers)
- * SOLR-2034: Switch to JavaBin codec version 2. Strings are now serialized
- as the number of UTF-8 bytes, followed by the bytes in UTF-8. Previously
- Strings were serialized as the number of UTF-16 chars, followed by the
- bytes in Modified UTF-8. (hossman, yonik, rmuir)
- * SOLR-2013: Add mapping-FoldToASCII.txt to example conf directory.
- (Steven Rowe via koji)
- * SOLR-2213: Upgrade to jQuery 1.4.3 (Erick Erickson via ryan)
- * SOLR-1826: Add unit tests for highlighting with termOffsets=true
- and overlapping tokens. (Stefan Oestreicher via rmuir)
- * SOLR-2340: Add version infos to message in JavaBinCodec when throwing
- exception. (koji)
- * SOLR-2350: Since Solr no longer requires XML files to be in UTF-8
- (see SOLR-96) SimplePostTool (aka: post.jar) has been improved to
- work with files of any mime-type or charset. (hossman)
- * SOLR-2365: Move DIH jars out of solr.war (David Smiley via yonik)
- * SOLR-2381: Include a patched version of Jetty (6.1.26 + JETTY-1340)
- to fix problematic UTF-8 handling for supplementary characters.
- (Bernd Fehling, uschindler, yonik, rmuir)
- * SOLR-2391: The preferred Content-Type for XML was changed to
- application/xml. XMLResponseWriter now only delivers using this
- type; updating documents and analyzing documents is still supported
- using text/xml as Content-Type, too. If you have clients that are
- hardcoded on text/xml as Content-Type, you have to change them.
- (uschindler, rmuir)
- * SOLR-2414: All ResponseWriters now use only ServletOutputStreams
- and wrap their own Writer around it when serializing. This fixes
- the bug in PHPSerializedResponseWriter that produced wrong string
- length if the servlet container had a broken UTF-8 encoding that was
- in fact CESU-8 (see SOLR-1091). The system property to enable the
- CESU-8 byte counting in PHPSerializesResponseWriters for broken
- servlet containers was therefore removed and is now ignored if set.
- Output is always UTF-8. (uschindler, yonik, rmuir)
- * SOLR-141: Errors and Exceptions are formated by ResponseWriter.
- (Mike Sokolov, Rich Cariens, Daniel Naber, ryan)
- * SOLR-1902: Upgraded to Tika 0.8 and changed deprecated parse call
- * SOLR-1813: Add ICU4j to contrib/extraction libs and add tests for Arabic
- extraction (Robert Muir via gsingers)
- * SOLR-1821: Fix TimeZone-dependent test failure in TestEvaluatorBag.
- (Chris Male via rmuir)
- * SOLR-2367: Reduced noise in test output by ensuring the properties file
- can be written. (Gunnlaugur Thor Briem via rmuir)
- Build
- ----------------------
- * SOLR-1522: Automated release signing process. (gsingers)
- * SOLR-1891: Make lucene-jars-to-solr fail if copying any of the jars fails, and
- update clean to remove the jars in that directory (Mark Miller)
- * LUCENE-2466: Commons-Codec was upgraded from 1.3 to 1.4. (rmuir)
- * SOLR-2042: Fixed some Maven deps (Drew Farris via gsingers)
- * LUCENE-2657: Switch from using Maven POM templates to full POMs when
- generating Maven artifacts (Steven Rowe)
- Documentation
- ----------------------
- * SOLR-1590: Javadoc for XMLWriter#startTag
- (Chris A. Mattmann via hossman)
- * SOLR-1792: Documented peculiar behavior of TestHarness.LocalRequestFactory
- (hossman)
- ================== Release 1.4.1 ==================
- Release Date: See http://lucene.apache.org/solr for the official release date.
- Upgrading from Solr 1.4
- -----------------------
- This is a bug fix release - no changes are required when upgrading from Solr 1.4.
- However, a reindex is needed for some of the analysis fixes to take effect.
- Versions of Major Components
- ----------------------------
- Apache Lucene 2.9.3
- Apache Tika 0.4
- Carrot2 3.1.0
- Lucene Information
- ----------------
- Since Solr is built on top of Lucene, many people add customizations to Solr
- that are dependent on Lucene. Please see http://lucene.apache.org/java/2_9_3/,
- especially http://lucene.apache.org/java/2_9_3/changes/Changes.html for more
- information on the version of Lucene used in Solr.
- Bug Fixes
- ----------------------
- * SOLR-1934: Upgrade to Apache Lucene 2.9.3 to obtain several bug
- fixes from the previous 2.9.1. See the Lucene 2.9.3 release notes
- for details. (hossman, Mark Miller)
- * SOLR-1432: Make the new ValueSource.getValues(context,reader) delegate
- to the original ValueSource.getValues(reader) so custom sources
- will work. (yonik)
- * SOLR-1572: FastLRUCache correctly implemented the LRU policy only
- for the first 2B accesses. (yonik)
- * SOLR-1595: StreamingUpdateSolrServer used the platform default character
- set when streaming updates, rather than using UTF-8 as the HTTP headers
- indicated, leading to an encoding mismatch. (hossman, yonik)
- * SOLR-1660: CapitalizationFilter crashes if you use the maxWordCountOption
- (Robert Muir via shalin)
- * SOLR-1662: Added Javadocs in BufferedTokenStream and fixed incorrect cloning
- in TestBufferedTokenStream (Robert Muir, Uwe Schindler via shalin)
- * SOLR-1711: SolrJ - StreamingUpdateSolrServer had a race condition that
- could halt the streaming of documents. The original patch to fix this
- (never officially released) introduced another hanging bug due to
- connections not being released. (Attila Babo, Erik Hetzner via yonik)
- * SOLR-1748, SOLR-1747, SOLR-1746, SOLR-1745, SOLR-1744: Streams and Readers
- retrieved from ContentStreams are not closed in various places, resulting
- in file descriptor leaks.
- (Christoff Brill, Mark Miller)
- * SOLR-1580: Solr Configuration ignores 'mergeFactor' parameter, always
- uses Lucene default. (Lance Norskog via Mark Miller)
- * SOLR-1777: fieldTypes with sortMissingLast=true or sortMissingFirst=true can
- result in incorrectly sorted results. (yonik)
- * SOLR-1797: fix ConcurrentModificationException and potential memory
- leaks in ResourceLoader. (yonik)
- * SOLR-1798: Small memory leak (~100 bytes) in fastLRUCache for every
- commit. (yonik)
- * SOLR-1522: Show proper message if <script> tag is missing for DIH
- ScriptTransformer (noble)
- * SOLR-1538: Reordering of object allocations in ConcurrentLRUCache to eliminate
- (an extremely small) potential for deadlock.
- (gabriele renzi via hossman)
- * SOLR-1558: QueryElevationComponent only works if the uniqueKey field is
- implemented using StrField. In previous versions of Solr no warning or
- error would be generated if you attempted to use QueryElevationComponent,
- it would just fail in unexpected ways. This has been changed so that it
- will fail with a clear error message on initialization. (hossman)
- * SOLR-1563: Binary fields, including trie-based numeric fields, caused null
- pointer exceptions in the luke request handler. (yonik)
- * SOLR-1579: Fixes to XML escaping in stats.jsp
- (David Bowen and hossman)
- * SOLR-1582: copyField was ignored for BinaryField types (gsingers)
- * SOLR-1596: A rollback operation followed by the shutdown of Solr
- or the close of a core resulted in a warning:
- "SEVERE: SolrIndexWriter was not closed prior to finalize()" although
- there were no other consequences. (yonik)
- * SOLR-1651: Fixed Incorrect dataimport handler package name in SolrResourceLoader
- (Akshay Ukey via shalin)
- * SOLR-1936: The JSON response format needed to escape unicode code point
- U+2028 - 'LINE SEPARATOR' (Robert Hofstra, yonik)
- * SOLR-1852: Fix WordDelimiterFilterFactory bug where position increments
- were not being applied properly to subwords. (Peter Wolanin via Robert Muir)
- * SOLR-1706: fixed WordDelimiterFilter for certain combinations of options
- where it would output incorrect tokens. (Robert Muir, Chris Male)
- * SOLR-1948: PatternTokenizerFactory should use parent's args (koji)
- * SOLR-1870: Indexing documents using the 'javabin' format no longer
- fails with a ClassCastException whenSolrInputDocuments contain field
- values which are Collections or other classes that implement
- Iterable. (noble, hossman)
- * SOLR-1769 Solr 1.4 Replication - Repeater throwing NullPointerException (noble)
- ================== Release 1.4.0 ==================
- Release Date: See http://lucene.apache.org/solr for the official release date.
- Upgrading from Solr 1.3
- -----------------------
- There is a new default faceting algorithm for multiVaued fields that should be
- faster for most cases. One can revert to the previous algorithm (which has
- also been improved somewhat) by adding facet.method=enum to the request.
- Searching and sorting is now done on a per-segment basis, meaning that
- the FieldCache entries used for sorting and for function queries are
- created and used per-segment and can be reused for segments that don't
- change between index updates. While generally beneficial, this can lead
- to increased memory usage over 1.3 in certain scenarios:
- 1) A single valued field that was used for both sorting and faceting
- in 1.3 would have used the same top level FieldCache entry. In 1.4,
- sorting will use entries at the segment level while faceting will still
- use entries at the top reader level, leading to increased memory usage.
- 2) Certain function queries such as ord() and rord() require a top level
- FieldCache instance and can thus lead to increased memory usage. Consider
- replacing ord() and rord() with alternatives, such as function queries
- based on ms() for date boosting.
- If you use custom Tokenizer or TokenFilter components in a chain specified in
- schema.xml, they must support reusability. If your Tokenizer or TokenFilter
- maintains state, it should implement reset(). If your TokenFilteFactory does
- not return a subclass of TokenFilter, then it should implement reset() and call
- reset() on its input TokenStream. TokenizerFactory implementations must
- now return a Tokenizer rather than a TokenStream.
- New users of Solr 1.4 will have omitTermFreqAndPositions enabled for non-text
- indexed fields by default, which avoids indexing term frequency, positions, and
- payloads, making the index smaller and faster. If you are upgrading from an
- earlier Solr release and want to enable omitTermFreqAndPositions by default,
- change the schema version from 1.1 to 1.2 in schema.xml. Remove any existing
- index and restart Solr to ensure that omitTermFreqAndPositions completely takes
- affect.
- The default QParserPlugin used by the QueryComponent for parsing the "q" param
- has been changed, to remove support for the deprecated use of ";" as a separator
- between the query string and the sort options when no "sort" param was used.
- Users who wish to continue using the semi-colon based method of specifying the
- sort options should explicitly set the defType param to "lucenePlusSort" on all
- requests. (The simplest way to do this is by specifying it as a default param
- for your request handlers in solrconfig.xml, see the example solrconfig.xml for
- sample syntax.)
- If spellcheck.extendedResults=true, the response format for suggestions
- has changed, see SOLR-1071.
- Use of the "charset" option when configuring the following Analysis
- Factories has been deprecated and will cause a warning to be logged.
- In future versions of Solr attempting to use this option will cause an
- error. See SOLR-1410 for more information.
- - GreekLowerCaseFilterFactory
- - RussianStemFilterFactory
- - RussianLowerCaseFilterFactory
- - RussianLetterTokenizerFactory
- DIH: Evaluator API has been changed in a non back-compatible way. Users who
- have developed custom Evaluators will need to change their code according to
- the new API for it to work. See SOLR-996 for details.
- DIH: The formatDate evaluator's syntax has been changed. The new syntax is
- formatDate(<variable>, '<format_string>'). For example,
- formatDate(x.date, 'yyyy-MM-dd'). In the old syntax, the date string was
- written without a single-quotes. The old syntax has been deprecated and will
- be removed in 1.5, until then, using the old syntax will log a warning.
- DIH: The Context API has been changed in a non back-compatible way. In
- particular, the Context.currentProcess() method now returns a String
- describing the type of the current import process instead of an int.
- Similarily, the public constants in Context viz. FULL_DUMP, DELTA_DUMP and
- FIND_DELTA are changed to a String type. See SOLR-969 for details.
- DIH: The EntityProcessor API has been simplified by moving logic for applying
- transformers and handling multi-row outputs from Transformers into an
- EntityProcessorWrapper class. The EntityProcessor#destroy is now called once
- per parent-row at the end of row (end of data). A new method
- EntityProcessor#close is added which is called at the end of import.
- DIH: In Solr 1.3, if the last_index_time was not available (first import) and
- a delta-import was requested, a full-import was run instead. This is no longer
- the case. In Solr 1.4 delta import is run with last_index_time as the epoch
- date (January 1, 1970, 00:00:00 GMT) if last_index_time is not available.
- Versions of Major Components
- ----------------------------
- Apache Lucene 2.9.1 (r832363 on 2.9 branch)
- Apache Tika 0.4
- Carrot2 3.1.0
- Lucene Information
- ----------------
- Since Solr is built on top of Lucene, many people add customizations to Solr
- that are dependent on Lucene. Please see http://lucene.apache.org/java/2_9_0/,
- especially http://lucene.apache.org/java/2_9_0/changes/Changes.html for more
- information on the version of Lucene used in Solr.
- Detailed Change List
- ----------------------
- New Features
- ----------------------
- 1. SOLR-560: Use SLF4J logging API rather then JDK logging. The packaged .war file is
- shipped with a JDK logging implementation, so logging configuration for the .war should
- be identical to solr 1.3. However, if you are using the .jar file, you can select
- which logging implementation to use by dropping a different binding.
- See: http://www.slf4j.org/ (ryan)
- 2. SOLR-617: Allow configurable index deletion policy and provide a default implementation which
- allows deletion of commit points on various criteria such as number of commits, age of commit
- point and optimized status.
- See http://lucene.apache.org/java/2_3_2/api/org/apache/lucene/index/IndexDeletionPolicy.html
- (yonik, Noble Paul, Akshay Ukey via shalin)
- 3. SOLR-658: Allow Solr to load index from arbitrary directory in dataDir
- (Noble Paul, Akshay Ukey via shalin)
- 4. SOLR-793: Add 'commitWithin' argument to the update add command. This behaves
- similar to the global autoCommit maxTime argument except that it is set for
- each request. (ryan)
- 5. SOLR-670: Add support for rollbacks in UpdateHandler. This allows user to rollback all changes
- since the last commit. (Noble Paul, koji via shalin)
- 6. SOLR-813: Adding DoubleMetaphone Filter and Factory. Similar to the PhoneticFilter,
- but this uses DoubleMetaphone specific calls (including alternate encoding)
- (Todd Feak via ryan)
- 7. SOLR-680: Add StatsComponent. This gets simple statistics on matched numeric fields,
- including: min, max, mean, median, stddev. (koji, ryan)
- - SOLR-1380: Added support for multi-valued fields (Harish Agarwal via gsingers)
- 8. SOLR-561: Added Replication implemented in Java as a request handler. Supports index replication
- as well as configuration replication and exposes detailed statistics and progress information
- on the Admin page. Works on all platforms. (Noble Paul, yonik, Akshay Ukey, shalin)
- 9. SOLR-746: Added "omitHeader" request parameter to omit the header from the response.
- (Noble Paul via shalin)
- 10. SOLR-651: Added TermVectorComponent for serving up term vector information, plus IDF.
- See http://wiki.apache.org/solr/TermVectorComponent (gsingers, Vaijanath N. Rao, Noble Paul)
- 12. SOLR-795: SpellCheckComponent supports building indices on optimize if configured in solrconfig.xml
- (Jason Rennie, shalin)
- 13. SOLR-667: A LRU cache implementation based upon ConcurrentHashMap and other techniques to reduce
- contention and synchronization overhead, to utilize multiple CPU cores more effectively.
- (Fuad Efendi, Noble Paul, yonik via shalin)
- 14. SOLR-465: Add configurable DirectoryProvider so that alternate Directory
- implementations can be specified via solrconfig.xml. The default
- DirectoryProvider will use NIOFSDirectory for better concurrency
- on non Windows platforms. (Mark Miller, TJ Laurenzo via yonik)
- 15. SOLR-822: Add CharFilter so that characters can be filtered (e.g. character normalization)
- before Tokenizer/TokenFilters. (koji)
- 16. SOLR-829: Allow slaves to request compressed files from master during replication
- (Simon Collins, Noble Paul, Akshay Ukey via shalin)
- 17. SOLR-877: Added TermsComponent for accessing Lucene's TermEnum capabilities.
- Useful for auto suggest and possibly distributed search. Not distributed search compliant. (gsingers)
- - Added mincount and maxcount options (Khee Chin via gsingers)
- 18. SOLR-538: Add maxChars attribute for copyField function so that the length limit for destination
- can be specified.
- (Georgios Stamatis, Lars Kotthoff, Chris Harris via koji)
- 19. SOLR-284: Added support for extracting content from binary documents like MS Word and PDF using Apache Tika. See also contrib/extraction/CHANGES.txt (Eric Pugh, Chris Harris, yonik, gsingers)
- 20. SOLR-819: Added factories for Arabic support (gsingers)
- 21. SOLR-781: Distributed search ability to sort field.facet values
- lexicographically. facet.sort values "true" and "false" are
- also deprecated and replaced with "count" and "lex".
- (Lars Kotthoff via yonik)
- 22. SOLR-821: Add support for replication to copy conf file to slave with a different name. This allows replication
- of solrconfig.xml
- (Noble Paul, Akshay Ukey via shalin)
- 23. SOLR-911: Add support for multi-select faceting by allowing filters to be
- tagged and facet commands to exclude certain filters. This patch also
- added the ability to change the output key for facets in the response, and
- optimized distributed faceting refinement by lowering parsing overhead and
- by making requests and responses smaller.
- 24. SOLR-876: WordDelimiterFilter now supports a splitOnNumerics
- option, as well as a list of protected terms.
- (Dan Rosher via hossman)
- 25. SOLR-928: SolrDocument and SolrInputDocument now implement the Map<String,?>
- interface. This should make plugging into other standard tools easier. (ryan)
- 26. SOLR-847: Enhance the snappull command in ReplicationHandler to accept masterUrl.
- (Noble Paul, Preetam Rao via shalin)
- 27. SOLR-540: Add support for globbing in field names to highlight.
- For example, hl.fl=*_text will highlight all fieldnames ending with
- _text. (Lars Kotthoff via yonik)
- 28. SOLR-906: Adding a StreamingUpdateSolrServer that writes update commands to
- an open HTTP connection. If you are using solrj for bulk update requests
- you should consider switching to this implementaion. However, note that
- the error handling is not immediate as it is with the standard SolrServer.
- (ryan)
- 29. SOLR-865: Adding support for document updates in binary format and corresponding support in Solrj client.
- (Noble Paul via shalin)
- 30. SOLR-763: Add support for Lucene's PositionFilter (Mck SembWever via shalin)
- 31. SOLR-966: Enhance the map() function query to take in an optional default value (Noble Paul, shalin)
- 32. SOLR-820: Support replication on startup of master with new index. (Noble Paul, Akshay Ukey via shalin)
- 33. SOLR-943: Make it possible to specify dataDir in solr.xml and accept the dataDir as a request parameter for
- the CoreAdmin create command. (Noble Paul via shalin)
- 34. SOLR-850: Addition of timeouts for distributed searching. Configurable through 'shard-socket-timeout' and
- 'shard-connection-timeout' parameters in SearchHandler. (Patrick O'Leary via shalin)
- 35. SOLR-799: Add support for hash based exact/near duplicate document
- handling. (Mark Miller, yonik)
- 36. SOLR-1026: Add protected words support to SnowballPorterFilterFactory (ehatcher)
- 37. SOLR-739: Add support for OmitTf (Mark Miller via yonik)
- 38. SOLR-1046: Nested query support for the function query parser
- and lucene query parser (the latter existed as an undocumented
- feature in 1.3) (yonik)
- 39. SOLR-940: Add support for Lucene's Trie Range Queries by providing new FieldTypes in
- schema for int, float, long, double and date. Single-valued Trie based
- fields with a precisionStep will index multiple precisions and enable
- faster range queries. (Uwe Schindler, yonik, shalin)
- 40. SOLR-1038: Enhance CommonsHttpSolrServer to add docs in batch using an iterator API (Noble Paul via shalin)
- 41. SOLR-844: A SolrServer implementation to front-end multiple solr servers and provides load balancing and failover
- support (Noble Paul, Mark Miller, hossman via shalin)
- 42. SOLR-939: ValueSourceRangeFilter/Query - filter based on values in a FieldCache entry or on any arbitrary function of field values. (yonik)
- 43. SOLR-1095: Fixed performance problem in the StopFilterFactory and simplified code. Added tests as well. (gsingers)
- 44. SOLR-1096: Introduced httpConnTimeout and httpReadTimeout in replication slave configuration to avoid stalled
- replication. (Jeff Newburn, Noble Paul, shalin)
- 45. SOLR-1115: <bool>on</bool> and <bool>yes</bool> work as expected in solrconfig.xml. (koji)
- 46. SOLR-1099: A FieldAnalysisRequestHandler which provides the analysis functionality of the web admin page as
- a service. The AnalysisRequestHandler is renamed to DocumentAnalysisRequestHandler which is enhanced with
- query analysis and showMatch support. AnalysisRequestHandler is now deprecated. Support for both
- FieldAnalysisRequestHandler and DocumentAnalysisRequestHandler is also provided in the Solrj client.
- (Uri Boness, shalin)
- 47. SOLR-1106: Made CoreAdminHandler Actions pluggable so that additional actions may be plugged in or the existing
- ones can be overridden if needed. (Kay Kay, Noble Paul, shalin)
- 48. SOLR-1124: Add a top() function query that causes its argument to
- have its values derived from the top level IndexReader, even when
- invoked from a sub-reader. top() is implicitly used for the
- ord() and rord() functions. (yonik)
- 49. SOLR-1110: Support sorting on trie fields with Distributed Search. (Mark Miller, Uwe Schindler via shalin)
- 50. SOLR-1121: CoreAdminhandler should not need a core . This makes it possible to start a Solr server w/o a core .(noble)
- 51. SOLR-769: Added support for clustering in contrib/clustering. See http://wiki.apache.org/solr/ClusteringComponent for more info. (gsingers, Stanislaw Osinski)
- 52. SOLR-1175: disable/enable replication on master side. added two commands 'enableReplication' and 'disableReplication' (noble)
- 53. SOLR-1179: DocSets can now be used as Lucene Filters via
- DocSet.getTopFilter() (yonik)
- 54. SOLR-1116: Add a Binary FieldType (noble)
- 55. SOLR-1051: Support the merge of multiple indexes as a CoreAdmin and an update command (Ning Li via shalin)
- 56. SOLR-1152: Snapshoot on ReplicationHandler should accept location as a request parameter (shalin)
- 57. SOLR-1204: Enhance SpellingQueryConverter to handle UTF-8 instead of ASCII only.
- Use the NMTOKEN syntax for matching field names.
- (Michael Ludwig, shalin)
- 58. SOLR-1189: Support providing username and password for basic HTTP authentication in Java replication
- (Matthew Gregg, shalin)
- 59. SOLR-243: Add configurable IndexReaderFactory so that alternate IndexReader implementations
- can be specified via solrconfig.xml. Note that using a custom IndexReader may be incompatible
- with ReplicationHandler (see comments in SOLR-1366). This should be treated as an experimental feature.
- (Andrzej Bialecki, hossman, Mark Miller, John Wang)
- 60. SOLR-1214: differentiate between solr home and instanceDir .deprecates the method SolrResourceLoader#locateInstanceDir()
- and it is renamed to locateSolrHome (noble)
- 61. SOLR-1216 : disambiguate the replication command names. 'snappull' becomes 'fetchindex' 'abortsnappull' becomes 'abortfetch' (noble)
- 62. SOLR-1145: Add capability to specify an infoStream log file for the underlying Lucene IndexWriter in solrconfig.xml.
- This is an advanced debug log file that can be used to aid developers in fixing IndexWriter bugs. See the commented
- out example in the example solrconfig.xml under the indexDefaults section.
- (Chris Harris, Mark Miller)
- 63. SOLR-1256: Show the output of CharFilters in analysis.jsp. (koji)
- 64. SOLR-1266: Added stemEnglishPossessive option (default=true) to WordDelimiterFilter
- that allows disabling of english possessive stemming (removal of trailing 's from tokens)
- (Robert Muir via yonik)
- 65. SOLR-1237: firstSearcher and newSearcher can now be identified via the CommonParams.EVENT (evt) parameter
- in a request. This allows a RequestHandler or SearchComponent to know when a newSearcher or firstSearcher
- event happened. QuerySenderListender is the only implementation in Solr that implements this, but outside
- implementations may wish to. See the AbstractSolrEventListener for a helper method. (gsingers)
- 66. SOLR-1343: Added HTMLStripCharFilter and marked HTMLStripReader, HTMLStripWhitespaceTokenizerFactory and
- HTMLStripStandardTokenizerFactory deprecated. To strip HTML tags, HTMLStripCharFilter can be used
- with an arbitrary Tokenizer. (koji)
- 67. SOLR-1275: Add expungeDeletes to DirectUpdateHandler2 (noble)
- 68. SOLR-1372: Enhance FieldAnalysisRequestHandler to accept field value from content stream (ehatcher)
- 69. SOLR-1370: Show the output of CharFilters in FieldAnalysisRequestHandler (koji)
- 70. SOLR-1373: Add Filter query to admin/form.jsp
- (Jason Rutherglen via hossman)
- 71. SOLR-1368: Add ms() function query for getting milliseconds from dates and for
- high precision date subtraction, add sub() for subtracting other arguments.
- (yonik)
- 72. SOLR-1156: Sort TermsComponent results by frequency (Matt Weber via yonik)
- 73. SOLR-1335 : load core properties from a properties file (noble)
- 74. SOLR-1385 : Add an 'enable' attribute to all plugins (noble)
- 75. SOLR-1414 : implicit core properties are not set for single core (noble)
- 76. SOLR-659 : Adds shards.start and shards.rows to distributed search
- to allow more efficient bulk queries (those that retrieve many or all
- documents). (Brian Whitman via yonik)
- 77. SOLR-1321: Add better support for efficient wildcard handling (Andrzej Bialecki, Robert Muir, gsingers)
- 78. SOLR-1326 : New interface PluginInfoInitialized for all types of plugin (noble)
- 79. SOLR-1447 : Simple property injection. <mergePolicy> & <mergeScheduler> syntaxes are now deprecated
- (Jason Rutherglen, noble)
- 80. SOLR-908 : CommonGramsFilterFactory/CommonGramsQueryFilterFactory for
- speeding up phrase queries containing common words by indexing
- n-grams and using them at query time.
- (Tom Burton-West, Jason Rutherglen via yonik)
- 81. SOLR-1292: Add FieldCache introspection to stats.jsp and JMX Monitoring via
- a new SolrFieldCacheMBean. (hossman)
- 82. SOLR-1167: Solr Config now supports XInclude for XML engines that can support it. (Bryan Talbot via gsingers)
- 83. SOLR-1478: Enable sort by Lucene docid. (ehatcher)
- 84. SOLR-1449: Add <lib> elements to solrconfig.xml to specifying additional
- classpath directories and regular expressions. (hossman via yonik)
- 85. SOLR-1128: Added metadata output to extraction request handler "extract
- only" option. (gsingers)
- 86. SOLR-1274: Added text serialization output for extractOnly
- (Peter Wolanin, gsingers)
- 87. SOLR-768: DIH: Set last_index_time variable in full-import command.
- (Wojtek Piaseczny, Noble Paul via shalin)
- 88. SOLR-811: Allow a "deltaImportQuery" attribute in SqlEntityProcessor
- which is used for delta imports instead of DataImportHandler manipulating
- the SQL itself. (Noble Paul via shalin)
- 89. SOLR-842: Better error handling in DataImportHandler with options to
- abort, skip and continue imports. (Noble Paul, shalin)
- 90. SOLR-833: DIH: A DataSource to read data from a field as a reader. This
- can be used, for example, to read XMLs residing as CLOBs or BLOBs in
- databases. (Noble Paul via shalin)
- 91. SOLR-887: A DIH Transformer to strip HTML tags. (Ahmed Hammad via shalin)
- 92. SOLR-886: DataImportHandler should rollback when an import fails or it is
- aborted (shalin)
- 93. SOLR-891: A DIH Transformer to read strings from Clob type.
- (Noble Paul via shalin)
- 94. SOLR-812: Configurable JDBC settings in JdbcDataSource including optimized
- defaults for read only mode. (David Smiley, Glen Newton, shalin)
- 95. SOLR-910: Add a few utility commands to the DIH admin page such as full
- import, delta import, status, reload config. (Ahmed Hammad via shalin)
- 96. SOLR-938: Add event listener API for DIH import start and end.
- (Kay Kay, Noble Paul via shalin)
- 97. SOLR-801: DIH: Add support for configurable pre-import and post-import
- delete query per root-entity. (Noble Paul via shalin)
- 98. SOLR-988: Add a new scope for session data stored in Context to store
- objects across imports. (Noble Paul via shalin)
- 99. SOLR-980: A PlainTextEntityProcessor which can read from any
- DataSource<Reader> and output a String.
- (Nathan Adams, Noble Paul via shalin)
- 100.SOLR-1003: XPathEntityprocessor must allow slurping all text from a given
- xml node and its children. (Noble Paul via shalin)
- 101.SOLR-1001: Allow variables in various attributes of RegexTransformer,
- HTMLStripTransformer and NumberFormatTransformer.
- (Fergus McMenemie, Noble Paul, shalin)
- 102.SOLR-989: DIH: Expose running statistics from the Context API.
- (Noble Paul, shalin)
- 103.SOLR-996: DIH: Expose Context to Evaluators. (Noble Paul, shalin)
- 104.SOLR-783: DIH: Enhance delta-imports by maintaining separate
- last_index_time for each entity. (Jon Baer, Noble Paul via shalin)
- 105.SOLR-1033: Current entity's namespace is made available to all DIH
- Transformers. This allows one to use an output field of TemplateTransformer
- in other transformers, among other things.
- (Fergus McMenemie, Noble Paul via shalin)
- 106.SOLR-1066: New methods in DIH Context to expose Script details.
- ScriptTransformer changed to read scripts through the new API methods.
- (Noble Paul via shalin)
- 107.SOLR-1062: A DIH LogTransformer which can log data in a given template
- format. (Jon Baer, Noble Paul via shalin)
- 108.SOLR-1065: A DIH ContentStreamDataSource which can accept HTTP POST data
- in a content stream. This can be used to push data to Solr instead of
- just pulling it from DB/Files/URLs. (Noble Paul via shalin)
- 109.SOLR-1061: Improve DIH RegexTransformer to create multiple columns from
- regex groups. (Noble Paul via shalin)
- 110.SOLR-1059: Special DIH flags introduced for deleting documents by query or
- id, skipping rows and stopping further transforms. Use $deleteDocById,
- $deleteDocByQuery for deleting by id and query respectively. Use $skipRow
- to skip the current row but continue with the document. Use $stopTransform
- to stop further transformers. New methods are introduced in Context for
- deleting by id and query. (Noble Paul, Fergus McMenemie, shalin)
- 111.SOLR-1076: JdbcDataSource should resolve DIH variables in all its
- configuration parameters. (shalin)
- 112.SOLR-1055: Make DIH JdbcDataSource easily extensible by making the
- createConnectionFactory method protected and return a
- Callable<Connection> object. (Noble Paul, shalin)
- 113.SOLR-1058: DIH: JdbcDataSource can lookup javax.sql.DataSource using JNDI.
- Use a jndiName attribute to specify the location of the data source.
- (Jason Shepherd, Noble Paul via shalin)
- 114.SOLR-1083: A DIH Evaluator for escaping query characters.
- (Noble Paul, shalin)
- 115.SOLR-934: A MailEntityProcessor to enable indexing mails from
- POP/IMAP sources into a solr index. (Preetam Rao, shalin)
- 116.SOLR-1060: A DIH LineEntityProcessor which can stream lines of text from a
- given file to be indexed directly or for processing with transformers and
- child entities.
- (Fergus McMenemie, Noble Paul, shalin)
- 117.SOLR-1127: Add support for DIH field name to be templatized.
- (Noble Paul, shalin)
- 118.SOLR-1092: Added a new DIH command named 'import' which does not
- automatically clean the index. This is useful and more appropriate when one
- needs to import only some of the entities.
- (Noble Paul via shalin)
- 119.SOLR-1153: DIH 'deltaImportQuery' is honored on child entities as well
- (noble)
- 120.SOLR-1230: Enhanced dataimport.jsp to work with all DataImportHandler
- request handler configurations, rather than just a hardcoded /dataimport
- handler. (ehatcher)
- 121.SOLR-1235: disallow period (.) in DIH entity names (noble)
- 122.SOLR-1234: Multiple DIH does not work because all of them write to
- dataimport.properties. Use the handler name as the properties file name
- (noble)
- 123.SOLR-1348: Support binary field type in convertType logic in DIH
- JdbcDataSource (shalin)
- 124.SOLR-1406: DIH: Make FileDataSource and FileListEntityProcessor to be more
- extensible (Luke Forehand, shalin)
- 125.SOLR-1437: DIH: XPathEntityProcessor can deal with xpath syntaxes such as
- //tagname , /root//tagname (Fergus McMenemie via noble)
- Optimizations
- ----------------------
- 1. SOLR-374: Use IndexReader.reopen to save resources by re-using parts of the
- index that haven't changed. (Mark Miller via yonik)
- 2. SOLR-808: Write string keys in Maps as extern strings in the javabin format. (Noble Paul via shalin)
- 3. SOLR-475: New faceting method with better performance and smaller memory usage for
- multi-valued fields with many unique values but relatively few values per document.
- Controllable via the facet.method parameter - "fc" is the new default method and "enum"
- is the original method. (yonik)
- 4. SOLR-970: Use an ArrayList in SolrPluginUtils.parseQueryStrings
- since we know exactly how long the List will be in advance.
- (Kay Kay via hossman)
- 5. SOLR-1002: Change SolrIndexSearcher to use insertWithOverflow
- with reusable priority queue entries to reduce the amount of
- generated garbage during searching. (Mark Miller via yonik)
- 6. SOLR-971: Replace StringBuffer with StringBuilder for instances that do not require thread-safety.
- (Kay Kay via shalin)
- 7. SOLR-921: SolrResourceLoader must cache short class name vs fully qualified classname
- (Noble Paul, hossman via shalin)
- 8. SOLR-973: CommonsHttpSolrServer writes the xml directly to the server.
- (Noble Paul via shalin)
- 9. SOLR-1108: Remove un-needed synchronization in SolrCore constructor.
- (Noble Paul via shalin)
- 10. SOLR-1166: Speed up docset/filter generation by avoiding top-level
- score() call and iterating over leaf readers with TermDocs. (yonik)
- 11. SOLR-1169: SortedIntDocSet - a new small set implementation
- that saves memory over HashDocSet, is faster to construct,
- is ordered for easier implementation of skipTo, and is faster
- in the general case. (yonik)
- 12. SOLR-1165: Use Lucene Filters and pass them down to the Lucene
- search methods to filter earlier and improve performance. (yonik)
- 13. SOLR-1111: Use per-segment sorting to share fieldcache elements
- across unchanged segments. This saves memory and reduces
- commit times for incremental updates to the index. (yonik)
- 14. SOLR-1188: Minor efficiency improvement in TermVectorComponent related to ignoring positions or offsets (gsingers)
- 15. SOLR-1150: Load Documents for Highlighting one at a time rather than
- all at once to avoid OOM with many large Documents. (Siddharth Gargate via Mark Miller)
- 16. SOLR-1353: Implement and use reusable token streams for analysis. (Robert Muir, yonik)
- 17. SOLR-1296: Enables setting IndexReader's termInfosIndexDivisor via a new attribute to StandardIndexReaderFactory. Enables
- setting termIndexInterval to IndexWriter via SolrIndexConfig. (Jason Rutherglen, hossman, gsingers)
- 18. SOLR-846: DIH: Reduce memory consumption during delta import by removing
- keys when used (Ricky Leung, Noble Paul via shalin)
- 19. SOLR-974: DataImportHandler skips commit if no data has been updated.
- (Wojtek Piaseczny, shalin)
- 20. SOLR-1004: DIH: Check for abort more frequently during delta-imports.
- (Marc Sturlese, shalin)
- 21. SOLR-1098: DIH DateFormatTransformer can cache the format objects.
- (Noble Paul via shalin)
- 22. SOLR-1465: Replaced string concatenations with StringBuilder append
- calls in DIH XPathRecordReader. (Mark Miller, shalin)
- Bug Fixes
- ----------------------
- 1. SOLR-774: Fixed logging level display (Sean Timm via Otis Gospodnetic)
- 2. SOLR-771: CoreAdminHandler STATUS should display 'normalized' paths (koji, hossman, shalin)
- 3. SOLR-532: WordDelimiterFilter now respects payloads and other attributes of the original Token by
- using Token.clone() (Tricia Williams, gsingers)
- 4. SOLR-805: DisMax queries are not being cached in QueryResultCache (Todd Feak via koji)
- 5. SOLR-751: WordDelimiterFilter didn't adjust the start offset of single
- tokens that started with delimiters, leading to incorrect highlighting.
- (Stefan Oestreicher via yonik)
- 7. SOLR-843: SynonymFilterFactory cannot handle multiple synonym files correctly (koji)
- 8. SOLR-840: BinaryResponseWriter does not handle incompatible data in fields (Noble Paul via shalin)
- 9. SOLR-803: CoreAdminRequest.createCore fails because name parameter isn't set (Sean Colombo via ryan)
- 10. SOLR-869: Fix file descriptor leak in SolrResourceLoader#getLines (Mark Miller, shalin)
- 11. SOLR-872: Better error message for incorrect copyField destination (Noble Paul via shalin)
- 12. SOLR-879: Enable position increments in the query parser and fix the
- example schema to enable position increments for the stop filter in
- both the index and query analyzers to fix the bug with phrase queries
- with stopwords. (yonik)
- 13. SOLR-836: Add missing "a" to the example stopwords.txt (yonik)
- 14. SOLR-892: Fix serialization of booleans for PHPSerializedResponseWriter
- (yonik)
- 15. SOLR-898: Fix null pointer exception for the JSON response writer
- based formats when nl.json=arrarr with null keys. (yonik)
- 16. SOLR-901: FastOutputStream ignores write(byte[]) call. (Noble Paul via shalin)
- 17. SOLR-807: BinaryResponseWriter writes fieldType.toExternal if it is not a supported type,
- otherwise it writes fieldType.toObject. This fixes the bug with encoding/decoding UUIDField.
- (koji, Noble Paul, shalin)
- 18. SOLR-863: SolrCore.initIndex should close the directory it gets for clearing the lock and
- use the DirectoryFactory. (Mark Miller via shalin)
- 19. SOLR-802: Fix a potential null pointer error in the distributed FacetComponent
- (David Bowen via ryan)
- 20. SOLR-346: Use perl regex to improve accuracy of finding latest snapshot in snapinstaller (billa)
- 21. SOLR-830: Use perl regex to improve accuracy of finding latest snapshot in snappuller (billa)
- 22. SOLR-897: Fixed Argument list too long error when there are lots of snapshots/backups (Dan Rosher via billa)
- 23. SOLR-925: Fixed highlighting on fields with multiValued="true" and termOffsets="true" (koji)
- 24. SOLR-902: FastInputStream#read(byte b[], int off, int len) gives incorrect results when amount left to read is less
- than buffer size (Noble Paul via shalin)
- 25. SOLR-978: Old files are not removed from slaves after replication (Jaco, Noble Paul, shalin)
- 26. SOLR-883: Implicit properties are not set for Cores created through CoreAdmin (Noble Paul via shalin)
- 27. SOLR-991: Better error message when parsing solrconfig.xml fails due to malformed XML. Error message notes the name
- of the file being parsed. (Michael Henson via shalin)
- 28. SOLR-1008: Fix stats.jsp XML encoding for <stat> item entries with ampersands in their names. (ehatcher)
- 29. SOLR-976: deleteByQuery is ignored when deleteById is placed prior to deleteByQuery in a <delete>.
- Now both delete by id and delete by query can be specified at the same time as follows.
- <delete>
- <id>05991</id><id>06000</id>
- <query>office:Bridgewater</query><query>office:Osaka</query>
- </delete>
- (koji)
- 30. SOLR-1016: HTTP 503 error changes 500 in SolrCore (koji)
- 31. SOLR-1015: Incomplete information in replication admin page and http command response when server
- is both master and slave i.e. when server is a repeater (Akshay Ukey via shalin)
- 32. SOLR-1018: Slave is unable to replicate when server acts as repeater (as both master and slave)
- (Akshay Ukey, Noble Paul via shalin)
- 33. SOLR-1031: Fix XSS vulnerability in schema.jsp (Paul Lovvik via ehatcher)
- 34. SOLR-1064: registry.jsp incorrectly displaying info for last core initialized
- regardless of what the current core is. (hossman)
- 35. SOLR-1072: absolute paths used in sharedLib attribute were
- incorrectly treated as relative paths. (hossman)
- 36. SOLR-1104: Fix some rounding errors in LukeRequestHandler's histogram (hossman)
- 37. SOLR-1125: Use query analyzer rather than index analyzer for queryFieldType in QueryElevationComponent
- (koji)
- 38. SOLR-1126: Replicated files have incorrect timestamp (Jian Han Guo, Jeff Newburn, Noble Paul via shalin)
- 39. SOLR-1094: Incorrect value of correctlySpelled attribute in some cases (David Smiley, Mark Miller via shalin)
- 40. SOLR-965: Better error message when <pingQuery> is not configured.
- (Mark Miller via hossman)
- 41. SOLR-1135: Java replication creates Snapshot in the directory where Solr was launched (Jianhan Guo via shalin)
- 42. SOLR-1138: Query Elevation Component now gracefully handles missing queries. (gsingers)
- 43. SOLR-929: LukeRequestHandler should return "dynamicBase" only if the field is dynamic.
- (Peter Wolanin, koji)
- 44. SOLR-1141: NullPointerException during snapshoot command in java based replication (Jian Han Guo, shalin)
- 45. SOLR-1078: Fixes to WordDelimiterFilter to avoid splitting or dropping
- international non-letter characters such as non spacing marks. (yonik)
- 46. SOLR-825, SOLR-1221: Enables highlighting for range/wildcard/fuzzy/prefix queries if using hl.usePhraseHighlighter=true
- and hl.highlightMultiTerm=true. Also make both options default to true. (Mark Miller, yonik)
- 47. SOLR-1174: Fix Logging admin form submit url for multicore. (Jacob Singh via shalin)
- 48. SOLR-1182: Fix bug in OrdFieldSource#equals which could cause a bug with OrdFieldSource caching
- on OrdFieldSource#hashcode collisions. (Mark Miller)
- 49. SOLR-1207: equals method should compare this and other of DocList in DocSetBase (koji)
- 50. SOLR-1242: Human readable JVM info from system handler does integer cutoff rounding, even when dealing
- with GB. Fixed to round to one decimal place. (Jay Hill, Mark Miller)
- 51. SOLR-1243: Admin RequestHandlers should not be cached over HTTP. (Mark Miller)
- 52. SOLR-1260: Fix implementations of set operations for DocList subclasses
- and fix a bug in HashDocSet construction when offset != 0. These bugs
- never manifested in normal Solr use and only potentially affect
- custom code. (yonik)
- 53. SOLR-1171: Fix LukeRequestHandler so it doesn't rely on SolrQueryParser
- and report incorrect stats when field names contain characters
- SolrQueryParser considers special.
- (hossman)
- 54. SOLR-1317: Fix CapitalizationFilterFactory to work when keep parameter is not specified.
- (ehatcher)
- 55. SOLR-1342: CapitalizationFilterFactory uses incorrect term length calculations.
- (Robert Muir via Mark Miller)
- 56. SOLR-1359: DoubleMetaphoneFilter didn't index original tokens if there was no
- alternative, and could incorrectly skip or reorder tokens. (yonik)
- 57. SOLR-1360: Prevent PhoneticFilter from producing duplicate tokens. (yonik)
- 58. SOLR-1371: LukeRequestHandler/schema.jsp errored if schema had no
- uniqueKey field. The new test for this also (hopefully) adds some
- future proofing against similar bugs in the future. As a side
- effect QueryElevationComponentTest was refactored, and a bug in
- that test was found. (hossman)
- 59. SOLR-914: General finalize() improvements. No finalizer delegates
- to the respective close/destroy method w/o first checking if it's
- already been closed/destroyed; if it hasn't a, SEVERE error is
- logged first. (noble, hossman)
- 60. SOLR-1362: WordDelimiterFilter had inconsistent behavior when setting
- the position increment of tokens following a token consisting of all
- delimiters, and could additionally lose big position increments.
- (Robert Muir, yonik)
- 61. SOLR-1091: Jetty's use of CESU-8 for code points outside the BMP
- resulted in invalid output from the serialized PHP writer. (yonik)
- 62. SOLR-1103: LukeRequestHandler (and schema.jsp) have been fixed to
- include the "1" (ie: 2**0) bucket in the term histogram data.
- (hossman)
- 63. SOLR-1398: Add offset corrections in PatternTokenizerFactory.
- (Anders Melchiorsen, koji)
- 64. SOLR-1400: Properly handle zero-length tokens in TrimFilter. This
- was not a bug in any released version. (Peter Wolanin, gsingers)
- 65. SOLR-1071: spellcheck.extendedResults returns an invalid JSON response
- when count > 1. To fix, the extendedResults format was changed.
- (Uri Boness, yonik)
- 66. SOLR-1381: Fixed improper handling of fields that have only term positions and not term offsets during Highlighting (Thorsten Fischer, gsingers)
- 67. SOLR-1427: Fixed registry.jsp issue with MBeans (gsingers)
- 68. SOLR-1468: SolrJ's XML response parsing threw an exception for null
- names, such as those produced when facet.missing=true (yonik)
- 69. SOLR-1471: Fixed issue with calculating missing values for facets in single valued cases in Stats Component.
- This is not correctly calculated for the multivalued case. (James Miller, gsingers)
- 70. SOLR-1481: Fixed omitHeader parameter for PHP ResponseWriter. (Jun Ohtani via billa)
- 71. SOLR-1448: Add weblogic.xml to solr webapp to enable correct operation in
- WebLogic. (Ilan Rabinovitch via yonik)
- 72. SOLR-1504: empty char mapping can cause ArrayIndexOutOfBoundsException in analysis.jsp and co.
- (koji)
- 73. SOLR-1394: HTMLStripCharFilter split tokens that contained entities and
- often calculated offsets incorrectly for entities.
- (Anders Melchiorsen via yonik)
- 74. SOLR-1517: Admin pages could stall waiting for localhost name resolution
- if reverse DNS wasn't configured; this was changed so the DNS resolution
- is attempted only once the first time an admin page is loaded.
- (hossman)
- 75. SOLR-1529: More than 8 deleteByQuery commands in a single request
- caused an error to be returned, although the deletes were
- still executed. (asmodean via yonik)
- 76. SOLR-800: Deep copy collections to avoid ConcurrentModificationException
- in XPathEntityprocessor while streaming
- (Kyle Morrison, Noble Paul via shalin)
- 77. SOLR-823: Request parameter variables ${dataimporter.request.xxx} are not
- resolved in DIH (Mck SembWever, Noble Paul, shalin)
- 78. SOLR-728: Add synchronization to avoid race condition of multiple DIH
- imports working concurrently (Walter Ferrara, shalin)
- 79. SOLR-742: Add ability to create dynamic fields with custom
- DataImportHandler transformers (Wojtek Piaseczny, Noble Paul, shalin)
- 80. SOLR-832: Rows parameter is not honored in DIH non-debug mode and can
- abort a running import in debug mode. (Akshay Ukey, shalin)
- 81. SOLR-838: The DIH VariableResolver obtained from a DataSource's context
- does not have current data. (Noble Paul via shalin)
- 82. SOLR-864: DataImportHandler does not catch and log Errors (shalin)
- 83. SOLR-873: Fix case-sensitive field names and columns (Jon Baer, shalin)
- 84. SOLR-893: Unable to delete documents via SQL and deletedPkQuery with
- deltaimport (Dan Rosher via shalin)
- 85. SOLR-888: DIH DateFormatTransformer cannot convert non-string type
- (Amit Nithian via shalin)
- 86. SOLR-841: DataImportHandler should throw exception if a field does not
- have column attribute (Michael Henson, shalin)
- 87. SOLR-884: CachedSqlEntityProcessor should check if the cache key is
- present in the query results (Noble Paul via shalin)
- 88. SOLR-985: Fix thread-safety issue with DIH TemplateString for concurrent
- imports with multiple cores. (Ryuuichi Kumai via shalin)
- 89. SOLR-999: DIH XPathRecordReader fails on XMLs with nodes mixed with
- CDATA content. (Fergus McMenemie, Noble Paul via shalin)
- 90. SOLR-1000: DIH FileListEntityProcessor should not apply fileName filter to
- directory names. (Fergus McMenemie via shalin)
- 91. SOLR-1009: Repeated column names result in duplicate values.
- (Fergus McMenemie, Noble Paul via shalin)
- 92. SOLR-1017: Fix DIH thread-safety issue with last_index_time for concurrent
- imports in multiple cores due to unsafe usage of SimpleDateFormat by
- multiple threads. (Ryuuichi Kumai via shalin)
- 93. SOLR-1024: Calling abort on DataImportHandler import commits data instead
- of calling rollback. (shalin)
- 94. SOLR-1037: DIH should not add null values in a row returned by
- EntityProcessor to documents. (shalin)
- 95. SOLR-1040: DIH XPathEntityProcessor fails with an xpath like
- /feed/entry/link[@type='text/html']/@href (Noble Paul via shalin)
- 96. SOLR-1042: Fix memory leak in DIH by making TemplateString non-static
- member in VariableResolverImpl (Ryuuichi Kumai via shalin)
- 97. SOLR-1053: IndexOutOfBoundsException in DIH SolrWriter.getResourceAsString
- when size of data-config.xml is a multiple of 1024 bytes.
- (Herb Jiang via shalin)
- 98. SOLR-1077: IndexOutOfBoundsException with useSolrAddSchema in DIH
- XPathEntityProcessor. (Sam Keen, Noble Paul via shalin)
- 99. SOLR-1080: DIH RegexTransformer should not replace if regex is not matched.
- (Noble Paul, Fergus McMenemie via shalin)
- 100.SOLR-1090: DataImportHandler should load the data-config.xml using UTF-8
- encoding. (Rui Pereira, shalin)
- 101.SOLR-1146: ConcurrentModificationException in DataImporter.getStatusMessages
- (Walter Ferrara, Noble Paul via shalin)
- 102.SOLR-1229: Fixes for DIH deletedPkQuery, particularly when using
- transformed Solr unique id's
- (Lance Norskog, Noble Paul via ehatcher)
- 103.SOLR-1286: Fix the IH commit parameter always defaulting to "true" even
- if "false" is explicitly passed in. (Jay Hill, Noble Paul via ehatcher)
- 104.SOLR-1323: Reset XPathEntityProcessor's $hasMore/$nextUrl when fetching
- next URL (noble, ehatcher)
- 105.SOLR-1450: DIH: Jdbc connection properties such as batchSize are not
- applied if the driver jar is placed in solr_home/lib.
- (Steve Sun via shalin)
- 106.SOLR-1474: DIH Delta-import should run even if last_index_time is not set.
- (shalin)
- Other Changes
- ----------------------
- 1. Upgraded to Lucene 2.4.0 (yonik)
- 2. SOLR-805: Upgraded to Lucene 2.9-dev (r707499) (koji)
- 3. DumpRequestHandler (/debug/dump): changed 'fieldName' to 'sourceInfo'. (ehatcher)
- 4. SOLR-852: Refactored common code in CSVRequestHandler and XMLUpdateRequestHandler (gsingers, ehatcher)
- 5. SOLR-871: Removed dependency on stax-utils.jar. If you using solr.jar and running
- java 6, you can also remove woodstox and geronimo. (ryan)
- 6. SOLR-465: Upgraded to Lucene 2.9-dev (r719351) (shalin)
- 7. SOLR-889: Upgraded to commons-io-1.4.jar and commons-fileupload-1.2.1.jar (ryan)
- 8. SOLR-875: Upgraded to Lucene 2.9-dev (r723985) and consolidated the BitSet implementations (Michael Busch, gsingers)
- 9. SOLR-819: Upgraded to Lucene 2.9-dev (r724059) to get access to Arabic public constructors (gsingers)
- 10. SOLR-900: Moved solrj into /src/solrj. The contents of solr-common.jar is now included
- in the solr-solrj.jar. (ryan)
- 11. SOLR-924: Code cleanup: make all existing finalize() methods call
- super.finalize() in a finally block. All current instances extend
- Object, so this doesn't fix any bugs, but helps protect against
- future changes. (Kay Kay via hossman)
- 12. SOLR-885: NamedListCodec is renamed to JavaBinCodec and returns Object instead of NamedList.
- (Noble Paul, yonik via shalin)
- 13. SOLR-84: Use new Solr logo in admin (Michiel via koji)
- 14. SOLR-981: groupId for Woodstox dependency in maven solrj changed to org.codehaus.woodstox (Tim Taranov via shalin)
- 15. Upgraded to Lucene 2.9-dev r738218 (yonik)
- 16. SOLR-959: Refactored TestReplicationHandler to remove hardcoded port numbers (hossman, Akshay Ukey via shalin)
- 17. Upgraded to Lucene 2.9-dev r742220 (yonik)
- 18. SOLR-1022: Better "ignored" field in example schema.xml (Peter Wolanin via hossman)
- 19. SOLR-967: New type-safe constructor for NamedList (Kay Kay via hossman)
- 20. SOLR-1036: Change default QParser from "lucenePlusSort" to "lucene" to
- reduce confusion of semicolon splitting behavior when no sort param is
- specified (hossman)
- 21. Upgraded to Lucene 2.9-dev r752164 (shalin)
- 22. SOLR-1068: Use fsync on replicated index and configuration files (yonik, Noble Paul, shalin)
- 23. SOLR-952: Cleanup duplicated code in deprecated HighlightingUtils (hossman)
- 24. Upgraded to Lucene 2.9-dev r764281 (shalin)
- 25. SOLR-1079: Rename omitTf to omitTermFreqAndPositions (shalin)
- 26. SOLR-804: Added Lucene's misc contrib JAR (rev 764281). (gsingers)
- 27. Upgraded to Lucene 2.9-dev r768228 (shalin)
- 28. Upgraded to Lucene 2.9-dev r768336 (shalin)
- 29. SOLR-997: Wait for a longer time for slave to complete replication in TestReplicationHandler
- (Mark Miller via shalin)
- 30. SOLR-748: FacetComponent helper classes are made public as an experimental API.
- (Wojtek Piaseczny via shalin)
- 31. Upgraded to Lucene 2.9-dev 773862 (Mark Miller)
- 32. Upgraded to Lucene 2.9-dev r776177 (shalin)
- 33. SOLR-1149: Made QParserPlugin and related classes extendible as an experimental API.
- (Kaktu Chakarabati via shalin)
- 34. Upgraded to Lucene 2.9-dev r779312 (yonik)
- 35. SOLR-786: Refactor DisMaxQParser to allow overriding certain features of DisMaxQParser
- (Wojciech Biela via shalin)
- 36. SOLR-458: Add equals and hashCode methods to NamedList (Stefan Rinner, shalin)
- 37. SOLR-1184: Add option in solrconfig to open a new IndexReader rather than
- using reopen. Done mainly as a fail-safe in the case that a user runs into
- a reopen bug/issue. (Mark Miller)
- 38. SOLR-1215 use double quotes to enclose attributes in solr.xml (noble)
- 39. SOLR-1151: add dynamic copy field and maxChars example to example schema.xml.
- (Peter Wolanin, Mark Miller)
- 40. SOLR-1233: remove /select?qt=/whatever restriction on /-prefixed request handlers.
- (ehatcher)
- 41. SOLR-1257: logging.jsp has been removed and now passes through to the
- hierarchical log level tool added in Solr 1.3. Users still
- hitting "/admin/logging.jsp" should switch to "/admin/logging".
- (hossman)
- 42. Upgraded to Lucene 2.9-dev r794238. Other changes include:
- - LUCENE-1614 - Use Lucene's DocIdSetIterator.NO_MORE_DOCS as the sentinel value.
- - LUCENE-1630 - Add acceptsDocsOutOfOrder method to Collector implementations.
- - LUCENE-1673, LUCENE-1701 - Trie has moved to Lucene core and renamed to NumericRangeQuery.
- - LUCENE-1662, LUCENE-1687 - Replace usage of ExtendedFieldCache by FieldCache.
- (shalin)
- 42. SOLR-1241: Solr's CharFilter has been moved to Lucene. Remove CharFilter and related classes
- from Solr and use Lucene's corresponding code (koji via shalin)
- 43. SOLR-1261: Lucene trunk renamed RangeQuery & Co to TermRangeQuery (Uwe Schindler via shalin)
- 44. Upgraded to Lucene 2.9-dev r801856 (Mark Miller)
- 45. SOLR-1276: Added StatsComponentTest (Rafał Kuć, gsingers)
- 46. SOLR-1377: The TokenizerFactory API has changed to explicitly return a Tokenizer
- rather then a TokenStream (that may be or may not be a Tokenizer). This change
- is required to take advantage of the Token reuse improvements in lucene 2.9. (ryan)
- 47. SOLR-1410: Log a warning if the deprecated charset option is used
- on GreekLowerCaseFilterFactory, RussianStemFilterFactory,
- RussianLowerCaseFilterFactory or RussianLetterTokenizerFactory.
- (Robert Muir via hossman)
- 48. SOLR-1423: Due to LUCENE-1906, Solr's tokenizer should use Tokenizer.correctOffset() instead of CharStream.correctOffset().
- (Uwe Schindler via koji)
- 49. SOLR-1319, SOLR-1345: Upgrade Solr Highlighter classes to new Lucene Highlighter API. This upgrade has
- resulted in a back compat break in the DefaultSolrHighlighter class - getQueryScorer is no longer
- protected. If you happened to be overriding that method in custom code, overide getHighlighter instead.
- Also, HighlightingUtils#getQueryScorer has been removed as it was deprecated and backcompat has been
- broken with it anyway. (Mark Miller)
- 50. SOLR-1357 SolrInputDocument cannot process dynamic fields (Lars Grote via noble)
- 51. SOLR-1075: Upgrade to Tika 0.3. See http://www.apache.org/dist/lucene/tika/CHANGES-0.3.txt (gsingers)
- 52. SOLR-1310: Upgrade to Tika 0.4. Note there are some differences in
- detecting Languages now in extracting request handler.
- See http://www.lucidimagination.com/search/document/d6f1899a85b2a45c/vote_apache_tika_0_4_release_candidate_2#d6f1899a85b2a45c
- for discussion on language detection.
- See http://www.apache.org/dist/lucene/tika/CHANGES-0.4.txt. (gsingers)
- 53. SOLR-782: DIH: Refactored SolrWriter to make it a concrete class and
- removed wrappers over SolrInputDocument. Refactored to load Evaluators
- lazily. Removed multiple document nodes in the configuration xml. Removed
- support for 'default' variables, they are automatically available as
- request parameters. (Noble Paul via shalin)
- 54. SOLR-964: DIH: XPathEntityProcessor now ignores DTD validations
- (Fergus McMenemie, Noble Paul via shalin)
- 55. SOLR-1029: DIH: Standardize Evaluator parameter parsing and added helper
- functions for parsing all evaluator parameters in a standard way.
- (Noble Paul, shalin)
- 56. SOLR-1081: Change DIH EventListener to be an interface so that components
- such as an EntityProcessor or a Transformer can act as an event listener.
- (Noble Paul, shalin)
- 57. SOLR-1027: DIH: Alias the 'dataimporter' namespace to a shorter name 'dih'.
- (Noble Paul via shalin)
- 58. SOLR-1084: Better error reporting when DIH entity name is a reserved word
- and data-config.xml root node is not <dataConfig>.
- (Noble Paul via shalin)
- 59. SOLR-1087: Deprecate 'where' attribute in CachedSqlEntityProcessor in
- favor of cacheKey and cacheLookup. (Noble Paul via shalin)
- 60. SOLR-969: Change the FULL_DUMP, DELTA_DUMP, FIND_DELTA constants in DIH
- Context to String. Change Context.currentProcess() to return a string
- instead of an integer. (Kay Kay, Noble Paul, shalin)
- 61. SOLR-1120: Simplified DIH EntityProcessor API by moving logic for applying
- transformers and handling multi-row outputs from Transformers into an
- EntityProcessorWrapper class. The behavior of the method
- EntityProcessor#destroy has been modified to be called once per parent-row
- at the end of row. A new method EntityProcessor#close is added which is
- called at the end of import. A new method
- Context#getResolvedEntityAttribute is added which returns the resolved
- value of an entity's attribute. Introduced a DocWrapper which takes care
- of maintaining document level session variables.
- (Noble Paul, shalin)
- 62. SOLR-1265: Add DIH variable resolving for URLDataSource properties like
- baseUrl. (Chris Eldredge via ehatcher)
- 63. SOLR-1269: Better error messages from DIH JdbcDataSource when JDBC Driver
- name or SQL is incorrect. (ehatcher, shalin)
- Build
- ----------------------
- 1. SOLR-776: Added in ability to sign artifacts via Ant for releases (gsingers)
- 2. SOLR-854: Added run-example target (Mark Miller via ehatcher)
- 3. SOLR-1054:Fix dist-src target for DataImportHandler (Ryuuichi Kumai via shalin)
- 4. SOLR-1219: Added proxy.setup target (koji)
- 5. SOLR-1386: In build.xml, use longfile="gnu" in tar task to avoid warnings about long file names
- (Mark Miller via shalin)
- 6. SOLR-1441: Make it possible to run all tests in a package (shalin)
- Documentation
- ----------------------
- 1. SOLR-789: The javadoc of RandomSortField is not readable (Nicolas Lalevée via koji)
- 2. SOLR-962: Note about null handling in ModifiableSolrParams.add javadoc
- (Kay Kay via hossman)
- 3. SOLR-1409: Added Solr Powered By Logos
- 4. SOLR-1369: Add HSQLDB Jar to example-DIH, unzip database and update
- instructions.
- ================== Release 1.3.0 ==================
- Upgrading from Solr 1.2
- -----------------------
- IMPORTANT UPGRADE NOTE: In a master/slave configuration, all searchers/slaves
- should be upgraded before the master! If the master were to be updated
- first, the older searchers would not be able to read the new index format.
- The Porter snowball based stemmers in Lucene were updated (LUCENE-1142),
- and are not guaranteed to be backward compatible at the index level
- (the stem of certain words may have changed). Re-indexing is recommended.
- Older Apache Solr installations can be upgraded by replacing
- the relevant war file with the new version. No changes to configuration
- files should be needed.
- This version of Solr contains a new version of Lucene implementing
- an updated index format. This version of Solr/Lucene can still read
- and update indexes in the older formats, and will convert them to the new
- format on the first index change. Be sure to backup your index before
- upgrading in case you need to downgrade.
- Solr now recognizes HTTP Request headers related to HTTP Caching (see
- RFC 2616 sec13) and will by default respond with "304 Not Modified"
- when appropriate. This should only affect users who access Solr via
- an HTTP Cache, or via a Web-browser that has an internal cache, but if
- you wish to suppress this behavior an '<httpCaching never304="true"/>'
- option can be added to your solrconfig.xml. See the wiki (or the
- example solrconfig.xml) for more details...
- http://wiki.apache.org/solr/SolrConfigXml#HTTPCaching
- In Solr 1.2, DateField did not enforce the canonical representation of
- the ISO 8601 format when parsing incoming data, and did not generation
- the canonical format when generating dates from "Date Math" strings
- (particularly as it pertains to milliseconds ending in trailing zeros).
- As a result equivalent dates could not always be compared properly.
- This problem is corrected in Solr 1.3, but DateField users that might
- have been affected by indexing inconsistent formats of equivalent
- dates (ie: 1995-12-31T23:59:59Z vs 1995-12-31T23:59:59.000Z) may want
- to consider reindexing to correct these inconsistencies. Users who
- depend on some of the the "broken" behavior of DateField in Solr 1.2
- (specificly: accepting any input that ends in a 'Z') should consider
- using the LegacyDateField class as a possible alternative. Users that
- desire 100% backwards compatibility should consider using the Solr 1.2
- version of DateField.
- Due to some changes in the lifecycle of TokenFilterFactories, users of
- Solr 1.2 who have written Java code which constructs new instances of
- StopFilterFactory, SynonymFilterFactory, or EnglishProterFilterFactory
- will need to modify their code by adding a line like the following
- prior to using the factory object...
- factory.inform(SolrCore.getSolrCore().getSolrConfig().getResourceLoader());
- These lifecycle changes do not affect people who use Solr "out of the
- box" or who have developed their own TokenFilterFactory plugins. More
- info can be found in SOLR-594.
- The python client that used to ship with Solr is no longer included in
- the distribution (see client/python/README.txt).
- Detailed Change List
- --------------------
- New Features
- 1. SOLR-69: Adding MoreLikeThisHandler to search for similar documents using
- lucene contrib/queries MoreLikeThis. MoreLikeThis is also available from
- the StandardRequestHandler using ?mlt=true. (bdelacretaz, ryan)
- 2. SOLR-253: Adding KeepWordFilter and KeepWordFilterFactory. A TokenFilter
- that keeps tokens with text in the registered keeplist. This behaves like
- the inverse of StopFilter. (ryan)
- 3. SOLR-257: WordDelimiterFilter has a new parameter splitOnCaseChange,
- which can be set to 0 to disable splitting "PowerShot" => "Power" "Shot".
- (klaas)
- 4. SOLR-193: Adding SolrDocument and SolrInputDocument to represent documents
- outside of the lucene Document infrastructure. This class will be used
- by clients and for processing documents. (ryan)
- 5. SOLR-244: Added ModifiableSolrParams - a SolrParams implementation that
- help you change values after initialization. (ryan)
- 6. SOLR-20: Added a java client interface with two implementations. One
- implementation uses commons httpclient to connect to solr via HTTP. The
- other connects to solr directly. Check client/java/solrj. This addition
- also includes tests that start jetty and test a connection using the full
- HTTP request cycle. (Darren Erik Vengroff, Will Johnson, ryan)
- 7. SOLR-133: Added StaxUpdateRequestHandler that uses StAX for XML parsing.
- This implementation has much better error checking and lets you configure
- a custom UpdateRequestProcessor that can selectively process update
- requests depending on the request attributes. This class will likely
- replace XmlUpdateRequestHandler. (Thorsten Scherler, ryan)
- 8. SOLR-264: Added RandomSortField, a utility field with a random sort order.
- The seed is based on a hash of the field name, so a dynamic field
- of this type is useful for generating different random sequences.
- This field type should only be used for sorting or as a value source
- in a FunctionQuery (ryan, hossman, yonik)
- 9. SOLR-266: Adding show=schema to LukeRequestHandler to show the parsed
- schema fields and field types. (ryan)
- 10. SOLR-133: The UpdateRequestHandler now accepts multiple delete options
- within a single request. For example, sending:
- <delete><id>1</id><id>2</id></delete> will delete both 1 and 2. (ryan)
- 11. SOLR-269: Added UpdateRequestProcessor plugin framework. This provides
- a reasonable place to process documents after they are parsed and
- before they are committed to the index. This is a good place for custom
- document manipulation or document based authorization. (yonik, ryan)
- 12. SOLR-260: Converting to a standard PluginLoader framework. This reworks
- RequestHandlers, FieldTypes, and QueryResponseWriters to share the same
- base code for loading and initializing plugins. This adds a new
- configuration option to define the default RequestHandler and
- QueryResponseWriter in XML using default="true". (ryan)
- 13. SOLR-225: Enable pluggable highlighting classes. Allow configurable
- highlighting formatters and Fragmenters. (ryan)
- 14. SOLR-273/376/452/516: Added hl.maxAnalyzedChars highlighting parameter, defaulting
- to 50k, hl.alternateField, which allows the specification of a backup
- field to use as summary if no keywords are matched, and hl.mergeContiguous,
- which combines fragments if they are adjacent in the source document.
- (klaas, Grant Ingersoll, Koji Sekiguchi via klaas)
- 15. SOLR-291: Control maximum number of documents to cache for any entry
- in the queryResultCache via queryResultMaxDocsCached solrconfig.xml
- entry. (Koji Sekiguchi via yonik)
- 16. SOLR-240: New <lockType> configuration setting in <mainIndex> and
- <indexDefaults> blocks supports all Lucene builtin LockFactories.
- 'single' is recommended setting, but 'simple' is default for total
- backwards compatibility.
- (Will Johnson via hossman)
- 17. SOLR-248: Added CapitalizationFilterFactory that creates tokens with
- normalized capitalization. This filter is useful for facet display,
- but will not work with a prefix query. (ryan)
- SOLR-468: Change to the semantics to keep the original token, not the
- token in the Map. Also switched to use Lucene's new reusable token
- capabilities. (gsingers)
- 18. SOLR-307: Added NGramFilterFactory and EdgeNGramFilterFactory.
- (Thomas Peuss via Otis Gospodnetic)
- 19. SOLR-305: analysis.jsp can be given a fieldtype instead of a field
- name. (hossman)
- 20. SOLR-102: Added RegexFragmenter, which splits text for highlighting
- based on a given pattern. (klaas)
- 21. SOLR-258: Date Faceting added to SimpleFacets. Facet counts
- computed for ranges of size facet.date.gap (a DateMath expression)
- between facet.date.start and facet.date.end. (hossman)
- 22. SOLR-196: A PHP serialized "phps" response writer that returns a
- serialized array that can be used with the PHP function unserialize,
- and a PHP response writer "php" that may be used by eval.
- (Nick Jenkin, Paul Borgermans, Pieter Berkel via yonik)
- 23. SOLR-308: A new UUIDField class which accepts UUID string values,
- as well as the special value of "NEW" which triggers generation of
- a new random UUID.
- (Thomas Peuss via hossman)
- 24. SOLR-349: New FunctionQuery functions: sum, product, div, pow, log,
- sqrt, abs, scale, map. Constants may now be used as a value source.
- (yonik)
- 25. SOLR-359: Add field type className to Luke response, and enabled access
- to the detailed field information from the solrj client API.
- (Grant Ingersoll via ehatcher)
- 26. SOLR-334: Pluggable query parsers. Allows specification of query
- type and arguments as a prefix on a query string. (yonik)
- 27. SOLR-351: External Value Source. An external file may be used
- to specify the values of a field, currently usable as
- a ValueSource in a FunctionQuery. (yonik)
- 28. SOLR-395: Many new features for the spell checker implementation, including
- an extended response mode with much richer output, multi-word spell checking,
- and a bevy of new and renamed options (see the wiki).
- (Mike Krimerman, Scott Taber via klaas).
- 29. SOLR-408: Added PingRequestHandler and deprecated SolrCore.getPingQueryRequest().
- Ping requests should be configured using standard RequestHandler syntax in
- solrconfig.xml rather then using the <pingQuery></pingQuery> syntax.
- (Karsten Sperling via ryan)
- 30. SOLR-281: Added a 'Search Component' interface and converted StandardRequestHandler
- and DisMaxRequestHandler to use this framework.
- (Sharad Agarwal, Henri Biestro, yonik, ryan)
- 31. SOLR-176: Add detailed timing data to query response output. The SearchHandler
- interface now returns how long each section takes. (klaas)
- 32. SOLR-414: Plugin initialization now supports SolrCore and ResourceLoader "Aware"
- plugins. Plugins that implement SolrCoreAware or ResourceLoaderAware are
- informed about the SolrCore/ResourceLoader. (Henri Biestro, ryan)
- 33. SOLR-350: Support multiple SolrCores running in the same solr instance and allows
- runtime runtime management for any running SolrCore. If a solr.xml file exists
- in solr.home, this file is used to instanciate multiple cores and enables runtime
- core manipulation. For more informaion see: http://wiki.apache.org/solr/CoreAdmin
- (Henri Biestro, ryan)
- 34. SOLR-447: Added an single request handler that will automatically register all
- standard admin request handlers. This replaces the need to register (and maintain)
- the set of admin request handlers. Assuming solrconfig.xml includes:
- <requestHandler name="/admin/" class="org.apache.solr.handler.admin.AdminHandlers" />
- This will register: Luke/SystemInfo/PluginInfo/ThreadDump/PropertiesRequestHandler.
- (ryan)
- 35. SOLR-142: Added RawResponseWriter and ShowFileRequestHandler. This returns config
- files directly. If AdminHandlers are configured, this will be added automatically.
- The jsp files /admin/get-file.jsp and /admin/raw-schema.jsp have been deprecated.
- The deprecated <admin><gettableFiles> will be automatically registered with
- a ShowFileRequestHandler instance for backwards compatibility. (ryan)
- 36. SOLR-446: TextResponseWriter can write SolrDocuments and SolrDocumentLists the
- same way it writes Document and DocList. (yonik, ryan)
- 37. SOLR-418: Adding a query elevation component. This is an optional component to
- elevate some documents to the top positions (or exclude them) for a given query.
- (ryan)
- 38. SOLR-478: Added ability to get back unique key information from the LukeRequestHandler.
- (gsingers)
- 39. SOLR-127: HTTP Caching awareness. Solr now recognizes HTTP Request
- headers related to HTTP Caching (see RFC 2616 sec13) and will respond
- with "304 Not Modified" when appropriate. New options have been added
- to solrconfig.xml to influence this behavior.
- (Thomas Peuss via hossman)
- 40. SOLR-303: Distributed Search over HTTP. Specification of shards
- argument causes Solr to query those shards and merge the results
- into a single response. Querying, field faceting (sorted only),
- query faceting, highlighting, and debug information are supported
- in distributed mode.
- (Sharad Agarwal, Patrick O'Leary, Sabyasachi Dalal, Stu Hood,
- Jayson Minard, Lars Kotthoff, ryan, yonik)
- 41. SOLR-356: Pluggable functions (value sources) that allow
- registration of new functions via solrconfig.xml
- (Doug Daniels via yonik)
- 42. SOLR-494: Added cool admin Ajaxed schema explorer.
- (Greg Ludington via ehatcher)
- 43. SOLR-497: Added date faceting to the QueryResponse in SolrJ
- and QueryResponseTest (Shalin Shekhar Mangar via gsingers)
- 44. SOLR-486: Binary response format, faster and smaller
- than XML and JSON response formats (use wt=javabin).
- BinaryResponseParser for utilizing the binary format via SolrJ
- and is now the default.
- (Noble Paul, yonik)
- 45. SOLR-521: StopFilterFactory support for "enablePositionIncrements"
- (Walter Ferrara via hossman)
- 46. SOLR-557: Added SolrCore.getSearchComponents() to return an unmodifiable Map. (gsingers)
- 47. SOLR-516: Added hl.maxAlternateFieldLength parameter, to set max length for hl.alternateField
- (Koji Sekiguchi via klaas)
- 48. SOLR-319: Changed SynonymFilterFactory to "tokenize" synonyms file.
- To use a tokenizer, specify "tokenizerFactory" attribute in <filter>.
- For example:
- <tokenizer class="solr.CJKTokenizerFactory"/>
- <filter class="solr.SynonymFilterFactory" synonyms="synonyms.txt" expand="true"
- ignoreCase="true" tokenizerFactory="solr.CJKTokenizerFactory"/>
- (koji)
- 49. SOLR-515: Added SimilarityFactory capability to schema.xml,
- making config file parameters usable in the construction of
- the global Lucene Similarity implementation.
- (ehatcher)
- 50. SOLR-536: Add a DocumentObjectBinder to solrj that converts Objects to and
- from SolrDocuments. (Noble Paul via ryan)
- 51. SOLR-595: Add support for Field level boosting in the MoreLikeThis Handler.
- (Tom Morton, gsingers)
- 52. SOLR-572: Added SpellCheckComponent and org.apache.solr.spelling package to support more spell
- checking functionality. Also includes ability to add your own SolrSpellChecker implementation that
- plugs in. See http://wiki.apache.org/solr/SpellCheckComponent for more details
- (Shalin Shekhar Mangar, Bojan Smid, gsingers)
- 53. SOLR-679: Added accessor methods to Lucene based spell checkers (gsingers)
- 54. SOLR-423: Added Request Handler close hook notification so that RequestHandlers can be notified
- when a core is closing. (gsingers, ryan)
- 55. SOLR-603: Added ability to partially optimize. (gsingers)
- 56. SOLR-483: Add byte/short sorting support (gsingers)
- 57. SOLR-14: Add preserveOriginal flag to WordDelimiterFilter
- (Geoffrey Young, Trey Hyde, Ankur Madnani, yonik)
- 58. SOLR-502: Add search timeout support. (Sean Timm via yonik)
- 59. SOLR-605: Add the ability to register callbacks programatically (ryan, Noble Paul)
- 60. SOLR-610: hl.maxAnalyzedChars can be -1 to highlight everything (Lars Kotthoff via klaas)
- 61. SOLR-522: Make analysis.jsp show payloads. (Tricia Williams via yonik)
- 62. SOLR-611: Expose sort_values returned by QueryComponent in SolrJ's QueryResponse
- (Dan Rosher via shalin)
- 63. SOLR-256: Support exposing Solr statistics through JMX (Sharad Agrawal, shalin)
- 64. SOLR-666: Expose warmup time in statistics for SolrIndexSearcher and LRUCache (shalin)
- 65. SOLR-663: Allow multiple files for stopwords, keepwords, protwords and synonyms
- (Otis Gospodnetic, shalin)
- 66. SOLR-469: Added DataImportHandler as a contrib project which makes indexing data from Databases,
- XML files and HTTP data sources into Solr quick and easy. Includes API and implementations for
- supporting multiple data sources, processors and transformers for importing data. Supports full
- data imports as well as incremental (delta) indexing. See http://wiki.apache.org/solr/DataImportHandler
- for more details. (Noble Paul, shalin)
- 67. SOLR-622: SpellCheckComponent supports auto-loading indices on startup and optionally, (re)builds
- indices on newSearcher event, if configured in solrconfig.xml (shalin)
- 68. SOLR-554: Hierarchical JDK log level selector for SOLR Admin replaces logging.jsp
- (Sean Timm via shalin)
- 69. SOLR-506: Emitting HTTP Cache headers can be enabled or disabled through configuration on a
- per-handler basis (shalin)
- 70. SOLR-716: Added support for properties in configuration files. Properties can be specified in
- solr.xml and can be used in solrconfig.xml and schema.xml (Henri Biestro, hossman, ryan, shalin)
- 71. SOLR-1129 : Support binding dynamic fields to beans in SolrJ (Avlesh Singh , noble)
- 72. SOLR-920 : Cache and reuse IndexSchema . A new attribute added in solr.xml called 'shareSchema' (noble)
- 73. SOLR-700: DIH: Allow configurable locales through a locale attribute in
- fields for NumberFormatTransformer. (Stefan Oestreicher, shalin)
- Changes in runtime behavior
- 1. SOLR-559: use Lucene updateDocument, deleteDocuments methods. This
- removes the maxBufferedDeletes parameter added by SOLR-310 as Lucene
- now manages the deletes. This provides slightly better indexing
- performance and makes overwrites atomic, eliminating the possibility of
- a crash causing duplicates. (yonik)
- 2. SOLR-689 / SOLR-695: If you have used "MultiCore" functionality in an unreleased
- version of 1.3-dev, many classes and configs have been renamed for the official
- 1.3 release. Speciffically, solr.xml has replaced multicore.xml, and uses a slightly
- different syntax. The solrj classes: MultiCore{Request/Response/Params} have been
- renamed: CoreAdmin{Request/Response/Params} (hossman, ryan, Henri Biestro)
- 3. SOLR-647: reference count the SolrCore uses to prevent a premature
- close while a core is still in use. (Henri Biestro, Noble Paul, yonik)
- 4. SOLR-737: SolrQueryParser now uses a ConstantScoreQuery for wildcard
- queries that prevent an exception from being thrown when the number
- of matching terms exceeds the BooleanQuery clause limit. (yonik)
- Optimizations
- 1. SOLR-276: improve JSON writer speed. (yonik)
- 2. SOLR-310: bound and reduce memory usage by providing <maxBufferedDeletes> parameter,
- which flushes deleted without forcing the user to use <commit/> for this purpose.
- (klaas)
- 3. SOLR-348: short-circuit faceting if less than mincount docs match. (yonik)
- 4. SOLR-354: Optimize removing all documents. Now when a delete by query
- of *:* is issued, the current index is removed. (yonik)
- 5. SOLR-377: Speed up response writers. (yonik)
- 6. SOLR-342: Added support into the SolrIndexWriter for using several new features of the new
- LuceneIndexWriter, including: setRAMBufferSizeMB(), setMergePolicy(), setMergeScheduler.
- Also, added support to specify Lucene's autoCommit functionality (not to be confused with Solr's
- similarily named autoCommit functionality) via the <luceneAutoCommit> config. item. See the test
- and example solrconfig.xml <indexDefaults> section for usage. Performance during indexing should
- be significantly increased by moving up to 2.3 due to Lucene's new indexing capabilities.
- Furthermore, the setRAMBufferSizeMB makes it more logical to decide on tuning factors related to
- indexing. For best performance, leave the mergePolicy and mergeScheduler as the defaults and set
- ramBufferSizeMB instead of maxBufferedDocs. The best value for this depends on the types of
- documents in use. 32 should be a good starting point, but reports have shown up to 48 MB provides
- good results. Note, it is acceptable to set both ramBufferSizeMB and maxBufferedDocs, and Lucene
- will flush based on whichever limit is reached first. (gsingers)
- 7. SOLR-330: Converted TokenStreams to use Lucene's new char array based
- capabilities. (gsingers)
- 8. SOLR-624: Only take snapshots if there are differences to the index (Richard Trey Hyde via gsingers)
- 9. SOLR-587: Delete by Query performance greatly improved by using
- new underlying Lucene IndexWriter implementation. (yonik)
- 10. SOLR-730: Use read-only IndexReaders that don't synchronize
- isDeleted(). This will speed up function queries and *:* queries
- as well as improve their scalability on multi-CPU systems.
- (Mark Miller via yonik)
- Bug Fixes
- 1. Make TextField respect sortMissingFirst and sortMissingLast fields.
- (J.J. Larrea via yonik)
- 2. autoCommit/maxDocs was not working properly when large autoCommit/maxTime
- was specified (klaas)
- 3. SOLR-283: autoCommit was not working after delete. (ryan)
- 4. SOLR-286: ContentStreamBase was not using default encoding for getBytes()
- (Toru Matsuzawa via ryan)
- 5. SOLR-292: Fix MoreLikeThis facet counting. (Pieter Berkel via ryan)
- 6. SOLR-297: Fix bug in RequiredSolrParams where requiring a field
- specific param would fail if a general default value had been supplied.
- (hossman)
- 7. SOLR-331: Fix WordDelimiterFilter handling of offsets for synonyms or
- other injected tokens that can break highlighting. (yonik)
- 8. SOLR-282: Snapshooter does not work on Solaris and OS X since the cp command
- there does not have the -l option. Also updated commit/optimize related
- scripts to handle both old and new response format. (bill)
- 9. SOLR-294: Logging of elapsed time broken on Solaris because the date command
- there does not support the %s output format. (bill)
- 10. SOLR-136: Snappuller - "date -d" and locales don't mix. (Jürgen Hermann via bill)
- 11. SOLR-333: Changed distributiondump.jsp to use Solr HOME instead of CWD to set path.
- 12. SOLR-393: Removed duplicate contentType from raw-schema.jsp. (bill)
- 13. SOLR-413: Requesting a large numbers of documents to be returned (limit)
- can result in an out-of-memory exception, even for a small index. (yonik)
- 14. The CSV loader incorrectly threw an exception when given
- header=true (the default). (ryan, yonik)
- 15. SOLR-449: the python and ruby response writers are now able to correctly
- output NaN and Infinity in their respective languages. (klaas)
- 16. SOLR-42: HTMLStripReader tokenizers now preserve correct source
- offsets for highlighting. (Grant Ingersoll via yonik)
- 17. SOLR-481: Handle UnknownHostException in _info.jsp (gsingers)
- 18. SOLR-324: Add proper support for Long and Doubles in sorting, etc. (gsingers)
- 19. SOLR-496: Cache-Control max-age changed to Long so Expires
- calculation won't cause overflow. (Thomas Peuss via hossman)
- 20. SOLR-535: Fixed typo (Tokenzied -> Tokenized) in schema.jsp (Thomas Peuss via billa)
- 21. SOLR-529: Better error messages from SolrQueryParser when field isn't
- specified and there is no defaultSearchField in schema.xml
- (Lars Kotthoff via hossman)
- 22. SOLR-530: Better error messages/warnings when parsing schema.xml:
- field using bogus fieldtype and multiple copyFields to a non-multiValue
- field. (Shalin Shekhar Mangar via hossman)
- 23. SOLR-528: Better error message when defaultSearchField is bogus or not
- indexed. (Lars Kotthoff via hossman)
- 24. SOLR-533: Fixed tests so they don't use hardcoded port numbers.
- (hossman)
- 25. SOLR-400: SolrExceptionTest should now handle using OpenDNS as a DNS provider (gsingers)
- 26. SOLR-541: Legacy XML update support (provided by SolrUpdateServlet
- when no RequestHandler is mapped to "/update") now logs error correctly.
- (hossman)
- 27. SOLR-267: Changed logging to report number of hits, and also provide a mechanism to add log
- messages to be output by the SolrCore via a NamedList toLog member variable.
- (Will Johnson, yseeley, gsingers)
- - SOLR-267: Removed adding values to the HTTP headers in SolrDispatchFilter (gsingers)
- 28. SOLR-509: Moved firstSearcher event notification to the end of the SolrCore constructor
- (Koji Sekiguchi via gsingers)
- 29. SOLR-470, SOLR-552, SOLR-544, SOLR-701: Multiple fixes to DateField
- regarding lenient parsing of optional milliseconds, and correct
- formating using the canonical representation. LegacyDateField has
- been added for people who have come to depend on the existing
- broken behavior. (hossman, Stefan Oestreicher)
- 30. SOLR-539: Fix for non-atomic long counters and a cast fix to avoid divide
- by zero. (Sean Timm via Otis Gospodnetic)
- 31. SOLR-514: Added explicit media-type with UTF* charset to *.xsl files that
- don't already have one. (hossman)
- 32. SOLR-505: Give RequestHandlers the possiblity to suppress the generation
- of HTTP caching headers. (Thomas Peuss via Otis Gospodnetic)
- 33. SOLR-553: Handle highlighting of phrase terms better when
- hl.usePhraseHighligher=true URL param is used.
- (Bojan Smid via Otis Gospodnetic)
- 34. SOLR-590: Limitation in pgrep on Linux platform breaks script-utils fixUser.
- (Hannes Schmidt via billa)
- 35. SOLR-597: SolrServlet no longer "caches" SolrCore. This was causing
- problems in Resin, and could potentially cause problems for customized
- usages of SolrServlet.
- 36. SOLR-585: Now sets the QParser on the ResponseBuilder (gsingers)
- 37. SOLR-604: If the spellchecking path is relative, make it relative to the Solr Data Directory.
- (Shalin Shekhar Mangar via gsingers)
- 38. SOLR-584: Make stats.jsp and stats.xsl more robust.
- (Yousef Ourabi and hossman)
- 39. SOLR-443: SolrJ: Declare UTF-8 charset on POSTed parameters
- to avoid problems with servlet containers that default to latin-1
- and allow switching of the exact POST mechanism for parameters
- via useMultiPartPost in CommonsHttpSolrServer.
- (Lars Kotthoff, Andrew Schurman, ryan, yonik)
- 40. SOLR-556: multi-valued fields always highlighted in disparate snippets
- (Lars Kotthoff via klaas)
- 41. SOLR-501: Fix admin/analysis.jsp UTF-8 input for some other servlet
- containers such as Tomcat. (Hiroaki Kawai, Lars Kotthoff via yonik)
- 42. SOLR-616: SpellChecker accuracy configuration is not applied for FileBasedSpellChecker.
- Apply it for FileBasedSpellChecker and IndexBasedSpellChecker both.
- (shalin)
- 43. SOLR-648: SpellCheckComponent throws NullPointerException on using spellcheck.q request
- parameter after restarting Solr, if reload is called but build is not called.
- (Jonathan Lee, shalin)
- 44. SOLR-598: DebugComponent now always occurs last in the SearchHandler list unless the
- components are explicitly declared. (gsingers)
- 45. SOLR-676: DataImportHandler should use UpdateRequestProcessor API instead of directly
- using UpdateHandler. (shalin)
- 46. SOLR-696: Fixed bug in NamedListCodec in regards to serializing Iterable objects. (gsingers)
- 47. SOLR-669: snappuler fix for FreeBSD/Darwin (Richard "Trey" Hyde via Otis Gospodnetic)
- 48. SOLR-606: Fixed spell check collation offset issue. (Stefan Oestreicher , Geoffrey Young, gsingers)
- 49. SOLR-589: Improved handling of badly formated query strings (Sean Timm via Otis Gospodnetic)
- 50. SOLR-749: Allow QParser and ValueSourceParsers to be extended with same name (hossman, gsingers)
- 51. SOLR-704: DIH NumberFormatTransformer can silently ignore part of the
- string while parsing. Now it tries to use the complete string for parsing.
- Failure to do so will result in an exception.
- (Stefan Oestreicher via shalin)
- 52. SOLR-729: DIH Context.getDataSource(String) gives current entity's
- DataSource instance regardless of argument. (Noble Paul, shalin)
- 53. SOLR-726: DIH: Jdbc Drivers and DataSources fail to load if placed in
- multicore sharedLib or core's lib directory.
- (Walter Ferrara, Noble Paul, shalin)
- Other Changes
- 1. SOLR-135: Moved common classes to org.apache.solr.common and altered the
- build scripts to make two jars: apache-solr-1.3.jar and
- apache-solr-1.3-common.jar. This common.jar can be used in client code;
- It does not have lucene or junit dependencies. The original classes
- have been replaced with a @Deprecated extended class and are scheduled
- to be removed in a later release. While this change does not affect API
- compatibility, it is recommended to update references to these
- deprecated classes. (ryan)
- 2. SOLR-268: Tweaks to post.jar so it prints the error message from Solr.
- (Brian Whitman via hossman)
- 3. Upgraded to Lucene 2.2.0; June 18, 2007.
- 4. SOLR-215: Static access to SolrCore.getSolrCore() and SolrConfig.config
- have been deprecated in order to support multiple loaded cores.
- (Henri Biestro via ryan)
- 5. SOLR-367: The create method in all TokenFilter and Tokenizer Factories
- provided by Solr now declare their specific return types instead of just
- using "TokenStream" (hossman)
- 6. SOLR-396: Hooks add to build system for automatic generation of (stub)
- Tokenizer and TokenFilter Factories.
- Also: new Factories for all Tokenizers and TokenFilters provided by the
- lucene-analyzers-2.2.0.jar -- includes support for German, Chinese,
- Russan, Dutch, Greek, Brazilian, Thai, and French. (hossman)
- 7. Upgraded to commons-CSV r609327, which fixes escaping bugs and
- introduces new escaping and whitespace handling options to
- increase compatibility with different formats. (yonik)
- 8. Upgraded to Lucene 2.3.0; Jan 23, 2008.
- 9. SOLR-451: Changed analysis.jsp to use POST instead of GET, also made the input area a
- bit bigger (gsingers)
- 10. Upgrade to Lucene 2.3.1
- 11. SOLR-531: Different exit code for rsyncd-start and snappuller if disabled (Thomas Peuss via billa)
- 12. SOLR-550: Clarified DocumentBuilder addField javadocs (gsingers)
- 13. Upgrade to Lucene 2.3.2
- 14. SOLR-518: Changed luke.xsl to use divs w/css for generating histograms
- instead of SVG (Thomas Peuss via hossman)
- 15. SOLR-592: Added ShardParams interface and changed several string literals
- to references to constants in CommonParams.
- (Lars Kotthoff via Otis Gospodnetic)
- 16. SOLR-520: Deprecated unused LengthFilter since already core in
- Lucene-Java (hossman)
- 17. SOLR-645: Refactored SimpleFacetsTest (Lars Kotthoff via hossman)
- 18. SOLR-591: Changed Solrj default value for facet.sort to true (Lars Kotthoff via Shalin)
- 19. Upgraded to Lucene 2.4-dev (r669476) to support SOLR-572 (gsingers)
- 20. SOLR-636: Improve/simplify example configs; and make index.jsp
- links more resilient to configs loaded via an InputStream
- (Lars Kotthoff, hossman)
- 21. SOLR-682: Scripts now support FreeBSD (Richard Trey Hyde via gsingers)
- 22. SOLR-489: Added in deprecation comments. (Sean Timm, Lars Kothoff via gsingers)
- 23. SOLR-692: Migrated to stable released builds of StAX API 1.0.1 and StAX 1.2.0 (shalin)
- 24. Upgraded to Lucene 2.4-dev (r686801) (yonik)
- 25. Upgraded to Lucene 2.4-dev (r688745) 27-Aug-2008 (yonik)
- 26. Upgraded to Lucene 2.4-dev (r691741) 03-Sep-2008 (yonik)
- 27. Replaced the StAX reference implementation with the geronimo
- StAX API jar, and the Woodstox StAX implementation. (yonik)
- Build
- 1. SOLR-411. Changed the names of the Solr JARs to use the defacto standard JAR names based on
- project-name-version.jar. This yields, for example:
- apache-solr-common-1.3-dev.jar
- apache-solr-solrj-1.3-dev.jar
- apache-solr-1.3-dev.jar
- 2. SOLR-479: Added clover code coverage targets for committers and the nightly build. Requires
- the Clover library, as licensed to Apache and only available privately. To run:
- ant -Drun.clover=true clean clover test generate-clover-reports
- 3. SOLR-510: Nightly release includes client sources. (koji)
- 4. SOLR-563: Modified the build process to build contrib projects
- (Shalin Shekhar Mangar via Otis Gospodnetic)
- 5. SOLR-673: Modify build file to create javadocs for core, solrj, contrib and "all inclusive" (shalin)
- 6. SOLR-672: Nightly release includes contrib sources. (Jeremy Hinegardner, shalin)
- 7. SOLR-586: Added ant target and POM files for building maven artifacts of the Solr core, common,
- client and contrib. The target can publish artifacts with source and javadocs.
- (Spencer Crissman, Craig McClanahan, shalin)
- ================== Release 1.2 ==================
- Upgrading from Solr 1.1
- -------------------------------------
- IMPORTANT UPGRADE NOTE: In a master/slave configuration, all searchers/slaves
- should be upgraded before the master! If the master were to be updated
- first, the older searchers would not be able to read the new index format.
- Older Apache Solr installations can be upgraded by replacing
- the relevant war file with the new version. No changes to configuration
- files should be needed.
- This version of Solr contains a new version of Lucene implementing
- an updated index format. This version of Solr/Lucene can still read
- and update indexes in the older formats, and will convert them to the new
- format on the first index change. One change in the new index format
- is that all "norms" are kept in a single file, greatly reducing the number
- of files per segment. Users of compound file indexes will want to consider
- converting to the non-compound format for faster indexing and slightly better
- search concurrency.
- The JSON response format for facets has changed to make it easier for
- clients to retain sorted order. Use json.nl=map explicitly in clients
- to get the old behavior, or add it as a default to the request handler
- in solrconfig.xml
- The Lucene based Solr query syntax is slightly more strict.
- A ':' in a field value must be escaped or the whole value must be quoted.
- The Solr "Request Handler" framework has been updated in two key ways:
- First, if a Request Handler is registered in solrconfig.xml with a name
- starting with "/" then it can be accessed using path-based URL, instead of
- using the legacy "/select?qt=name" URL structure. Second, the Request
- Handler framework has been extended making it possible to write Request
- Handlers that process streams of data for doing updates, and there is a
- new-style Request Handler for XML updates given the name of "/update" in
- the example solrconfig.xml. Existing installations without this "/update"
- handler will continue to use the old update servlet and should see no
- changes in behavior. For new-style update handlers, errors are now
- reflected in the HTTP status code, Content-type checking is more strict,
- and the response format has changed and is controllable via the wt
- parameter.
- Detailed Change List
- --------------------
- New Features
- 1. SOLR-82: Default field values can be specified in the schema.xml.
- (Ryan McKinley via hossman)
- 2. SOLR-89: Two new TokenFilters with corresponding Factories...
- * TrimFilter - Trims leading and trailing whitespace from Tokens
- * PatternReplaceFilter - applies a Pattern to each token in the
- stream, replacing match occurances with a specified replacement.
- (hossman)
- 3. SOLR-91: allow configuration of a limit of the number of searchers
- that can be warming in the background. This can be used to avoid
- out-of-memory errors, or contention caused by more and more searchers
- warming in the background. An error is thrown if the limit specified
- by maxWarmingSearchers in solrconfig.xml is exceeded. (yonik)
- 4. SOLR-106: New faceting parameters that allow specification of a
- minimum count for returned facets (facet.mincount), paging through facets
- (facet.offset, facet.limit), and explicit sorting (facet.sort).
- facet.zeros is now deprecated. (yonik)
- 5. SOLR-80: Negative queries are now allowed everywhere. Negative queries
- are generated and cached as their positive counterpart, speeding
- generation and generally resulting in smaller sets to cache.
- Set intersections in SolrIndexSearcher are more efficient,
- starting with the smallest positive set, subtracting all negative
- sets, then intersecting with all other positive sets. (yonik)
- 6. SOLR-117: Limit a field faceting to constraints with a prefix specified
- by facet.prefix or f.<field>.facet.prefix. (yonik)
- 7. SOLR-107: JAVA API: Change NamedList to use Java5 generics
- and implement Iterable<Map.Entry> (Ryan McKinley via yonik)
- 8. SOLR-104: Support for "Update Plugins" -- RequestHandlers that want
- access to streams of data for doing updates. ContentStreams can come
- from the raw POST body, multi-part form data, or remote URLs.
- Included in this change is a new SolrDispatchFilter that allows
- RequestHandlers registered with names that begin with a "/" to be
- accessed using a URL structure based on that name.
- (Ryan McKinley via hossman)
- 9. SOLR-126: DirectUpdateHandler2 supports autocommitting after a specified time
- (in ms), using <autoCommit><maxTime>10000</maxTime></autoCommit>.
- (Ryan McKinley via klaas).
- 10. SOLR-116: IndexInfoRequestHandler added. (Erik Hatcher)
- 11. SOLR-79: Add system property ${<sys.prop>[:<default>]} substitution for
- configuration files loaded, including schema.xml and solrconfig.xml.
- (Erik Hatcher with inspiration from Andrew Saar)
- 12. SOLR-149: Changes to make Solr more easily embeddable, in addition
- to logging which request handler handled each request.
- (Ryan McKinley via yonik)
- 13. SOLR-86: Added standalone Java-based command-line updater.
- (Erik Hatcher via Bertrand Delecretaz)
- 14. SOLR-152: DisMaxRequestHandler now supports configurable alternate
- behavior when q is not specified. A "q.alt" param can be specified
- using SolrQueryParser syntax as a mechanism for specifying what query
- the dismax handler should execute if the main user query (q) is blank.
- (Ryan McKinley via hossman)
- 15. SOLR-158: new "qs" (Query Slop) param for DisMaxRequestHandler
- allows for specifying the amount of default slop to use when parsing
- explicit phrase queries from the user.
- (Adam Hiatt via hossman)
- 16. SOLR-81: SpellCheckerRequestHandler that uses the SpellChecker from
- the Lucene contrib.
- (Otis Gospodnetic and Adam Hiatt)
- 17. SOLR-182: allow lazy loading of request handlers on first request.
- (Ryan McKinley via yonik)
- 18. SOLR-81: More SpellCheckerRequestHandler enhancements, inlcluding
- support for relative or absolute directory path configurations, as
- well as RAM based directory. (hossman)
- 19. SOLR-197: New parameters for input: stream.contentType for specifying
- or overriding the content type of input, and stream.file for reading
- local files. (Ryan McKinley via yonik)
- 20. SOLR-66: CSV data format for document additions and updates. (yonik)
- 21. SOLR-184: add echoHandler=true to responseHeader, support echoParams=all
- (Ryan McKinley via ehatcher)
- 22. SOLR-211: Added a regex PatternTokenizerFactory. This extracts tokens
- from the input string using a regex Pattern. (Ryan McKinley)
- 23. SOLR-162: Added a "Luke" request handler and other admin helpers.
- This exposes the system status through the standard requestHandler
- framework. (ryan)
- 24. SOLR-212: Added a DirectSolrConnection class. This lets you access
- solr using the standard request/response formats, but does not require
- an HTTP connection. It is designed for embedded applications. (ryan)
- 25. SOLR-204: The request dispatcher (added in SOLR-104) can handle
- calls to /select. This offers uniform error handling for /update and
- /select. To enable this behavior, you must add:
- <requestDispatcher handleSelect="true" > to your solrconfig.xml
- See the example solrconfig.xml for details. (ryan)
- 26. SOLR-170: StandardRequestHandler now supports a "sort" parameter.
- Using the ';' syntax is still supported, but it is recommended to
- transition to the new syntax. (ryan)
- 27. SOLR-181: The index schema now supports "required" fields. Attempts
- to add a document without a required field will fail, returning a
- descriptive error message. By default, the uniqueKey field is
- a required field. This can be disabled by setting required=false
- in schema.xml. (Greg Ludington via ryan)
- 28. SOLR-217: Fields configured in the schema to be neither indexed or
- stored will now be quietly ignored by Solr when Documents are added.
- The example schema has a comment explaining how this can be used to
- ignore any "unknown" fields.
- (Will Johnson via hossman)
- 29. SOLR-227: If schema.xml defines multiple fieldTypes, fields, or
- dynamicFields with the same name, a severe error will be logged rather
- then quietly continuing. Depending on the <abortOnConfigurationError>
- settings, this may halt the server. Likewise, if solrconfig.xml
- defines multiple RequestHandlers with the same name it will also add
- an error. (ryan)
- 30. SOLR-226: Added support for dynamic field as the destination of a
- copyField using glob (*) replacement. (ryan)
- 31. SOLR-224: Adding a PhoneticFilterFactory that uses apache commons codec
- language encoders to build phonetically similar tokens. This currently
- supports: DoubleMetaphone, Metaphone, Soundex, and RefinedSoundex (ryan)
- 32. SOLR-199: new n-gram tokenizers available via NGramTokenizerFactory
- and EdgeNGramTokenizerFactory. (Adam Hiatt via yonik)
- 33. SOLR-234: TrimFilter can update the Token's startOffset and endOffset
- if updateOffsets="true". By default the Token offsets are unchanged.
- (ryan)
- 34. SOLR-208: new example_rss.xsl and example_atom.xsl to provide more
- examples for people about the Solr XML response format and how they
- can transform it to suit different needs.
- (Brian Whitman via hossman)
- 35. SOLR-249: Deprecated SolrException( int, ... ) constructors in favor
- of constructors that takes an ErrorCode enum. This will ensure that
- all SolrExceptions use a valid HTTP status code. (ryan)
- 36. SOLR-386: Abstracted SolrHighlighter and moved existing implementation
- to DefaultSolrHighlighter. Adjusted SolrCore and solrconfig.xml so
- that highlighter is configurable via a class attribute. Allows users
- to use their own highlighter implementation. (Tricia Williams via klaas)
- Changes in runtime behavior
- 1. Highlighting using DisMax will only pick up terms from the main
- user query, not boost or filter queries (klaas).
- 2. SOLR-125: Change default of json.nl to flat, change so that
- json.nl only affects items where order matters (facet constraint
- listings). Fix JSON output bug for null values. Internal JAVA API:
- change most uses of NamedList to SimpleOrderedMap. (yonik)
- 3. A new method "getSolrQueryParser" has been added to the IndexSchema
- class for retrieving a new SolrQueryParser instance with all options
- specified in the schema.xml's <solrQueryParser> block set. The
- documentation for the SolrQueryParser constructor and its use of
- IndexSchema have also been clarified.
- (Erik Hatcher and hossman)
- 4. DisMaxRequestHandler's bq, bf, qf, and pf parameters can now accept
- multiple values (klaas).
- 5. Query are re-written before highlighting is performed. This enables
- proper highlighting of prefix and wildcard queries (klaas).
- 6. A meaningful exception is raised when attempting to add a doc missing
- a unique id if it is declared in the schema and allowDups=false.
- (ryan via klaas)
- 7. SOLR-183: Exceptions with error code 400 are raised when
- numeric argument parsing fails. RequiredSolrParams class added
- to facilitate checking for parameters that must be present.
- (Ryan McKinley, J.J. Larrea via yonik)
- 8. SOLR-179: By default, solr will abort after any severe initialization
- errors. This behavior can be disabled by setting:
- <abortOnConfigurationError>false</abortOnConfigurationError>
- in solrconfig.xml (ryan)
- 9. The example solrconfig.xml maps /update to XmlUpdateRequestHandler using
- the new request dispatcher (SOLR-104). This requires posted content to
- have a valid contentType: curl -H 'Content-type:text/xml; charset=utf-8'
- The response format matches that of /select and returns standard error
- codes. To enable solr1.1 style /update, do not map "/update" to any
- handler in solrconfig.xml (ryan)
- 10. SOLR-231: If a charset is not specified in the contentType,
- ContentStream.getReader() will use UTF-8 encoding. (ryan)
- 11. SOLR-230: More options for post.jar to support stdin, xml on the
- commandline, and defering commits. Tutorial modified to take
- advantage of these options so there is no need for curl.
- (hossman)
- 12. SOLR-128: Upgraded Jetty to the latest stable release 6.1.3 (ryan)
- Optimizations
- 1. SOLR-114: HashDocSet specific implementations of union() and andNot()
- for a 20x performance improvement for those set operations, and a new
- hash algorithm speeds up exists() by 10% and intersectionSize() by 8%.
- (yonik)
- 2. SOLR-115: Solr now uses BooleanQuery.clauses() instead of
- BooleanQuery.getClauses() in any situation where there is no risk of
- modifying the original query.
- (hossman)
- 3. SOLR-221: Speed up sorted faceting on multivalued fields by ~60%
- when the base set consists of a relatively large portion of the
- index. (yonik)
- 4. SOLR-221: Added a facet.enum.cache.minDf parameter which avoids
- using the filterCache for terms that match few documents, trading
- decreased memory usage for increased query time. (yonik)
- Bug Fixes
- 1. SOLR-87: Parsing of synonym files did not correctly handle escaped
- whitespace such as \r\n\t\b\f. (yonik)
- 2. SOLR-92: DOMUtils.getText (used when parsing config files) did not
- work properly with many DOM implementations when dealing with
- "Attributes". (Ryan McKinley via hossman)
- 3. SOLR-9,SOLR-99: Tighten up sort specification error checking, throw
- exceptions for missing sort specifications or a sort on a non-indexed
- field. (Ryan McKinley via yonik)
- 4. SOLR-145: Fix for bug introduced in SOLR-104 where some Exceptions
- were being ignored by all "out of the box" RequestHandlers. (hossman)
- 5. SOLR-166: JNDI solr.home code refactoring. SOLR-104 moved
- some JNDI related code to the init method of a Servlet Filter -
- according to the Servlet Spec, all Filter's should be initialized
- prior to initializing any Servlets, but this is not the case in at
- least one Servlet Container (Resin). This "bug fix" refactors
- this JNDI code so that it should be executed the first time any
- attempt is made to use the solr.home dir.
- (Ryan McKinley via hossman)
- 6. SOLR-173: Bug fix to SolrDispatchFilter to reduce "too many open
- files" problem was that SolrDispatchFilter was not closing requests
- when finished. Also modified ResponseWriters to only fetch a Searcher
- reference if necessary for writing out DocLists.
- (Ryan McKinley via hossman)
- 7. SOLR-168: Fix display positioning of multiple tokens at the same
- position in analysis.jsp (yonik)
- 8. SOLR-167: The SynonymFilter sometimes generated incorrect offsets when
- multi token synonyms were mached in the source text. (yonik)
- 9. SOLR-188: bin scripts do not support non-default webapp names. Added "-U"
- option to specify a full path to the update url, overriding the
- "-h" (hostname), "-p" (port) and "-w" (webapp name) parameters.
- (Jeff Rodenburg via billa)
- 10. SOLR-198: RunExecutableListener always waited for the process to
- finish, even when wait="false" was set. (Koji Sekiguchi via yonik)
- 11. SOLR-207: Changed distribution scripts to remove recursive find
- and avoid use of "find -maxdepth" on platforms where it is not
- supported. (yonik)
- 12. SOLR-222: Changing writeLockTimeout in solrconfig.xml did not
- change the effective timeout. (Koji Sekiguchi via yonik)
- 13. Changed the SOLR-104 RequestDispatcher so that /select?qt=xxx can not
- access handlers that start with "/". This makes path based authentication
- possible for path based request handlers. (ryan)
- 14. SOLR-214: Some servlet containers (including Tomcat and Resin) do not
- obey the specified charset. Rather then letting the the container handle
- it solr now uses the charset from the header contentType to decode posted
- content. Using the contentType: "text/xml; charset=utf-8" will force
- utf-8 encoding. If you do not specify a contentType, it will use the
- platform default. (Koji Sekiguchi via ryan)
- 15. SOLR-241: Undefined system properties used in configuration files now
- cause a clear message to be logged rather than an obscure exception thrown.
- (Koji Sekiguchi via ehatcher)
- Other Changes
- 1. Updated to Lucene 2.1
- 2. Updated to Lucene 2007-05-20_00-04-53
- ================== Release 1.1.0 ==================
- Status
- ------
- This is the first release since Solr joined the Incubator, and brings many
- new features and performance optimizations including highlighting,
- faceted browsing, and JSON/Python/Ruby response formats.
- Upgrading from previous Solr versions
- -------------------------------------
- Older Apache Solr installations can be upgraded by replacing
- the relevant war file with the new version. No changes to configuration
- files are needed and the index format has not changed.
- The default version of the Solr XML response syntax has been changed to 2.2.
- Behavior can be preserved for those clients not explicitly specifying a
- version by adding a default to the request handler in solrconfig.xml
- By default, Solr will no longer use a searcher that has not fully warmed,
- and requests will block in the meantime. To change back to the previous
- behavior of using a cold searcher in the event there is no other
- warm searcher, see the useColdSearcher config item in solrconfig.xml
- The XML response format when adding multiple documents to the collection
- in a single <add> command has changed to return a single <result>.
- Detailed Change List
- --------------------
- New Features
- 1. added support for setting Lucene's positionIncrementGap
- 2. Admin: new statistics for SolrIndexSearcher
- 3. Admin: caches now show config params on stats page
- 3. max() function added to FunctionQuery suite
- 4. postOptimize hook, mirroring the functionallity of the postCommit hook,
- but only called on an index optimize.
- 5. Ability to HTTP POST query requests to /select in addition to HTTP-GET
- 6. The default search field may now be overridden by requests to the
- standard request handler using the df query parameter. (Erik Hatcher)
- 7. Added DisMaxRequestHandler and SolrPluginUtils. (Chris Hostetter)
- 8. Support for customizing the QueryResponseWriter per request
- (Mike Baranczak / SOLR-16 / hossman)
- 9. Added KeywordTokenizerFactory (hossman)
- 10. copyField accepts dynamicfield-like names as the source.
- (Darren Erik Vengroff via yonik, SOLR-21)
- 11. new DocSet.andNot(), DocSet.andNotSize() (yonik)
- 12. Ability to store term vectors for fields. (Mike Klaas via yonik, SOLR-23)
- 13. New abstract BufferedTokenStream for people who want to write
- Tokenizers or TokenFilters that require arbitrary buffering of the
- stream. (SOLR-11 / yonik, hossman)
- 14. New RemoveDuplicatesToken - useful in situations where
- synonyms, stemming, or word-deliminater-ing produce identical tokens at
- the same position. (SOLR-11 / yonik, hossman)
- 15. Added highlighting to SolrPluginUtils and implemented in StandardRequestHandler
- and DisMaxRequestHandler (SOLR-24 / Mike Klaas via hossman,yonik)
- 16. SnowballPorterFilterFactory language is configurable via the "language"
- attribute, with the default being "English". (Bertrand Delacretaz via yonik, SOLR-27)
- 17. ISOLatin1AccentFilterFactory, instantiates ISOLatin1AccentFilter to remove accents.
- (Bertrand Delacretaz via yonik, SOLR-28)
- 18. JSON, Python, Ruby QueryResponseWriters: use wt="json", "python" or "ruby"
- (yonik, SOLR-31)
- 19. Make web admin pages return UTF-8, change Content-type declaration to include a
- space between the mime-type and charset (Philip Jacob, SOLR-35)
- 20. Made query parser default operator configurable via schema.xml:
- <solrQueryParser defaultOperator="AND|OR"/>
- The default operator remains "OR".
- 21. JAVA API: new version of SolrIndexSearcher.getDocListAndSet() which takes
- flags (Greg Ludington via yonik, SOLR-39)
- 22. A HyphenatedWordsFilter, a text analysis filter used during indexing to rejoin
- words that were hyphenated and split by a newline. (Boris Vitez via yonik, SOLR-41)
- 23. Added a CompressableField base class which allows fields of derived types to
- be compressed using the compress=true setting. The field type also gains the
- ability to specify a size threshold at which field data is compressed.
- (klaas, SOLR-45)
- 24. Simple faceted search support for fields (enumerating terms)
- and arbitrary queries added to both StandardRequestHandler and
- DisMaxRequestHandler. (hossman, SOLR-44)
- 25. In addition to specifying default RequestHandler params in the
- solrconfig.xml, support has been added for configuring values to be
- appended to the multi-val request params, as well as for configuring
- invariant params that can not overridden in the query. (hossman, SOLR-46)
- 26. Default operator for query parsing can now be specified with q.op=AND|OR
- from the client request, overriding the schema value. (ehatcher)
- 27. New XSLTResponseWriter does server side XSLT processing of XML Response.
- In the process, an init(NamedList) method was added to QueryResponseWriter
- which works the same way as SolrRequestHandler.
- (Bertrand Delacretaz / SOLR-49 / hossman)
- 28. json.wrf parameter adds a wrapper-function around the JSON response,
- useful in AJAX with dynamic script tags for specifying a JavaScript
- callback function. (Bertrand Delacretaz via yonik, SOLR-56)
- 29. autoCommit can be specified every so many documents added (klaas, SOLR-65)
- 30. ${solr.home}/lib directory can now be used for specifying "plugin" jars
- (hossman, SOLR-68)
- 31. Support for "Date Math" relative "NOW" when specifying values of a
- DateField in a query -- or when adding a document.
- (hossman, SOLR-71)
- 32. useColdSearcher control in solrconfig.xml prevents the first searcher
- from being used before it's done warming. This can help prevent
- thrashing on startup when multiple requests hit a cold searcher.
- The default is "false", preventing use before warm. (yonik, SOLR-77)
- Changes in runtime behavior
- 1. classes reorganized into different packages, package names changed to Apache
- 2. force read of document stored fields in QuerySenderListener
- 3. Solr now looks in ./solr/conf for config, ./solr/data for data
- configurable via solr.solr.home system property
- 4. Highlighter params changed to be prefixed with "hl."; allow fragmentsize
- customization and per-field overrides on many options
- (Andrew May via klaas, SOLR-37)
- 5. Default param values for DisMaxRequestHandler should now be specified
- using a '<lst name="defaults">...</lst>' init param, for backwards
- compatability all init prams will be used as defaults if an init param
- with that name does not exist. (hossman, SOLR-43)
- 6. The DisMaxRequestHandler now supports multiple occurances of the "fq"
- param. (hossman, SOLR-44)
- 7. FunctionQuery.explain now uses ComplexExplanation to provide more
- accurate score explanations when composed in a BooleanQuery.
- (hossman, SOLR-25)
- 8. Document update handling locking is much sparser, allowing performance gains
- through multiple threads. Large commits also might be faster (klaas, SOLR-65)
- 9. Lazy field loading can be enabled via a solrconfig directive. This will be faster when
- not all stored fields are needed from a document (klaas, SOLR-52)
- 10. Made admin JSPs return XML and transform them with new XSL stylesheets
- (Otis Gospodnetic, SOLR-58)
- 11. If the "echoParams=explicit" request parameter is set, request parameters are copied
- to the output. In an XML output, they appear in new <lst name="params"> list inside
- the new <lst name="responseHeader"> element, which replaces the old <responseHeader>.
- Adding a version=2.1 parameter to the request produces the old format, for backwards
- compatibility (bdelacretaz and yonik, SOLR-59).
- Optimizations
- 1. getDocListAndSet can now generate both a DocList and a DocSet from a
- single lucene query.
- 2. BitDocSet.intersectionSize(HashDocSet) no longer generates an intermediate
- set
- 3. OpenBitSet completed, replaces BitSet as the implementation for BitDocSet.
- Iteration is faster, and BitDocSet.intersectionSize(BitDocSet) and unionSize
- is between 3 and 4 times faster. (yonik, SOLR-15)
- 4. much faster unionSize when one of the sets is a HashDocSet: O(smaller_set_size)
- 5. Optimized getDocSet() for term queries resulting in a 36% speedup of facet.field
- queries where DocSets aren't cached (for example, if the number of terms in the field
- is larger than the filter cache.) (yonik)
- 6. Optimized facet.field faceting by as much as 500 times when the field has
- a single token per document (not multiValued & not tokenized) by using the
- Lucene FieldCache entry for that field to tally term counts. The first request
- utilizing the FieldCache will take longer than subsequent ones.
- Bug Fixes
- 1. Fixed delete-by-id for field types who's indexed form is different
- from the printable form (mainly sortable numeric types).
- 2. Added escaping of attribute values in the XML response (Erik Hatcher)
- 3. Added empty extractTerms() to FunctionQuery to enable use in
- a MultiSearcher (Yonik)
- 4. WordDelimiterFilter sometimes lost token positionIncrement information
- 5. Fix reverse sorting for fields were sortMissingFirst=true
- (Rob Staveley, yonik)
- 6. Worked around a Jetty bug that caused invalid XML responses for fields
- containing non ASCII chars. (Bertrand Delacretaz via yonik, SOLR-32)
- 7. WordDelimiterFilter can throw exceptions if configured with both
- generate and catenate off. (Mike Klaas via yonik, SOLR-34)
- 8. Escape '>' in XML output (because ]]> is illegal in CharData)
- 9. field boosts weren't being applied and doc boosts were being applied to fields (klaas)
- 10. Multiple-doc update generates well-formed xml (klaas, SOLR-65)
- 11. Better parsing of pingQuery from solrconfig.xml (hossman, SOLR-70)
- 12. Fixed bug with "Distribution" page introduced when Versions were
- added to "Info" page (hossman)
- 13. Fixed HTML escaping issues with user input to analysis.jsp and action.jsp
- (hossman, SOLR-74)
- Other Changes
- 1. Upgrade to Lucene 2.0 nightly build 2006-06-22, lucene SVN revision 416224,
- http://svn.apache.org/viewvc/lucene/java/trunk/CHANGES.txt?view=markup&pathrev=416224
- 2. Modified admin styles to improve display in Internet Explorer (Greg Ludington via billa, SOLR-6)
- 3. Upgrade to Lucene 2.0 nightly build 2006-07-15, lucene SVN revision 422302,
- 4. Included unique key field name/value (if available) in log message of add (billa, SOLR-18)
- 5. Updated to Lucene 2.0 nightly build 2006-09-07, SVN revision 462111
- 6. Added javascript to catch empty query in admin query forms (Tomislav Nakic-Alfirevic via billa, SOLR-48
- 7. blackslash escape * in ssh command used in snappuller for zsh compatibility, SOLR-63
- 8. check solr return code in admin scripts, SOLR-62
- 9. Updated to Lucene 2.0 nightly build 2006-11-15, SVN revision 475069
- 10. Removed src/apps containing the legacy "SolrTest" app (hossman, SOLR-3)
- 11. Simplified index.jsp and form.jsp, primarily by removing/hiding XML
- specific params, and adding an option to pick the output type. (hossman)
- 12. Added new numeric build property "specversion" to allow clean
- MANIFEST.MF files (hossman)
- 13. Added Solr/Lucene versions to "Info" page (hossman)
- 14. Explicitly set mime-type of .xsl files in web.xml to
- application/xslt+xml (hossman)
- 15. Config parsing should now work useing DOM Level 2 parsers -- Solr
- previously relied on getTextContent which is a DOM Level 3 addition
- (Alexander Saar via hossman, SOLR-78)
- 2006/01/17 Solr open sourced, moves to Apache Incubator
|