Aspekte (LTW) mit Spring-DM und OSGI

fkh

Mitglied
Hallo Gemeinde,

ich hoffe dass ist das richtige Forenbereich für meine Frage. Ich entwickle derzeit mit Spring, Spring-DM und Equinox eine Anwendung. Nun würde ich gerne AspectJ bzw. AOP allgemein einsetzen, um bestimmte technische Anforderungen damit abzuhandeln, bin mir aber nicht sicher, was dort jetzt der beste Ansatz ist. Compile-Time-Weaving scheidet eigentlich aus, da zusätzliche Aspekte sich über die Zeit hin entwickeln werden und ich dann jedes bereits deployte Bundle anfassen müsste, damit neue Aspekte via CTW in diese Bundles einfließen. Daher wäre mein präferierter Ansatz LTW, um so auch nachträglich Aspekte auf Bundles anzuwenden. Kurze Zwischenfrage an die Experten hier: wenn ich LTW richtig verstanden habe, ist das Vorhaben so ja möglich oder? Also speziell auch der beschriebene dynamische Charakter, mit dem aspekte eingesetzt werden sollen (neue Aspekte auf bestehende Bundles anwenden, Aspekte auf neu deployte bundles anwenden etc.)

Ich hab von Equinox Aspects gelesen, welches LTW mit AspectJ innerhalb eines OSGI-Containers ermöglicht. Allerdings ist das letzte Release (ein Milestone) bereits ein paar Monate alt und das ganze Projekt macht nicht gerade einen aktiven Eindruck (das letzte was ich davon gehört habe war Eclipse weaving, das in irgendeiner Weise in Eclipse 3.6 einfließen soll. Auf der anderen Seite habe ich gelesen, dass der Spring DM Server sowas ebenfalls ermöglichen soll (wobei ich gerne so lange wie möglich Unabhängig von einem bestimmten OSGI-Container bleiben möchte, zumal man bei Spring DM Server jetzt auch erstmal abwarten sollte wie sich das mit der Überführung in Eclipse Virgo verhalten wird). Letztlich gibts noch den ganz normalen AOP Support durch das Spring Framework selbst. Ist der in einer OSGI-Umgebung für meine Anforderungen nutzbar?

Wisst ihr einen Weg, wie man Aspekte global auf alle Bundles innerhalb eines OSGI-Containers anwenden kann? Ideal wäre ein dynamischer Ansatz, ohne jedes bereits deployte Bundle nochmal anfassen zu müssen (siehe die Aufzählung bei der Zwischenfrage oben)?

Vielen Dank für eure Hilfe

fkh
 
Zuletzt bearbeitet:

FArt

Top Contributor
Selten so gut gestellte Fragen gelesen :)

Leider ist mein Wissen an dieser Stelle sehr bescheiden. So nah am Puls der Zeit entwickel ich noch nicht. Das hat zwei Gründe: man kann mit AOP und LTW viele tolle Sachen machen... bis hin zu untestbarem Code, was letztendlich zu schlechter Softwarequalität führt. Deshalt würde ich diese Technik nur sehr sparsam einsetzen. Das zweite ist, dass die Framworks noch nicht wirklich abgehangen sind für den produktiven Einsatz.... aber ein Blick ist es sicher wert.

Zu den Fragen:
Meine (bescheidenen) Kenntnisse zu LTW in obiger Konstellation decken sich mit deinen, d.h. ich denke, dass es möglich sein sollte. Der reine Spring-AOP Support ist mit AspectJ nicht zu vergleichen. Spring bietet hier lediglich den Eingriff über dynamische Proxies an, das ist nur AOP-light. Den Rest kann ich nicht beantworten.

Tipp: fange mal schnell mit einem proof of concept an... das sollte dich auf jeden Fall weiter bringen oder auf konkrete Probleme stoßen lassen, denen man dann nachgehen kann...
 

fkh

