2016-10-17 2 views
0

프레임 워크 구현 Felix 5.4를 통해 OSGi를 사용하고 있습니다. 현재 OSGi 프레임 워크에 응용 프로그램 서버를 번들로 설치하려고합니다. 저는 Pax-web을 보았습니다. 그것은 나를위한 완벽한 해결책으로 보입니다. 성공적으로 필요한 모든 번들을 시작한 후 그러나,이 소프트웨어는 다음과 같은 오류로 불평 :Pax-Web을 시작할 수 없습니다.

org.ops4j.pax.web.pax-web-jetty-bundle[org.ops4j.pax.web.service.internal.Activator] : Unable to start pax web server: Exception while starting Jetty 
java.lang.RuntimeException: Exception while starting Jetty 
     at org.ops4j.pax.web.service.jetty.internal.JettyServerImpl.start(JettyServerImpl.java:188) 
     at org.ops4j.pax.web.service.jetty.internal.ServerControllerImpl$Stopped.start(ServerControllerImpl.java:415) 
     at org.ops4j.pax.web.service.jetty.internal.ServerControllerImpl.start(ServerControllerImpl.java:71) 
     at org.ops4j.pax.web.service.jetty.internal.ServerControllerImpl$Unconfigured.configure(ServerControllerImpl.java:707) 
     at org.ops4j.pax.web.service.jetty.internal.ServerControllerImpl.configure(ServerControllerImpl.java:87) 
     at org.ops4j.pax.web.service.internal.Activator.updateController(Activator.java:353) 
     at org.ops4j.pax.web.service.internal.Activator$3.run(Activator.java:295) 
     at java.util.concurrent.Executors$RunnableAdapter.call(Unknown Source) 
     at java.util.concurrent.FutureTask.run(Unknown Source) 
     at java.util.concurrent.ThreadPoolExecutor.runWorker(Unknown Source) 
     at java.util.concurrent.ThreadPoolExecutor$Worker.run(Unknown Source) 
     at java.lang.Thread.run(Unknown Source) 
Caused by: java.lang.reflect.InvocationTargetException 
     at sun.reflect.NativeMethodAccessorImpl.invoke0(Native Method) 
     at sun.reflect.NativeMethodAccessorImpl.invoke(Unknown Source) 
     at sun.reflect.DelegatingMethodAccessorImpl.invoke(Unknown Source) 
     at java.lang.reflect.Method.invoke(Unknown Source) 
     at org.ops4j.pax.web.service.jetty.internal.JettyServerImpl.start(JettyServerImpl.java:151) 
     ... 11 more 
Caused by: java.lang.NoSuchMethodException: class org.eclipse.jetty.server.HttpConfiguration.setMaxErrorDispatches(class java.lang.String) 
     at org.eclipse.jetty.xml.XmlConfiguration$JettyXmlConfiguration.set(XmlConfiguration.java:582) 
     at org.eclipse.jetty.xml.XmlConfiguration$JettyXmlConfiguration.configure(XmlConfiguration.java:411) 
     at org.eclipse.jetty.xml.XmlConfiguration$JettyXmlConfiguration.newObj(XmlConfiguration.java:815) 
     at org.eclipse.jetty.xml.XmlConfiguration$JettyXmlConfiguration.configure(XmlConfiguration.java:423) 
     at org.eclipse.jetty.xml.XmlConfiguration$JettyXmlConfiguration.configure(XmlConfiguration.java:298) 
     at org.eclipse.jetty.xml.XmlConfiguration.configure(XmlConfiguration.java:248) 
     ... 16 more 

오류 살펴보면, 일부 부두 구성이 인원 내장 부두 버전에서 사용할 수없는 것으로 보인다. 특히 maxErrorDispatches, blockingTimeoutpersistentConnectionsEnabled은 오류를 발생시킵니다.

org.ops4j.pax.web.pax-web-jetty-bundle[org.ops4j.pax.web.service.internal.ConfigurationImpl] : Reading configuration property org.ops4j.pax.web.config.url has failed

