Query http listeners. Closes #10.

This commit is contained in:
kimchy 2010-02-14 21:29:14 +02:00
parent cfafb52beb
commit b5f3fc9ae1
6 changed files with 87 additions and 6 deletions

View File

@ -19,22 +19,45 @@
package org.elasticsearch.action.admin.cluster.node.info; package org.elasticsearch.action.admin.cluster.node.info;
import com.google.common.collect.ImmutableMap;
import org.elasticsearch.action.support.nodes.NodeOperationResponse; import org.elasticsearch.action.support.nodes.NodeOperationResponse;
import org.elasticsearch.cluster.node.Node; import org.elasticsearch.cluster.node.Node;
import org.elasticsearch.util.settings.ImmutableSettings;
import org.elasticsearch.util.settings.Settings;
import java.io.DataInput; import java.io.DataInput;
import java.io.DataOutput;
import java.io.IOException; import java.io.IOException;
import java.util.Map;
/** /**
* @author kimchy (Shay Banon) * @author kimchy (Shay Banon)
*/ */
public class NodeInfo extends NodeOperationResponse { public class NodeInfo extends NodeOperationResponse {
protected NodeInfo() { private ImmutableMap<String, String> attributes;
private Settings settings;
NodeInfo() {
} }
public NodeInfo(Node node) { public NodeInfo(Node node, Map<String, String> attributes, Settings settings) {
this(node, ImmutableMap.copyOf(attributes), settings);
}
public NodeInfo(Node node, ImmutableMap<String, String> attributes, Settings settings) {
super(node); super(node);
this.attributes = attributes;
this.settings = settings;
}
public ImmutableMap<String, String> attributes() {
return this.attributes;
}
public Settings settings() {
return this.settings;
} }
public static NodeInfo readNodeInfo(DataInput in) throws ClassNotFoundException, IOException { public static NodeInfo readNodeInfo(DataInput in) throws ClassNotFoundException, IOException {
@ -42,4 +65,25 @@ public class NodeInfo extends NodeOperationResponse {
nodeInfo.readFrom(in); nodeInfo.readFrom(in);
return nodeInfo; return nodeInfo;
} }
@Override public void readFrom(DataInput in) throws IOException, ClassNotFoundException {
super.readFrom(in);
ImmutableMap.Builder<String, String> builder = ImmutableMap.builder();
int size = in.readInt();
for (int i = 0; i < size; i++) {
builder.put(in.readUTF(), in.readUTF());
}
attributes = builder.build();
settings = ImmutableSettings.readSettingsFromStream(in);
}
@Override public void writeTo(DataOutput out) throws IOException {
super.writeTo(out);
out.writeInt(attributes.size());
for (Map.Entry<String, String> entry : attributes.entrySet()) {
out.writeUTF(entry.getKey());
out.writeUTF(entry.getValue());
}
ImmutableSettings.writeSettingsToStream(settings, out);
}
} }

View File

@ -19,6 +19,7 @@
package org.elasticsearch.action.admin.cluster.node.info; package org.elasticsearch.action.admin.cluster.node.info;
import com.google.common.collect.ImmutableMap;
import com.google.inject.Inject; import com.google.inject.Inject;
import org.elasticsearch.ElasticSearchException; import org.elasticsearch.ElasticSearchException;
import org.elasticsearch.action.TransportActions; import org.elasticsearch.action.TransportActions;
@ -28,6 +29,7 @@ import org.elasticsearch.cluster.ClusterName;
import org.elasticsearch.cluster.ClusterService; import org.elasticsearch.cluster.ClusterService;
import org.elasticsearch.threadpool.ThreadPool; import org.elasticsearch.threadpool.ThreadPool;
import org.elasticsearch.transport.TransportService; import org.elasticsearch.transport.TransportService;
import org.elasticsearch.util.MapBuilder;
import org.elasticsearch.util.settings.Settings; import org.elasticsearch.util.settings.Settings;
import java.util.ArrayList; import java.util.ArrayList;
@ -39,11 +41,21 @@ import java.util.concurrent.atomic.AtomicReferenceArray;
*/ */
public class TransportNodesInfo extends TransportNodesOperationAction<NodesInfoRequest, NodesInfoResponse, TransportNodesInfo.NodeInfoRequest, NodeInfo> { public class TransportNodesInfo extends TransportNodesOperationAction<NodesInfoRequest, NodesInfoResponse, TransportNodesInfo.NodeInfoRequest, NodeInfo> {
private volatile ImmutableMap<String, String> nodeAttributes = ImmutableMap.of();
@Inject public TransportNodesInfo(Settings settings, ClusterName clusterName, ThreadPool threadPool, @Inject public TransportNodesInfo(Settings settings, ClusterName clusterName, ThreadPool threadPool,
ClusterService clusterService, TransportService transportService) { ClusterService clusterService, TransportService transportService) {
super(settings, clusterName, threadPool, clusterService, transportService); super(settings, clusterName, threadPool, clusterService, transportService);
} }
public synchronized void putNodeAttribute(String key, String value) {
nodeAttributes = new MapBuilder<String, String>().putAll(nodeAttributes).put(key, value).immutableMap();
}
public synchronized void removeNodeAttribute(String key) {
nodeAttributes = new MapBuilder<String, String>().putAll(nodeAttributes).remove(key).immutableMap();
}
@Override protected String transportAction() { @Override protected String transportAction() {
return TransportActions.Admin.Cluster.Node.INFO; return TransportActions.Admin.Cluster.Node.INFO;
} }
@ -80,7 +92,7 @@ public class TransportNodesInfo extends TransportNodesOperationAction<NodesInfoR
} }
@Override protected NodeInfo nodeOperation(NodeInfoRequest nodeInfoRequest) throws ElasticSearchException { @Override protected NodeInfo nodeOperation(NodeInfoRequest nodeInfoRequest) throws ElasticSearchException {
return new NodeInfo(clusterService.state().nodes().localNode()); return new NodeInfo(clusterService.state().nodes().localNode(), nodeAttributes, settings);
} }
@Override protected boolean accumulateExceptions() { @Override protected boolean accumulateExceptions() {

View File

@ -21,6 +21,7 @@ package org.elasticsearch.http;
import com.google.inject.Inject; import com.google.inject.Inject;
import org.elasticsearch.ElasticSearchException; import org.elasticsearch.ElasticSearchException;
import org.elasticsearch.action.admin.cluster.node.info.TransportNodesInfo;
import org.elasticsearch.threadpool.ThreadPool; import org.elasticsearch.threadpool.ThreadPool;
import org.elasticsearch.util.component.AbstractComponent; import org.elasticsearch.util.component.AbstractComponent;
import org.elasticsearch.util.component.Lifecycle; import org.elasticsearch.util.component.Lifecycle;
@ -42,15 +43,19 @@ public class HttpServer extends AbstractComponent implements LifecycleComponent<
private final ThreadPool threadPool; private final ThreadPool threadPool;
private final TransportNodesInfo nodesInfo;
private final PathTrie<HttpServerHandler> getHandlers; private final PathTrie<HttpServerHandler> getHandlers;
private final PathTrie<HttpServerHandler> postHandlers; private final PathTrie<HttpServerHandler> postHandlers;
private final PathTrie<HttpServerHandler> putHandlers; private final PathTrie<HttpServerHandler> putHandlers;
private final PathTrie<HttpServerHandler> deleteHandlers; private final PathTrie<HttpServerHandler> deleteHandlers;
@Inject public HttpServer(Settings settings, HttpServerTransport transport, ThreadPool threadPool) { @Inject public HttpServer(Settings settings, HttpServerTransport transport, ThreadPool threadPool,
TransportNodesInfo nodesInfo) {
super(settings); super(settings);
this.transport = transport; this.transport = transport;
this.threadPool = threadPool; this.threadPool = threadPool;
this.nodesInfo = nodesInfo;
getHandlers = new PathTrie<HttpServerHandler>(); getHandlers = new PathTrie<HttpServerHandler>();
postHandlers = new PathTrie<HttpServerHandler>(); postHandlers = new PathTrie<HttpServerHandler>();
@ -88,6 +93,7 @@ public class HttpServer extends AbstractComponent implements LifecycleComponent<
if (logger.isInfoEnabled()) { if (logger.isInfoEnabled()) {
logger.info("{}", transport.boundAddress()); logger.info("{}", transport.boundAddress());
} }
nodesInfo.putNodeAttribute("httpAddress", transport.boundAddress().publishAddress().toString());
return this; return this;
} }
@ -95,6 +101,7 @@ public class HttpServer extends AbstractComponent implements LifecycleComponent<
if (!lifecycle.moveToStopped()) { if (!lifecycle.moveToStopped()) {
return this; return this;
} }
nodesInfo.removeNodeAttribute("httpAddress");
transport.stop(); transport.stop();
return this; return this;
} }

View File

@ -32,6 +32,7 @@ import org.elasticsearch.util.json.JsonBuilder;
import org.elasticsearch.util.settings.Settings; import org.elasticsearch.util.settings.Settings;
import java.io.IOException; import java.io.IOException;
import java.util.Map;
/** /**
* @author kimchy (Shay Banon) * @author kimchy (Shay Banon)
@ -47,6 +48,7 @@ public class HttpNodesInfoAction extends BaseHttpServerHandler {
@Override public void handleRequest(final HttpRequest request, final HttpChannel channel) { @Override public void handleRequest(final HttpRequest request, final HttpChannel channel) {
String[] nodesIds = HttpActions.splitNodes(request.param("nodeId")); String[] nodesIds = HttpActions.splitNodes(request.param("nodeId"));
final boolean includeSettings = HttpActions.paramAsBoolean("settings", false);
NodesInfoRequest nodesInfoRequest = new NodesInfoRequest(nodesIds); NodesInfoRequest nodesInfoRequest = new NodesInfoRequest(nodesIds);
nodesInfoRequest.listenerThreaded(false); nodesInfoRequest.listenerThreaded(false);
client.admin().cluster().execNodesInfo(nodesInfoRequest, new ActionListener<NodesInfoResponse>() { client.admin().cluster().execNodesInfo(nodesInfoRequest, new ActionListener<NodesInfoResponse>() {
@ -55,6 +57,8 @@ public class HttpNodesInfoAction extends BaseHttpServerHandler {
JsonBuilder builder = HttpJsonBuilder.cached(request); JsonBuilder builder = HttpJsonBuilder.cached(request);
builder.startObject(); builder.startObject();
builder.field("clusterName", result.clusterName().value()); builder.field("clusterName", result.clusterName().value());
builder.startObject("nodes");
for (NodeInfo nodeInfo : result) { for (NodeInfo nodeInfo : result) {
builder.startObject(nodeInfo.node().id()); builder.startObject(nodeInfo.node().id());
@ -62,8 +66,22 @@ public class HttpNodesInfoAction extends BaseHttpServerHandler {
builder.field("transportAddress", nodeInfo.node().address().toString()); builder.field("transportAddress", nodeInfo.node().address().toString());
builder.field("dataNode", nodeInfo.node().dataNode()); builder.field("dataNode", nodeInfo.node().dataNode());
for (Map.Entry<String, String> nodeAttribute : nodeInfo.attributes().entrySet()) {
builder.field(nodeAttribute.getKey(), nodeAttribute.getValue());
}
if (includeSettings) {
builder.startObject("settings");
for (Map.Entry<String, String> entry : nodeInfo.settings().getAsMap().entrySet()) {
builder.field(entry.getKey(), entry.getValue());
}
builder.endObject(); builder.endObject();
} }
builder.endObject();
}
builder.endObject();
builder.endObject(); builder.endObject();
channel.sendResponse(new JsonHttpResponse(request, HttpResponse.Status.OK, builder)); channel.sendResponse(new JsonHttpResponse(request, HttpResponse.Status.OK, builder));
} catch (Exception e) { } catch (Exception e) {

View File

@ -66,7 +66,7 @@ public class HttpClusterStateAction extends BaseHttpServerHandler {
builder.startObject("settings"); builder.startObject("settings");
for (Map.Entry<String, String> entry : indexMetaData.settings().getAsMap().entrySet()) { for (Map.Entry<String, String> entry : indexMetaData.settings().getAsMap().entrySet()) {
builder.startObject("setting").field("name", entry.getKey()).field("value", entry.getValue()).endObject(); builder.field(entry.getKey(), entry.getValue());
} }
builder.endObject(); builder.endObject();

View File

@ -75,7 +75,7 @@ public class HttpIndicesStatusAction extends BaseHttpServerHandler {
builder.startObject("settings"); builder.startObject("settings");
for (Map.Entry<String, String> entry : indexStatus.settings().getAsMap().entrySet()) { for (Map.Entry<String, String> entry : indexStatus.settings().getAsMap().entrySet()) {
builder.startObject("setting").field("name", entry.getKey()).field("value", entry.getValue()).endObject(); builder.field(entry.getKey(), entry.getValue());
} }
builder.endObject(); builder.endObject();