Анализ запросов Lucene выполняется медленно при использовании длинных запросов с подстановочными знаками (*).JAVA

Программисты JAVA общаются здесь
Ответить
Anonymous
 Анализ запросов Lucene выполняется медленно при использовании длинных запросов с подстановочными знаками (*).

Сообщение Anonymous »

У меня есть запрос Lucene, анализ которого занимает несколько секунд. Посмотрев на трассировку стека, выяснилось, что задержка вызвана подстановочными знаками (*) в запросе.
В своих тестах я заметил, что время синтаксического анализа значительно увеличивается, если строка запроса длинная и содержит несколько подстановочных знаков.
Мне интересно, есть ли какие-либо оптимизации для ускорения синтаксического анализа или есть ли рекомендуемый способ лучше понять такое поведение синтаксического анализа. Я использую lucene 5.
Вот минимальный пример:

Код: Выделить всё

static String luceneQuery =
"fieldname:*hellomatethen?=?@*nocheckyz*xosdAK*bangbeat*randanhan\\ 7*nope\\ therealherl\\ baddy*caddy\\ okadlo*xomsdo\\ vac\\ racd*udotanda\\ logorand\\ bokonoso\\ maraloko*donopoa\\ zxcvbnm\\ mnbvcxz\\ asdfg\\ lkjhgfdsaz*poiuyt\\ qwert*mnb\\ lpmkojn\\ mkonjib*poiupoi*hahaha*pouiopi?=?@gyb\\:\\\\bhuuhbv\\\\tyughkv\\\\tyuibijd\\\\tyuioprewqasdf\\\\tyuioper\\\\ashu\\:\\\\njibhuvg\\\\aplzkcvjasd\\\\iop123wqwe\\\\7890acasd\\\\kjhbn8345601ad\\\\98ujhbgta*";

Код: Выделить всё

static String luceneQuery =
"fieldname:*hellomatethen?=?@*nocheckyz*xosdAK*bangbeat*randanhan\\ 7*nope\\ therealherl\\ baddy*caddy\\ okadlo*xomsdo\\ vac\\ racd*udotanda\\ logorand\\ bokonoso\\ maraloko*donopoa\\ zxcvbnm\\ mnbvcxz\\ asdfg\\ lkjhgfdsaz*poiuyt\\ qwert*mnb\\ lpmkojn\\ mkonjib*poiupoi*hahaha*pouiopi?=?@gyb\\:\\\\bhuuhbv\\\\tyughkv\\\\tyuibijd\\\\tyuioprewqasdf\\\\tyuioper\\\\ashu\\:\\\\njibhuvg\\\\aplzkcvjasd\\\\iop123wqwe\\\\7890acasd\\\\kjhbn8345601ad\\\\98ujhbgta*";

public static void main(String[] args) throws Exception {
QueryParser queryParser = new QueryParser("fieldname", new StandardAnalyzer());
queryParser.setAllowLeadingWildcard(true);
Query parsed = queryParser.parse(luceneQuery);
}



Подробнее здесь: https://stackoverflow.com/questions/798 ... -character
Ответить

Быстрый ответ

Изменение регистра текста: 
Смайлики
:) :( :oops: :roll: :wink: :muza: :clever: :sorry: :angel: :read: *x)
Ещё смайлики…
   
К этому ответу прикреплено по крайней мере одно вложение.

Если вы не хотите добавлять вложения, оставьте поля пустыми.

Максимально разрешённый размер вложения: 15 МБ.

Вернуться в «JAVA»