Mitglied
Selten so gut gestellte Fragen gelesen :)

Ich versuch halt so gut es geht die Problemstellung zu beschreiben. Ist ja auch in meinem Interesse, wenn die Leute wissen, wo mein Schuh drückt und nicht noch nachfragen müssen ;)

Zum Problem

Ich werde mein Glück mal mit Equinox Aspects versuchen und euch über den Fortschritt auf dem laufenden halten.

Ansonsten wenn jemand weitere Infos oder Tips hat, bin ich natürlich dankbar drum.

Viele Grüße & schönes Wochenende

fkh
 

fkh

Mitglied
Anbei mal ein kleines Zwischenergebnis (für die unter euch, die es interessiert)

Also Equinox Aspects funktioniert soweit mit AspectJ und LTW ziemlich gut (habe hier ein Equinox 3.5.1 SDK laufen, gestartet wird aus STS 2.3.0.RELEASE mit nem Eclipse 3.5.1 darunter, also alles recht aktuell). Zur Stabilität kann ich natürlich noch nichts sagen, da ich derzeit erst noch damit rumspiele (aber anscheinend soll die Allianz das in einem "mission critial" Projekt einsetzen, was mich aber etwas verwundert da es ja nur Milestones und Dev Builds bisher gibt aber nunja). Auch die Möglichkeit, die Aspekte in zwei Richtungen einbinden zu können ist sehr gut:

+ Entweder gibt man im Aspect-Bundle die Bundles an, in die die Aspekte eingewoben werden sollen (das geschieht über den Eintrag Eclipse-SupplementBundle).

Code:
Eclipse-SupplementBundle: org.example.bundles.*

+ Oder aber die Bundles importieren das package mit den Aspekten (lt. Quick guide soll require bundle genutzt werden, aber bei mir funktioniert es auch mit import package)

Code:
Import-Package: org.example.aspects

Unter Equinox Aspects – Quick-start guide gibts den Quick start für diejenigen von euch, die das ganze interessiert. Einzig für den Start und das Deployment bevorzuge ich persönlich einen anderen Weg als in dem Guide angegeben (ich setz mir in den Preferences meine Target platform und konfiguriere das ganze später über Run configurations - OSGI Framework), aber da sind Geschmäcker bekanntlich ja verschieden.

Es gibt lt. Springforum auch noch die Möglichkeit, das ganze mit Spring zu verknüpfen, indem man eine springweaver-Bibliothek nutzt. Das werde ich mir bei nächster Gelegenheit mal anschauen und euch weiter auf dem laufenden halten ;)

man kann mit AOP und LTW viele tolle Sachen machen... bis hin zu untestbarem Code, was letztendlich zu schlechter Softwarequalität führt. Deshalt würde ich diese Technik nur sehr sparsam einsetzen.

Primär untersuche ich das ganze deshalb, weil ich gerne das ganze Logging (speziell auch Exception logging via after throwing) in Aspekte auslagern möchte. Auch Transaktionen und Zugriffsrestriktionen könnte ich mir mit Aspekten gut vorstellen. Ansonsten stimme ich dir aber zu, dass man damit auch viel Schund anstellen kann (wie mit fast allem eigentlich ;))

Gruß
fkh
 
Ähnliche Java Themen
  Titel Forum Antworten Datum
