@ -173,7 +173,7 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
public plasmaHTCache cacheManager ;
public plasmaHTCache cacheManager ;
public plasmaSnippetCache snippetCache ;
public plasmaSnippetCache snippetCache ;
public plasmaCrawlLoader cacheLoader ;
public plasmaCrawlLoader cacheLoader ;
public LinkedList process Stack = new LinkedList ( ) ;
public LinkedList queue Stack = new LinkedList ( ) ;
public messageBoard messageDB ;
public messageBoard messageDB ;
public wikiBoard wikiDB ;
public wikiBoard wikiDB ;
public String remoteProxyHost ;
public String remoteProxyHost ;
@ -334,14 +334,18 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
// deploy threads
// deploy threads
log . logSystem ( "Starting Threads" ) ;
log . logSystem ( "Starting Threads" ) ;
int indexing_cluster = Integer . parseInt ( getConfig ( "?80_indexing_cluster" , "1" ) ) ;
if ( indexing_cluster < 1 ) indexing_cluster = 1 ;
deployThread ( "90_cleanup" , "Cleanup" , "simple cleaning process for monitoring information" ,
deployThread ( "90_cleanup" , "Cleanup" , "simple cleaning process for monitoring information" ,
new serverInstantThread ( this , "cleanupJob" , "cleanupJobSize" ) , 10000 ) ; // all 5 Minutes
new serverInstantThread ( this , "cleanupJob" , "cleanupJobSize" ) , 10000 ) ; // all 5 Minutes
deployThread ( "80_ dequeue", "Indexing Dequeue" , "thread that creates database entries from scraped web content and performes indexing" ,
deployThread ( "80_ indexing", "Parsing/Indexing" , "thread that performes document parsing and indexing" ,
new serverInstantThread ( this , "deQueue" , "queueSize" ) , 10000 ) ;
new serverInstantThread ( this , "deQueue" , "queueSize" ) , 10000 ) ;
setConfig ( "81_dequeue_idlesleep" , getConfig ( "80_dequeue_idlesleep" , "" ) ) ;
for ( int i = 1 ; i < indexing_cluster ; i + + ) {
setConfig ( "81_dequeue_busysleep" , getConfig ( "80_dequeue_busysleep" , "" ) ) ;
setConfig ( ( i + 80 ) + "_indexing_idlesleep" , getConfig ( "80_indexing_idlesleep" , "" ) ) ;
deployThread ( "81_dequeue" , "Indexing Dequeue (second job, test run)" , "thread that creates database entries from scraped web content and performes indexing" ,
setConfig ( ( i + 80 ) + "_indexing_busysleep" , getConfig ( "80_indexing_busysleep" , "" ) ) ;
new serverInstantThread ( this , "deQueue" , "queueSize" ) , 11000 ) ;
deployThread ( ( i + 80 ) + "_indexing" , "Parsing/Indexing (cluster job)" , "thread that performes document parsing and indexing" ,
new serverInstantThread ( this , "deQueue" , "queueSize" ) , 10000 + ( i * 1000 ) ) ;
}
deployThread ( "70_cachemanager" , "Proxy Cache Enqueue" , "job takes new proxy files from RAM stack, stores them, and hands over to the Indexing Stack" ,
deployThread ( "70_cachemanager" , "Proxy Cache Enqueue" , "job takes new proxy files from RAM stack, stores them, and hands over to the Indexing Stack" ,
new serverInstantThread ( cacheManager , "job" , "size" ) , 10000 ) ;
new serverInstantThread ( cacheManager , "job" , "size" ) , 10000 ) ;
deployThread ( "62_remotetriggeredcrawl" , "Remote Crawl Job" , "thread that performes a single crawl/indexing step triggered by a remote peer" ,
deployThread ( "62_remotetriggeredcrawl" , "Remote Crawl Job" , "thread that performes a single crawl/indexing step triggered by a remote peer" ,
@ -406,7 +410,7 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
} catch ( IOException e ) { }
} catch ( IOException e ) { }
}
}
private void cleanProfiles ( ) {
private void cleanProfiles ( ) {
if ( queueS ize( ) > 0 ) return ;
if ( ( queueS tack. s ize( ) > 0 ) | | ( cacheLoader . size ( ) > 0 ) | | ( noticeURL . stackSize ( ) > 0 ) ) return ;
Iterator i = profiles . profiles ( true ) ;
Iterator i = profiles . profiles ( true ) ;
plasmaCrawlProfile . entry entry ;
plasmaCrawlProfile . entry entry ;
try {
try {
@ -467,7 +471,8 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
* /
* /
public int queueSize ( ) {
public int queueSize ( ) {
return processStack . size ( ) + cacheLoader . size ( ) + noticeURL . stackSize ( ) ;
return queueStack . size ( ) ;
//return processStack.size() + cacheLoader.size() + noticeURL.stackSize();
}
}
public int lUrlSize ( ) {
public int lUrlSize ( ) {
@ -480,13 +485,13 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
public void enQueue ( Object job ) {
public void enQueue ( Object job ) {
plasmaHTCache . Entry entry = ( plasmaHTCache . Entry ) job ;
plasmaHTCache . Entry entry = ( plasmaHTCache . Entry ) job ;
process Stack. addLast ( entry ) ;
queue Stack. addLast ( entry ) ;
}
}
public boolean deQueue ( ) {
public boolean deQueue ( ) {
// work off fresh entries from the proxy or from the crawler
// work off fresh entries from the proxy or from the crawler
if ( process Stack. size ( ) = = 0 ) {
if ( queue Stack. size ( ) = = 0 ) {
//log.logDebug("DEQUEUE: queue is empty");
//log.logDebug("DEQUEUE: queue is empty");
return false ; // nothing to do
return false ; // nothing to do
}
}
@ -496,12 +501,12 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
// do one processing step
// do one processing step
log . logDebug ( "DEQUEUE: cacheManager=" + ( ( cacheManager . idle ( ) ) ? "idle" : "busy" ) +
log . logDebug ( "DEQUEUE: cacheManager=" + ( ( cacheManager . idle ( ) ) ? "idle" : "busy" ) +
", processStack=" + process Stack. size ( ) +
", queueStack=" + queue Stack. size ( ) +
", coreStackSize=" + noticeURL . coreStackSize ( ) +
", coreStackSize=" + noticeURL . coreStackSize ( ) +
", limitStackSize=" + noticeURL . limitStackSize ( ) +
", limitStackSize=" + noticeURL . limitStackSize ( ) +
", overhangStackSize=" + noticeURL . overhangStackSize ( ) +
", overhangStackSize=" + noticeURL . overhangStackSize ( ) +
", remoteStackSize=" + noticeURL . remoteStackSize ( ) ) ;
", remoteStackSize=" + noticeURL . remoteStackSize ( ) ) ;
processResourceStack ( ( plasmaHTCache . Entry ) process Stack. removeFirst ( ) ) ;
processResourceStack ( ( plasmaHTCache . Entry ) queue Stack. removeFirst ( ) ) ;
return true ;
return true ;
}
}
@ -574,9 +579,9 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
//log.logDebug("CoreCrawl: queue is empty");
//log.logDebug("CoreCrawl: queue is empty");
return false ;
return false ;
}
}
if ( process Stack. size ( ) > = crawlSlots ) {
if ( queue Stack. size ( ) > = crawlSlots ) {
log . logDebug ( "CoreCrawl: too many processes in queue, dismissed (" +
log . logDebug ( "CoreCrawl: too many processes in queue, dismissed (" +
" processStack=" + process Stack. size ( ) + ")" ) ;
" queueStack=" + queue Stack. size ( ) + ")" ) ;
return false ;
return false ;
}
}
if ( cacheLoader . size ( ) > = crawlSlots ) {
if ( cacheLoader . size ( ) > = crawlSlots ) {
@ -652,7 +657,7 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
", permission=" + ( ( yacyCore . seedDB = = null ) ? "undefined" : ( ( ( yacyCore . seedDB . mySeed . isSenior ( ) ) | | ( yacyCore . seedDB . mySeed . isPrincipal ( ) ) ) ? "true" : "false" ) ) ) ;
", permission=" + ( ( yacyCore . seedDB = = null ) ? "undefined" : ( ( ( yacyCore . seedDB . mySeed . isSenior ( ) ) | | ( yacyCore . seedDB . mySeed . isPrincipal ( ) ) ) ? "true" : "false" ) ) ) ;
boolean tryRemote =
boolean tryRemote =
( ( noticeURL . coreStackSize ( ) ! = 0 ) | | ( process Stack. size ( ) ! = 0 ) ) /* should do ourself */ & &
( ( noticeURL . coreStackSize ( ) ! = 0 ) | | ( queue Stack. size ( ) ! = 0 ) ) /* should do ourself */ & &
( profile . remoteIndexing ( ) ) /* granted */ & &
( profile . remoteIndexing ( ) ) /* granted */ & &
( urlEntry . initiator ( ) ! = null ) & & ( ! ( urlEntry . initiator ( ) . equals ( plasmaURL . dummyHash ) ) ) /* not proxy */ & &
( urlEntry . initiator ( ) ! = null ) & & ( ! ( urlEntry . initiator ( ) . equals ( plasmaURL . dummyHash ) ) ) /* not proxy */ & &
( ( yacyCore . seedDB . mySeed . isSenior ( ) ) | |
( ( yacyCore . seedDB . mySeed . isSenior ( ) ) | |
@ -664,9 +669,9 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
}
}
// alternatively do a local crawl
// alternatively do a local crawl
if ( process Stack. size ( ) > = crawlSlots ) {
if ( queue Stack. size ( ) > = crawlSlots ) {
log . logDebug ( "LimitCrawl: too many processes in queue, dismissed (" +
log . logDebug ( "LimitCrawl: too many processes in queue, dismissed (" +
" processStack=" + process Stack. size ( ) + ")" ) ;
" queueStack=" + queue Stack. size ( ) + ")" ) ;
return false ;
return false ;
}
}
if ( cacheLoader . size ( ) > = crawlSlots ) {
if ( cacheLoader . size ( ) > = crawlSlots ) {
@ -692,9 +697,10 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
//log.logDebug("GlobalCrawl: queue is empty");
//log.logDebug("GlobalCrawl: queue is empty");
return false ;
return false ;
}
}
if ( processStack . size ( ) > 0 ) {
/ *
if ( queueStack . size ( ) > 0 ) {
log . logDebug ( "GlobalCrawl: any processe is in queue, dismissed (" +
log . logDebug ( "GlobalCrawl: any processe is in queue, dismissed (" +
"processStack=" + process Stack. size ( ) + ")" ) ;
"processStack=" + queue Stack. size ( ) + ")" ) ;
return false ;
return false ;
}
}
if ( noticeURL . coreStackSize ( ) > 0 ) {
if ( noticeURL . coreStackSize ( ) > 0 ) {
@ -702,6 +708,7 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
"coreStackSize=" + noticeURL . coreStackSize ( ) + ")" ) ;
"coreStackSize=" + noticeURL . coreStackSize ( ) + ")" ) ;
return false ;
return false ;
}
}
* /
// if the server is busy, we do this more slowly
// if the server is busy, we do this more slowly
if ( ! ( cacheManager . idle ( ) ) ) try { Thread . currentThread ( ) . sleep ( 2000 ) ; } catch ( InterruptedException e ) { }
if ( ! ( cacheManager . idle ( ) ) ) try { Thread . currentThread ( ) . sleep ( 2000 ) ; } catch ( InterruptedException e ) { }
@ -1377,7 +1384,7 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
public String toString ( ) {
public String toString ( ) {
// it is possible to use this method in the cgi pages.
// it is possible to use this method in the cgi pages.
// actually it is used there for testing purpose
// actually it is used there for testing purpose
return "PROPS: " + super . toString ( ) + "; QUEUE: " + process Stack. toString ( ) ;
return "PROPS: " + super . toString ( ) + "; QUEUE: " + queue Stack. toString ( ) ;
}
}
// method for index deletion
// method for index deletion
@ -1448,7 +1455,10 @@ public final class plasmaSwitchboard extends serverAbstractSwitch implements ser
int transferred ;
int transferred ;
long starttime = System . currentTimeMillis ( ) ;
long starttime = System . currentTimeMillis ( ) ;
try {
try {
if ( ( queueSize ( ) = = 0 ) & &
if (
( queueStack . size ( ) = = 0 ) & &
( cacheLoader . size ( ) = = 0 ) & &
( noticeURL . stackSize ( ) = = 0 ) & &
( getConfig ( "allowDistributeIndex" , "false" ) . equals ( "true" ) ) & &
( getConfig ( "allowDistributeIndex" , "false" ) . equals ( "true" ) ) & &
( ( transferred = performTransferIndex ( indexCount , peerCount , true ) ) > 0 ) ) {
( ( transferred = performTransferIndex ( indexCount , peerCount , true ) ) > 0 ) ) {
indexCount = transferred ;
indexCount = transferred ;