http://www.infoq.com/presentations/colyer-keynote-springone2gx
Telnet console 2401 – ssh shell -2402 in DM2 .
2.0 release will have both osgi console and dm shell (osgi console will be disabled by default)
Dm Kernel – lightweight – no web profile.
No plans to support EJB
Bundles in usr directory is not exposing service because – not in active state – need to get some code to move it to active state.
Bundles in pick up move to active state by default.
Import – org.osgi.framework – will not work , as jar is in lib directory .Work Around is to copy paste it into repository/bundles/usr.
Spring dm automatically creates a property for service by name – bean name.
Also application context itself is exposed as service – can be verified with osgi console
Logback – for logging in dm 2.0
http://logback.qos.ch/
In JVM failure - can be achieved using ranking attribute
Load time weaving – more complex when many bundles are there , so hardcoded in DM server - just below boot Classloader (this is not possible with aspectj being a bundle)
Require Bundle(used for Split packages)
Require bundle – all exported packages are imported
Deployment pipeline – Like wars and non osgi headers still works under spring DM because –this is processed by DM server to convert it into osgi complaint bundle - End result is visible in work directory
When Dm server starts all bundles are not seen in osgi console – They move to resolved state , only when required(looking to find required imports) they move to resolved state.
Osgi reference has bean name attribute which can be used as default filter.
Bundles have version , services have ranking – Service ranking is part of OSGi spec
Custom osgi commands – implement Command Provider – equinox specific
2.0 modules – has attribute - sticky for service.
Spring integration
Enterprise Integration Pattern –implementers are SI and Camel
http://www.ibm.com/developerworks/library/os-ecl-osgiconsole/index.html
Thursday, November 12, 2009
Spring Training -Day 6
Spring Training -Day 5
Create new platform (may be equinox 3.5) – eclipse may be using 3.4
Eclipse takes ini file – which when bundles added to a folder adds it to the file –Eclipse can do it easily.
Uses conflict may be ClassCastExceptions or Linkage Exceptions
http://blog.springsource.com/2008/11/22/diagnosing-osgi-uses-conflicts/
Uses is whatever the bundle is resolved to .(Ex If struts has import;log4j and in any Export blabla;uses log4j – no issues because it will resolves to log4j in applications classpath just forcing us to use the same log4j.. When uses is with version becomes very critical)
Ideally 3rd party guys should not be ideally using uses –unless they want to restrict , but still relaxed using import in struts lib without version – so whatever 3rd party resolves to in our lib.
Import without version no – resolves to latest.
Class loader performance may increase -steps reduced for loading from the conventional model.
Osgi command – packages - searches for the package in all bundles.
BundleContext- used to install/uninstall bundles, deal with events and services programmatically
When multiple services have same ranking – will be solved based on service id – least one – the first one registered.
Extender bundle
Spring extender bundle creates bundle context for bundles which are in ACTIVE state . May be this is the reason bundles in usr lib cannot exposes services.(because they don’t move to active state)
Application context for bundles are created asynchronously when DM server starts up. It can be changed to get a sync behaviour.
When synchronous, it does not spawn a new thread for creating context and waits until context is created.(If any bundle is picked up before by the extender that may run in a separate thread)
Appcontext fails – it uninstalls the bundle – hence cannot verify errors from osgi console.
Service mandatory wait is asynchronous.
Extender Bundle – is like SpringContextLoadListener in web Apps
Extender bundles creates appContext for all bundles which are in ACTIVE state.
Accessing BundleContext – implements BundleContextAware
Either put appcontext file in META-INF / spring or use Spring-Context header in manifest file.
Mandatory Service
Timeout
Cardinality - 1:1 ,0:1, 0:n,1:n – renamed as availability attribute in Dm 2.0
osgi: set and osgi:list
Consumers can listen to bind-unbind events
Publishers can register to register and unregister events.
RFC 124 – Moving towards component and service than spring specific osgi:service and bean .
Spring Training - Day 4
Spring Security
http://blog.springsource.com/2009/01/02/spring-security-customization-part-1-customizing-userdetails-or-extending-grantedauthority/
http://blog.springsource.com/2009/01/02/spring-security-customization-part-2-adjusting-secured-session-in-real-time/
Principal –User,Device or system that performs action
Authentication –Establishing principals credentials are proper.(LDAP ,Database etc)
Authorization –Deciding if a principal is allowed to perform an action.
Secured Item – resource being secured.
Spring security is Portable across containers.
Secure item – method , web page(url) or flow(web flow)
Voters – 2 default- role based and authenticate based
3 types of AccessDecision manager (judges)
1. AffirmativeBased (anyone says yes –it’s a yes) -Default
2. Unanimous based – very conservative – one voter says no – it’s a no
3. Consensus based – based on majority says yes – majority is configurable – all these are configurable
Configuration in Web Application
<security:http> - configures default accessmgr, default filters, voters, security interceptor etc
Configures a servlet filter in web.xml
<security intercept-url pattern=”…” filters=”” acess=””/> can be configured
Spring security Taglibs since spring 2.0
Method Security(based on AOP)
Xml based - point cuts in xml with access role
Configuration based – have to register to get this enabled. , also has JSR specific annotations
Bad to put security constraints inside class – use xml approach over annotations – security is infrastructure
Advanced Security In web –
HttpSessionContextIntegrationFilter – stores context in session - if exists gets it and binds to thread local –way back binds it to session
LogoutFilter –clears security context on logoff
AuthenticationProcessingFilter - If not authenticated then send to login page
ExceptionTranslationFilter – converts exception into http responses and redirects
FilterSecurityInterceptor - authorises web requests based on url patterns
Any of these can be replaced and any can be added in the required order.
So filters for all these purposes are already placed.
Security context can be obtained anywhere in the code using – spring class SecurityContext.getCtx();
Obfuscating – is just setting bean – to avoid knowing technology
Spring Remoting
Consistency across all protocols and flipping from one protocol to another is simple.
Supported Protocols
RMI
HttpInvoker – is a protocol –over http
EJB
Hessian/Burlap(for sending XML over HTTP –Less predictable with complex types)
Hessian –uses binary xml
Burlap –uses textual xml
Spring on Server & Client –Use Http Invoker
Java Env but no Web Server –Use RMI
Interop with other languages Using HTTP – Hessian
Spring JMS
Message,Destination,Connection,Session,MessageProducer,MesageConsumer
Spring JMSTemplate
DynamicDestinationResolver
JMSTemplate – takes connectionFactory,MessageConvertor,DestinationResolver,
Spring JMX
MBean is a standard java bean with an additional management interface – attributes (with getters and setters) and Operations
Rmi is default protocol – can be changed
JVM runs a default MBean server , we can also override this by one given from spring
<context mbean –export>
Default –export everything – mostly a bundle will have only mbeans exposed
Export bean as MBean.
Strategies –
objectNamingStratergy- keyNamingStratergy(Default) , IdetitynamingStratergy(naming by objected from JVM),MetaDataNamingStratergy (annotations) – not recommended
One strategy can be overriden by the other.
MBeanInfoAssembler- by implementations of the MBeanInfoAssembler interface
To run with JMX add -Dcom.sun.management.jmxremote as VM param
OSGI
Single Version mean atleast that version
Resolves to the greatest -
Running in eclipse
Added vm param for clean
In manifest given space for the next line – because its reserved for headers
Import package , not mentioned – binds to the latest
Resolved phase- doesn’t mean classes are loaded
When classloader gets GC’ed - when objects are Gc'ed and all bundles importing from this bundle are refreshed(osgi refresh command)
Using Eclipse to simulate Equinox
Run configurations - > OSGi Configurations – new - Uncheck target platform - In filter search org.eclipse.osgi(any version ) – select it – apply – run
ss will show only equinox bundle.
Change run config as - -Dosgi.clean=true
Create new project – plugin – new plugin project - select run environment as equinox
Can run this new project under equinox with the created run configurations – Run as ...