OSGiベースのアプリケーションに正常なシャットダウンフックを実装しようとしています。ランチャーソースに直接アクセスできないため、バンドルに実装しています。メソッドにパラメータがある場合、OSGi @Activateはブレークします。エラー:メソッドを検出できません。コンポーネントが失敗する
/**
* Shutdown Hook for OSGi
* Based On: https://stackoverflow.com/a/32216407/5284104
*/
@Component()
public class ShutdownHookActivator{
@Activate
public void start(ComponentContext cc, BundleContext bc, Map<String,Object> config) {
Thread hook = new Thread() {
@Override
public void run() {
System.out.println("Stopping OSGi Framework.");
try {
Framework systemBundle = bc.getBundle(0).adapt(Framework.class);
systemBundle.stop();
System.out.println("Waiting up to 2s for OSGi shutdown to complete...");
systemBundle.waitForStop(2000);
} catch (Exception e) {
System.err.println("Failed to cleanly shutdown OSGi Framework: " + e.getMessage());
e.printStackTrace();
}
}
};
System.out.println("Installing shutdown hook.");
Runtime.getRuntime().addShutdownHook(hook);
}
}
しかし、私はそれを起動するたびに、エラーが返されます:ここで
はクラスがある
ERROR: [ShutdownHookActivator(8)] activate method [start] not found; Component will fail
をしかし、私は開始メソッドからパラメータを削除すると、その後すべての作品。ですから、私は混乱しています。@ActivateメソッドがOSGiフレームワーク(http://enroute.osgi.org/services/org.osgi.service.component.html)によって自動注入されるパラメータを持っていて、これがうまくいくとわかっているので、ただ空の他の例を見てきました。 (OSGiのように感じるのは運が大好きです)
DSアノテーションを使用してFramework BundleContextを取得する適切な方法は何ですか?それも可能ですか?
EDIT: のOSGi環境: BndTools(?aQuteランチャー) ApacheのフェリックスSCR 2.0.12(OSGiのDS注釈 - 6.0.1)が ソースはここで見ることができます:https://github.com/Jafre13/ISS-Product
EDIT 2: 自動生成ShutdownHookActivator.xml:
<?xml version="1.0" encoding="UTF-8"?>
<scr:component xmlns:scr="http://www.osgi.org/xmlns/scr/v1.3.0" name="dk.sdu.sso.sred.utils.ShutdownHookActivator" activate="start">
<implementation class="dk.sdu.sso.sred.utils.ShutdownHookActivator"/>
</scr:component>
マニフェスト:
Manifest-Version: 1.0
Bnd-LastModified: 1512410080758
Bundle-ManifestVersion: 2
Bundle-Name: dk.sdu.sso.sred
Bundle-SymbolicName: dk.sdu.sso.sred
Bundle-Version: 0.0.0.201712041754
Created-By: 1.8.0_151 (Oracle Corporation)
Import-Package: javax.security.auth.x500,junit.framework,org.junit,org
.xml.sax,org.xml.sax.ext,org.xml.sax.helpers
Private-Package: dk.sdu.sso.sred.cmd,dk.sdu.sso.sred.lingpipe,dk.sdu.s
so.sred.api;version="1.0.0",dk.sdu.sso.sred,com.aliasi.test.unit.xml,
com.aliasi.test.unit.io,com.aliasi.suffixarray,com.aliasi.test.unit.u
til,com.aliasi.test.unit.crf,com.aliasi.matrix,com.aliasi.test.unit.s
entences,com.aliasi.test.unit,com.aliasi.tag,com.aliasi.test.unit.hmm
,com.aliasi.chunk,com.aliasi.coref,com.aliasi.spell,com.aliasi.test.u
nit.chunk,com.aliasi.test.unit.features,com.aliasi.coref.matchers,com
.aliasi.lm,com.aliasi.test.unit.coref,com.aliasi.cluster,com.aliasi.f
eatures,com.aliasi.test.unit.symbol,com.aliasi.io,com.aliasi.test.uni
t.tokenizer,com.aliasi.sentences,com.aliasi.test.unit.coref.matchers,
com.aliasi.test.unit.spell,com.aliasi.test.unit.corpus,com.aliasi.uti
l,com.aliasi.dca,com.aliasi.symbol,com.aliasi.test.unit.lm,com.aliasi
.dict,com.aliasi.test.unit.tag,com.aliasi.corpus,com.aliasi.classify,
com.aliasi.test.unit.dca,com.aliasi.tokenizer,com.aliasi.test.unit.cl
assify,com.aliasi.crf,com.aliasi.test.unit.cluster,com.aliasi.stats,c
om.aliasi.test.unit.stats,com.aliasi.test.unit.dict,com.aliasi.test.u
nit.matrix,com.aliasi.test.unit.suffixarray,com.aliasi.xml,com.aliasi
.hmm,dk.sdu.sso.sred.utils,org.apache.felix.service.command,org.osgi.
framework;version="1.8",org.osgi.service.component;version="1.3"
Provide-Capability: osgi.service;objectClass:List<String>="dk.sdu.sso.
sred.api.SRedAPI",osgi.service;objectClass:List<String>="dk.sdu.sso.s
red.cmd.ModelCommands",osgi.service;objectClass:List<String>="dk.sdu.
sso.sred.cmd.SRedCommands"
Require-Capability: osgi.extender;filter:="(&(osgi.extender=osgi.compo
nent)(version>=1.3.0)(!(version>=2.0.0)))",osgi.ee;filter:="(&(osgi.e
e=JavaSE)(version=1.8))"
Service-Component: OSGI-INF/dk.sdu.sso.sred.SRed.xml,OSGI-INF/dk.sdu.s
so.sred.cmd.ModelCommands.xml,OSGI-INF/dk.sdu.sso.sred.cmd.SRedComman
ds.xml,OSGI-INF/dk.sdu.sso.sred.utils.ShutdownHookActivator.xml
Tool: Bnd-3.5.0.201709291849
ビルド時にどのバージョンのDS仕様を使用しますか?実行時に使用するscrのバージョンは何ですか? –
@ChristianSchneider DS仕様は6.0.1です。 SCRランタイムは2.0.12です。 –
それはかなり古いですので、私は古いバージョンから生じる問題は期待していません。おそらく、すべてのパラメータが同時にサポートされているとは限りません。 –