나는이 문제를 해결하기 위해 시도했다 : 그러나, 이들 3 곳을 주석, 팍스 - 웹은 일부 로그 후, 간단하게 인쇄됩니다 시작 (127.0.0.1에 연결할 수 없습니다) 및하지 않습니다 문제는 아니지만 OSGi와 Jetty 모두 전문가가 아니기 때문에 해결책이 없었습니다. 내 시나리오에 상황을 추가하려면 다음과 같은 추가 정보가 필요합니다.

  • 나는 펠릭스 5.4를 사용하고 있습니다.
  • Windows 10 64 비트를 사용하고 있습니다.
  • jetty.xml i conf/bin/felix 폴더의 동일한 디렉토리에 있습니다.
  • 설치 java -jar bin\felix.jar

번들을 통해 발사 펠릭스 :

lb 
START LEVEL 1 
    ID|State  |Level|Name 
    0|Active  | 0|System Bundle (5.6.0)|5.6.0 
    1|Active  | 1|ASM (5.1.0)|5.1.0 
    2|Active  | 1|ASM commons classes (5.1.0)|5.1.0 
    3|Active  | 1|ASM Tree class visitor (5.1.0)|5.1.0 
    4|Active  | 1|javax.servlet API v.3.0 (3.0.0.SNAPSHOT)|3.0.0.SNAPSHOT 
    5|Active  | 1|Apache Felix Bundle Repository (2.0.8)|2.0.8 
    6|Active  | 1|Apache Felix Gogo Command (0.16.0)|0.16.0 
    7|Active  | 1|Apache Felix Gogo Runtime (0.16.2)|0.16.2 
    8|Active  | 1|Apache Felix Gogo Shell (0.10.0)|0.10.0 
    9|Active  | 1|osgi (3.0.0)|3.0.0 
    10|Active  | 1|OPS4J Pax Logging - API (1.9.0)|1.9.0 
    11|Active  | 1|OPS4J Pax Web - API (4.3.0)|4.3.0 
    12|Active  | 1|OPS4J Pax Web - Extender - WAR (4.3.0)|4.3.0 
    13|Active  | 1|OPS4J Pax Web - Jetty Bundle (4.3.0)|4.3.0 
    14|Active  | 1|OPS4J Pax Web - Jsp Support (4.3.0)|4.3.0 
    15|Active  | 1|OPS4J Pax Web - Service SPI (4.3.0)|4.3.0 
    16|Active  | 1|Apache XBean OSGI Bundle Utilities (4.5.0)|4.5.0 
    17|Active  | 1|Apache XBean :: Classpath Resource Finder (4.5.0)|4.5.0 
(코멘트에서 제거)

config.properties :

org.osgi.framework.system.packages.extra=org.apache.juli.logging 

org.osgi.framework.bootdelegation=sun.*,com.sun.* 

org.osgi.framework.storage.clean=onFirstInit 

felix.auto.deploy.action=install,start 

felix.auto.deploy.dir=pax 

felix.log.level=1 

org.osgi.framework.startlevel.beginning=1 

felix.startlevel.bundle=1 

org.osgi.service.http.port=8080 
obr.repository.url=http://felix.apache.org/obr/releases.xml 

org.ops4j.pax.web.config.file=jetty.xml 

부두 구성 (코멘트없이) :

<?xml version="1.0"?> 
<?xml version="1.0"?> 
<!DOCTYPE Configure PUBLIC "-//Jetty//Configure//EN" "http://www.eclipse.org/jetty/configure_9_3.dtd"> 

