SlideShare a Scribd company logo
<Insert Picture Here>




OSGi-enabled Java EE Applications in GlassFish
Arun Gupta, Java EE & GlassFish Guy
blogs.oracle.com/arungupta, @arungupta
The following/preceding is intended to outline our
general product direction. It is intended for
information purposes only, and may not be
incorporated into any contract. It is not a
commitment to deliver any material, code, or
functionality, and should not be relied upon in
making purchasing decisions.
The development, release, and timing of any
features or functionality described for Oracle’s
products remains at the sole discretion of Oracle.



                                                     2
3
4
5
6
Generally complex ...

• 13 assembly missions
• 16 pressurized modules
• 35k cubic feet
• 400 metric tons ~ 400K kg ~ 882K lbs
• 173 – 286 miles above Earth
• Average speed: 17,227 mph
• 15.7 orbits/day
• Estimated cost: $157 billion


                                         7
8
The OSGi Alliance is a worldwide
consortium of technology innovators
that advances a proven and mature
process to assure interoperability of
applications and services based on
its component integration platform.


                                    9
OSGi Alliance provides ...

• Specifications
• Reference Implementation
• Test Suites
• Certifications




                               10
What is OSGi Specification ?

• Delivered by OSGi Alliance
  • Originally for embedded devices, set top boxes, network
• Architecture for modular application development
 in Java
  • Breaks applications into “modules” or “bundles”
• Can install, uninstall, start, and stop each bundle
 dynamically without restarting container
  • Multiple versions are supported
• Dependencies explicitly defined with clear
 boundaries

                                                          11
“JAR Hell”

• JAR is a build-time and deploy-time
 concept, not run-time
  • Based on the ZIP file format
• No metadata to indicate dependencies
• Multiple versions of JARs cannot be
  loaded
• All “public” classes are public
  • Access modifiers are for packages, not JAR



                                                 12
OSGi Layers

                Service



               Life Cycle



                Module



         Execution Environment


                                 13
OSGi Bundle – Just a JAR File!
                                 Export-Package
                                 Import-Package
 Java Classes, Static Files, …   Bundle-ClassPath
          (bundle private)             ...


  META-INF/MANIFEST.MF
                                  Persistent
          OSGI-OPT
     (docs, source code, ...)

                                    Atomic


                                                  14
Bundle is identified by ...

• Bundle Identifier
  • Unique for the lifetime
  • getBundleId()
• Bundle Location
  • Unique location of the bundle
  • getLocation()
• Bundle Symbolic Name and Version
  • Globally unique identifier
  • getSymbolicName(), getVersion()




                                      15
Java Classes, Static Files, ...    Service

 META-INF/MANIFEST.MF
              ...
        Export-Package
              ...
                                                     Client

                            Java Classes, Static Files, ...

                             META-INF/MANIFEST.MF
                                          ...
                                    Import-Package
                                          ...


                                                              16
Interaction between layers
           register / unregister
                get / unget         Service
                                        manage

                start / stop
                                   Life Cycle
  Bundle




                                        install
                                        uninstall
                classload
                                    Module


                execute
                                      EE


                                                    17
Bundle State Diagram

    update
    refresh                     install


                         INSTALLED
                                                  STARTING
               update                        rt
                             resolv       sta
               refresh       e

                         RESOLVED                  ACTIVE

                  uninstal                            stop
                  l
                                                  STOPPING



Each bundle installation is new

                                                             18
OSGi Containers




    http://stackoverflow.com/questions/560794/what-osgi-container-do-you-recommend


                                                                                     19
OSGi in GlassFish
• GlassFish runs on top of OSGi
• Felix is default, also runs on Equinox &
  Knopflerfish
    • Runs in an existing shell
    • 260+ bundles in 3.1
• All GlassFish modules are OSGi bundles
• No OSGi APIs are used in GlassFish
    • HK2 provides abstraction layer

http://blogs.oracle.com/arungupta/entry/totd_103_glassfish_v3_with
http://blogs.oracle.com/arungupta/entry/totd_127_embedding_glassfish_in



                                                                          20
GlassFish: Modular Platform
     REST
     REST             SOAP
                      SOAP                                 High
                                                            High
                                    Clustering
                                    Clustering                                  JMS
                                                                                JMS
  Web Services
  Web Services     Web Services
                   Web Services                          Availability
                                                         Availability


      Web
      Web                          Connection
                                   Connection               Java
                                                             Java
                          JSF
                          JSF                                               EJB Container
                                                                            EJB Container
                   Application Container
    Container
    Container                     Pooling (JCA)
                                  Pooling (JCA)          Persistence
                                                         Persistence



     Management Console              Update Center                      Management CLI



  Naming                          Grizzly Framework                                Monitoring/
                   Injection
  Service Config         Deploy
                   Manager
                                   Security           Monitor Configuration
                                                                     Cluster      Serviceability/
                                                                                    Logging

                                  GlassFish V3 Core
Transaction        Security       (Module Subsystem)
  Service          Service                                     Deployment           Clustering




                                      OSGi
                                      OSGi
                                      Java SE
                                      Java SE

                                                                                                    21
GlassFish v3 Runtime with OSGi


 GlassFish V3 modules
                                Random OSGi Bundle
(OSGi + extra metadata)


                          Service        OSGi
   HK2 Service layer
                          Mapper     Service Layer




              OSGi Bundle Management




                                                     22
Benefits of OSGi for GlassFish
• Demands and enforces stronger modularity
• Enables custom tailored App server
• Lazy loading based on usage patterns
• Successfully maintained quick startup
• Available to GlassFish developers and
 users




                                          23
Create an OSGi Bundle – Maven

• Create a Maven project
• Implement “BundleActivator”
• Update “pom.xml”
 • Change packaging to “bundle”
 • Add dependencies on OSGI APIs
 • Use “maven-bundle-plugin” to package
• Build the bundle


   http://blogs.oracle.com/arungupta/entry/totd_36_deploy_osgi_bundles



                                                                         24
Create an OSGi bundle – NetBeans




http://blogs.oracle.com/arungupta/entry/totd_125_creating_an_osgi


                                                                    25
Create an OSGi bundle – NetBeans




http://blogs.oracle.com/arungupta/entry/totd_125_creating_an_osgi


                                                                    26
Create an OSGi bundle – Eclipse




http://blogs.oracle.com/arungupta/entry/totd_126_creating_an_osgi


                                                                    27
OSGi Bundles in GlassFish
• asadmin deploy –type osgi
• “cp”/“rm”
    glassfish/domains/domain1/autodeploy/bundles
•   telnet localhost 6666
•   Apache Felix Web Console
•   REST Console bundle
•   Perl-based shell (Osgish)
•   VisualVM OSGi Plugin
•   Supports OBR
    • Discover and deploy dependencies together
http://blogs.oracle.com/arungupta/entry/totd_118_managing_osgi_bundles



                                                                         28
29
Dynamic Discovery of OSGi service

                                                                           OSGi
   Export-Package         API                                             Service
                                                                          Registry

   Import-Package
                         Impl
   Bundle-Activator



   Import-Package
                                                                cker
                        Client                       Service Tra
   Bundle-Activator

                                                                Filters
http://blogs.oracle.com/arungupta/entry/totd_131_dynamic_osgi_services


                                                                                     30
Why OSGi in Enterprise Apps ?

• Improved modularity
  •   Reusable bundles
  •   Dependencies are more visible
  •   Better isolation / Cleaner class loading model
  •   Better version control
  •   Faster deployment cycle
• Better tools for deployment
• Observable bundle life cycle
• Service Tracking
• Criteria-based service selection


                                                       31
Why Java EE in Enterprise Apps ?

• Better API (JPA, JTA, JAXB, JNDI)
• Better component model (Servlet, EJB, JAX-RS)
• Better frameworks (JSF, CDI)
• Ease-of-use (Annotations, Convention-over-
  configuration)
• Platform provided integrated infrastructure
  services
  • Transaction, Security, Persistence, Remoting, ...
• Many more reasons ...



                                                        32
33
OSGi Enterprise Expert Group

 The OSGi Enterprise Expert Group
   (EEG) is chartered to define the
      technical requirements and
specifications to tailor and extend the
 OSGi Service Platform to address
   information technology software
  infrastructure use cases found in
    enterprise business scenarios.
            http://www.osgi.org/EEG/HomePage


                                               34
OSGi EEG Focus

• Scaling, including multi-container and multi-process
  environments
