io.zulia.server.cmd.ZuliaDump Maven / Gradle / Ivy
package io.zulia.server.cmd;
import com.beust.jcommander.JCommander;
import com.beust.jcommander.Parameter;
import com.beust.jcommander.ParameterException;
import com.google.common.base.Charsets;
import com.google.protobuf.util.JsonFormat;
import io.zulia.client.command.GetIndexConfig;
import io.zulia.client.config.ZuliaPoolConfig;
import io.zulia.client.pool.ZuliaWorkPool;
import io.zulia.client.result.GetIndexesResult;
import io.zulia.log.LogUtil;
import java.io.File;
import java.io.FileWriter;
import java.io.IOException;
import java.nio.file.Files;
import java.nio.file.Paths;
import java.util.concurrent.atomic.AtomicInteger;
import java.util.logging.Level;
import java.util.logging.Logger;
public class ZuliaDump {
private static final Logger LOG = Logger.getLogger(ZuliaDump.class.getSimpleName());
public static class ZuliaDumpArgs {
@Parameter(names = "--help", help = true)
private boolean help;
@Parameter(names = "--address", description = "Zulia Server Address", order = 1)
private String address = "localhost";
@Parameter(names = "--port", description = "Zulia Port", order = 2)
private Integer port = 32191;
@Parameter(names = "--index", description = "Index name to dump.")
private String index;
@Parameter(names = "--indexes", description = "Comma separated or name* for wild card multiple index names.")
private String indexes;
@Parameter(names = "--out", description = "Full path to the output directory. [Defaults to current_directory/zuliadump")
private String out = System.getProperty("user.dir");
@Parameter(names = "--q", description = "Zulia query, matches all docs by default.")
private String q = "*:*";
@Parameter(names = "--rows", description = "Number of records to return. [Defaults to 1000]")
private Integer rows = 1000;
}
public static void main(String[] args) {
LogUtil.init();
ZuliaDumpArgs zuliaDumpArgs = new ZuliaDumpArgs();
JCommander jCommander = JCommander.newBuilder().addObject(zuliaDumpArgs).build();
try {
jCommander.parse(args);
ZuliaPoolConfig zuliaPoolConfig = new ZuliaPoolConfig().addNode(zuliaDumpArgs.address, zuliaDumpArgs.port);
ZuliaWorkPool workPool = new ZuliaWorkPool(zuliaPoolConfig);
String index = zuliaDumpArgs.index;
String indexes = zuliaDumpArgs.indexes;
if (index == null && indexes == null) {
LOG.log(Level.SEVERE, "Please pass in an index name.");
jCommander.usage();
System.exit(2);
}
String q = zuliaDumpArgs.q;
Integer rows = zuliaDumpArgs.rows;
String out = zuliaDumpArgs.out;
if (indexes != null) {
if (indexes.contains(",")) {
for (String ind : indexes.split(",")) {
queryAndWriteOutput(workPool, ind, q, rows, out);
}
}
else if (indexes.contains("*")) {
GetIndexesResult indexesResult = workPool.getIndexes();
for (String ind : indexesResult.getIndexNames()) {
if (ind.startsWith(indexes.replace("*", ""))) {
queryAndWriteOutput(workPool, ind, q, rows, out);
}
}
}
}
else {
queryAndWriteOutput(workPool, index, q, rows, out);
}
}
catch (ParameterException e) {
System.err.println(e.getMessage());
jCommander.usage();
System.exit(2);
}
catch (UnsupportedOperationException e) {
System.err.println("Error: " + e.getMessage());
System.exit(2);
}
catch (Exception e) {
System.err.println("Error: " + e.getMessage());
e.printStackTrace();
System.exit(1);
}
}
private static void queryAndWriteOutput(ZuliaWorkPool workPool, String index, String q, Integer rows, String out) throws Exception {
io.zulia.client.command.Query zuliaQuery;
// create zuliadump dir first
String zuliaDumpDir = out + File.separator + "zuliadump";
if (!Files.exists(Paths.get(zuliaDumpDir))) {
Files.createDirectory(Paths.get(zuliaDumpDir));
}
// create index dir
String indOutputDir = zuliaDumpDir + File.separator + index;
if (!Files.exists(Paths.get(indOutputDir))) {
Files.createDirectory(Paths.get(indOutputDir));
}
String recordsFilename = indOutputDir + File.separator + index + ".json";
String settingsFilename = indOutputDir + File.separator + index + "_settings.json";
AtomicInteger count = new AtomicInteger();
try (FileWriter fileWriter = new FileWriter(new File(recordsFilename), Charsets.UTF_8)) {
LOG.info("Dumping index <" + index + ">");
zuliaQuery = new io.zulia.client.command.Query(index, q, rows);
workPool.queryAll(zuliaQuery, queryResult -> {
long totalHits = queryResult.getTotalHits();
queryResult.getDocuments().forEach(doc -> {
try {
fileWriter.write(doc.toJson());
fileWriter.write(System.lineSeparator());
if (count.incrementAndGet() % 10000 == 0) {
LOG.info("So far written <" + count + "> of <" + totalHits + ">");
}
}
catch (IOException e) {
LOG.log(Level.SEVERE, "Could not write output for index <" + index + ">", e);
}
});
});
LOG.info("Finished dumping index <" + index + ">");
}
try (FileWriter fileWriter = new FileWriter(new File(settingsFilename), Charsets.UTF_8)) {
LOG.info("Writing settings for index <" + index + ">");
JsonFormat.Printer printer = JsonFormat.printer();
fileWriter.write(printer.print(workPool.getIndexConfig(new GetIndexConfig(index)).getIndexConfig().getIndexSettings()));
LOG.info("Finished writing settings for index <" + index + ">");
}
}
}
© 2015 - 2025 Weber Informatics LLC | Privacy Policy