mirror of https://github.com/apache/lucene.git
SOLR-2698: Enhance CoreAdmin STATUS command to return index size.
git-svn-id: https://svn.apache.org/repos/asf/lucene/dev/trunk@1155194 13f79535-47bb-0310-9956-ffa450edef68
This commit is contained in:
parent
12eab24036
commit
fda091ef24
|
@ -287,6 +287,9 @@ Other Changes
|
||||||
|
|
||||||
* SOLR-2331,SOLR-2691: Refactor CoreContainer's SolrXML serialization code and improve testing
|
* SOLR-2331,SOLR-2691: Refactor CoreContainer's SolrXML serialization code and improve testing
|
||||||
(Yury Kats, hossman, Mark Miller)
|
(Yury Kats, hossman, Mark Miller)
|
||||||
|
|
||||||
|
* SOLR-2698: Enhance CoreAdmin STATUS command to return index size.
|
||||||
|
(Yury Kats, hossman, Mark Miller)
|
||||||
|
|
||||||
Documentation
|
Documentation
|
||||||
----------------------
|
----------------------
|
||||||
|
|
|
@ -16,6 +16,30 @@
|
||||||
*/
|
*/
|
||||||
package org.apache.solr.handler;
|
package org.apache.solr.handler;
|
||||||
|
|
||||||
|
import java.io.File;
|
||||||
|
import java.io.FileInputStream;
|
||||||
|
import java.io.IOException;
|
||||||
|
import java.io.OutputStream;
|
||||||
|
import java.io.Writer;
|
||||||
|
import java.nio.ByteBuffer;
|
||||||
|
import java.nio.channels.FileChannel;
|
||||||
|
import java.util.ArrayList;
|
||||||
|
import java.util.Arrays;
|
||||||
|
import java.util.Collection;
|
||||||
|
import java.util.Date;
|
||||||
|
import java.util.HashMap;
|
||||||
|
import java.util.HashSet;
|
||||||
|
import java.util.List;
|
||||||
|
import java.util.Map;
|
||||||
|
import java.util.Properties;
|
||||||
|
import java.util.concurrent.atomic.AtomicBoolean;
|
||||||
|
import java.util.concurrent.locks.ReentrantLock;
|
||||||
|
import java.util.zip.Adler32;
|
||||||
|
import java.util.zip.Checksum;
|
||||||
|
import java.util.zip.DeflaterOutputStream;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
|
import org.apache.commons.io.IOUtils;
|
||||||
import org.apache.lucene.index.IndexCommit;
|
import org.apache.lucene.index.IndexCommit;
|
||||||
import org.apache.lucene.index.IndexDeletionPolicy;
|
import org.apache.lucene.index.IndexDeletionPolicy;
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
|
@ -26,28 +50,21 @@ import org.apache.solr.common.util.FastOutputStream;
|
||||||
import org.apache.solr.common.util.NamedList;
|
import org.apache.solr.common.util.NamedList;
|
||||||
import org.apache.solr.common.util.SimpleOrderedMap;
|
import org.apache.solr.common.util.SimpleOrderedMap;
|
||||||
import org.apache.solr.common.util.StrUtils;
|
import org.apache.solr.common.util.StrUtils;
|
||||||
import org.apache.solr.core.*;
|
import org.apache.solr.core.CloseHook;
|
||||||
|
import org.apache.solr.core.IndexDeletionPolicyWrapper;
|
||||||
|
import org.apache.solr.core.SolrCore;
|
||||||
|
import org.apache.solr.core.SolrDeletionPolicy;
|
||||||
|
import org.apache.solr.core.SolrEventListener;
|
||||||
import org.apache.solr.request.SolrQueryRequest;
|
import org.apache.solr.request.SolrQueryRequest;
|
||||||
import org.apache.solr.response.BinaryQueryResponseWriter;
|
import org.apache.solr.response.BinaryQueryResponseWriter;
|
||||||
import org.apache.solr.response.SolrQueryResponse;
|
import org.apache.solr.response.SolrQueryResponse;
|
||||||
import org.apache.solr.search.SolrIndexSearcher;
|
import org.apache.solr.search.SolrIndexSearcher;
|
||||||
|
import org.apache.solr.util.NumberUtils;
|
||||||
import org.apache.solr.util.RefCounted;
|
import org.apache.solr.util.RefCounted;
|
||||||
import org.apache.solr.util.plugin.SolrCoreAware;
|
import org.apache.solr.util.plugin.SolrCoreAware;
|
||||||
import org.apache.commons.io.IOUtils;
|
|
||||||
import org.slf4j.Logger;
|
import org.slf4j.Logger;
|
||||||
import org.slf4j.LoggerFactory;
|
import org.slf4j.LoggerFactory;
|
||||||
|
|
||||||
import java.io.*;
|
|
||||||
import java.nio.ByteBuffer;
|
|
||||||
import java.nio.channels.FileChannel;
|
|
||||||
import java.text.NumberFormat;
|
|
||||||
import java.util.*;
|
|
||||||
import java.util.concurrent.locks.ReentrantLock;
|
|
||||||
import java.util.concurrent.atomic.AtomicBoolean;
|
|
||||||
import java.util.zip.Adler32;
|
|
||||||
import java.util.zip.Checksum;
|
|
||||||
import java.util.zip.DeflaterOutputStream;
|
|
||||||
|
|
||||||
/**
|
/**
|
||||||
* <p> A Handler which provides a REST API for replication and serves replication requests from Slaves. <p/> </p>
|
* <p> A Handler which provides a REST API for replication and serves replication requests from Slaves. <p/> </p>
|
||||||
* <p>When running on the master, it provides the following commands <ol> <li>Get the current replicatable index version
|
* <p>When running on the master, it provides the following commands <ol> <li>Get the current replicatable index version
|
||||||
|
@ -423,18 +440,7 @@ public class ReplicationHandler extends RequestHandlerBase implements SolrCoreAw
|
||||||
}
|
}
|
||||||
|
|
||||||
long getIndexSize() {
|
long getIndexSize() {
|
||||||
return computeIndexSize(new File(core.getIndexDir()));
|
return FileUtils.sizeOfDirectory(new File(core.getIndexDir()));
|
||||||
}
|
|
||||||
|
|
||||||
private long computeIndexSize(File f) {
|
|
||||||
if (f.isFile())
|
|
||||||
return f.length();
|
|
||||||
File[] files = f.listFiles();
|
|
||||||
long size = 0;
|
|
||||||
if (files != null && files.length > 0) {
|
|
||||||
for (File file : files) size += file.length();
|
|
||||||
}
|
|
||||||
return size;
|
|
||||||
}
|
}
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -468,20 +474,6 @@ public class ReplicationHandler extends RequestHandlerBase implements SolrCoreAw
|
||||||
return "$Revision$";
|
return "$Revision$";
|
||||||
}
|
}
|
||||||
|
|
||||||
String readableSize(long size) {
|
|
||||||
NumberFormat formatter = NumberFormat.getNumberInstance();
|
|
||||||
formatter.setMaximumFractionDigits(2);
|
|
||||||
if (size / (1024 * 1024 * 1024) > 0) {
|
|
||||||
return formatter.format(size * 1.0d / (1024 * 1024 * 1024)) + " GB";
|
|
||||||
} else if (size / (1024 * 1024) > 0) {
|
|
||||||
return formatter.format(size * 1.0d / (1024 * 1024)) + " MB";
|
|
||||||
} else if (size / 1024 > 0) {
|
|
||||||
return formatter.format(size * 1.0d / 1024) + " KB";
|
|
||||||
} else {
|
|
||||||
return String.valueOf(size) + " bytes";
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
private long[] getIndexVersion() {
|
private long[] getIndexVersion() {
|
||||||
long version[] = new long[2];
|
long version[] = new long[2];
|
||||||
RefCounted<SolrIndexSearcher> searcher = core.getSearcher();
|
RefCounted<SolrIndexSearcher> searcher = core.getSearcher();
|
||||||
|
@ -501,7 +493,7 @@ public class ReplicationHandler extends RequestHandlerBase implements SolrCoreAw
|
||||||
public NamedList getStatistics() {
|
public NamedList getStatistics() {
|
||||||
NamedList list = super.getStatistics();
|
NamedList list = super.getStatistics();
|
||||||
if (core != null) {
|
if (core != null) {
|
||||||
list.add("indexSize", readableSize(getIndexSize()));
|
list.add("indexSize", NumberUtils.readableSize(getIndexSize()));
|
||||||
long[] versionGen = getIndexVersion();
|
long[] versionGen = getIndexVersion();
|
||||||
list.add("indexVersion", versionGen[0]);
|
list.add("indexVersion", versionGen[0]);
|
||||||
list.add(GENERATION, versionGen[1]);
|
list.add(GENERATION, versionGen[1]);
|
||||||
|
@ -555,7 +547,7 @@ public class ReplicationHandler extends RequestHandlerBase implements SolrCoreAw
|
||||||
NamedList<Object> master = new SimpleOrderedMap<Object>();
|
NamedList<Object> master = new SimpleOrderedMap<Object>();
|
||||||
NamedList<Object> slave = new SimpleOrderedMap<Object>();
|
NamedList<Object> slave = new SimpleOrderedMap<Object>();
|
||||||
|
|
||||||
details.add("indexSize", readableSize(getIndexSize()));
|
details.add("indexSize", NumberUtils.readableSize(getIndexSize()));
|
||||||
details.add("indexPath", core.getIndexDir());
|
details.add("indexPath", core.getIndexDir());
|
||||||
details.add(CMD_SHOW_COMMITS, getCommits());
|
details.add(CMD_SHOW_COMMITS, getCommits());
|
||||||
details.add("isMaster", String.valueOf(isMaster));
|
details.add("isMaster", String.valueOf(isMaster));
|
||||||
|
@ -631,7 +623,7 @@ public class ReplicationHandler extends RequestHandlerBase implements SolrCoreAw
|
||||||
|
|
||||||
slave.add("filesToDownload", filesToDownload);
|
slave.add("filesToDownload", filesToDownload);
|
||||||
slave.add("numFilesToDownload", String.valueOf(filesToDownload.size()));
|
slave.add("numFilesToDownload", String.valueOf(filesToDownload.size()));
|
||||||
slave.add("bytesToDownload", readableSize(bytesToDownload));
|
slave.add("bytesToDownload", NumberUtils.readableSize(bytesToDownload));
|
||||||
|
|
||||||
long bytesDownloaded = 0;
|
long bytesDownloaded = 0;
|
||||||
List<String> filesDownloaded = new ArrayList<String>();
|
List<String> filesDownloaded = new ArrayList<String>();
|
||||||
|
@ -681,13 +673,13 @@ public class ReplicationHandler extends RequestHandlerBase implements SolrCoreAw
|
||||||
downloadSpeed = (bytesDownloaded / elapsed);
|
downloadSpeed = (bytesDownloaded / elapsed);
|
||||||
if (currFile != null)
|
if (currFile != null)
|
||||||
slave.add("currentFile", currFile);
|
slave.add("currentFile", currFile);
|
||||||
slave.add("currentFileSize", readableSize(currFileSize));
|
slave.add("currentFileSize", NumberUtils.readableSize(currFileSize));
|
||||||
slave.add("currentFileSizeDownloaded", readableSize(currFileSizeDownloaded));
|
slave.add("currentFileSizeDownloaded", NumberUtils.readableSize(currFileSizeDownloaded));
|
||||||
slave.add("currentFileSizePercent", String.valueOf(percentDownloaded));
|
slave.add("currentFileSizePercent", String.valueOf(percentDownloaded));
|
||||||
slave.add("bytesDownloaded", readableSize(bytesDownloaded));
|
slave.add("bytesDownloaded", NumberUtils.readableSize(bytesDownloaded));
|
||||||
slave.add("totalPercent", String.valueOf(totalPercent));
|
slave.add("totalPercent", String.valueOf(totalPercent));
|
||||||
slave.add("timeRemaining", String.valueOf(estimatedTimeRemaining) + "s");
|
slave.add("timeRemaining", String.valueOf(estimatedTimeRemaining) + "s");
|
||||||
slave.add("downloadSpeed", readableSize(downloadSpeed));
|
slave.add("downloadSpeed", NumberUtils.readableSize(downloadSpeed));
|
||||||
} catch (Exception e) {
|
} catch (Exception e) {
|
||||||
LOG.error("Exception while writing replication details: ", e);
|
LOG.error("Exception while writing replication details: ", e);
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
|
|
||||||
package org.apache.solr.handler.admin;
|
package org.apache.solr.handler.admin;
|
||||||
|
|
||||||
|
import org.apache.commons.io.FileUtils;
|
||||||
import org.apache.lucene.index.IndexReader;
|
import org.apache.lucene.index.IndexReader;
|
||||||
import org.apache.lucene.util.IOUtils;
|
import org.apache.lucene.util.IOUtils;
|
||||||
import org.apache.solr.cloud.CloudDescriptor;
|
import org.apache.solr.cloud.CloudDescriptor;
|
||||||
|
@ -33,6 +34,7 @@ import org.apache.solr.request.SolrQueryRequest;
|
||||||
import org.apache.solr.request.LocalSolrQueryRequest;
|
import org.apache.solr.request.LocalSolrQueryRequest;
|
||||||
import org.apache.solr.response.SolrQueryResponse;
|
import org.apache.solr.response.SolrQueryResponse;
|
||||||
import org.apache.solr.search.SolrIndexSearcher;
|
import org.apache.solr.search.SolrIndexSearcher;
|
||||||
|
import org.apache.solr.util.NumberUtils;
|
||||||
import org.apache.solr.util.RefCounted;
|
import org.apache.solr.util.RefCounted;
|
||||||
import org.apache.solr.update.MergeIndexesCommand;
|
import org.apache.solr.update.MergeIndexesCommand;
|
||||||
import org.apache.solr.update.processor.UpdateRequestProcessor;
|
import org.apache.solr.update.processor.UpdateRequestProcessor;
|
||||||
|
@ -530,7 +532,11 @@ public class CoreAdminHandler extends RequestHandlerBase {
|
||||||
info.add("uptime", System.currentTimeMillis() - core.getStartTime());
|
info.add("uptime", System.currentTimeMillis() - core.getStartTime());
|
||||||
RefCounted<SolrIndexSearcher> searcher = core.getSearcher();
|
RefCounted<SolrIndexSearcher> searcher = core.getSearcher();
|
||||||
try {
|
try {
|
||||||
info.add("index", LukeRequestHandler.getIndexInfo(searcher.get().getIndexReader(), false));
|
SimpleOrderedMap<Object> indexInfo = LukeRequestHandler.getIndexInfo(searcher.get().getIndexReader(), false);
|
||||||
|
long size = getIndexSize(core);
|
||||||
|
indexInfo.add("sizeInBytes", size);
|
||||||
|
indexInfo.add("size", NumberUtils.readableSize(size));
|
||||||
|
info.add("index", indexInfo);
|
||||||
} finally {
|
} finally {
|
||||||
searcher.decref();
|
searcher.decref();
|
||||||
}
|
}
|
||||||
|
@ -540,6 +546,10 @@ public class CoreAdminHandler extends RequestHandlerBase {
|
||||||
}
|
}
|
||||||
return info;
|
return info;
|
||||||
}
|
}
|
||||||
|
|
||||||
|
private long getIndexSize(SolrCore core) {
|
||||||
|
return FileUtils.sizeOfDirectory(new File(core.getIndexDir()));
|
||||||
|
}
|
||||||
|
|
||||||
protected static String normalizePath(String path) {
|
protected static String normalizePath(String path) {
|
||||||
if (path == null)
|
if (path == null)
|
||||||
|
|
|
@ -17,6 +17,8 @@
|
||||||
|
|
||||||
package org.apache.solr.util;
|
package org.apache.solr.util;
|
||||||
|
|
||||||
|
import java.text.NumberFormat;
|
||||||
|
|
||||||
import org.apache.lucene.util.BytesRef;
|
import org.apache.lucene.util.BytesRef;
|
||||||
|
|
||||||
/**
|
/**
|
||||||
|
@ -24,9 +26,19 @@ import org.apache.lucene.util.BytesRef;
|
||||||
*/
|
*/
|
||||||
public class NumberUtils {
|
public class NumberUtils {
|
||||||
|
|
||||||
|
public static String readableSize(long size) {
|
||||||
|
NumberFormat formatter = NumberFormat.getNumberInstance();
|
||||||
|
formatter.setMaximumFractionDigits(2);
|
||||||
|
if (size / (1024 * 1024 * 1024) > 0) {
|
||||||
|
return formatter.format(size * 1.0d / (1024 * 1024 * 1024)) + " GB";
|
||||||
|
} else if (size / (1024 * 1024) > 0) {
|
||||||
|
return formatter.format(size * 1.0d / (1024 * 1024)) + " MB";
|
||||||
|
} else if (size / 1024 > 0) {
|
||||||
|
return formatter.format(size * 1.0d / 1024) + " KB";
|
||||||
|
} else {
|
||||||
|
return String.valueOf(size) + " bytes";
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
public static String int2sortableStr(int val) {
|
public static String int2sortableStr(int val) {
|
||||||
char[] arr = new char[3];
|
char[] arr = new char[3];
|
||||||
|
|
Loading…
Reference in New Issue