doh ensure we scan repository to index datas for the first scan, ensure we are not searching on all index

git-svn-id: https://svn.apache.org/repos/asf/archiva/trunk@1158468 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
Olivier Lamy 2011-08-16 23:03:05 +00:00
parent 70bd4e3ede
commit fb8ff53c01
4 changed files with 80 additions and 24 deletions

View File

@ -112,7 +112,7 @@ public class NexusIndexerConsumer
try try
{ {
log.info( "Creating indexing context for repo : " + repository.getId() ); log.info( "Creating indexing context for repo : {}", repository.getId() );
context = ArtifactIndexingTask.createContext( repository, nexusIndexer, allIndexCreators ); context = ArtifactIndexingTask.createContext( repository, nexusIndexer, allIndexCreators );
} }
catch ( IOException e ) catch ( IOException e )

View File

@ -46,6 +46,7 @@ import org.springframework.stereotype.Service;
import javax.inject.Inject; import javax.inject.Inject;
import java.io.File; import java.io.File;
import java.io.IOException; import java.io.IOException;
import java.util.ArrayList;
import java.util.List; import java.util.List;
import java.util.Map; import java.util.Map;
import java.util.Set; import java.util.Set;
@ -83,7 +84,7 @@ public class NexusRepositorySearch
List<String> previousSearchTerms ) List<String> previousSearchTerms )
throws RepositorySearchException throws RepositorySearchException
{ {
addIndexingContexts( selectedRepos ); List<String> indexingContextIds = addIndexingContexts( selectedRepos );
// since upgrade to nexus 2.0.0, query has changed from g:[QUERIED TERM]* to g:*[QUERIED TERM]* // since upgrade to nexus 2.0.0, query has changed from g:[QUERIED TERM]* to g:*[QUERIED TERM]*
// resulting to more wildcard searches so we need to increase max clause count // resulting to more wildcard searches so we need to increase max clause count
@ -109,7 +110,7 @@ public class NexusRepositorySearch
q.add( iQuery, Occur.MUST ); q.add( iQuery, Occur.MUST );
} }
return search( limits, q ); return search( limits, q, indexingContextIds );
} }
/** /**
@ -123,7 +124,7 @@ public class NexusRepositorySearch
throw new RepositorySearchException( "Repositories cannot be null." ); throw new RepositorySearchException( "Repositories cannot be null." );
} }
addIndexingContexts( searchFields.getRepositories() ); List<String> indexingContextIds = addIndexingContexts( searchFields.getRepositories() );
BooleanQuery q = new BooleanQuery(); BooleanQuery q = new BooleanQuery();
if ( StringUtils.isNotBlank( searchFields.getGroupId() ) ) if ( StringUtils.isNotBlank( searchFields.getGroupId() ) )
@ -191,15 +192,16 @@ public class NexusRepositorySearch
throw new RepositorySearchException( "No search fields set." ); throw new RepositorySearchException( "No search fields set." );
} }
return search( limits, q ); return search( limits, q, indexingContextIds );
} }
private SearchResults search( SearchResultLimits limits, BooleanQuery q ) private SearchResults search( SearchResultLimits limits, BooleanQuery q, List<String> indexingContextIds )
throws RepositorySearchException throws RepositorySearchException
{ {
try try
{ {
FlatSearchRequest request = new FlatSearchRequest( q ); FlatSearchRequest request = new FlatSearchRequest( q );
request.setContexts( getIndexingContexts( indexingContextIds ) );
FlatSearchResponse response = indexer.searchFlat( request ); FlatSearchResponse response = indexer.searchFlat( request );
if ( response == null || response.getTotalHits() == 0 ) if ( response == null || response.getTotalHits() == 0 )
@ -238,6 +240,26 @@ public class NexusRepositorySearch
}*/ }*/
} }
private List<IndexingContext> getIndexingContexts( List<String> ids )
{
List<IndexingContext> contexts = new ArrayList<IndexingContext>( ids.size() );
for ( String id : ids )
{
IndexingContext context = indexer.getIndexingContexts().get( id );
if ( context != null )
{
contexts.add( context );
}
else
{
log.warn( "context with id {} not exists", id );
}
}
return contexts;
}
private void constructQuery( String term, BooleanQuery q ) private void constructQuery( String term, BooleanQuery q )
{ {
q.add( indexer.constructQuery( MAVEN.GROUP_ID, new StringSearchExpression( term ) ), Occur.SHOULD ); q.add( indexer.constructQuery( MAVEN.GROUP_ID, new StringSearchExpression( term ) ), Occur.SHOULD );
@ -245,11 +267,18 @@ public class NexusRepositorySearch
q.add( indexer.constructQuery( MAVEN.VERSION, new StringSearchExpression( term ) ), Occur.SHOULD ); q.add( indexer.constructQuery( MAVEN.VERSION, new StringSearchExpression( term ) ), Occur.SHOULD );
q.add( indexer.constructQuery( MAVEN.PACKAGING, new StringSearchExpression( term ) ), Occur.SHOULD ); q.add( indexer.constructQuery( MAVEN.PACKAGING, new StringSearchExpression( term ) ), Occur.SHOULD );
q.add( indexer.constructQuery( MAVEN.CLASSNAMES, new StringSearchExpression( term ) ), Occur.SHOULD ); q.add( indexer.constructQuery( MAVEN.CLASSNAMES, new StringSearchExpression( term ) ), Occur.SHOULD );
// olamy IMHO we could set this option as at least one must match
//q.setMinimumNumberShouldMatch( 1 );
} }
private void addIndexingContexts( List<String> selectedRepos ) /**
* @param selectedRepos
* @return indexing contextId used
*/
private List<String> addIndexingContexts( List<String> selectedRepos )
{ {
List<String> indexingContextIds = new ArrayList<String>();
for ( String repo : selectedRepos ) for ( String repo : selectedRepos )
{ {
try try
@ -270,18 +299,30 @@ public class NexusRepositorySearch
indexDirectory = new File( repoConfig.getLocation(), ".indexer" ); indexDirectory = new File( repoConfig.getLocation(), ".indexer" );
} }
if ( indexer.getIndexingContexts().containsKey( repoConfig.getId() ) ) IndexingContext context = indexer.getIndexingContexts().get( repoConfig.getId() );
if ( context != null )
{ {
// alreday here so no need to record it again // alreday here so no need to record it again
log.info( "index with id {} already exists skip adding it", repoConfig.getId() ); log.debug( "index with id {} already exists skip adding it", repoConfig.getId() );
// set searchable flag
context.setSearchable( repoConfig.isScanned() );
indexingContextIds.add( context.getId() );
continue; continue;
} }
IndexingContext context = indexer.addIndexingContext( repoConfig.getId(), repoConfig.getId(), context = indexer.addIndexingContext( repoConfig.getId(), repoConfig.getId(),
new File( repoConfig.getLocation() ), new File( repoConfig.getLocation() ), indexDirectory, null,
indexDirectory, null, null, null, getAllIndexCreators() );
getAllIndexCreators() );
context.setSearchable( repoConfig.isScanned() ); context.setSearchable( repoConfig.isScanned() );
if ( context.isSearchable() )
{
indexingContextIds.add( context.getId() );
}
else
{
log.warn( "indexingContext with id {} not searchable", repoConfig.getId() );
}
} }
else else
{ {
@ -299,6 +340,7 @@ public class NexusRepositorySearch
continue; continue;
} }
} }
return indexingContextIds;
} }

