2013-01-15 25 views
5

oracle-ds.xmlという名前のデータソースxmlファイルをJBoss 7.1のフォルダに追加しようとしています。そのため、そのサーバにデプロイするプロジェクトでそのデータソースを使用できるようになりました。Jboss 7.1にdatasource.xmlをデプロイ

jboss.orgで説明したように、そのファイルをdeploymentsフォルダに配置する必要があります。

私は何をしましたか?しかし、上記のリンクで言われたこととは異なり、私は自分のOrcaleドライバjarをローカルMavenリポジトリに持っています。とにかく、mavenはプロジェクトをビルドすることができます。

私は、JBossを再起動すると、それが展開する必要がプロジェクト(JAR)としてoracle-ds.xmlについて同様に今、それがないファイルを設定するXMLとして、そうです...

ここでは、JBoss中にコンソール出力の一部であります'再起動:

15:58:16,666 INFO [org.jboss.as.server.deployment] (MSC service thread 1-3) JBAS015876: Starting deployment of "oracle-ds.xml" 
15:58:16,728 ERROR [org.jboss.msc.service.fail] (MSC service thread 1-8) MSC00001: Failed to start service jboss.deployment.unit."oracle-ds.xml".PARSE: org.jboss.msc.se 
rvice.StartException in service jboss.deployment.unit."oracle-ds.xml".PARSE: Failed to process phase PARSE of deployment "oracle-ds.xml" 
     at org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:119) [jboss-as-server-7.1.0.Final.jar:7.1.0.Final] 
     at org.jboss.msc.service.ServiceControllerImpl$StartTask.startService(ServiceControllerImpl.java:1811) [jboss-msc-1.0.2.GA.jar:1.0.2.GA] 
     at org.jboss.msc.service.ServiceControllerImpl$StartTask.run(ServiceControllerImpl.java:1746) [jboss-msc-1.0.2.GA.jar:1.0.2.GA] 
     at java.util.concurrent.ThreadPoolExecutor$Worker.runTask(ThreadPoolExecutor.java:886) [rt.jar:1.6.0_29] 
     at java.util.concurrent.ThreadPoolExecutor$Worker.run(ThreadPoolExecutor.java:908) [rt.jar:1.6.0_29] 
     at java.lang.Thread.run(Thread.java:662) [rt.jar:1.6.0_29] 
Caused by: org.jboss.as.server.deployment.DeploymentUnitProcessingException: IJ010061: Unexpected element: local-tx-datasource 
     at org.jboss.as.connector.deployers.processors.DsXmlDeploymentParsingProcessor.deploy(DsXmlDeploymentParsingProcessor.java:85) 
     at org.jboss.as.server.deployment.DeploymentUnitPhaseService.start(DeploymentUnitPhaseService.java:113) [jboss-as-server-7.1.0.Final.jar:7.1.0.Final] 
     ... 5 more 
Caused by: org.jboss.jca.common.metadata.ParserException: IJ010061: Unexpected element: local-tx-datasource 
     at org.jboss.jca.common.metadata.ds.DsParser.parseDataSources(DsParser.java:183) 
     at org.jboss.jca.common.metadata.ds.DsParser.parse(DsParser.java:119) 
     at org.jboss.jca.common.metadata.ds.DsParser.parse(DsParser.java:82) 
     at org.jboss.as.connector.deployers.processors.DsXmlDeploymentParsingProcessor.deploy(DsXmlDeploymentParsingProcessor.java:80) 
     ... 6 more 

なぜこの現象が発生するのですか?

答えて

6

oracle-ds.xmlstandalone\deploymentsにコピーすることは、それを展開する正しい方法です。独立したxmlファイルではなく、standalone.xmlまたは管理コンソールまたはCLIでデータソースを定義することをお勧めします。

ここでの問題は、oracle-ds.xmlがXSD検証に失敗していることです。データソースxmlのXSDを見ると、XSDにはlocal-tx-datasource要素がないことがわかります。

これを解決するには、XMLファイルがXSD検証に合格していることを確認する必要があります。または、管理コンソールまたはCLIを使用してデータソースを定義し、手動で作成してこれらのタイプの問題にぶつからないようにすることもできます。

+0

ありがとうございます。現在のXMLで検証を実行するにはどうすればよいですか? – rapt

+2

Eclipse XSD検証ツールを使用できます。 – CoolBeans

+1

@rapt答えがあなたを助けた場合upvoteして受け入れてください。ありがとうございました! – CoolBeans

関連する問題