8u3631984 Ist es möglich in Spring Entity generische Listen verwenden Frameworks - Spring, Play, Blade, Vaadin & Co 3
R Spring Boot Test Assertions mit Objekten Frameworks - Spring, Play, Blade, Vaadin & Co 6
8u3631984 Pfad zu Test Datei in application.yml in Spring Boot Test Frameworks - Spring, Play, Blade, Vaadin & Co 7
R Spring Boot sql Beziehungen Frameworks - Spring, Play, Blade, Vaadin & Co 12
8u3631984 Spring JPA Probleme beim SPeichern von Sets Frameworks - Spring, Play, Blade, Vaadin & Co 3
M Spring Boot 3 Datenbanken zur Laufzeit Verbinden Frameworks - Spring, Play, Blade, Vaadin & Co 5
8u3631984 Spring JDBC Probleme beim Spaltennamen Frameworks - Spring, Play, Blade, Vaadin & Co 3
LimDul Spring-Batches in Docker über Rest starten/verfolgen Frameworks - Spring, Play, Blade, Vaadin & Co 0
ExceptionOfExpectation In Meiner Spring-Boot Applikation verlangt die Datenbank Wert für eine ID Frameworks - Spring, Play, Blade, Vaadin & Co 5
H Spring Boot Applikation und JHM Benchmark sowie ContextConfiguration in H2 Tests ich bekomme es nicht hin Frameworks - Spring, Play, Blade, Vaadin & Co 2
ExceptionOfExpectation Tests in Spring-Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
R Eure Erfahrungen mit Primefaces und Spring - wer managed die Beans Frameworks - Spring, Play, Blade, Vaadin & Co 4
Avalon Get Request doppelt abfeuern ohne Post Redirect Get Pattern. Spring Boot Thymeleaf MVC Frameworks - Spring, Play, Blade, Vaadin & Co 12
thor_norsk Konfigurationsprobleme mit Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 9
R Spring Boot Integration-testing mit Keycloak Frameworks - Spring, Play, Blade, Vaadin & Co 1
R Spring Boot Integration-testing mit Keycloak Frameworks - Spring, Play, Blade, Vaadin & Co 13
L Spring Data und Rest Controller? Frameworks - Spring, Play, Blade, Vaadin & Co 4
thor_norsk Spring Boot Fehler Frameworks - Spring, Play, Blade, Vaadin & Co 1
L Spring Data und Rest Conroller? Frameworks - Spring, Play, Blade, Vaadin & Co 4
thor_norsk Spring Boot und Docker Frameworks - Spring, Play, Blade, Vaadin & Co 5
B Spring Amazon-SP-Api Frameworks - Spring, Play, Blade, Vaadin & Co 3
8u3631984 Aktualisiere Spring Controller Frameworks - Spring, Play, Blade, Vaadin & Co 4
L Spring Data: Modellierung mit einer Embeddable bean Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Spring Boot Test ob Validation geprüft wurde Frameworks - Spring, Play, Blade, Vaadin & Co 8
K Spring Boot OneToMany Frameworks - Spring, Play, Blade, Vaadin & Co 6
8u3631984 Spring Boot Docker Image erstellen und mit docker-compose konfigurieren Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Wann Spring Batch nutzen? Frameworks - Spring, Play, Blade, Vaadin & Co 1
P Spring Hessian Remote Beispiel Frameworks - Spring, Play, Blade, Vaadin & Co 20
8u3631984 Spring 2.7.8 Info Enpoint nicht zuerreichen Frameworks - Spring, Play, Blade, Vaadin & Co 1
gradlew.bat spring-boot:run funktioniert nicht Frameworks - Spring, Play, Blade, Vaadin & Co 4
Zrebna Spring Boot/Thymeleaf: Bestätigungsemail senden. Frameworks - Spring, Play, Blade, Vaadin & Co 2
Zrebna Spring - Thymeleaf: Wieso wird gem. Fallunterscheidung entsprechende View nicht geladen? Frameworks - Spring, Play, Blade, Vaadin & Co 3
Dimax Spring UsernameNotFoundException(msg); auf der View msg ausdrücken Frameworks - Spring, Play, Blade, Vaadin & Co 1
Dimax Spring UsernameNotFoundException(Message) auf der View Message ausdrücken Frameworks - Spring, Play, Blade, Vaadin & Co 2
B Spring Boot und JPA Error creating bean Frameworks - Spring, Play, Blade, Vaadin & Co 24
R Spring Security: Wie kommt 'UserDetails' an Username und Passwort ran? Frameworks - Spring, Play, Blade, Vaadin & Co 6
R Spring Security: Wie den User dynamisch authentifizieren? Frameworks - Spring, Play, Blade, Vaadin & Co 8
R Spring Security: Authentication & Permissions Frameworks - Spring, Play, Blade, Vaadin & Co 4
R Spring Boot: Warum soll PasswordEncoder in einer neuen Methode definiert sein? Frameworks - Spring, Play, Blade, Vaadin & Co 1
8u3631984 Cross-Origin beim Abrufen von Spring Endpoint Frameworks - Spring, Play, Blade, Vaadin & Co 1
D Spring Boot und Microservices Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Boot additional Datasource for a single entity Frameworks - Spring, Play, Blade, Vaadin & Co 0
T Spring Resourcen Ordner ermitteln Frameworks - Spring, Play, Blade, Vaadin & Co 5
B Spring JPA und Repository Frameworks - Spring, Play, Blade, Vaadin & Co 12
D Mapstruct Dependency Injection funktioniert nicht mit Spring Frameworks - Spring, Play, Blade, Vaadin & Co 15
Avalon Wie sieht bei Euch das Deployment einer Spring Boot Anwendung aus? Frameworks - Spring, Play, Blade, Vaadin & Co 4
M Threads in Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 7
W DI-Problem in Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 4
T Spring Boot: Was bewirkt parent in maven genau? Frameworks - Spring, Play, Blade, Vaadin & Co 4
T Spring Security: Run-as replacement Einsatzbereich? Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Vaadin+Spring Boot erster Seitenload nach Neustart endlos Frameworks - Spring, Play, Blade, Vaadin & Co 0
doncarlito87 Wie erhalte ich ein JSON aus eine NativeQuery (Spring Boot)? Frameworks - Spring, Play, Blade, Vaadin & Co 8
Avalon @Query Select Abfrage liefert falsche Werte (Spring Boot, JPA, Hibernate) Frameworks - Spring, Play, Blade, Vaadin & Co 3
Avalon Erstellung Dockerimage mit spring-boot:build-image in Spring Boot mit Umgebungsvariablen Frameworks - Spring, Play, Blade, Vaadin & Co 0
N Spring Integration - Logging Frameworks - Spring, Play, Blade, Vaadin & Co 7
D Spring Boot Field Injection in MapStruct Frameworks - Spring, Play, Blade, Vaadin & Co 5
D Spring Anfänger benötigt Hilfe Frameworks - Spring, Play, Blade, Vaadin & Co 9
OnDemand Spring Boot seltsame Logeinträge: Manipulationsversuche? Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Spring Date keine neue Tabelle fuer Attribut Frameworks - Spring, Play, Blade, Vaadin & Co 1
T Spring Security Config File anpassen Frameworks - Spring, Play, Blade, Vaadin & Co 1
8u3631984 Spring Cloud : Resttemplate mit Loadballancer Frameworks - Spring, Play, Blade, Vaadin & Co 11
Dimax Spring resource not found Frameworks - Spring, Play, Blade, Vaadin & Co 2
M Spring MongoDB unique index Frameworks - Spring, Play, Blade, Vaadin & Co 3
M Spring Entity testen Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Entity testen Frameworks - Spring, Play, Blade, Vaadin & Co 5
Dimax Spring App Probleme beim Ausführen auf dem Tomcat Server Frameworks - Spring, Play, Blade, Vaadin & Co 1
D Spring WebFlux Cors konfigurieren Frameworks - Spring, Play, Blade, Vaadin & Co 1
Dimax Schöne View mit anchor scrolling in Spring Frameworks - Spring, Play, Blade, Vaadin & Co 2
Dimax Spring JPA Multiple Keys Frameworks - Spring, Play, Blade, Vaadin & Co 3
S Spring Security mit oauth2 in lokaler Konfiguration principal mocken Frameworks - Spring, Play, Blade, Vaadin & Co 0
D Spring Boot Mile Stone und Snapshot Versionen Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Spring Boot Exception Body Frameworks - Spring, Play, Blade, Vaadin & Co 2
D Was ist das Framework "Spring"? Frameworks - Spring, Play, Blade, Vaadin & Co 1
M Spring Unit/Integrations Testing Frameworks - Spring, Play, Blade, Vaadin & Co 3
D Spring Unit Test: UnsatisfiedDependencyException: Error creating bean with name Frameworks - Spring, Play, Blade, Vaadin & Co 2
H Resource Liste Lazy Autowired Spring Context Frameworks - Spring, Play, Blade, Vaadin & Co 2
M Java Spring Security Frameworks - Spring, Play, Blade, Vaadin & Co 5
M Spring Security Login with Credentials Frameworks - Spring, Play, Blade, Vaadin & Co 0
N Spring Boot - Overkill für private Projekte? Frameworks - Spring, Play, Blade, Vaadin & Co 3
krgewb Spring und GWT - & wird zu & amp; Frameworks - Spring, Play, Blade, Vaadin & Co 2
K Migration eines internen Frameworks zu Spring:Boot Frameworks - Spring, Play, Blade, Vaadin & Co 0
OnDemand JPA/Spring Repository Like Suche leeres Ergebnis Frameworks - Spring, Play, Blade, Vaadin & Co 0
Z Hibernate & Postgres in Spring Boot (Syntaxprobleme) Frameworks - Spring, Play, Blade, Vaadin & Co 2
Z Spring Boot mit JPA;, Hibernate, Rest & Lombok Frameworks - Spring, Play, Blade, Vaadin & Co 8
M Spring Initializer - Webservices Frameworks - Spring, Play, Blade, Vaadin & Co 0
D Spring Hateoas Frameworks - Spring, Play, Blade, Vaadin & Co 1
ma095 Spring und Postgresql Errors Frameworks - Spring, Play, Blade, Vaadin & Co 4
OnDemand Spring+Vaadin App startet nicht Frameworks - Spring, Play, Blade, Vaadin & Co 1
OnDemand Spring Request externe API SSL Error Frameworks - Spring, Play, Blade, Vaadin & Co 7
OnDemand Spring Repo speichert, aber es kommt in der DB nicht an Frameworks - Spring, Play, Blade, Vaadin & Co 3
Dimax Im Spring ,Mysql-Funktion aufrufen Frameworks - Spring, Play, Blade, Vaadin & Co 2
OnDemand Spring Security/Boot/Vaadin Cookie Problem bei iFrame Frameworks - Spring, Play, Blade, Vaadin & Co 4
OnDemand Spring Boot: Feld ignorieren Frameworks - Spring, Play, Blade, Vaadin & Co 3
8u3631984 Spring + Thymleaf : Checkbox Object mappen Frameworks - Spring, Play, Blade, Vaadin & Co 0
N Buch zum Spring Framework bzw. Spring Boot Frameworks - Spring, Play, Blade, Vaadin & Co 3
OnDemand Jasypt Spring Boot HIbernate wie komme ich an den Key? Frameworks - Spring, Play, Blade, Vaadin & Co 4
8u3631984 Spring Boot im Docker Container - Logback wird nicht verwendet Frameworks - Spring, Play, Blade, Vaadin & Co 13
sascha-sphw Spring - Authentication object was not found Frameworks - Spring, Play, Blade, Vaadin & Co 3
8u3631984 Welches Spring Frontend Framework verwendet ihr und wie bzw wo ? Frameworks - Spring, Play, Blade, Vaadin & Co 7
8u3631984 Spring security - 403 bei Role Access Regel Frameworks - Spring, Play, Blade, Vaadin & Co 6

Ähnliche Java Themen

Neue Themen


Oben