jUDDI 简单安装使用
发表于:2007-07-01来源:作者:点击数:
标签:
来源:http://xio.mblogger.cn jUDDI,发音(Judy),是服务于WebServices 的UDDI的 java 实现 开源 包。 1 安装1.1 下载下载地址:http://ws.apache.org/juddi/releases.html 目前的jUDDI的最新版本是0.9rc3(Release Candidate #3 for Version 0.9),不过
来源:http://xio.mblogger.cn
jUDDI,发音(Judy),是服务于WebServices 的UDDI的
java实现
开源包。 1 安装1.1 下载下载地址:http://ws.apache.org/juddi/releases.html 目前的jUDDI的最新版本是0.9rc3(Release Candidate #3 for Version 0.9),不过在这个版本中有一些的
bug。 juddi0.9版本发布应该是不会久,可以参考下面这段话,是Viens Stephen(juddi主要
开发者之一)在mail list中说的:we@#ve closed 40+ issues since January 1, 2005. We@#ll be releasing a 0.9rc4 as soon as Axis 1.2 final is released and then releasing a 0.9 final a few weeks after that. (March 22, 2005) 1.2
数据库安装UDDI需要有一个地方来存储注册的数据,因此首先要选择一个关系数据库安装。JUDDI可以使用任何支持ANSI standard SQL关系数据库( 例如MySQL, DB2, Sybase, JdataStore等)。本实例使用MySQL。 数据库安装完成后,在MySQL数据库中运行juddi-0.9rc3 ql\mysql\create_database.sql, juddi-0.9rc3 ql\mysql\insert_publishers.sql。数据库准备完成。 1.3 安装juddi及配置首先将juddi-0.9rc3\webapp下的juddi文件夹复制到
Tomcat下的webapps中,并将 mysql-connector-java-3.1.7\mysql-connector-java-3.1.7-bin.jar复制到Tomcat 5.0\webapps\juddi\WEB-INF\lib下。 下面就是连接数据库的配置,在Tomcat/conf/server.xml的Host element中加入:
<Context path="/juddi" docBase="juddi" debug="5" reloadable="true" crossContext="true"> <Logger className="org.apache.catalina.logger.FileLogger" prefix="localhost_juddiDB_log" suffix=".txt" timestamp="true"/> <Resource name="jdbc/juddiDB" auth="Container" type="javax.sql.DataSource"/> <ResourceParams name="jdbc/juddiDB"> <parameter> <name>factory</name> <value>org.apache.commons.dbcp.BasicDataSourceFactory</value> </parameter> <!-- Maximum number of dB connections in pool. Make sure you configure your mysqld max_connections large enough to handle all of your db connections. Set to 0 for no limit. --> <parameter><name>maxActive</name><value>100</value></parameter> <!-- Maximum number of idle dB connections to retain in pool. Set to 0 for no limit. --> <parameter><name>maxIdle</name><value>30</value></parameter> <parameter><name>maxWait</name><value>10000</value></parameter> <!-- MySQL dB username and password for dB connections 帐号密码根据数据库安装配置修改 --> <parameter><name>username</name><value>root</value></parameter> <parameter><name>password</name><value>****</value></parameter> <!-- Class name for mysql JDBC driver --> <parameter> <name>driverClassName</name> <value>com.mysql.jdbc.Driver</value> </parameter> <!-- The JDBC connection url for connecting to your MySQL dB. The autoReconnect=true argument to the url makes sure that the mm.mysql JDBC Driver will automatically reconnect if mysqld closed the connection. mysqld by default closes idle connections after 8 hours. 数据库url连接配置 --> <parameter> <name>url</name> <value>jdbc:mysql://host.domain.com:3306/juddi?autoReconnect=true</value> </parameter> <parameter> <name>validationQuery</name> <value>select count(*) from PUBLISHER</value> </parameter> </ResourceParams></Context>
1.4 本地安装检查访问http://127.0.0.1:8080/juddi/happyjuddi.jsp页面,此页面检查了jUDDI所必须的包和配置的正确性,并
测试数据库连接是否成功。 如果没有红色文字,即本地安装成功,即可进行webservices的发布发现等服务。 2 测试实例以上安装成功的是UDDI的
服务器端,而进行发布、查找服务的客户端的应用则要用jUDDI、UDDI4J等包来进行开发。我们可以直接使用jUDDI自 带的测试代码来进行客户端使用的学习。 2.1 使用uddi4j测试使用uddi4j作为客户端进行测试。 代码位置:juddi-0.9rc3 rc\uddi4j\org\apache\juddi\uddi4j 新建立好一个工程并引入此代码,然后对代码进行必要的修改,主要是包名和配置。引入必要的包,比如:
junit.jar、 uddi4j.jar、juddi.jar、
soap.jar等(因为欧的代码库中有很多种代码,对应很多包,不知道其他哪些是必须的了:)。 接着是数据库的初始化,需要插入一个可以添加其他Publisher的Publisher,sql 语句: INSERT INTO PUBLISHER (PUBLISHER_ID,PUBLISHER_NAME,ENABLIED,AD
MIN) VALUES (@#juddi@#,@#juddi user@#,@#true@#,@#true@#); 调试代码后,运行TestAll测试,您可能会发现测试FAILURE很多,这些当中有些是测试代码的错误,也有可能是juddi-0.9rc3的
缺陷( juddi-0.9rc3不是正式发布版)。 以下列举一些本
测试案例测试失败的可能出现的修改方法: 2.1.1 加载配置文件时访问不到samples.prop我的解决办法是将建立一个新配置文件位置,在工程目录下的:conf amples.prop。 在Configurator.load()方法中代码可以这样修改:
Properties config = new Properties(); try { config.load(new java.io.FileInputStream("./conf/samples.prop")); } catch (Exception e) { System.out.println("Error loading samples property file\n" + e); }
解决方法很多,您可以自己思索。 2.1.2 TransportClassName配置错误如果错误提示中有这样的报告,即可能是此错误: org.xml.sax.SA
XParseException: Element or attribute do not match QName production: QName::=(NCName@#:@#)?NCName. 在当前测试实例代码中的默认配置(samples.prop)中,TransportClassName定义成org.uddi4j.transport.Apache
SOAPTransport, 而我们使用的包是axis.jar,因此需要修改成相应的类,代码修改如下:
# -----------------------------------------------------------------------# Transport classname. Typically defined on commandline as# -Dorg.uddi4j.TransportClassName=xxx.# -----------------------------------------------------------------------#TransportClassName=org.uddi4j.transport.ApacheSOAPTransport TransportClassName=org.uddi4j.transport.ApacheAxisTransport# TransportClassName=org.uddi4j.transport.HPSOAPTransport
2.1.3 TestFindBusiness案例不通过TestFindBusiness中有大小写匹配测试,但是在juddi-0.9rc3中的大小写匹配(caseSensitiveMatch)有bug,因此可以将大小写匹配的测 试案例注释掉。 2.1.4 PublisherManager的代码错误在测试Test_save_tModel的时候_testAuthTokenExpired()中,我们测试过期验证时,在错误匹配的时候,会出现测试失败,如果捕捉这个 匹配的结果,你会发现,出错的类型是E_authTokenRequired而不是期待的E_authTokenExpired。 这是因为在我们所获得的AuthToken是空的,在根源就是在PublisherManager. getExpiredAuthToken(String, String)方法中,代码:
RegistryProxy proxy = new RegistryProxy();
proxy的实例的配置是空的。因此,我们修改这个方法变成:
/** * changed by xio * @param publisher String * @param password String * @param testprops Properties:增加的参数,传入基本配置 * @return String */public static String getExpiredAuthToken(String publisher, String password, Properties testprops) { Properties props = new Properties(); props.setProperty(RegistryProxy.ADMIN_ENDPOINT_PROPERTY_NAME, testprops.getProperty("adminURL")); props.setProperty(RegistryProxy.INQUIRY_ENDPOINT_PROPERTY_NAME, testprops.getProperty("inquiryURL")); props.setProperty(RegistryProxy.PUBLISH_ENDPOINT_PROPERTY_NAME, testprops.getProperty("publishURL")); RegistryProxy proxy = new RegistryProxy(props); AuthToken token = null; AuthInfo authInfo = null; String ret = null; try { token = proxy.getAuthToken(publisher, password); authInfo = token.getAuthInfo(); ret = authInfo.getValue(); System.out.println("getExpiredAuthToken:" + authInfo); proxy.discardAuthToken(authInfo); } catch (Exception ex) { ex.printStackTrace(); } return ret; }
2.2 使用jUDDI测试在juddi-0.9rc3版本中自带的代码中没有客户端的使用实例,虽然附带了整个项目代码的测试代码,但是估计没什么人喜欢从这里抽取学 习客户端使用的学习。 当然,学习的实例还是有的,在cvs当前的工程代码中,有个samples的文件夹,这部分代码便是一个十分齐全的实例(有几个类没完成, 但不影响:)。 Cvs服务器数据:http://ws.apache.org/juddi/cvs.html Wincvs的使用请网上下载阅读。 其他:在进行代码学习的同时,建议阅读webservices相关资料文档。强烈建议阅读:理解 UDDI 注册中心的 WSDL 系列 (http://www-900.ibm.com/developerWorks/cn/webservices/ws-uwsdl/part1/) 参考资料:http://wiki.apache.org/ws/jUDDI_HOW-TOs http://ws.apache.org/juddi/lists.html
原作者:xio@qq.com来 源:http://xio.mblogger.cn
原文转自:http://www.ltesting.net