Apache Solr Search Patterns
eBook - ePub

Apache Solr Search Patterns

Jayant Kumar

Compartir libro
  1. 316 páginas
  2. English
  3. ePUB (apto para móviles)
  4. Disponible en iOS y Android
eBook - ePub

Apache Solr Search Patterns

Jayant Kumar

Detalles del libro
Vista previa del libro
Índice
Citas

Preguntas frecuentes

¿Cómo cancelo mi suscripción?
Simplemente, dirígete a la sección ajustes de la cuenta y haz clic en «Cancelar suscripción». Así de sencillo. Después de cancelar tu suscripción, esta permanecerá activa el tiempo restante que hayas pagado. Obtén más información aquí.
¿Cómo descargo los libros?
Por el momento, todos nuestros libros ePub adaptables a dispositivos móviles se pueden descargar a través de la aplicación. La mayor parte de nuestros PDF también se puede descargar y ya estamos trabajando para que el resto también sea descargable. Obtén más información aquí.
¿En qué se diferencian los planes de precios?
Ambos planes te permiten acceder por completo a la biblioteca y a todas las funciones de Perlego. Las únicas diferencias son el precio y el período de suscripción: con el plan anual ahorrarás en torno a un 30 % en comparación con 12 meses de un plan mensual.
¿Qué es Perlego?
Somos un servicio de suscripción de libros de texto en línea que te permite acceder a toda una biblioteca en línea por menos de lo que cuesta un libro al mes. Con más de un millón de libros sobre más de 1000 categorías, ¡tenemos todo lo que necesitas! Obtén más información aquí.
¿Perlego ofrece la función de texto a voz?
Busca el símbolo de lectura en voz alta en tu próximo libro para ver si puedes escucharlo. La herramienta de lectura en voz alta lee el texto en voz alta por ti, resaltando el texto a medida que se lee. Puedes pausarla, acelerarla y ralentizarla. Obtén más información aquí.
¿Es Apache Solr Search Patterns un PDF/ePUB en línea?
Sí, puedes acceder a Apache Solr Search Patterns de Jayant Kumar en formato PDF o ePUB, así como a otros libros populares de Informatica y Programmazione open source. Tenemos más de un millón de libros disponibles en nuestro catálogo para que explores.

Información

Año
2015
ISBN
9781783981847

Apache Solr Search Patterns


Table of Contents

