本篇内容介绍了“elasticsearch的jvm插件怎么使用”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!
elasticsearch 的 jvm插件要实现Plugin接口,或者继承子AbstractPlugin抽象类。可以实现 Module 和 Services 两种组件,它们分别有 3个 生命周期 global , index ,shard 。
整体的项目结构是这样的。
我们这里继承子AbstractPlugin ,来增加我们的 TranslogRestModule 模块
package org.elasticsearch.plugin.translog; import java.util.Collection; import org.elasticsearch.common.collect.Lists; import org.elasticsearch.common.inject.Module; import org.elasticsearch.plugins.AbstractPlugin; public class TranslogRestPlugin extends AbstractPlugin{ public String name() { return "translog-rest"; } @Override public String description() { return "view translog"; } @Override public Collection<Class<? extends Module>> modules() { Collection<Class<? extends Module>> modules = Lists.newArrayList(); modules.add(TranslogRestModule.class); return modules; } }
TranslogRestModule类 ,实例化我们的 TranslogRestHandler
package org.elasticsearch.plugin.translog; import org.elasticsearch.common.inject.AbstractModule; public class TranslogRestModule extends AbstractModule { @Override protected void configure() { bind(TranslogRestHandler.class).asEagerSingleton(); } }
TranslogRestHandler是我们最主要的一个类 , 他负责处理 /_translog 这个REST请求,通过 TranslogStreams.readTranslogOperation 方法读取 Translog 然后用 XContentBuilder 构造 JSON格式 ,返回给客户端。
package org.elasticsearch.plugin.translog; import java.io.FileInputStream; import java.io.IOException; import org.elasticsearch.common.inject.Inject; import org.elasticsearch.common.io.stream.InputStreamStreamInput; import org.elasticsearch.common.xcontent.XContentBuilder; import org.elasticsearch.index.translog.Translog; import org.elasticsearch.index.translog.TranslogStreams; import org.elasticsearch.rest.*; import org.elasticsearch.rest.action.support.RestXContentBuilder; import static org.elasticsearch.rest.RestRequest.Method.GET; import static org.elasticsearch.rest.RestStatus.OK; public class TranslogRestHandler implements RestHandler{ private XContentBuilder builder; @Inject public TranslogRestHandler(RestController restController) { restController.registerHandler(GET, "/_translog", this); } public void buildSave(Translog.Index op){ try { builder.startObject() .field("opType").value("save") .field("id").value(op.id()) .field("type").value(op.type()) .field("version").value(op.version()) .field("routing").value(op.routing()) .field("parent").value(op.parent()) .field("timestamp").value(op.timestamp()) .field("ttl").value(op.ttl()) .field("version").value(op.version()) .field("source").value(op.source().toUtf8()) .endObject(); } catch (IOException e) { e.printStackTrace(); } } public void buildCreate(Translog.Create op){ try { builder.startObject() .field("opType").value("create") .field("id").value(op.id()) .field("type").value(op.type()) .field("version").value(op.version()) .field("routing").value(op.routing()) .field("parent").value(op.parent()) .field("timestamp").value(op.timestamp()) .field("ttl").value(op.ttl()) .field("version").value(op.version()) .field("source").value(op.source().toUtf8()) .endObject(); } catch (IOException e) { e.printStackTrace(); } } public void buildDelete(Translog.Delete op){ try { builder.startObject() .field("opType").value("delete") .field("id").value(op.uid().text()) .field("version").value(op.version()) .endObject(); } catch (IOException e) { e.printStackTrace(); } } public void buildDeleteByQuery(Translog.DeleteByQuery op){ try { builder.startObject() .field("opType").value("deleteByQuery") .field("source").value(op.source().toUtf8()) .endObject(); } catch (IOException e) { e.printStackTrace(); } } public XContentBuilder buildTranslog(String filePath,int size){ FileInputStream fs = null; int count = 0; try { fs = new FileInputStream(filePath); InputStreamStreamInput si = new InputStreamStreamInput(fs); while (true) { if(count>=size){ break; } Translog.Operation operation; try { int opSize = si.readInt(); // System.out.println("opSize = "+opSize); operation = TranslogStreams.readTranslogOperation(si); switch (operation.opType()) { case CREATE: Translog.Create create = (Translog.Create) operation; buildCreate(create); break; case SAVE: Translog.Index index = (Translog.Index) operation; buildSave(index); break; case DELETE: Translog.Delete delete = (Translog.Delete) operation; buildDelete(delete); break; case DELETE_BY_QUERY: Translog.DeleteByQuery dbq = (Translog.DeleteByQuery) operation; buildDeleteByQuery(dbq); break; default: System.out.println("Invaid Operation Type"); break; } count++; }catch(Exception e){ break; } } }catch(Exception e){ e.printStackTrace(); }finally{ if(null!=fs){ try { fs.close(); } catch (IOException e) { e.printStackTrace(); } } } return builder; } @Override public void handleRequest(final RestRequest request, final RestChannel channel) { String file = request.param("file"); String sizeStr = request.param("size"); int size = 10; if(null!=sizeStr){ size = Integer.parseInt(sizeStr); } try { builder = RestXContentBuilder.restContentBuilder(request); if(null!=file){ builder.startArray(); buildTranslog(file,size); builder.endArray(); }else{ builder.startObject() .field("success").value(false) .field("error").value("缺少参数:file") .endObject(); } channel.sendResponse(new XContentRestResponse(request,OK,builder)); } catch (IOException e) { e.printStackTrace(); } } }
最后 es-plugin.properties 这个配置文件,是我们必须的一个类,它主要告诉ES, 哪个类是我们插件的实现类 ,对于site插件,提供插件的名称和描述信息,细节可以参考 PluginsService类 和 loadPluginsFromClasspath 方法
plugin=org.elasticsearch.plugin.translog.TranslogRestPlugin
好了,现在可以去安装我们的插件了。有2个办法。
手动安装,导出Jar包,复制到 /plugins/translogRest/TranslogRest.jar 下面。
命令安装,plugin --install translogRest --url file:/d:/TranslogRest.jar
浏览器里或者curl
http://localhost:9200/_translog?pretty=true
返回
{
success: false,
error: "缺少参数:file"
}
表示我们的插件,已经安装成功。
“elasticsearch的jvm插件怎么使用”的内容就介绍到这里了,感谢大家的阅读。如果想了解更多行业相关的知识可以关注亿速云网站,小编将为大家输出更多高质量的实用文章!
免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。