• Distributed and/or federated service model for
  • Multiple Service Platforms
  • External, heterogeneous systems
• Requirements for extensions to the OSGi
  publish/find/bind service model
• Enterprise-class life cycle and configuration
  management
• Integration of established Java EE technology into
  OSGi

                                                         35
Hybrid Applications

 “A hybrid application is an OSGi
   bundle as well as a Java EE
  archive and hence has both an
OSGi bundle context and Java EE
    context at runtime and can
 leverage capabilities of both the
            platforms.”

                                     36
Why Hybrid Apps ?




       Best of both worlds!!!
Why do you want to learn new APIs ?




                                 37
Role of GlassFish

• Provides a runtime for Hybrid Applications
• Implements Java EE related OSGi services
  and standards
• Don't have to assemble the bits
• OSGi is no longer under the cover
 • Raises visibility from GlassFish developers to users




                                                      38
OSGi Compendium Specs in GlassFish

• OSGi/HTTP Service
• OSGi/Web Application (rfc #66)
• OSGi/JTA (rfc #98)
• OSGi/JDBC (rfc #122)
• OSGi/JPA (rfc #143)
• OSGi/JNDI (rfc #142, coming post 3.1)




 http://wikis.sun.com/display/GlassFish/3.1OSGi



                                                  39
OSGi/Web Application (rfc #66)

• Web Application Bundle (WAB)
  • WAR + OSGi + Web-ContextPath Header
  • Can use all enterprise APIs include JPA with lazy loading
  • Sample manifest:
    Manifest-Version: 1.0
    Import-Package: javax.servlet.http; javax.persistence
    Bundle-ClassPath: WEB-INF/classes/,WEB-INF/lib/entities.jar
    Bundle-Version: 1.0
    Bundle-ManifestVersion: 2
    Web-ContextPath: /hello
    Bundle-SymbolicName: test.hellowab

• Wrapped WAR Support
  • webbundle: URL scheme


                                                                  40
OSGi Declarative Services

• Complications of Publish/Find/Bind
  • Long startup time
  • Memory footprint
  • Complex service programming model
• OSGi services in Java EE
    @Resource(mappedName=”osgiName”)
    SomeOSGiService osgiService;
  • JNDI Lookup
  • Portable, no OSGi dependencies in application
• Exported APIs visible to Java EE apps



                                                    41
OSGi Declarative Service
                                          <scr:component enabled="true" name="hello-service">
                                              <implementation class="org.glassfish.samples.osgi.helloservice.impl.HelloImpl"/>
                                              <service servicefactory="false">
              OSGI-INF/                         <provide interface="org.glassfish.samples.osgi.helloservice.api.HelloService"/>
                                              </service>
       serviceComponents.xml                  <property name="service.pid" value="hello-service"/>
                                          </scr:component>



Export-Package   API                                                                         Servlet Client
                                            ...
                                            import   org.glassfish.samples.osgi.helloservice.api.HelloService;


           HelloImpl                        @WebServlet(urlPatterns={"/HelloClient"})
                                            public class HelloClient extends HttpServlet {

                                             @Resource(mappedName="hello-service")
                                             HelloService helloService;

                                             @Resource(mappedName="howdy-service")
          HowdyImpl                          HelloService howdyService;

                                            ...




   http://blogs.oracle.com/arungupta/entry/totd_124_osgi_declarative_services


                                                                                                                                  42
OSGi Declarative Services


 import org.apache.felix.scr.annotations.Component;
 import org.apache.felix.scr.annotations.Service;
 import org.glassfish.samples.osgi.helloservice.api.HelloService;            maven-
                                                                             bundle-
 @Component(name="hello-service")                                             plugin
 @Service
 public class HelloImpl implements HelloService {                            maven-
   public String sayHello(String name) {                                      scr-
     return "Hello " + name;                                                 plugin
   }
 }




http://blogs.oracle.com/arungupta/entry/totd_124_osgi_declarative_services



                                                                                       43
JAX-WS & OSGi




          Artifacts   WSDL
                             JAX-WS
JAX-WS                       Endpoint
 Client                          Business
                                  Method




                                            44
JAX-WS & OSGi

                     Artifacts                                     WSDL
                                                                          JAX-WS
    JAX-WS                                                                Endpoint
     Client                                                                   Business
                                                                              Delegate
                                                                               Method
                                               Query
                                               Registry


                              OSGi                                        OSGi
                                                    Register
                             Service
                                                    Service
                                                                          Bundle
                             Registry
                                                                              Business
                                                                               Method
http://blogs.oracle.com/arungupta/entry/totd_130_invoking_a_osgi


                                                                                         45
OSGi & EJB

                 Client                                            OSGi Service Registry


                               login
Export-Package
                  API         register




  Export-EJB     Impl
                                         Container-managed
                                                JPA

               LoadData


   http://weblogs.java.net/blog/ss141213/archive/2010/03/30/ejb-osgi-service-demo-eclipsecon


                                                                                               46
OSGi + EJB

• Export EJB as OSGi services

  Export-EJB: ALL/None/<names>
• Pure OSGi components can discover/invoke
• Advantages
  • Declarative security, transaction, CDI, … are available
   to non-EE components
• Tx context from pure OSGi bundle propagates
  to invoked EJB
  • Ditto for security and persistence context



                                                              47
OSGi & JMS


Export-EJB: None   Consumer


                                              Destination
                                           ConnectionFactory
                                              Messages#


 BundleActivator   Producer

                                                                   OSGi Config Admin
 http://www.java.net/blog/ss141213/archive/2010/04/21/osgijmsmdb-example


                                                                                       48
Extending GlassFish v3
    Using Spring dm Container


                                                            • Simple Spring bean
                                                              implementing the
                                                              service
                                                            • Invoke the service
                                                              from a servlet using
                                                              standard @Resource
                                                              injection
                                                            • Single runtime for
                                                              both Spring and full
                                                              Java EE
http://blogs.oracle.com/dochez/entry/glassfish_v3_extensions_part_4


                                                                                   49
OSGi + CDI

                                                                           OSGi
  Export-Package         API                                              Service
                                                                          Registry

   Import-Package
                        Impl
  Bundle-Activator



   Import-Package
                                                              cker
                                                                ice
                       Client                       Ser SGiServ
                                                    @OviceTra
  Bundle-Activator

                                                                Filters
http://blogs.oracle.com/arungupta/entry/totd_154_dynamic_osgi_services


                                                                                     50
OSGi + CDI

ServiceTracker tracker = new ServiceTracker(context,
Hello.class.getName(), null);
tracker.open();
Hello hello = (Hello) tracker.getService();
System.out.println(hello.sayHello("Duke"));

@Inject @OSGiService(dynamic=true) Hello hello;
System.out.println(hello.sayHello("Duke"));

• Injected reference is never null because
  of CDI proxies

                                                       51
OSGi + JPA

• Enhancement of JPA entities at runtime
• Entities + persistence.xml bundled as OSGi
  bundle
• EntityManagerFactory available as

  @Inject @OSGiService
• Shared persistence unit and there by shared second
  level cache




                                                       52
OSGi + EE Resources

• Define a DataSource, JavaMail, or JMS resource
  available in Admin Console
• Corresponding OSGi service is already available
• Resource/Services are dynamic




                                                    53
JavaOne 2010 / EclipseCon 2011
    Hands-on Lab




NetBeans - http://blogs.oracle.com/arungupta/entry/s313522_instructions_for_osgi_enabled
Eclipse - http://blogs.oracle.com/arungupta/entry/screencast_38_developing_osgi_enabled


                                                                                       54
References
• oracle.com/javaee
• glassfish.org
• oracle.com/goto/glassfish
• blogs.oracle.com/theaquarium
• youtube.com/GlassFishVideos
• Follow @glassfish
• http://wikis.sun.com/display/GlassFish/OSGi
• http://wikis.sun.com/download/attachments/20
 9655166/GF-OSGi-Features-1.0.pdf

                                            55
<Insert Picture Here>




OSGi-enabled Java EE Applications in GlassFish
Arun Gupta, Java EE & GlassFish Guy
blogs.oracle.com/arungupta, @arungupta

More Related Content

What's hot

Java EE 6 & GlassFish 3
Java EE 6 & GlassFish 3Java EE 6 & GlassFish 3
Java EE 6 & GlassFish 3
Arun Gupta
 
Running your Java EE 6 applications in the Cloud @ Silicon Valley Code Camp 2010
Running your Java EE 6 applications in the Cloud @ Silicon Valley Code Camp 2010Running your Java EE 6 applications in the Cloud @ Silicon Valley Code Camp 2010
Running your Java EE 6 applications in the Cloud @ Silicon Valley Code Camp 2010
Arun Gupta
 
Java 7 workshop
Java 7 workshopJava 7 workshop
Java 7 workshop
Dennis Laumen
 
Java EE6 CodeCamp16 oct 2010
Java EE6 CodeCamp16 oct 2010Java EE6 CodeCamp16 oct 2010
Java EE6 CodeCamp16 oct 2010
Codecamp Romania
 
GlassFish & Java EE Business Update @ CEJUG
GlassFish & Java EE Business Update @ CEJUGGlassFish & Java EE Business Update @ CEJUG
GlassFish & Java EE Business Update @ CEJUG
Arun Gupta
 
Understanding
Understanding Understanding
Understanding
Arun Gupta
 
Glass Fishv3 March2010
Glass Fishv3 March2010Glass Fishv3 March2010
Glass Fishv3 March2010
Stephan Janssen
 
Running your Java EE 6 applications in the Cloud
Running your Java EE 6 applications in the CloudRunning your Java EE 6 applications in the Cloud
Running your Java EE 6 applications in the Cloud
Arun Gupta
 
Andrei Niculae - JavaEE6 - 24mai2011
Andrei Niculae - JavaEE6 - 24mai2011Andrei Niculae - JavaEE6 - 24mai2011
Andrei Niculae - JavaEE6 - 24mai2011
Agora Group
 
GlassFish 3.1 at JCertif 2011
GlassFish 3.1 at JCertif 2011GlassFish 3.1 at JCertif 2011
GlassFish 3.1 at JCertif 2011
Arun Gupta
 
The Java EE 7 Platform: Productivity & HTML5 at JavaOne Latin America 2012
The Java EE 7 Platform: Productivity & HTML5 at JavaOne Latin America 2012The Java EE 7 Platform: Productivity & HTML5 at JavaOne Latin America 2012
The Java EE 7 Platform: Productivity & HTML5 at JavaOne Latin America 2012
Arun Gupta
 
Powering the Next Generation Services with Java Platform - Spark IT 2010
Powering the Next Generation Services with Java Platform - Spark IT 2010Powering the Next Generation Services with Java Platform - Spark IT 2010
Powering the Next Generation Services with Java Platform - Spark IT 2010
Arun Gupta
 
Arun Gupta: London Java Community: Java EE 6 and GlassFish 3
Arun Gupta: London Java Community: Java EE 6 and GlassFish 3 Arun Gupta: London Java Community: Java EE 6 and GlassFish 3
Arun Gupta: London Java Community: Java EE 6 and GlassFish 3
Skills Matter
 
OTN Developer Days - Java EE 6
OTN Developer Days - Java EE 6OTN Developer Days - Java EE 6
OTN Developer Days - Java EE 6
glassfish
 
TDC 2011: The Java EE 7 Platform: Developing for the Cloud
TDC 2011: The Java EE 7 Platform: Developing for the CloudTDC 2011: The Java EE 7 Platform: Developing for the Cloud
TDC 2011: The Java EE 7 Platform: Developing for the Cloud
Arun Gupta
 
Getting Started with Rails on GlassFish (Hands-on Lab) - Spark IT 2010
Getting Started with Rails on GlassFish (Hands-on Lab) - Spark IT 2010Getting Started with Rails on GlassFish (Hands-on Lab) - Spark IT 2010
Getting Started with Rails on GlassFish (Hands-on Lab) - Spark IT 2010
Arun Gupta
 
Java EE 6 & GlassFish = Less Code + More Power at CEJUG
Java EE 6 & GlassFish = Less Code + More Power at CEJUGJava EE 6 & GlassFish = Less Code + More Power at CEJUG
Java EE 6 & GlassFish = Less Code + More Power at CEJUG
Arun Gupta
 
Java Summit Chennai: JAX-RS 2.0
Java Summit Chennai: JAX-RS 2.0Java Summit Chennai: JAX-RS 2.0
Java Summit Chennai: JAX-RS 2.0
Arun Gupta
 
WildFly AppServer - State of the Union
WildFly AppServer - State of the UnionWildFly AppServer - State of the Union
WildFly AppServer - State of the Union
Dimitris Andreadis
 
Deep Dive Hands-on in Java EE 6 - Oredev 2010
Deep Dive Hands-on in Java EE 6 - Oredev 2010Deep Dive Hands-on in Java EE 6 - Oredev 2010
Deep Dive Hands-on in Java EE 6 - Oredev 2010
Arun Gupta
 

What's hot (20)

Java EE 6 & GlassFish 3
Java EE 6 & GlassFish 3Java EE 6 & GlassFish 3
Java EE 6 & GlassFish 3
 
Running your Java EE 6 applications in the Cloud @ Silicon Valley Code Camp 2010
Running your Java EE 6 applications in the Cloud @ Silicon Valley Code Camp 2010Running your Java EE 6 applications in the Cloud @ Silicon Valley Code Camp 2010
Running your Java EE 6 applications in the Cloud @ Silicon Valley Code Camp 2010
 
Java 7 workshop
Java 7 workshopJava 7 workshop
Java 7 workshop
 
Java EE6 CodeCamp16 oct 2010
Java EE6 CodeCamp16 oct 2010Java EE6 CodeCamp16 oct 2010
Java EE6 CodeCamp16 oct 2010
 
GlassFish & Java EE Business Update @ CEJUG
GlassFish & Java EE Business Update @ CEJUGGlassFish & Java EE Business Update @ CEJUG
GlassFish & Java EE Business Update @ CEJUG
 
Understanding
Understanding Understanding
Understanding
 
Glass Fishv3 March2010
Glass Fishv3 March2010Glass Fishv3 March2010
Glass Fishv3 March2010
 
Running your Java EE 6 applications in the Cloud
Running your Java EE 6 applications in the CloudRunning your Java EE 6 applications in the Cloud
Running your Java EE 6 applications in the Cloud
 
Andrei Niculae - JavaEE6 - 24mai2011
Andrei Niculae - JavaEE6 - 24mai2011Andrei Niculae - JavaEE6 - 24mai2011
Andrei Niculae - JavaEE6 - 24mai2011
 
GlassFish 3.1 at JCertif 2011
GlassFish 3.1 at JCertif 2011GlassFish 3.1 at JCertif 2011
GlassFish 3.1 at JCertif 2011
 
The Java EE 7 Platform: Productivity & HTML5 at JavaOne Latin America 2012
The Java EE 7 Platform: Productivity & HTML5 at JavaOne Latin America 2012The Java EE 7 Platform: Productivity & HTML5 at JavaOne Latin America 2012
The Java EE 7 Platform: Productivity & HTML5 at JavaOne Latin America 2012
 
Powering the Next Generation Services with Java Platform - Spark IT 2010
Powering the Next Generation Services with Java Platform - Spark IT 2010Powering the Next Generation Services with Java Platform - Spark IT 2010
Powering the Next Generation Services with Java Platform - Spark IT 2010
 
Arun Gupta: London Java Community: Java EE 6 and GlassFish 3
Arun Gupta: London Java Community: Java EE 6 and GlassFish 3 Arun Gupta: London Java Community: Java EE 6 and GlassFish 3
Arun Gupta: London Java Community: Java EE 6 and GlassFish 3
 
OTN Developer Days - Java EE 6
OTN Developer Days - Java EE 6OTN Developer Days - Java EE 6
OTN Developer Days - Java EE 6
 
TDC 2011: The Java EE 7 Platform: Developing for the Cloud
TDC 2011: The Java EE 7 Platform: Developing for the CloudTDC 2011: The Java EE 7 Platform: Developing for the Cloud
TDC 2011: The Java EE 7 Platform: Developing for the Cloud
 
Getting Started with Rails on GlassFish (Hands-on Lab) - Spark IT 2010
Getting Started with Rails on GlassFish (Hands-on Lab) - Spark IT 2010Getting Started with Rails on GlassFish (Hands-on Lab) - Spark IT 2010
Getting Started with Rails on GlassFish (Hands-on Lab) - Spark IT 2010
 
Java EE 6 & GlassFish = Less Code + More Power at CEJUG
Java EE 6 & GlassFish = Less Code + More Power at CEJUGJava EE 6 & GlassFish = Less Code + More Power at CEJUG
Java EE 6 & GlassFish = Less Code + More Power at CEJUG
 
Java Summit Chennai: JAX-RS 2.0
Java Summit Chennai: JAX-RS 2.0Java Summit Chennai: JAX-RS 2.0
Java Summit Chennai: JAX-RS 2.0
 
WildFly AppServer - State of the Union
WildFly AppServer - State of the UnionWildFly AppServer - State of the Union
WildFly AppServer - State of the Union
 
Deep Dive Hands-on in Java EE 6 - Oredev 2010
Deep Dive Hands-on in Java EE 6 - Oredev 2010Deep Dive Hands-on in Java EE 6 - Oredev 2010
Deep Dive Hands-on in Java EE 6 - Oredev 2010
 

Similar to OSGi-enabled Java EE Applications using GlassFish at JCertif 2011

OSGi-enabled Java EE applications in GlassFish
OSGi-enabled Java EE applications in GlassFishOSGi-enabled Java EE applications in GlassFish
OSGi-enabled Java EE applications in GlassFish
Arun Gupta
 
OSGi-enabled Java EE Applications using GlassFish
OSGi-enabled Java EE Applications using GlassFishOSGi-enabled Java EE Applications using GlassFish
OSGi-enabled Java EE Applications using GlassFish
Arun Gupta
 
TDC 2011: OSGi-enabled Java EE Application
TDC 2011: OSGi-enabled Java EE ApplicationTDC 2011: OSGi-enabled Java EE Application
TDC 2011: OSGi-enabled Java EE Application
Arun Gupta
 
OSGi & Java EE in GlassFish - Best of both worlds
OSGi & Java EE in GlassFish - Best of both worldsOSGi & Java EE in GlassFish - Best of both worlds
OSGi & Java EE in GlassFish - Best of both worlds
Arun Gupta
 
OSGi and Java EE in GlassFish - Tech Days 2010 India
OSGi and Java EE in GlassFish - Tech Days 2010 IndiaOSGi and Java EE in GlassFish - Tech Days 2010 India
OSGi and Java EE in GlassFish - Tech Days 2010 India
Arun Gupta
 
Liferay Module Framework
Liferay Module FrameworkLiferay Module Framework
Liferay Module Framework
Miguel Pastor
 
Java Modularity with OSGi
Java Modularity with OSGiJava Modularity with OSGi
Java Modularity with OSGi
Ilya Rybak
 
Osgi Sun 20080820
Osgi Sun 20080820Osgi Sun 20080820
Osgi Sun 20080820
Eduardo Pelegri-Llopart
 
OSGi tech session
OSGi tech sessionOSGi tech session
OSGi tech session
Bram de Kruijff
 
Enterprise OSGi at eBay
Enterprise OSGi at eBayEnterprise OSGi at eBay
Enterprise OSGi at eBay
Tony Ng
 
Polyglot OSGi
Polyglot OSGiPolyglot OSGi
Polyglot OSGi
Matt Stine
 
Enabling modularization through OSGi and SpringDM
Enabling modularization through OSGi and SpringDMEnabling modularization through OSGi and SpringDM
Enabling modularization through OSGi and SpringDM
mukulobject
 
GlassFish OSGi Server
GlassFish OSGi ServerGlassFish OSGi Server
GlassFish OSGi Server
Artur Alves
 
The Java EE 7 Platform: Developing for the Cloud (FISL 12)
The Java EE 7 Platform: Developing for the Cloud  (FISL 12)The Java EE 7 Platform: Developing for the Cloud  (FISL 12)
The Java EE 7 Platform: Developing for the Cloud (FISL 12)
Arun Gupta
 
Hybrid Applications
Hybrid ApplicationsHybrid Applications
Hybrid Applications
Andreas Enbohm
 
Part 8 - Enforcing modularity of JasForge using OSGI and Futures Evolutions
Part 8 - Enforcing modularity of JasForge using OSGI and Futures EvolutionsPart 8 - Enforcing modularity of JasForge using OSGI and Futures Evolutions
Part 8 - Enforcing modularity of JasForge using OSGI and Futures Evolutions
Jasmine Conseil
 
Deploying Java EE 6 Apps in a Cluster: GlassFish 3.1 at Dallas Tech Fest 2011
Deploying Java EE 6 Apps in a Cluster: GlassFish 3.1 at Dallas Tech Fest 2011Deploying Java EE 6 Apps in a Cluster: GlassFish 3.1 at Dallas Tech Fest 2011
Deploying Java EE 6 Apps in a Cluster: GlassFish 3.1 at Dallas Tech Fest 2011
Arun Gupta
 
An introduction to OSGi
An introduction to OSGi An introduction to OSGi
An introduction to OSGi
Andrea Chiodoni
 
The OSGi Framework Multiplication
The OSGi Framework MultiplicationThe OSGi Framework Multiplication
The OSGi Framework Multiplication
Clément Escoffier
 
Gemini WEB and Virgo
Gemini WEB and VirgoGemini WEB and Virgo
Gemini WEB and Virgo
Hristo Iliev
 

Similar to OSGi-enabled Java EE Applications using GlassFish at JCertif 2011 (20)

OSGi-enabled Java EE applications in GlassFish
OSGi-enabled Java EE applications in GlassFishOSGi-enabled Java EE applications in GlassFish
OSGi-enabled Java EE applications in GlassFish
 
OSGi-enabled Java EE Applications using GlassFish
OSGi-enabled Java EE Applications using GlassFishOSGi-enabled Java EE Applications using GlassFish
OSGi-enabled Java EE Applications using GlassFish
 
TDC 2011: OSGi-enabled Java EE Application
TDC 2011: OSGi-enabled Java EE ApplicationTDC 2011: OSGi-enabled Java EE Application
TDC 2011: OSGi-enabled Java EE Application
 
OSGi & Java EE in GlassFish - Best of both worlds
OSGi & Java EE in GlassFish - Best of both worldsOSGi & Java EE in GlassFish - Best of both worlds
OSGi & Java EE in GlassFish - Best of both worlds
 
OSGi and Java EE in GlassFish - Tech Days 2010 India
OSGi and Java EE in GlassFish - Tech Days 2010 IndiaOSGi and Java EE in GlassFish - Tech Days 2010 India
OSGi and Java EE in GlassFish - Tech Days 2010 India
 
Liferay Module Framework
Liferay Module FrameworkLiferay Module Framework
Liferay Module Framework
 
Java Modularity with OSGi
Java Modularity with OSGiJava Modularity with OSGi
Java Modularity with OSGi
 
Osgi Sun 20080820
Osgi Sun 20080820Osgi Sun 20080820
Osgi Sun 20080820
 
OSGi tech session
OSGi tech sessionOSGi tech session
OSGi tech session
 
Enterprise OSGi at eBay
Enterprise OSGi at eBayEnterprise OSGi at eBay
Enterprise OSGi at eBay
 
Polyglot OSGi
Polyglot OSGiPolyglot OSGi
Polyglot OSGi
 
Enabling modularization through OSGi and SpringDM
Enabling modularization through OSGi and SpringDMEnabling modularization through OSGi and SpringDM
Enabling modularization through OSGi and SpringDM
 
GlassFish OSGi Server
GlassFish OSGi ServerGlassFish OSGi Server
GlassFish OSGi Server
 
The Java EE 7 Platform: Developing for the Cloud (FISL 12)
The Java EE 7 Platform: Developing for the Cloud  (FISL 12)The Java EE 7 Platform: Developing for the Cloud  (FISL 12)
The Java EE 7 Platform: Developing for the Cloud (FISL 12)
 
Hybrid Applications
Hybrid ApplicationsHybrid Applications
Hybrid Applications
 
Part 8 - Enforcing modularity of JasForge using OSGI and Futures Evolutions
Part 8 - Enforcing modularity of JasForge using OSGI and Futures EvolutionsPart 8 - Enforcing modularity of JasForge using OSGI and Futures Evolutions
Part 8 - Enforcing modularity of JasForge using OSGI and Futures Evolutions
 
Deploying Java EE 6 Apps in a Cluster: GlassFish 3.1 at Dallas Tech Fest 2011
Deploying Java EE 6 Apps in a Cluster: GlassFish 3.1 at Dallas Tech Fest 2011Deploying Java EE 6 Apps in a Cluster: GlassFish 3.1 at Dallas Tech Fest 2011
Deploying Java EE 6 Apps in a Cluster: GlassFish 3.1 at Dallas Tech Fest 2011
 
An introduction to OSGi
An introduction to OSGi An introduction to OSGi
An introduction to OSGi
 
The OSGi Framework Multiplication
The OSGi Framework MultiplicationThe OSGi Framework Multiplication
The OSGi Framework Multiplication
 
Gemini WEB and Virgo
Gemini WEB and VirgoGemini WEB and Virgo
Gemini WEB and Virgo
 

More from Arun Gupta

5 Skills To Force Multiply Technical Talents.pdf
5 Skills To Force Multiply Technical Talents.pdf5 Skills To Force Multiply Technical Talents.pdf
5 Skills To Force Multiply Technical Talents.pdf
Arun Gupta
 
Machine Learning using Kubernetes - AI Conclave 2019
Machine Learning using Kubernetes - AI Conclave 2019Machine Learning using Kubernetes - AI Conclave 2019
Machine Learning using Kubernetes - AI Conclave 2019
Arun Gupta
 
Machine Learning using Kubeflow and Kubernetes
Machine Learning using Kubeflow and KubernetesMachine Learning using Kubeflow and Kubernetes
Machine Learning using Kubeflow and Kubernetes
Arun Gupta
 
Secure and Fast microVM for Serverless Computing using Firecracker
Secure and Fast microVM for Serverless Computing using FirecrackerSecure and Fast microVM for Serverless Computing using Firecracker
Secure and Fast microVM for Serverless Computing using Firecracker
Arun Gupta
 
Building Java in the Open - j.Day at OSCON 2019
Building Java in the Open - j.Day at OSCON 2019Building Java in the Open - j.Day at OSCON 2019
Building Java in the Open - j.Day at OSCON 2019
Arun Gupta
 
Why Amazon Cares about Open Source
Why Amazon Cares about Open SourceWhy Amazon Cares about Open Source
Why Amazon Cares about Open Source
Arun Gupta
 
Machine learning using Kubernetes
Machine learning using KubernetesMachine learning using Kubernetes
Machine learning using Kubernetes
Arun Gupta
 
Building Cloud Native Applications
Building Cloud Native ApplicationsBuilding Cloud Native Applications
Building Cloud Native Applications
Arun Gupta
 
Chaos Engineering with Kubernetes
Chaos Engineering with KubernetesChaos Engineering with Kubernetes
Chaos Engineering with Kubernetes
Arun Gupta
 
How to be a mentor to bring more girls to STEAM
How to be a mentor to bring more girls to STEAMHow to be a mentor to bring more girls to STEAM
How to be a mentor to bring more girls to STEAM
Arun Gupta
 
Java in a World of Containers - DockerCon 2018
Java in a World of Containers - DockerCon 2018Java in a World of Containers - DockerCon 2018
Java in a World of Containers - DockerCon 2018
Arun Gupta
 
The Serverless Tidal Wave - SwampUP 2018 Keynote
The Serverless Tidal Wave - SwampUP 2018 KeynoteThe Serverless Tidal Wave - SwampUP 2018 Keynote
The Serverless Tidal Wave - SwampUP 2018 Keynote
Arun Gupta
 
Introduction to Amazon EKS - KubeCon 2018
Introduction to Amazon EKS - KubeCon 2018Introduction to Amazon EKS - KubeCon 2018
Introduction to Amazon EKS - KubeCon 2018
Arun Gupta
 
Mastering Kubernetes on AWS - Tel Aviv Summit
Mastering Kubernetes on AWS - Tel Aviv SummitMastering Kubernetes on AWS - Tel Aviv Summit
Mastering Kubernetes on AWS - Tel Aviv Summit
Arun Gupta
 
Top 10 Technology Trends Changing Developer's Landscape
Top 10 Technology Trends Changing Developer's LandscapeTop 10 Technology Trends Changing Developer's Landscape
Top 10 Technology Trends Changing Developer's Landscape
Arun Gupta
 
Container Landscape in 2017
Container Landscape in 2017Container Landscape in 2017
Container Landscape in 2017
Arun Gupta
 
Java EE and NoSQL using JBoss EAP 7 and OpenShift
Java EE and NoSQL using JBoss EAP 7 and OpenShiftJava EE and NoSQL using JBoss EAP 7 and OpenShift
Java EE and NoSQL using JBoss EAP 7 and OpenShift
Arun Gupta
 
Docker, Kubernetes, and Mesos recipes for Java developers
Docker, Kubernetes, and Mesos recipes for Java developersDocker, Kubernetes, and Mesos recipes for Java developers
Docker, Kubernetes, and Mesos recipes for Java developers
Arun Gupta
 
Thanks Managers!
Thanks Managers!Thanks Managers!
Thanks Managers!
Arun Gupta
 
Migrate your traditional VM-based Clusters to Containers
Migrate your traditional VM-based Clusters to ContainersMigrate your traditional VM-based Clusters to Containers
Migrate your traditional VM-based Clusters to Containers
Arun Gupta
 

More from Arun Gupta (20)

5 Skills To Force Multiply Technical Talents.pdf
5 Skills To Force Multiply Technical Talents.pdf5 Skills To Force Multiply Technical Talents.pdf
5 Skills To Force Multiply Technical Talents.pdf
 
Machine Learning using Kubernetes - AI Conclave 2019
Machine Learning using Kubernetes - AI Conclave 2019Machine Learning using Kubernetes - AI Conclave 2019
Machine Learning using Kubernetes - AI Conclave 2019
 
Machine Learning using Kubeflow and Kubernetes
Machine Learning using Kubeflow and KubernetesMachine Learning using Kubeflow and Kubernetes
Machine Learning using Kubeflow and Kubernetes
 
Secure and Fast microVM for Serverless Computing using Firecracker
Secure and Fast microVM for Serverless Computing using FirecrackerSecure and Fast microVM for Serverless Computing using Firecracker
Secure and Fast microVM for Serverless Computing using Firecracker
 
Building Java in the Open - j.Day at OSCON 2019
Building Java in the Open - j.Day at OSCON 2019Building Java in the Open - j.Day at OSCON 2019
Building Java in the Open - j.Day at OSCON 2019
 
Why Amazon Cares about Open Source
Why Amazon Cares about Open SourceWhy Amazon Cares about Open Source
Why Amazon Cares about Open Source
 
Machine learning using Kubernetes
Machine learning using KubernetesMachine learning using Kubernetes
Machine learning using Kubernetes
 
Building Cloud Native Applications
Building Cloud Native ApplicationsBuilding Cloud Native Applications
Building Cloud Native Applications
 
Chaos Engineering with Kubernetes
Chaos Engineering with KubernetesChaos Engineering with Kubernetes
Chaos Engineering with Kubernetes
 
How to be a mentor to bring more girls to STEAM
How to be a mentor to bring more girls to STEAMHow to be a mentor to bring more girls to STEAM
How to be a mentor to bring more girls to STEAM
 
Java in a World of Containers - DockerCon 2018
Java in a World of Containers - DockerCon 2018Java in a World of Containers - DockerCon 2018
Java in a World of Containers - DockerCon 2018
 
The Serverless Tidal Wave - SwampUP 2018 Keynote
The Serverless Tidal Wave - SwampUP 2018 KeynoteThe Serverless Tidal Wave - SwampUP 2018 Keynote
The Serverless Tidal Wave - SwampUP 2018 Keynote
 
Introduction to Amazon EKS - KubeCon 2018
Introduction to Amazon EKS - KubeCon 2018Introduction to Amazon EKS - KubeCon 2018
Introduction to Amazon EKS - KubeCon 2018
 
Mastering Kubernetes on AWS - Tel Aviv Summit
Mastering Kubernetes on AWS - Tel Aviv SummitMastering Kubernetes on AWS - Tel Aviv Summit
Mastering Kubernetes on AWS - Tel Aviv Summit
 
Top 10 Technology Trends Changing Developer's Landscape
Top 10 Technology Trends Changing Developer's LandscapeTop 10 Technology Trends Changing Developer's Landscape
Top 10 Technology Trends Changing Developer's Landscape
 
Container Landscape in 2017
Container Landscape in 2017Container Landscape in 2017
Container Landscape in 2017
 
Java EE and NoSQL using JBoss EAP 7 and OpenShift
Java EE and NoSQL using JBoss EAP 7 and OpenShiftJava EE and NoSQL using JBoss EAP 7 and OpenShift
Java EE and NoSQL using JBoss EAP 7 and OpenShift
 
Docker, Kubernetes, and Mesos recipes for Java developers
Docker, Kubernetes, and Mesos recipes for Java developersDocker, Kubernetes, and Mesos recipes for Java developers
Docker, Kubernetes, and Mesos recipes for Java developers
 
Thanks Managers!
Thanks Managers!Thanks Managers!
Thanks Managers!
 
Migrate your traditional VM-based Clusters to Containers
Migrate your traditional VM-based Clusters to ContainersMigrate your traditional VM-based Clusters to Containers
Migrate your traditional VM-based Clusters to Containers
 

Recently uploaded

Freshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
Freshworks Rethinks NoSQL for Rapid Scaling & Cost-EfficiencyFreshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
Freshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
ScyllaDB
 
GraphRAG for LifeSciences Hands-On with the Clinical Knowledge Graph
GraphRAG for LifeSciences Hands-On with the Clinical Knowledge GraphGraphRAG for LifeSciences Hands-On with the Clinical Knowledge Graph
GraphRAG for LifeSciences Hands-On with the Clinical Knowledge Graph
Neo4j
 
9 CEO's who hit $100m ARR Share Their Top Growth Tactics Nathan Latka, Founde...
9 CEO's who hit $100m ARR Share Their Top Growth Tactics Nathan Latka, Founde...9 CEO's who hit $100m ARR Share Their Top Growth Tactics Nathan Latka, Founde...
9 CEO's who hit $100m ARR Share Their Top Growth Tactics Nathan Latka, Founde...
saastr
 
5th LF Energy Power Grid Model Meet-up Slides
5th LF Energy Power Grid Model Meet-up Slides5th LF Energy Power Grid Model Meet-up Slides
5th LF Energy Power Grid Model Meet-up Slides
DanBrown980551
 
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdfHow to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
Chart Kalyan
 
Fueling AI with Great Data with Airbyte Webinar
Fueling AI with Great Data with Airbyte WebinarFueling AI with Great Data with Airbyte Webinar
Fueling AI with Great Data with Airbyte Webinar
Zilliz
 
Y-Combinator seed pitch deck template PP
Y-Combinator seed pitch deck template PPY-Combinator seed pitch deck template PP
Y-Combinator seed pitch deck template PP
c5vrf27qcz
 
Digital Marketing Trends in 2024 | Guide for Staying Ahead
Digital Marketing Trends in 2024 | Guide for Staying AheadDigital Marketing Trends in 2024 | Guide for Staying Ahead
Digital Marketing Trends in 2024 | Guide for Staying Ahead
Wask
 
“How Axelera AI Uses Digital Compute-in-memory to Deliver Fast and Energy-eff...
“How Axelera AI Uses Digital Compute-in-memory to Deliver Fast and Energy-eff...“How Axelera AI Uses Digital Compute-in-memory to Deliver Fast and Energy-eff...
“How Axelera AI Uses Digital Compute-in-memory to Deliver Fast and Energy-eff...
Edge AI and Vision Alliance
 
The Microsoft 365 Migration Tutorial For Beginner.pptx
The Microsoft 365 Migration Tutorial For Beginner.pptxThe Microsoft 365 Migration Tutorial For Beginner.pptx
The Microsoft 365 Migration Tutorial For Beginner.pptx
operationspcvita
 
"Choosing proper type of scaling", Olena Syrota
"Choosing proper type of scaling", Olena Syrota"Choosing proper type of scaling", Olena Syrota
"Choosing proper type of scaling", Olena Syrota
Fwdays
 
TrustArc Webinar - 2024 Global Privacy Survey
TrustArc Webinar - 2024 Global Privacy SurveyTrustArc Webinar - 2024 Global Privacy Survey
TrustArc Webinar - 2024 Global Privacy Survey
TrustArc
 
[OReilly Superstream] Occupy the Space: A grassroots guide to engineering (an...
[OReilly Superstream] Occupy the Space: A grassroots guide to engineering (an...[OReilly Superstream] Occupy the Space: A grassroots guide to engineering (an...
[OReilly Superstream] Occupy the Space: A grassroots guide to engineering (an...
Jason Yip
 
Biomedical Knowledge Graphs for Data Scientists and Bioinformaticians
Biomedical Knowledge Graphs for Data Scientists and BioinformaticiansBiomedical Knowledge Graphs for Data Scientists and Bioinformaticians
Biomedical Knowledge Graphs for Data Scientists and Bioinformaticians
Neo4j
 
Presentation of the OECD Artificial Intelligence Review of Germany
Presentation of the OECD Artificial Intelligence Review of GermanyPresentation of the OECD Artificial Intelligence Review of Germany
Presentation of the OECD Artificial Intelligence Review of Germany
innovationoecd
 
What is an RPA CoE? Session 1 – CoE Vision
What is an RPA CoE?  Session 1 – CoE VisionWhat is an RPA CoE?  Session 1 – CoE Vision
What is an RPA CoE? Session 1 – CoE Vision
DianaGray10
 
Best 20 SEO Techniques To Improve Website Visibility In SERP
Best 20 SEO Techniques To Improve Website Visibility In SERPBest 20 SEO Techniques To Improve Website Visibility In SERP
Best 20 SEO Techniques To Improve Website Visibility In SERP
Pixlogix Infotech
 
Main news related to the CCS TSI 2023 (2023/1695)
Main news related to the CCS TSI 2023 (2023/1695)Main news related to the CCS TSI 2023 (2023/1695)
Main news related to the CCS TSI 2023 (2023/1695)
Jakub Marek
 
“Temporal Event Neural Networks: A More Efficient Alternative to the Transfor...
“Temporal Event Neural Networks: A More Efficient Alternative to the Transfor...“Temporal Event Neural Networks: A More Efficient Alternative to the Transfor...
“Temporal Event Neural Networks: A More Efficient Alternative to the Transfor...
Edge AI and Vision Alliance
 
Skybuffer SAM4U tool for SAP license adoption
Skybuffer SAM4U tool for SAP license adoptionSkybuffer SAM4U tool for SAP license adoption
Skybuffer SAM4U tool for SAP license adoption
Tatiana Kojar
 

Recently uploaded (20)

Freshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
Freshworks Rethinks NoSQL for Rapid Scaling & Cost-EfficiencyFreshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
Freshworks Rethinks NoSQL for Rapid Scaling & Cost-Efficiency
 
GraphRAG for LifeSciences Hands-On with the Clinical Knowledge Graph
GraphRAG for LifeSciences Hands-On with the Clinical Knowledge GraphGraphRAG for LifeSciences Hands-On with the Clinical Knowledge Graph
GraphRAG for LifeSciences Hands-On with the Clinical Knowledge Graph
 
9 CEO's who hit $100m ARR Share Their Top Growth Tactics Nathan Latka, Founde...
9 CEO's who hit $100m ARR Share Their Top Growth Tactics Nathan Latka, Founde...9 CEO's who hit $100m ARR Share Their Top Growth Tactics Nathan Latka, Founde...
9 CEO's who hit $100m ARR Share Their Top Growth Tactics Nathan Latka, Founde...
 
5th LF Energy Power Grid Model Meet-up Slides
5th LF Energy Power Grid Model Meet-up Slides5th LF Energy Power Grid Model Meet-up Slides
5th LF Energy Power Grid Model Meet-up Slides
 
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdfHow to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
How to Interpret Trends in the Kalyan Rajdhani Mix Chart.pdf
 
Fueling AI with Great Data with Airbyte Webinar
Fueling AI with Great Data with Airbyte WebinarFueling AI with Great Data with Airbyte Webinar
Fueling AI with Great Data with Airbyte Webinar
 
Y-Combinator seed pitch deck template PP
Y-Combinator seed pitch deck template PPY-Combinator seed pitch deck template PP
Y-Combinator seed pitch deck template PP
 
Digital Marketing Trends in 2024 | Guide for Staying Ahead
Digital Marketing Trends in 2024 | Guide for Staying AheadDigital Marketing Trends in 2024 | Guide for Staying Ahead
Digital Marketing Trends in 2024 | Guide for Staying Ahead
 
“How Axelera AI Uses Digital Compute-in-memory to Deliver Fast and Energy-eff...
“How Axelera AI Uses Digital Compute-in-memory to Deliver Fast and Energy-eff...“How Axelera AI Uses Digital Compute-in-memory to Deliver Fast and Energy-eff...
“How Axelera AI Uses Digital Compute-in-memory to Deliver Fast and Energy-eff...
 
The Microsoft 365 Migration Tutorial For Beginner.pptx
The Microsoft 365 Migration Tutorial For Beginner.pptxThe Microsoft 365 Migration Tutorial For Beginner.pptx
The Microsoft 365 Migration Tutorial For Beginner.pptx
 
"Choosing proper type of scaling", Olena Syrota
"Choosing proper type of scaling", Olena Syrota"Choosing proper type of scaling", Olena Syrota
"Choosing proper type of scaling", Olena Syrota
 
TrustArc Webinar - 2024 Global Privacy Survey
TrustArc Webinar - 2024 Global Privacy SurveyTrustArc Webinar - 2024 Global Privacy Survey
TrustArc Webinar - 2024 Global Privacy Survey
 
[OReilly Superstream] Occupy the Space: A grassroots guide to engineering (an...
[OReilly Superstream] Occupy the Space: A grassroots guide to engineering (an...[OReilly Superstream] Occupy the Space: A grassroots guide to engineering (an...
[OReilly Superstream] Occupy the Space: A grassroots guide to engineering (an...
 
Biomedical Knowledge Graphs for Data Scientists and Bioinformaticians
Biomedical Knowledge Graphs for Data Scientists and BioinformaticiansBiomedical Knowledge Graphs for Data Scientists and Bioinformaticians
Biomedical Knowledge Graphs for Data Scientists and Bioinformaticians
 
Presentation of the OECD Artificial Intelligence Review of Germany
Presentation of the OECD Artificial Intelligence Review of GermanyPresentation of the OECD Artificial Intelligence Review of Germany
Presentation of the OECD Artificial Intelligence Review of Germany
 
What is an RPA CoE? Session 1 – CoE Vision
What is an RPA CoE?  Session 1 – CoE VisionWhat is an RPA CoE?  Session 1 – CoE Vision
What is an RPA CoE? Session 1 – CoE Vision
 
Best 20 SEO Techniques To Improve Website Visibility In SERP
Best 20 SEO Techniques To Improve Website Visibility In SERPBest 20 SEO Techniques To Improve Website Visibility In SERP
Best 20 SEO Techniques To Improve Website Visibility In SERP
 
Main news related to the CCS TSI 2023 (2023/1695)
Main news related to the CCS TSI 2023 (2023/1695)Main news related to the CCS TSI 2023 (2023/1695)
Main news related to the CCS TSI 2023 (2023/1695)
 
“Temporal Event Neural Networks: A More Efficient Alternative to the Transfor...
“Temporal Event Neural Networks: A More Efficient Alternative to the Transfor...“Temporal Event Neural Networks: A More Efficient Alternative to the Transfor...
“Temporal Event Neural Networks: A More Efficient Alternative to the Transfor...
 
Skybuffer SAM4U tool for SAP license adoption
Skybuffer SAM4U tool for SAP license adoptionSkybuffer SAM4U tool for SAP license adoption
Skybuffer SAM4U tool for SAP license adoption
 

OSGi-enabled Java EE Applications using GlassFish at JCertif 2011

  • 1. <Insert Picture Here> OSGi-enabled Java EE Applications in GlassFish Arun Gupta, Java EE & GlassFish Guy blogs.oracle.com/arungupta, @arungupta
  • 2. The following/preceding is intended to outline our general product direction. It is intended for information purposes only, and may not be incorporated into any contract. It is not a commitment to deliver any material, code, or functionality, and should not be relied upon in making purchasing decisions. The development, release, and timing of any features or functionality described for Oracle’s products remains at the sole discretion of Oracle. 2
  • 3. 3
  • 4. 4
  • 5. 5
  • 6. 6
  • 7. Generally complex ... • 13 assembly missions • 16 pressurized modules • 35k cubic feet • 400 metric tons ~ 400K kg ~ 882K lbs • 173 – 286 miles above Earth • Average speed: 17,227 mph • 15.7 orbits/day • Estimated cost: $157 billion 7
  • 8. 8
  • 9. The OSGi Alliance is a worldwide consortium of technology innovators that advances a proven and mature process to assure interoperability of applications and services based on its component integration platform. 9
  • 10. OSGi Alliance provides ... • Specifications • Reference Implementation • Test Suites • Certifications 10
  • 11. What is OSGi Specification ? • Delivered by OSGi Alliance • Originally for embedded devices, set top boxes, network • Architecture for modular application development in Java • Breaks applications into “modules” or “bundles” • Can install, uninstall, start, and stop each bundle dynamically without restarting container • Multiple versions are supported • Dependencies explicitly defined with clear boundaries 11
  • 12. “JAR Hell” • JAR is a build-time and deploy-time concept, not run-time • Based on the ZIP file format • No metadata to indicate dependencies • Multiple versions of JARs cannot be loaded • All “public” classes are public • Access modifiers are for packages, not JAR 12
  • 13. OSGi Layers Service Life Cycle Module Execution Environment 13
  • 14. OSGi Bundle – Just a JAR File! Export-Package Import-Package Java Classes, Static Files, … Bundle-ClassPath (bundle private) ... META-INF/MANIFEST.MF Persistent OSGI-OPT (docs, source code, ...) Atomic 14
  • 15. Bundle is identified by ... • Bundle Identifier • Unique for the lifetime • getBundleId() • Bundle Location • Unique location of the bundle • getLocation() • Bundle Symbolic Name and Version • Globally unique identifier • getSymbolicName(), getVersion() 15
  • 16. Java Classes, Static Files, ... Service META-INF/MANIFEST.MF ... Export-Package ... Client Java Classes, Static Files, ... META-INF/MANIFEST.MF ... Import-Package ... 16
  • 17. Interaction between layers register / unregister get / unget Service manage start / stop Life Cycle Bundle install uninstall classload Module execute EE 17
  • 18. Bundle State Diagram update refresh install INSTALLED STARTING update rt resolv sta refresh e RESOLVED ACTIVE uninstal stop l STOPPING Each bundle installation is new 18
  • 19. OSGi Containers http://stackoverflow.com/questions/560794/what-osgi-container-do-you-recommend 19
  • 20. OSGi in GlassFish • GlassFish runs on top of OSGi • Felix is default, also runs on Equinox & Knopflerfish • Runs in an existing shell • 260+ bundles in 3.1 • All GlassFish modules are OSGi bundles • No OSGi APIs are used in GlassFish • HK2 provides abstraction layer http://blogs.oracle.com/arungupta/entry/totd_103_glassfish_v3_with http://blogs.oracle.com/arungupta/entry/totd_127_embedding_glassfish_in 20
  • 21. GlassFish: Modular Platform REST REST SOAP SOAP High High Clustering Clustering JMS JMS Web Services Web Services Web Services Web Services Availability Availability Web Web Connection Connection Java Java JSF JSF EJB Container EJB Container Application Container Container Container Pooling (JCA) Pooling (JCA) Persistence Persistence Management Console Update Center Management CLI Naming Grizzly Framework Monitoring/ Injection Service Config Deploy Manager Security Monitor Configuration Cluster Serviceability/ Logging GlassFish V3 Core Transaction Security (Module Subsystem) Service Service Deployment Clustering OSGi OSGi Java SE Java SE 21
  • 22. GlassFish v3 Runtime with OSGi GlassFish V3 modules Random OSGi Bundle (OSGi + extra metadata) Service OSGi HK2 Service layer Mapper Service Layer OSGi Bundle Management 22
  • 23. Benefits of OSGi for GlassFish • Demands and enforces stronger modularity • Enables custom tailored App server • Lazy loading based on usage patterns • Successfully maintained quick startup • Available to GlassFish developers and users 23
  • 24. Create an OSGi Bundle – Maven • Create a Maven project • Implement “BundleActivator” • Update “pom.xml” • Change packaging to “bundle” • Add dependencies on OSGI APIs • Use “maven-bundle-plugin” to package • Build the bundle http://blogs.oracle.com/arungupta/entry/totd_36_deploy_osgi_bundles 24
  • 25. Create an OSGi bundle – NetBeans http://blogs.oracle.com/arungupta/entry/totd_125_creating_an_osgi 25
  • 26. Create an OSGi bundle – NetBeans http://blogs.oracle.com/arungupta/entry/totd_125_creating_an_osgi 26
  • 27. Create an OSGi bundle – Eclipse http://blogs.oracle.com/arungupta/entry/totd_126_creating_an_osgi 27
  • 28. OSGi Bundles in GlassFish • asadmin deploy –type osgi • “cp”/“rm” glassfish/domains/domain1/autodeploy/bundles • telnet localhost 6666 • Apache Felix Web Console • REST Console bundle • Perl-based shell (Osgish) • VisualVM OSGi Plugin • Supports OBR • Discover and deploy dependencies together http://blogs.oracle.com/arungupta/entry/totd_118_managing_osgi_bundles 28
  • 29. 29
  • 30. Dynamic Discovery of OSGi service OSGi Export-Package API Service Registry Import-Package Impl Bundle-Activator Import-Package cker Client Service Tra Bundle-Activator Filters http://blogs.oracle.com/arungupta/entry/totd_131_dynamic_osgi_services 30
  • 31. Why OSGi in Enterprise Apps ? • Improved modularity • Reusable bundles • Dependencies are more visible • Better isolation / Cleaner class loading model • Better version control • Faster deployment cycle • Better tools for deployment • Observable bundle life cycle • Service Tracking • Criteria-based service selection 31
  • 32. Why Java EE in Enterprise Apps ? • Better API (JPA, JTA, JAXB, JNDI) • Better component model (Servlet, EJB, JAX-RS) • Better frameworks (JSF, CDI) • Ease-of-use (Annotations, Convention-over- configuration) • Platform provided integrated infrastructure services • Transaction, Security, Persistence, Remoting, ... • Many more reasons ... 32
  • 33. 33
  • 34. OSGi Enterprise Expert Group The OSGi Enterprise Expert Group (EEG) is chartered to define the technical requirements and specifications to tailor and extend the OSGi Service Platform to address information technology software infrastructure use cases found in enterprise business scenarios. http://www.osgi.org/EEG/HomePage 34
  • 35. OSGi EEG Focus • Scaling, including multi-container and multi-process environments • Distributed and/or federated service model for • Multiple Service Platforms • External, heterogeneous systems • Requirements for extensions to the OSGi publish/find/bind service model • Enterprise-class life cycle and configuration management • Integration of established Java EE technology into OSGi 35
  • 36. Hybrid Applications “A hybrid application is an OSGi bundle as well as a Java EE archive and hence has both an OSGi bundle context and Java EE context at runtime and can leverage capabilities of both the platforms.” 36
  • 37. Why Hybrid Apps ? Best of both worlds!!! Why do you want to learn new APIs ? 37
  • 38. Role of GlassFish • Provides a runtime for Hybrid Applications • Implements Java EE related OSGi services and standards • Don't have to assemble the bits • OSGi is no longer under the cover • Raises visibility from GlassFish developers to users 38
  • 39. OSGi Compendium Specs in GlassFish • OSGi/HTTP Service • OSGi/Web Application (rfc #66) • OSGi/JTA (rfc #98) • OSGi/JDBC (rfc #122) • OSGi/JPA (rfc #143) • OSGi/JNDI (rfc #142, coming post 3.1) http://wikis.sun.com/display/GlassFish/3.1OSGi 39
  • 40. OSGi/Web Application (rfc #66) • Web Application Bundle (WAB) • WAR + OSGi + Web-ContextPath Header • Can use all enterprise APIs include JPA with lazy loading • Sample manifest: Manifest-Version: 1.0 Import-Package: javax.servlet.http; javax.persistence Bundle-ClassPath: WEB-INF/classes/,WEB-INF/lib/entities.jar Bundle-Version: 1.0 Bundle-ManifestVersion: 2 Web-ContextPath: /hello Bundle-SymbolicName: test.hellowab • Wrapped WAR Support • webbundle: URL scheme 40
  • 41. OSGi Declarative Services • Complications of Publish/Find/Bind • Long startup time • Memory footprint • Complex service programming model • OSGi services in Java EE @Resource(mappedName=”osgiName”) SomeOSGiService osgiService; • JNDI Lookup • Portable, no OSGi dependencies in application • Exported APIs visible to Java EE apps 41
  • 42. OSGi Declarative Service <scr:component enabled="true" name="hello-service">     <implementation class="org.glassfish.samples.osgi.helloservice.impl.HelloImpl"/>     <service servicefactory="false"> OSGI-INF/       <provide interface="org.glassfish.samples.osgi.helloservice.api.HelloService"/>     </service> serviceComponents.xml     <property name="service.pid" value="hello-service"/> </scr:component> Export-Package API Servlet Client ... import org.glassfish.samples.osgi.helloservice.api.HelloService; HelloImpl @WebServlet(urlPatterns={"/HelloClient"}) public class HelloClient extends HttpServlet { @Resource(mappedName="hello-service") HelloService helloService; @Resource(mappedName="howdy-service") HowdyImpl HelloService howdyService; ... http://blogs.oracle.com/arungupta/entry/totd_124_osgi_declarative_services 42
  • 43. OSGi Declarative Services import org.apache.felix.scr.annotations.Component; import org.apache.felix.scr.annotations.Service; import org.glassfish.samples.osgi.helloservice.api.HelloService; maven- bundle- @Component(name="hello-service") plugin @Service public class HelloImpl implements HelloService { maven- public String sayHello(String name) { scr- return "Hello " + name; plugin } } http://blogs.oracle.com/arungupta/entry/totd_124_osgi_declarative_services 43
  • 44. JAX-WS & OSGi Artifacts WSDL JAX-WS JAX-WS Endpoint Client Business Method 44
  • 45. JAX-WS & OSGi Artifacts WSDL JAX-WS JAX-WS Endpoint Client Business Delegate Method Query Registry OSGi OSGi Register Service Service Bundle Registry Business Method http://blogs.oracle.com/arungupta/entry/totd_130_invoking_a_osgi 45
  • 46. OSGi & EJB Client OSGi Service Registry login Export-Package API register Export-EJB Impl Container-managed JPA LoadData http://weblogs.java.net/blog/ss141213/archive/2010/03/30/ejb-osgi-service-demo-eclipsecon 46
  • 47. OSGi + EJB • Export EJB as OSGi services Export-EJB: ALL/None/<names> • Pure OSGi components can discover/invoke • Advantages • Declarative security, transaction, CDI, … are available to non-EE components • Tx context from pure OSGi bundle propagates to invoked EJB • Ditto for security and persistence context 47
  • 48. OSGi & JMS Export-EJB: None Consumer Destination ConnectionFactory Messages# BundleActivator Producer OSGi Config Admin http://www.java.net/blog/ss141213/archive/2010/04/21/osgijmsmdb-example 48
  • 49. Extending GlassFish v3 Using Spring dm Container • Simple Spring bean implementing the service • Invoke the service from a servlet using standard @Resource injection • Single runtime for both Spring and full Java EE http://blogs.oracle.com/dochez/entry/glassfish_v3_extensions_part_4 49
  • 50. OSGi + CDI OSGi Export-Package API Service Registry Import-Package Impl Bundle-Activator Import-Package cker ice Client Ser SGiServ @OviceTra Bundle-Activator Filters http://blogs.oracle.com/arungupta/entry/totd_154_dynamic_osgi_services 50
  • 51. OSGi + CDI ServiceTracker tracker = new ServiceTracker(context, Hello.class.getName(), null); tracker.open(); Hello hello = (Hello) tracker.getService(); System.out.println(hello.sayHello("Duke")); @Inject @OSGiService(dynamic=true) Hello hello; System.out.println(hello.sayHello("Duke")); • Injected reference is never null because of CDI proxies 51
  • 52. OSGi + JPA • Enhancement of JPA entities at runtime • Entities + persistence.xml bundled as OSGi bundle • EntityManagerFactory available as @Inject @OSGiService • Shared persistence unit and there by shared second level cache 52
  • 53. OSGi + EE Resources • Define a DataSource, JavaMail, or JMS resource available in Admin Console • Corresponding OSGi service is already available • Resource/Services are dynamic 53
  • 54. JavaOne 2010 / EclipseCon 2011 Hands-on Lab NetBeans - http://blogs.oracle.com/arungupta/entry/s313522_instructions_for_osgi_enabled Eclipse - http://blogs.oracle.com/arungupta/entry/screencast_38_developing_osgi_enabled 54
  • 55. References • oracle.com/javaee • glassfish.org • oracle.com/goto/glassfish • blogs.oracle.com/theaquarium • youtube.com/GlassFishVideos • Follow @glassfish • http://wikis.sun.com/display/GlassFish/OSGi • http://wikis.sun.com/download/attachments/20 9655166/GF-OSGi-Features-1.0.pdf 55
  • 56. <Insert Picture Here> OSGi-enabled Java EE Applications in GlassFish Arun Gupta, Java EE & GlassFish Guy blogs.oracle.com/arungupta, @arungupta