Package org.apache.blur.manager.indexserver

Source Code of org.apache.blur.manager.indexserver.DefaultBlurIndexWarmup

package org.apache.blur.manager.indexserver;

/**
* Licensed to the Apache Software Foundation (ASF) under one or more
* contributor license agreements.  See the NOTICE file distributed with
* this work for additional information regarding copyright ownership.
* The ASF licenses this file to You under the Apache License, Version 2.0
* (the "License"); you may not use this file except in compliance with
* the License.  You may obtain a copy of the License at
*
*     http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
import java.io.IOException;
import java.lang.reflect.Field;
import java.util.Collections;
import java.util.HashMap;
import java.util.HashSet;
import java.util.List;
import java.util.Map;
import java.util.Set;
import java.util.TreeSet;
import java.util.concurrent.TimeUnit;
import java.util.concurrent.atomic.AtomicBoolean;
import java.util.concurrent.atomic.AtomicLong;

import org.apache.blur.log.Log;
import org.apache.blur.log.LogFactory;
import org.apache.blur.lucene.warmup.IndexTracerResult;
import org.apache.blur.lucene.warmup.IndexWarmup;
import org.apache.blur.manager.indexserver.DistributedIndexServer.ReleaseReader;
import org.apache.blur.thrift.generated.TableDescriptor;
import org.apache.blur.utils.GCAction;
import org.apache.blur.utils.GCWatcher;
import org.apache.lucene.index.AtomicReader;
import org.apache.lucene.index.AtomicReaderContext;
import org.apache.lucene.index.FilterDirectoryReader;
import org.apache.lucene.index.IndexReader;
import org.apache.lucene.index.IndexReaderContext;
import org.apache.lucene.index.SegmentReader;
import org.apache.lucene.util.OpenBitSet;

public class DefaultBlurIndexWarmup extends BlurIndexWarmup {

  private static final Log LOG = LogFactory.getLog(DefaultBlurIndexWarmup.class);

  private Set<AtomicBoolean> _stops = Collections.synchronizedSet(new HashSet<AtomicBoolean>());

  public DefaultBlurIndexWarmup(long warmupBandwidthThrottleBytesPerSec) {
    super(warmupBandwidthThrottleBytesPerSec);
    GCWatcher.registerAction(new GCAction() {
      @Override
      public void takeAction() throws Exception {
        synchronized (_stops) {
          for (AtomicBoolean stop : _stops) {
            stop.set(true);
          }
        }
      }
    });
  }

  @Override
  public void warmBlurIndex(final TableDescriptor table, final String shard, IndexReader reader,
      AtomicBoolean isClosed, ReleaseReader releaseReader, AtomicLong pauseWarmup) throws IOException {
    LOG.info("Running warmup for reader [{0}]", reader);
    long s = System.nanoTime();
    AtomicBoolean stop = new AtomicBoolean();
    try {
      if (reader instanceof FilterDirectoryReader) {
        reader = getBase((FilterDirectoryReader) reader);
      }
      int maxSampleSize = 1000;
      synchronized (_stops) {
        _stops.add(stop);
      }
      IndexWarmup indexWarmup = new IndexWarmup(isClosed, stop, maxSampleSize, _warmupBandwidthThrottleBytesPerSec);
      String context = table.getName() + "/" + shard;
      Map<String, List<IndexTracerResult>> sampleIndex = indexWarmup.sampleIndex(reader, context);
      Iterable<String> preCacheCols = table.getPreCacheCols();
      if (preCacheCols == null) {
        // All fields.
        preCacheCols = getFields(reader);
      }
      boolean _oldWay = false;
      if (_oldWay) {
        warm(reader, preCacheCols, indexWarmup, sampleIndex, context, isClosed, pauseWarmup);
      } else {
        int blockSize = 8192;// @TODO
        int bufferSize = 1024 * 1024;// @TODO
        Map<String, OpenBitSet> filePartsToWarm = new HashMap<String, OpenBitSet>();
        for (String fieldName : preCacheCols) {
          indexWarmup.getFilePositionsToWarm(reader, sampleIndex, fieldName, context, filePartsToWarm, blockSize);
        }
        indexWarmup.warmFile(reader, filePartsToWarm, context, blockSize, bufferSize);
      }

    } finally {
      synchronized (_stops) {
        _stops.remove(stop);
      }
      releaseReader.release();
      long e = System.nanoTime();
      LOG.info("Warmup completed for table [{0}] shard [{1}] in [{2} ms]", table.name, shard, (e - s) / 1000000.0);
    }
  }

  private IndexReader getBase(FilterDirectoryReader reader) {
    try {
      Field field = FilterDirectoryReader.class.getDeclaredField("in");
      field.setAccessible(true);
      return (IndexReader) field.get(reader);
    } catch (Exception e) {
      LOG.error("Unknown error trying to get base reader from [{0}]", e, reader);
      return reader;
    }
  }

  private Iterable<String> getFields(IndexReader reader) throws IOException {
    Set<String> fields = new TreeSet<String>();
    for (IndexReaderContext ctext : reader.getContext().leaves()) {
      AtomicReaderContext atomicReaderContext = (AtomicReaderContext) ctext;
      AtomicReader atomicReader = atomicReaderContext.reader();
      if (atomicReader instanceof SegmentReader) {
        for (String f : atomicReader.fields()) {
          fields.add(f);
        }
      }
    }
    return fields;
  }

  private void warm(IndexReader reader, Iterable<String> preCacheCols, IndexWarmup indexWarmup,
      Map<String, List<IndexTracerResult>> sampleIndex, String context, AtomicBoolean isClosed, AtomicLong pauseWarmup) {
    for (String field : preCacheCols) {
      maybePause(pauseWarmup);
      try {
        indexWarmup.warmFile(reader, sampleIndex, field, context);
      } catch (IOException e) {
        LOG.error("Context [{0}] unknown error trying to warmup the [{1}] field", e, context, field);
      }
      if (isClosed.get()) {
        LOG.info("Context [{0}] index closed", context);
        return;
      }
    }
  }

  private void maybePause(AtomicLong pauseWarmup) {
    while (pauseWarmup.get() > 0) {
      synchronized (this) {
        try {
          this.wait(TimeUnit.SECONDS.toMillis(5));
        } catch (InterruptedException e) {
          return;
        }
      }
    }
  }

}
TOP

Related Classes of org.apache.blur.manager.indexserver.DefaultBlurIndexWarmup

TOP
Copyright © 2018 www.massapi.com. All rights reserved.
All source code are property of their respective owners. Java is a trademark of Sun Microsystems, Inc and owned by ORACLE Inc. Contact coftware#gmail.com.