configuration option for maxload limit for remote search

pull/1/head
Michael Peter Christen 10 years ago
parent c454ef69c6
commit 97ba5ddbb7

@ -865,6 +865,8 @@ search.verify.delete = true
remotesearch.maxcount = 10 remotesearch.maxcount = 10
remotesearch.maxtime = 3000 remotesearch.maxtime = 3000
remotesearch.result.store=true remotesearch.result.store=true
remotesearch.maxload.rwi=8.0
remotesearch.maxload.solr=4.0
# specifies if yacy should set it's own referer if no referer URL # specifies if yacy should set it's own referer if no referer URL
# was set by the client. # was set by the client.

@ -147,6 +147,7 @@ public class RemoteSearch extends Thread {
final SortedSet<byte[]> clusterselection) { final SortedSet<byte[]> clusterselection) {
// check own peer status // check own peer status
//if (wordIndex.seedDB.mySeed() == null || wordIndex.seedDB.mySeed().getPublicAddress() == null) { return null; } //if (wordIndex.seedDB.mySeed() == null || wordIndex.seedDB.mySeed().getPublicAddress() == null) { return null; }
Switchboard sb = Switchboard.getSwitchboard();
// check the peer memory and lifesign-situation to get a scaling for the number of remote search processes // check the peer memory and lifesign-situation to get a scaling for the number of remote search processes
final boolean shortmem = MemoryControl.shortStatus(); final boolean shortmem = MemoryControl.shortStatus();
@ -212,12 +213,12 @@ public class RemoteSearch extends Thread {
final Collection<Seed> robinsonPeers = DHTSelection.selectExtraTargets(event.peers, event.query.getQueryGoal().getIncludeHashes(), minage, dhtPeers, robinsoncount, random); final Collection<Seed> robinsonPeers = DHTSelection.selectExtraTargets(event.peers, event.query.getQueryGoal().getIncludeHashes(), minage, dhtPeers, robinsoncount, random);
if (event.peers != null) { if (event.peers != null) {
if (Switchboard.getSwitchboard().getConfigBool(SwitchboardConstants.DEBUG_SEARCH_REMOTE_DHT_TESTLOCAL, false)) { if (sb.getConfigBool(SwitchboardConstants.DEBUG_SEARCH_REMOTE_DHT_TESTLOCAL, false)) {
dhtPeers.clear(); dhtPeers.clear();
dhtPeers.add(event.peers.mySeed()); dhtPeers.add(event.peers.mySeed());
} }
if (Switchboard.getSwitchboard().getConfigBool(SwitchboardConstants.DEBUG_SEARCH_REMOTE_SOLR_TESTLOCAL, false)) { if (sb.getConfigBool(SwitchboardConstants.DEBUG_SEARCH_REMOTE_SOLR_TESTLOCAL, false)) {
robinsonPeers.clear(); robinsonPeers.clear();
robinsonPeers.add(event.peers.mySeed()); robinsonPeers.add(event.peers.mySeed());
} }
@ -229,20 +230,20 @@ public class RemoteSearch extends Thread {
// start solr searches // start solr searches
final int targets = dhtPeers.size() + robinsonPeers.size(); final int targets = dhtPeers.size() + robinsonPeers.size();
if (!Switchboard.getSwitchboard().getConfigBool(SwitchboardConstants.DEBUG_SEARCH_REMOTE_SOLR_OFF, false)) { if (!sb.getConfigBool(SwitchboardConstants.DEBUG_SEARCH_REMOTE_SOLR_OFF, false)) {
final SolrQuery solrQuery = event.query.solrQuery(event.getQuery().contentdom, start == 0, event.excludeintext_image); final SolrQuery solrQuery = event.query.solrQuery(event.getQuery().contentdom, start == 0, event.excludeintext_image);
for (Seed s: robinsonPeers) { for (Seed s: robinsonPeers) {
if (MemoryControl.shortStatus() || Memory.load() > 4.0) continue; if (MemoryControl.shortStatus() || Memory.load() > sb.getConfigFloat(SwitchboardConstants.REMOTESEARCH_MAXLOAD_SOLR, 4.0f)) continue;
Thread t = solrRemoteSearch(event, solrQuery, start, count, s, targets, blacklist); Thread t = solrRemoteSearch(event, solrQuery, start, count, s, targets, blacklist);
event.nodeSearchThreads.add(t); event.nodeSearchThreads.add(t);
} }
} }
// start search to YaCy DHT peers // start search to YaCy DHT peers
if (!Switchboard.getSwitchboard().getConfigBool(SwitchboardConstants.DEBUG_SEARCH_REMOTE_DHT_OFF, false)) { if (!sb.getConfigBool(SwitchboardConstants.DEBUG_SEARCH_REMOTE_DHT_OFF, false)) {
for (Seed dhtPeer: dhtPeers) { for (Seed dhtPeer: dhtPeers) {
if (dhtPeer == null || dhtPeer.hash == null) continue; if (dhtPeer == null || dhtPeer.hash == null) continue;
if (MemoryControl.shortStatus() || Memory.load() > 8.0) continue; if (MemoryControl.shortStatus() || Memory.load() > sb.getConfigFloat(SwitchboardConstants.REMOTESEARCH_MAXLOAD_RWI, 8.0f)) continue;
try { try {
RemoteSearch rs = new RemoteSearch( RemoteSearch rs = new RemoteSearch(
event, event,

@ -330,8 +330,9 @@ public final class SwitchboardConstants {
public static final String REMOTESEARCH_MAXTIME_DEFAULT = "network.unit.remotesearch.maxtime"; public static final String REMOTESEARCH_MAXTIME_DEFAULT = "network.unit.remotesearch.maxtime";
public static final String REMOTESEARCH_MAXCOUNT_USER = "remotesearch.maxcount"; public static final String REMOTESEARCH_MAXCOUNT_USER = "remotesearch.maxcount";
public static final String REMOTESEARCH_MAXTIME_USER = "remotesearch.maxtime"; public static final String REMOTESEARCH_MAXTIME_USER = "remotesearch.maxtime";
public static final String REMOTESEARCH_RESULT_STORE = "remotesearch.result.store"; // add remote results to local index public static final String REMOTESEARCH_RESULT_STORE = "remotesearch.result.store"; // add remote results to local index
public static final String REMOTESEARCH_MAXLOAD_RWI = "remotesearch.maxload.rwi";
public static final String REMOTESEARCH_MAXLOAD_SOLR = "remotesearch.maxload.solr";
public static final String FEDERATED_SERVICE_SOLR_INDEXING_ENABLED = "federated.service.solr.indexing.enabled"; public static final String FEDERATED_SERVICE_SOLR_INDEXING_ENABLED = "federated.service.solr.indexing.enabled";
public static final String FEDERATED_SERVICE_SOLR_INDEXING_URL = "federated.service.solr.indexing.url"; public static final String FEDERATED_SERVICE_SOLR_INDEXING_URL = "federated.service.solr.indexing.url";

Loading…
Cancel
Save