Apache Solr Search Patterns
Credits
About the Author
About the Reviewers
www.PacktPub.com
Support files, eBooks, discount offers, and more
Why subscribe?
Free access for Packt account holders
Preface
What this book covers
What you need for this book
Who this book is for
Conventions
Reader feedback
Customer support
Downloading the example code
Errata
Piracy
Questions
1. Solr Indexing Internals
The job site problem statement – Solr indexing fundamentals
Working of analyzers, tokenizers, and filters
Handling a multilingual search
Measuring the quality of search results
The e-commerce problem statement
The job site problem statement
Challenges of large-scale indexing
Using multiple threads for indexing on Solr
Using the Java binary format of data for indexing
Using the ConcurrentUpdateSolrServer class for indexing
Solr configuration changes that can improve indexing performance
Planning your commit strategy
Using better hardware
Distributed indexing
The SolrCloud solution
Summary
2. Customizing the Solr Scoring Algorithm
Relevance calculation
Building a custom scorer
Drawbacks of the TF-IDF model
The information gain model
Implementing the information gain model
Options to TF-IDF similarity
BM25 similarity
DFR similarity
Summary
3. Solr Internals and Custom Queries
Working of a scorer on an inverted index
Working of OR and AND clauses
The eDisMax query parser
Working of the eDisMax query parser
The minimum should match parameter
Working of filters
Using BRS queries instead of DisMax
Building a custom query parser
Proximity search using SWAN queries
Creating a parboiled parser
Building a Solr plugin for SWAN queries
Integrating the SWAN plugin in Solr
Summary
4. Solr for Big Data
Introduction to big data
Getting data points using facets
Field faceting
Query and range faceting
Radius faceting for location-based data
The geofilt filter
The bounding box filter
The rectangle filter
Distance function queries
Radius faceting
Data analysis using pivot faceting
Graphs for analytics
Getting started with Highcharts
Displaying Solr data using Highcharts
Summary
5. Solr in E-commerce
Designing an e-commerce search
Handling unclean data
Handling variations in the product
Sorting
Problems and solutions of flash sale searches
Faceting with the option of multi-select
Faceting with hierarchical taxonomy
Faceting with size
Implementing semantic search
Optimizations
Summary
6. Solr for Spatial Search
Features of spatial search
Java Topology Suite
Well-known Text
The Spatial4j library
Lucene 4 spatial module
SpatialRecursivePrefixTreeFieldType
BBoxField (to be introduced in Solr 4.10)
Indexing for spatial search
Searching and filtering on a spatial index
The bbox query
Distance sort and relevancy boost
Advanced concepts
Quadtree
Indexing data
Searching data
Geohash
Summary
7. Using Solr in an Advertising System
Ad system functionalities
Architecture of an ad distribution system
Requirements of an ad distribution system
Schema for a listing ad
Schema for targeted ads
Performance improvements
fieldCache
fieldValueCache
documentCache
filterCache
queryResultCache
Application cache
Garbage collection
Merging Solr with Redis
Summary
8. AJAX Solr
The purpose of AJAX Solr
The AJAX Solr architecture
The Manager controller
The ParameterStore model
Available parameters
Exposed parameters
Using the ParameterHashStore class
Extending the ParameterStore class
Widgets
Working with AJAX Solr
Talking to AJAX Solr
Displaying the result
Adding facets
Adding pagination
Adding a tag cloud
Performance tuning
Summary
9. SolrCloud
The SolrCloud architecture
Centralized configuration
Setting up SolrCloud
Test setup for SolrCloud
Setting up SolrCloud in production
Setting up the Zookeeper ensemble
Setting up Tomcat with Solr
Distributed indexing and search
Routing documents to a particular shard
Adding more nodes to the SolrCloud
Fault tolerance and high availability in SolrCloud
Advanced sharding with SolrCloud
Shard splitting
Deleting a shard
Moving the existing shard to a new node
Shard splitting based on split key
Asynchronous calls
Migrating documents to another collection
Sizing and monitoring of SolrCloud
Using SolrCloud as a NoSQL database
Summary
10. Text Tagging with Lucene FST
An overview of FST and text tagging
Implementation of FST in Lucene
Text tagging algorithms
Fuzzy string matching algorithm
The Levenshtein distance algorithm
Damerau–Levenshtein distance
Using Solr for text tagging
Implementing a text tagger using Solr
Summary
Index

Apache Solr Search Patterns

Copyright © 2015 Packt Publishing
All rights reserved. No part of this book may be reproduced, stored in a retrieval system, or transmitted in any form or by any means, without the prior written permission of the publisher, except in the case of brief quotations embedded in critical articles or reviews.
Every effort has been made in the preparation of this book to ensure the accuracy of the information presented. However, the information contained in this book is sold without warranty, either express or implied. Neither the author nor Packt Publishing, and its dealers and distributors will be held liable for any damages caused or alleged to be caused directly or indirectly by this book.
Packt Publishing has endeavored to provide trademark information about all of the companies and products mentioned in this book by the appropriate use of capitals. However, Packt Publishing cannot guarantee the accuracy of this information.
First published: April 2015
Production reference: 1210415
Published by Packt Publishing Ltd.
Livery Place
35 Livery Street
Birmingham B3 2PB, UK.
ISBN 978-1-78398-184-7
www.packtpub.com

Credits

Author
Jayant Kumar
Reviewers
Ramzi Alqrainy
Damiano Braga
Omar Shaban
Commissioning Editor
Edward Bowkett
Acquisition Editor
Vinay Argekar
Content Development Editor
Sumeet Sawant
Technical Editor
Tanmayee Patil
Copy Editors
Janbal Dharmaraj
Pooja Iyer
Project Coordinator
Akash Poojary
Proofreaders
Ting Baker
Simran Bhogal
Safis Editing
Index...

Índice