View File

@ -112,6 +112,16 @@ public class ArchivaIndexingTaskExecutor
if ( ArtifactIndexingTask.Action.FINISH.equals( indexingTask.getAction() ) if ( ArtifactIndexingTask.Action.FINISH.equals( indexingTask.getAction() )
&& indexingTask.isExecuteOnEntireRepo() ) && indexingTask.isExecuteOnEntireRepo() )
{ {
// TODO update or not !!
// do the full scan
try
{
nexusIndexer.scan( context );
}
catch ( IOException e )
{
throw new TaskExecutionException( "Error scan repository " + repository, e );
}
log.debug( "Finishing indexing task on repo: {}", repository.getId() ); log.debug( "Finishing indexing task on repo: {}", repository.getId() );
finishIndexingTask( indexingTask, repository, context ); finishIndexingTask( indexingTask, repository, context );
} }
@ -129,12 +139,14 @@ public class ArchivaIndexingTaskExecutor
catch ( IOException e ) catch ( IOException e )
{ {
log.error( "Error occurred while creating context: " + e.getMessage() ); log.error( "Error occurred while creating context: " + e.getMessage() );
throw new TaskExecutionException( "Error occurred while creating context: " + e.getMessage() ); throw new TaskExecutionException( "Error occurred while creating context: " + e.getMessage(),
e );
} }
catch ( UnsupportedExistingLuceneIndexException e ) catch ( UnsupportedExistingLuceneIndexException e )
{ {
log.error( "Error occurred while creating context: " + e.getMessage() ); log.error( "Error occurred while creating context: " + e.getMessage() );
throw new TaskExecutionException( "Error occurred while creating context: " + e.getMessage() ); throw new TaskExecutionException( "Error occurred while creating context: " + e.getMessage(),
e );
} }
} }
@ -163,12 +175,12 @@ public class ArchivaIndexingTaskExecutor
ac.getArtifactInfo().artifactId ) ), BooleanClause.Occur.MUST ); ac.getArtifactInfo().artifactId ) ), BooleanClause.Occur.MUST );
q.add( nexusIndexer.constructQuery( MAVEN.VERSION, new SourcedSearchExpression( q.add( nexusIndexer.constructQuery( MAVEN.VERSION, new SourcedSearchExpression(
ac.getArtifactInfo().version ) ), BooleanClause.Occur.MUST ); ac.getArtifactInfo().version ) ), BooleanClause.Occur.MUST );
if (ac.getArtifactInfo().classifier != null) if ( ac.getArtifactInfo().classifier != null )
{ {
q.add( nexusIndexer.constructQuery( MAVEN.CLASSIFIER, new SourcedSearchExpression( q.add( nexusIndexer.constructQuery( MAVEN.CLASSIFIER, new SourcedSearchExpression(
ac.getArtifactInfo().classifier ) ), BooleanClause.Occur.MUST ); ac.getArtifactInfo().classifier ) ), BooleanClause.Occur.MUST );
} }
if (ac.getArtifactInfo().packaging != null) if ( ac.getArtifactInfo().packaging != null )
{ {
q.add( nexusIndexer.constructQuery( MAVEN.PACKAGING, new SourcedSearchExpression( q.add( nexusIndexer.constructQuery( MAVEN.PACKAGING, new SourcedSearchExpression(
ac.getArtifactInfo().packaging ) ), BooleanClause.Occur.MUST ); ac.getArtifactInfo().packaging ) ), BooleanClause.Occur.MUST );
@ -212,8 +224,8 @@ public class ArchivaIndexingTaskExecutor
} }
catch ( IOException e ) catch ( IOException e )
{ {
log.error( log.error( "Error occurred while executing indexing task '" + indexingTask + "': " + e.getMessage(),
"Error occurred while executing indexing task '" + indexingTask + "': " + e.getMessage() ); e );
throw new TaskExecutionException( throw new TaskExecutionException(
"Error occurred while executing indexing task '" + indexingTask + "'", e ); "Error occurred while executing indexing task '" + indexingTask + "'", e );
} }

View File

@ -175,16 +175,18 @@ public class ArtifactIndexingTask
indexDirectory = new File( managedRepository, ".indexer" ); indexDirectory = new File( managedRepository, ".indexer" );
} }
if ( indexer.getIndexingContexts().containsKey( repository.getId() ) ) IndexingContext context = indexer.getIndexingContexts().get( repository.getId() );
if ( context != null )
{ {
LoggerFactory.getLogger( ArtifactIndexingTask.class ).warn( LoggerFactory.getLogger( ArtifactIndexingTask.class ).warn(
"skip adding repository with id {} as already exists", repository.getId() ); "skip adding repository with id {} as already exists", repository.getId() );
return context;
} }
IndexingContext context = context = indexer.addIndexingContext( repository.getId(), repository.getId(), managedRepository, indexDirectory,
indexer.addIndexingContext( repository.getId(), repository.getId(), managedRepository, indexDirectory, managedRepository.toURI().toURL().toString(),
managedRepository.toURI().toURL().toString(), indexDirectory.toURI().toURL().toString(), indexCreators );
indexDirectory.toURI().toURL().toString(), indexCreators );
context.setSearchable( repository.isScanned() ); context.setSearchable( repository.isScanned() );
return context; return context;