Questo contenuto non è disponibile nella lingua selezionata.
12.4. Indexing
			When indexing is set up, the Query module transparently indexes every added, updated, or removed cache entry. Indices improve performance of queries, though induce additional overhead during updates. For index-less querying see Chapter 16, The Infinispan Query DSL.
		
			For data that already exists in the grid, create an initial Lucene index. After relevant properties and annotations are added, trigger an initial batch index as shown in Section 12.4.3, “Rebuilding the Index”.
		
12.4.1. Indexing with Transactional and Non-transactional Caches
Copia collegamentoCollegamento copiato negli appunti!
		In Red Hat JBoss Data Grid, the relationship between transactions and indexing is as follows:
	
- If the cache is transactional, index updates are applied using a listener after the commit process (after-commit listener). Index update failure does not cause the write to fail.
- If the cache is not transactional, index updates are applied using a listener that works after the event completes (post-event listener). Index update failure does not cause the write to fail.
12.4.2. Configure Indexing Programmatically
Copia collegamentoCollegamento copiato negli appunti!
		Indexing can be configured programmatically, avoiding XML configuration files.
	
		In this example, Red Hat JBoss Data Grid is started programmatically and also maps an object 
Author, which is stored in the grid and made searchable via two properties, without annotating the class.
	Example 12.1. Configure Indexing Programmatically
12.4.3. Rebuilding the Index
Copia collegamentoCollegamento copiato negli appunti!
		The Lucene index can be rebuilt, if required, by reconstructing it from the data store in the cache.
	
		The index must be rebuilt if:
	
- The definition of what is indexed in the types has changed.
- A parameter affecting how the index is defined, such as theAnalyserchanges.
- The index is destroyed or corrupted, possibly due to a system administration error.
		To rebuild the index, obtain a reference to the 
MassIndexer and start it as follows:
	SearchManager searchManager = Search.getSearchManager(cache); searchManager.getMassIndexer().start();
SearchManager searchManager = Search.getSearchManager(cache);
searchManager.getMassIndexer().start();
		This operation reprocesses all data in the grid, and therefore may take some time.