Skip to content

juergen-albert/springboot-osgi-sample

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 

History

12 Commits
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

Java CI

SpringBoot / OSGi framework

This project is showing a simple way to use a SpringBoot application server and extending it with OSGi bundle. The application is including a service which is loading and exposing the Felix OSGi Framework. With a proper configuration you will be able to use it for "plugins".

The target it is to have a lit of bundles implementing an interface exposed by the core. The main application will use this class to invoke bundles code.

Software Architecture

Inside the project there are several modules:

  • commons is a module shared with bundles and containing Interface for shared service class.
  • core is the main project containing controllers for API, the OSGi framework, ...
  • sample-bundle is a test bundle. By default it is deployed during the build inside the auto-deploy folder.

To autodeploy bundles, the project is using the felix fileinstall bundle. The maven build is adding the bundle library to the correct OSGi framework lib folder.

<outputDirectory>${project.build.directory}/internal-bundles</outputDirectory>

Build the project

With a simple

mvn clean install

all the files will be placed in the correct folders.

Start the application

Once build you can start the SpringBoot application within you terminal console (or any IDE will work the same)

java -jar core/target/core-0.0.1-SNAPSHOT.jar

The application will even load the sample bundle within the plugins folder. You can play with it simply removing, adding back, ... and check what the OSGi server will be

Docker

The application is coming with a sample Dockerfile which shows how an OSGi / SpringBoot application can be packaged, following the Docker best practices. To build the docker image you can use the following command from the project root folder:

docker build -t osgi-sample -f core/src/docker/Dockerfile core

To start the container once build you can use a command like the following (you need to adapt it based on your environment):

docker run -it -e pluginsService.org.osgi.framework.storage=/app/felix-cache -e pluginsService.felix.auto.deploy.dir=/app/internal-bundles  -e pluginsService.felix.fileinstall.dir=/app/plugins -v /Users/Marco/Projects/springboot-osgi-sample/plugins:/app/plugins -p 8080:8080 osgi-sample

The plugins/bundle are managed in a docker external volume. This means you can easily add them without rebuilding your base image. Only the internal-bundles folder is inside the docker itself. This because this JARs are considered mandatory for this sample project.

As we are using a multi layer best practices splitting libraries from project source file. If we do not change the dependencies, only the last layer of the Dockerfile will be updated when we modified the source code. This will also allow a quick deployment of your images.

Test the application

The application is exposing simples APIs:

GET /v1/samples to retrieve the list of installed bundles.

curl http://localhost:8080/v1/sample
[
"com.mornati.sample.sample-bundle"
]

GET /v1/samples/<bundle-name> to execute the Action method inside the deployed bundle with the bandle-name.

curl http://localhost:8080/v1/samples/sample-bundle
{
"body": "Action Worked !!"
}

curl http://localhost:8080/v1/samples/sample-bundle2
{
"body": "Plugin not found for sample-bundle2"
}

GET /v1/samples/sample-bundle/notification to execute the Notification method inside the deployed bundle with the bandle-name.

curl http://localhost:8080/v1/samples/sample-bundle/notification
{
"body": "Notification Processed..."
}

About

OSGi framework integrated into SpringBoot application

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Java 95.0%
  • Dockerfile 5.0%