J2EE Web服务客户端质量报告(五)
2008-01-05 08:21:06 来源:WEB开发网核心提示:建立样品客户端应用要建立样品客户端应用,请将下列文件系统添加到IDE中:<download Directory>/Metrics/TransactionClient. 该文件系统包含一个应用类和一个Xact 软件包,J2EE Web服务客户端质量报告(五),应用类可模拟客户端事务的执行,Xact 软件包包含客户端Web
建立样品客户端应用
要建立样品客户端应用,请将下列文件系统添加到IDE中:<download Directory>/Metrics/TransactionClient.
该文件系统包含一个应用类和一个Xact 软件包。应用类可模拟客户端事务的执行,Xact 软件包包含客户端Web服务处理器。
Xact软件包可使用Sun Web服务开发者工具包来创建,这个工具包包括在Sun ONE应用框架内。批文件gen.bat使用wscompile命令创建Xact软件包。假如你想重建该软件包的话, 你只需调整环境变量和它使用的config.xml 中的URL。但是,假如你这样做的话,你得重写添加到Stub 类Web方法的代码行,你要用它来覆盖原来的代码行。
我们看看XactClientApp,样品客户端应用程序类:
import Xact.*;
import javax.xml.rpc.Stub;
import Payload.*;
public class XactClientApp {
/** Creates a new instance of XactClientApp */
public XactClientApp() {
}
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
try {
int cyclesPerXact = 1;
int numberXacts = 5;
String transactionID = "";
String transactionType =
String.valueOf(cyclesPerXact) +" submit,check,gets";
Stub stub = createPRoxy();
XactServiceServantInterface xact = (XactServiceServantInterface)stub;
CurrentReport cr = new CurrentReport();
for (int x=1; x<= numberXacts;x++){
cr.BeginTransaction();
for (int i=1; i<=cyclesPerXact;i++){
transactionID = xact.submitWork("new transaction");
System.out.println("Transaction:" + transactionID);
boolean unused = xact.checkWork(transactionID);
String ignore = xact.getResult(transactionID);
}
cr.CommitTransaction(transactionID, transactionType,"sUCcess");
}
} catch (Exception ex) {
ex.printStackTrace();
}
}
private static Stub createProxy() {
return (Stub)(new XactService_Impl()).getXactServiceServantInterfacePort();
}
}
先看它的内部循环。客户端应用判定商业事务的组成。在本例中,它包括三个Web服务调用:针对submitWork()、checkWork()和getResult()的分别调用。客户端使用beginTransaction()和 commitTransaction()定界事务。在该循环的第二个循环中,在CurrentReport.LastReport 对象中将出现一个完整的ClientReport。当客户端调用submitWork()时,Web 服务客户端Stub 类中相应方法调用Serializer.attachPendingReportToMessage() 将该报告连接到SOAP信息上。
CyclesperXact和numberXacts用于控制每件事务的Web服务调用数和客户端在运行过程中递交的事务数。
右击应用程序图标XactClientApp;先选择Build All项,接着选择Execute项。在执行窗口中,你会看到:对于每件事务,应用都报告它收到的事务标志符。观察应用服务Windows输出控制台,你可以看到以下的代码行:
INFO: CORE3274: successful server startup
INFO: CORE5053: application onReady complete.
INFO: CORE3282: stdout: Exception occurred connecting to queue: javax.naming.Nam
eNotFoundException
INFO: CORE3282: stdout: Exception occurred connecting to queue: javax.naming.Nam
eNotFoundException
INFO: CORE3282: stdout: Exception occurred connecting to queue: javax.naming.Nam
eNotFoundException
INFO: CORE3282: stdout: Exception occurred connecting to queue: javax.naming.Nam
eNotFoundException
我们还没有安装应用服务次数排列或者配置应用服务次数读取器EJB。客户端产生次数福建,服务器接收它,并试图将它列队到一个不存在的队列中。Serializer 类只是报告错误并答应应用程序继续运行。回想我们的目标之一就是保持商业事物系统的总可靠性。可是我们却看到即使新的次数组件失败,要害的商业事务仍然可以照常进行。进入讨论组讨论。
要建立样品客户端应用,请将下列文件系统添加到IDE中:<download Directory>/Metrics/TransactionClient.
该文件系统包含一个应用类和一个Xact 软件包。应用类可模拟客户端事务的执行,Xact 软件包包含客户端Web服务处理器。
Xact软件包可使用Sun Web服务开发者工具包来创建,这个工具包包括在Sun ONE应用框架内。批文件gen.bat使用wscompile命令创建Xact软件包。假如你想重建该软件包的话, 你只需调整环境变量和它使用的config.xml 中的URL。但是,假如你这样做的话,你得重写添加到Stub 类Web方法的代码行,你要用它来覆盖原来的代码行。
我们看看XactClientApp,样品客户端应用程序类:
import Xact.*;
import javax.xml.rpc.Stub;
import Payload.*;
public class XactClientApp {
/** Creates a new instance of XactClientApp */
public XactClientApp() {
}
/**
* @param args the command line arguments
*/
public static void main(String[] args) {
try {
int cyclesPerXact = 1;
int numberXacts = 5;
String transactionID = "";
String transactionType =
String.valueOf(cyclesPerXact) +" submit,check,gets";
Stub stub = createPRoxy();
XactServiceServantInterface xact = (XactServiceServantInterface)stub;
CurrentReport cr = new CurrentReport();
for (int x=1; x<= numberXacts;x++){
cr.BeginTransaction();
for (int i=1; i<=cyclesPerXact;i++){
transactionID = xact.submitWork("new transaction");
System.out.println("Transaction:" + transactionID);
boolean unused = xact.checkWork(transactionID);
String ignore = xact.getResult(transactionID);
}
cr.CommitTransaction(transactionID, transactionType,"sUCcess");
}
} catch (Exception ex) {
ex.printStackTrace();
}
}
private static Stub createProxy() {
return (Stub)(new XactService_Impl()).getXactServiceServantInterfacePort();
}
}
先看它的内部循环。客户端应用判定商业事务的组成。在本例中,它包括三个Web服务调用:针对submitWork()、checkWork()和getResult()的分别调用。客户端使用beginTransaction()和 commitTransaction()定界事务。在该循环的第二个循环中,在CurrentReport.LastReport 对象中将出现一个完整的ClientReport。当客户端调用submitWork()时,Web 服务客户端Stub 类中相应方法调用Serializer.attachPendingReportToMessage() 将该报告连接到SOAP信息上。
CyclesperXact和numberXacts用于控制每件事务的Web服务调用数和客户端在运行过程中递交的事务数。
右击应用程序图标XactClientApp;先选择Build All项,接着选择Execute项。在执行窗口中,你会看到:对于每件事务,应用都报告它收到的事务标志符。观察应用服务Windows输出控制台,你可以看到以下的代码行:
INFO: CORE3274: successful server startup
INFO: CORE5053: application onReady complete.
INFO: CORE3282: stdout: Exception occurred connecting to queue: javax.naming.Nam
eNotFoundException
INFO: CORE3282: stdout: Exception occurred connecting to queue: javax.naming.Nam
eNotFoundException
INFO: CORE3282: stdout: Exception occurred connecting to queue: javax.naming.Nam
eNotFoundException
INFO: CORE3282: stdout: Exception occurred connecting to queue: javax.naming.Nam
eNotFoundException
我们还没有安装应用服务次数排列或者配置应用服务次数读取器EJB。客户端产生次数福建,服务器接收它,并试图将它列队到一个不存在的队列中。Serializer 类只是报告错误并答应应用程序继续运行。回想我们的目标之一就是保持商业事物系统的总可靠性。可是我们却看到即使新的次数组件失败,要害的商业事务仍然可以照常进行。进入讨论组讨论。
- ››Web服务器和应用服务器的区别
- ››web安全之信息刺探防范1
- ››webqq 最新加密算法
- ››webdriver 数据库验证方法
- ››服务层
- ››WebSphere Application Server 7.0 XML Feature P...
- ››Web2.0网络时代基于社会影响力的声望值
- ››Web服务器搭建:配置Linux+Apache+Mysql+PHP(或Pe...
- ››WebLogic调整Java虚拟机性能优化参数
- ››webqq2.0协议研究(3)-ClientId生成
- ››Web.config配置文件
- ››WebBrowser组件的execWB方法——Delphi控制浏览器...
更多精彩
赞助商链接