<Configure id="Server" class="org.eclipse.jetty.server.Server"> 

    <Get name="ThreadPool"> 
     <Set name="minThreads" type="int"><Property name="jetty.threadPool.minThreads" deprecated="threads.min" default="10"/></Set> 
     <Set name="maxThreads" type="int"><Property name="jetty.threadPool.maxThreads" deprecated="threads.max" default="200"/></Set> 
     <Set name="idleTimeout" type="int"><Property name="jetty.threadPool.idleTimeout" deprecated="threads.timeout" default="60000"/></Set> 
     <Set name="detailedDump">false</Set> 
    </Get> 

    <Call name="addBean"> 
     <Arg> 
     <New class="org.eclipse.jetty.util.thread.ScheduledExecutorScheduler"/> 
     </Arg> 
    </Call> 

    <New id="httpConfig" class="org.eclipse.jetty.server.HttpConfiguration"> 
     <Set name="secureScheme"><Property name="jetty.httpConfig.secureScheme" default="https" /></Set> 
     <Set name="securePort"><Property name="jetty.httpConfig.securePort" deprecated="jetty.secure.port" default="8443" /></Set> 
     <Set name="outputBufferSize"><Property name="jetty.httpConfig.outputBufferSize" deprecated="jetty.output.buffer.size" default="32768" /></Set> 
     <Set name="outputAggregationSize"><Property name="jetty.httpConfig.outputAggregationSize" deprecated="jetty.output.aggregation.size" default="8192" /></Set> 
     <Set name="requestHeaderSize"><Property name="jetty.httpConfig.requestHeaderSize" deprecated="jetty.request.header.size" default="8192" /></Set> 
     <Set name="responseHeaderSize"><Property name="jetty.httpConfig.responseHeaderSize" deprecated="jetty.response.header.size" default="8192" /></Set> 
     <Set name="sendServerVersion"><Property name="jetty.httpConfig.sendServerVersion" deprecated="jetty.send.server.version" default="true" /></Set> 
     <Set name="sendDateHeader"><Property name="jetty.httpConfig.sendDateHeader" deprecated="jetty.send.date.header" default="false" /></Set> 
     <Set name="headerCacheSize"><Property name="jetty.httpConfig.headerCacheSize" default="512" /></Set> 
     <Set name="delayDispatchUntilContent"><Property name="jetty.httpConfig.delayDispatchUntilContent" deprecated="jetty.delayDispatchUntilContent" default="true"/></Set> 
     <Set name="maxErrorDispatches"><Property name="jetty.httpConfig.maxErrorDispatches" default="10"/></Set> 
     <Set name="blockingTimeout"><Property name="jetty.httpConfig.blockingTimeout" default="-1"/></Set> 
     <Set name="persistentConnectionsEnabled"><Property name="jetty.httpConfig.persistentConnectionsEnabled" default="true"/></Set> 
    </New> 

    <Set name="handler"> 
     <New id="Handlers" class="org.eclipse.jetty.server.handler.HandlerCollection"> 
     <Set name="handlers"> 
     <Array type="org.eclipse.jetty.server.Handler"> 
      <Item> 
      <New id="Contexts" class="org.eclipse.jetty.server.handler.ContextHandlerCollection"/> 
      </Item> 
      <Item> 
      <New id="DefaultHandler" class="org.eclipse.jetty.server.handler.DefaultHandler"/> 
      </Item> 
     </Array> 
     </Set> 
     </New> 
    </Set> 

    <Set name="stopAtShutdown"><Property name="jetty.server.stopAtShutdown" default="true"/></Set> 
    <Set name="stopTimeout"><Property name="jetty.server.stopTimeout" default="5000"/></Set> 
    <Set name="dumpAfterStart"><Property name="jetty.server.dumpAfterStart" deprecated="jetty.dump.start" default="false"/></Set> 
    <Set name="dumpBeforeStop"><Property name="jetty.server.dumpBeforeStop" deprecated="jetty.dump.stop" default="false"/></Set> 

</Configure> 
+0

어떤 부두 버전을 사용하십니까? 번들 목록에 부두가 표시되지 않습니다. –

+0

@ChristianSchneider : 지금은 "pax-web-jetty-bundle"버전 4.3.0을 사용하고 있습니다. 항아리 내부를 살펴보면 Jetty가 내장되어 있음을 알았습니다.이 번들의 매니페스트에는 org.eclipse.jetty; version = "9.2.19.v20160908"과 같은 내보내기 패키지 항목이 들어 있습니다. 나는 9.2의 부두 판을 사용하고 있다고 추론한다. 내가 잘못? – Koldar

답변

0

귀하의 부두 버전이 pax 웹 버전과 일치하는 것 같습니다. 그래서 이것이 문제가되어서는 안됩니다.

Apache karaf 4.0.7에서 pax web을 테스트했습니다. pax-web 4.3.0과 jetty 9.2.1도 사용됩니다. Karaf는 개개의 부두 묶음을 사용합니다.

그래서 pax-web-jetty-bundle에 오류가있는 것으로 의심됩니다. ops4j에서 jira 문제를 열 ​​수 있습니까?

이제 문제를 해결하려면 Apache karaf에서 사용하는 것과 동일한 번들을 설치해야합니다. karaf 4.0.7을 다운로드하여 시작하고 기능을 수행하십시오. http를 설치하십시오.

그런 다음 la -u를 사용하여 번들을 확인하십시오. 동일한 번들을 사용한다면 그것은 당신을 위해서도 효과가 있습니다.