Jboss EAP:native management API学习
上一节已经学习了CLI命令行来控制JBOSS,如果想在程序中以编码方式来控制JBOSS,可以参考下面的代码,实际上在前面的文章,用代码控制Jboss上的DataSource,已经有所接触了,API与CLI是完全等价的,一个是人工敲指令,一个是代码控制,二者最终的效果一致。
import com.sun.javafx.sg.PGShape;
import org.jboss.as.controller.client.ModelControllerClient;
import org.jboss.as.controller.client.helpers.ClientConstants;
import org.jboss.dmr.ModelNode;
import org.junit.Test; import javax.security.auth.callback.*;
import javax.security.sasl.RealmCallback;
import java.io.IOException;
import java.net.InetAddress;
import java.net.UnknownHostException;
import java.util.ArrayList;
import java.util.List; public class JBossClient { private String host = "172.16.38.***";
private int port = 9999;
private String userid = "jimmy";
private String password = "*****"; @Test
public void testGetServers() {
//相当于CLI命令行: ls /host=master/server-config
List<String> servers = getServers("master");
for (String s : servers) {
System.out.println(s);
}
} @Test
public void getServerStatus() {
//相当于CLI命令行:/host=master/server=server-one:read-attribute(name=server-state)
System.out.println(getServerStatus("master", "server-one"));
//相当于CLI命令行:/host=master/server-config=server-one:read-attribute(name=status)
System.out.println(getServerStatus2("master", "server-one"));
} @Test
public void testStartServer() {
//相当于CLI命令行:/host=master/server-config=server-one:start
System.out.println(startServer("master", "server-one"));
} @Test
public void testStopServer() {
//相当于CLI命令行:/host=master/server-config=server-one:stop
System.out.println(stopServer("master", "server-one"));
} /**
* 获取指定服务器运行状态
* @param hostName
* @param serverName
* @return
*/
public String getServerStatus(String hostName, String serverName) {
String status = "unknown";
ModelControllerClient client = null;
try {
client = createClient(InetAddress.getByName(host), port, userid, password.toCharArray(), "ManagementRealm");
} catch (UnknownHostException uhe) {
uhe.printStackTrace();
System.out.println("UHE: " + uhe.getMessage());
}
try {
ModelNode op = new ModelNode();
op.get(ClientConstants.OP).set(ClientConstants.READ_ATTRIBUTE_OPERATION);
op.get(ClientConstants.OP_ADDR).add("host", hostName);
op.get(ClientConstants.OP_ADDR).add("server", serverName);
op.get("name").set("server-state"); status = client.execute(op).get(ClientConstants.RESULT).asString(); if (client != null) client.close();
} catch (Exception e) {
e.printStackTrace();
System.out.println("Exception: " + e.getMessage());
} return status;
} /**
* 另一种获取服务器运行状态的方法
* @param hostName
* @param serverName
* @return
*/
public String getServerStatus2(String hostName, String serverName) {
String status = "unknown";
ModelControllerClient client = null;
try {
client = createClient(InetAddress.getByName(host), port, userid, password.toCharArray(), "ManagementRealm");
} catch (UnknownHostException uhe) {
uhe.printStackTrace();
System.out.println("UHE: " + uhe.getMessage());
}
try {
ModelNode op = new ModelNode();
op.get(ClientConstants.OP).set(ClientConstants.READ_ATTRIBUTE_OPERATION);
op.get(ClientConstants.OP_ADDR).add("host", hostName);
op.get(ClientConstants.OP_ADDR).add("server-config", serverName);
op.get("name").set("status"); status = client.execute(op).get(ClientConstants.RESULT).asString(); if (client != null) client.close();
} catch (Exception e) {
e.printStackTrace();
System.out.println("Exception: " + e.getMessage());
} return status;
} /**
* 启动指定服务器
*
* @param hostName
* @param serverName
*/
public ModelNode startServer(String hostName, String serverName) { ModelControllerClient client = null;
ModelNode returnVal = null;
try {
client = createClient(InetAddress.getByName(host), port, userid, password.toCharArray(), "ManagementRealm");
} catch (UnknownHostException uhe) {
uhe.printStackTrace();
System.out.println("UHE: " + uhe.getMessage());
}
try {
ModelNode op = new ModelNode();
op.get(ClientConstants.OP).set("start");
op.get(ClientConstants.OP_ADDR).add("host", hostName);
op.get(ClientConstants.OP_ADDR).add("server-config", serverName); returnVal = client.execute(op).get(ClientConstants.RESULT); if (client != null) client.close();
} catch (Exception e) {
e.printStackTrace();
System.out.println("Exception: " + e.getMessage());
} return returnVal; } /**
* 停止指定服务器
*
* @param hostName
* @param serverName
*/
public ModelNode stopServer(String hostName, String serverName) { ModelControllerClient client = null;
ModelNode returnVal = null;
try {
client = createClient(InetAddress.getByName(host), port, userid, password.toCharArray(), "ManagementRealm");
} catch (UnknownHostException uhe) {
uhe.printStackTrace();
System.out.println("UHE: " + uhe.getMessage());
}
try {
ModelNode op = new ModelNode();
op.get(ClientConstants.OP).set("stop");
op.get(ClientConstants.OP_ADDR).add("host", hostName);
op.get(ClientConstants.OP_ADDR).add("server-config", serverName);
returnVal = client.execute(op).get(ClientConstants.RESULT);
if (client != null) client.close();
} catch (Exception e) {
e.printStackTrace();
System.out.println("Exception: " + e.getMessage());
} return returnVal; } /**
* 获取指定host下的所有server
*
* @param hostName
* @return
*/
public List<String> getServers(String hostName) {
List<String> servers = new ArrayList<String>();
ModelControllerClient client = null;
try {
client = createClient(InetAddress.getByName(host), 9999, userid, password.toCharArray(), "ManagementRealm");
} catch (UnknownHostException uhe) {
uhe.printStackTrace();
System.out.println("UHE: " + uhe.getMessage());
}
try {
ModelNode op = new ModelNode();
op.get(ClientConstants.OP).set(ClientConstants.READ_RESOURCE_OPERATION);
op.get(ClientConstants.OP_ADDR).add("host", hostName);
List<ModelNode> returnVal = client.execute(op).get(ClientConstants.RESULT).get("server-config").asList(); for (ModelNode _ : returnVal) {
servers.add(_.asProperty().getName());
} if (client != null) client.close();
} catch (Exception e) {
e.printStackTrace();
System.out.println("Exception: " + e.getMessage());
}
return servers;
} private ModelControllerClient createClient(final InetAddress host, final int port, final String username, final char[] password, final String securityRealmName) {
final CallbackHandler callbackHandler = new CallbackHandler() {
public void handle(Callback[] callbacks) throws IOException, UnsupportedCallbackException {
for (Callback current : callbacks) {
if (current instanceof NameCallback) {
NameCallback ncb = (NameCallback) current;
ncb.setName(username);
} else if (current instanceof PasswordCallback) {
PasswordCallback pcb = (PasswordCallback) current;
//pcb.setPassword("admin123".toCharArray());
pcb.setPassword(password);
} else if (current instanceof RealmCallback) {
RealmCallback rcb = (RealmCallback) current;
rcb.setText(rcb.getDefaultText());
} else {
throw new UnsupportedCallbackException(current);
}
}
}
};
return ModelControllerClient.Factory.create(host, port, callbackHandler);
}
}
除了native managent API外,jboss还提供了一套基于http的REST风格API,即9990端口对应的API,有兴趣的可以参考下面的文章
https://docs.jboss.org/author/display/AS71/The+HTTP+management+API
https://docs.jboss.org/author/display/AS71/The+native+management+API
GitHub有一个开源项目,从手机上管理jboss,就是基于http的这一套API实现的,技术上讲 ,利用这二套API,完全可以自己定制一套Jboss管理控制台(不管是c/s还是b/s)
最后送点福利,GitHub上的开源项目jboss-controller-operation-executor,我在原来的基础上,增加了几个domain模式下的控制方法,包括 停止/启用某一台服务器、获取服务器状态、停止/启用某个ServerGroup下所有Server,并增加了单元测试的示例代码,并将pom依赖项,升级到7.5,以兼容JBOSS EAP 6.4
项目地址:https://github.com/yjmyzz/jboss-controller-operation-executor
Jboss EAP:native management API学习的更多相关文章
- 动态配置 JBOSS ( eap 6.2 ) 数据源
操作环境 windows + jboss eap 6.2 + MyEclipse 10.0 项目用的是jboss eap 6.2,作为Red公司升级后的eap稳定版. 相比之前的 AS 系列,不管是安 ...
- node-webkit学习(4)Native UI API 之window
node-webkit学习(4)Native UI API 之window 文/玄魂 目录 node-webkit学习(4)Native UI API 之window 前言 4.1 window a ...
- node-webkit学习(3)Native UI API概览
node-webkit学习(3)Native UI API概览 文/玄魂 目录 node-webkit学习(3)Native UI API概览 前言 3.1 Native UI api概览 Exte ...
- CAS (8) —— Mac下配置CAS到JBoss EAP 6.4(6.x)的Standalone模式(服务端)
CAS (8) -- Mac下配置CAS到JBoss EAP 6.4(6.x)的Standalone模式(服务端) jboss版本: jboss-eap-6.4-CVE-2015-7501 jdk版本 ...
- Oracle Coherence应用部署到Jboss EAP 6.x 时 NoClassDefFoundError: sun/rmi/server/MarshalOutputStream 的解决办法
今天将一个web应用从weblogic 10.3迁移到jboss EAP 6.3上,该应用使用oracle coherence做为缓存,部署上去后,启动时一直报如下错误: at java.ut ...
- jboss eap 6.3 域(Domain)模式配置
jboss提供了二种运行模式:standalone(独立运行模式).domain(域模式),日常开发中,使用standalone模式足已:但生产部署时,一个app,往往是部署在jboss集群环境中的, ...
- JBOSS EAP实战(1)
JBOSS的诞生 1998年,在硅谷SUN公司的SAP实验室,一个年轻人正坐在电脑前面思考,然后写着什么东西.不,他没有在写程序,他在写辞呈.他正在做出人生的一个重大决定:他要辞掉在SUN的这份工作, ...
- JBOSS EAP 6 系列四 EJB实现——调用(贯穿始终的模块)
本文主要介绍在JBOSS EAP 6.2(或者JBOSS AS7)中模块是如何贯穿EJB实现的始终.延续上一博文<认识模块的使用>的话题继续聊JBOSS做为模块申明式容器的这一特性在EJB ...
- JVM Management API
JVM本身提供了一组管理的API,通过该API,我们可以获取得到JVM内部主要运行信息,包括内存各代的数据.JVM当前所有线程及其栈相关信 息等等.各种JDK自带的剖析工具,包括jps.jstack. ...
随机推荐
- js location对象
location提供了与当前窗口中加载文档有关的信息.还提供了一些导航功能.它既是window对象的属性,又是document对象的属性,window.location与document.locati ...
- IT行业常见职位职业路线图
我曾经面试过一些计算机相关毕业的应届生,问他希望做什么工作时,他回答只要是软件开发就好了,再细问一下你了解到的软件开发是怎样的?除了软件开发,还有其它什么工作?就答不出来了. 这里我先给出一张IT知识 ...
- BitTorrent Sync - 神奇的文件同步软件,无需服务器让多台电脑互相同步!
176,487 微博 腾讯 空间 微信 141 49 如今人们对文件备份和同步的需求已经越来越强烈了.像 Dropbox 一样的云存储网盘有很多,但它们都有一个局限性,就是所有的文件都得经过它们的服务 ...
- JAVA 8 函数式接口 - Functional Interface
什么是函数式接口(Functional Interface) 其实之前在讲Lambda表达式的时候提到过,所谓的函数式接口,当然首先是一个接口,然后就是在这个接口里面只能有一个抽象方法. 这种类型的接 ...
- MySQL入门(三)
写了两篇<MySQL入门>以后我发现,写书的人还是都挺有本事的,起码人家知道怎么编排自己想讲的知识点,我实在是不知道该先说那里后说哪里,那我就想到什么讲什么吧. 一 写SQL 其实我是不想 ...
- oracle学习笔记系列------oracle 基本操作之表的增删改查
--创建一个表 CREATE TABLE employee_souvc( id ), name ), gender ), birth DATE, salary ,), job ), deptno ) ...
- 命令行选项解析函数(C语言):getopt()和getopt_long()
命令行选项解析函数(C语言):getopt()和getopt_long() 上午在看源码项目webbench时,刚开始就被一个似乎挺陌生函数getopt_long()给卡住了,说实话这函数没怎么见过, ...
- How to create and apply a patch with Git
Creating a patch file with git is quite easy to do, you just need to see how it’s done a few times. ...
- [转]html5 js 访问 sqlite 数据库的操作类
本文转自:http://blog.csdn.net/tsxw24/article/details/7613815 webkit 核心的浏览器提供了 3个 api接口,用于访问本地sqlite数据,但使 ...
- MMORPG大型游戏设计与开发(客户端架构 part1 of vegine)
重写有些核心接口的时候,其实遇到了许多的问题,甚至一度的想过要放弃,但是最终还是坚持了下来.在客户端提供的这些接口中,可以清晰的看到客户端所依赖的各种模块的支持,以及各自之间的一些关联.下面只是介绍了 ...