The document outlines the key features of Servlet 3.0 including making development easier through the use of annotations, increased pluggability through modular web deployment descriptors and programmatic configuration, support for asynchronous processing to improve performance of blocking operations, and enhanced security. Major changes include simplifying deployment through optional web.xml, dynamic registration of servlets and filters, asynchronous processing APIs, and modular web fragments to simplify framework configuration. The new features aim to enable modern web application styles and increase developer productivity.
Changes in WebLogic 12.1.3 Every Administrator Must KnowBruno Borges
WebLogic 12c has evolved quite a lote since its first release (12.1.1). Now on 12.1.3 it has more to offer, optimizations for Exalogic, support of some Java EE 7 APIs and more.
Complete Training on Youtube with all topics - FREE
http://www.youtube.com/playlist?list=PLeHUvPtMTsdeaE4YBiPPZlMYVaDfKt_DH
Weblogic Application Server overview and concepts
Weblogic integration with apache and security hardening with multi user realms and SSL
JMS Overview with queues/topic and jms bridges
JDBC overview with failover and HA modes
WLST & Node manager commands and setup
Weblogic deployment concepts
Offline and online backup recovery comcepts
Changes in WebLogic 12.1.3 Every Administrator Must KnowBruno Borges
WebLogic 12c has evolved quite a lote since its first release (12.1.1). Now on 12.1.3 it has more to offer, optimizations for Exalogic, support of some Java EE 7 APIs and more.
Complete Training on Youtube with all topics - FREE
http://www.youtube.com/playlist?list=PLeHUvPtMTsdeaE4YBiPPZlMYVaDfKt_DH
Weblogic Application Server overview and concepts
Weblogic integration with apache and security hardening with multi user realms and SSL
JMS Overview with queues/topic and jms bridges
JDBC overview with failover and HA modes
WLST & Node manager commands and setup
Weblogic deployment concepts
Offline and online backup recovery comcepts
Have you ever used Oracle WebLogic Server? If the answer is no, this presentation is for you. We explain core WebLogic Server concepts and perform a live walkthrough of the console covering core administration areas that include managed servers, JVM servers, JMS resources, logs, data sources, application deployments, and more.
Weblogic 11g admin basic with screencastRajiv Gupta
Installation of weblogic 11g
Creation and configuration of Admin server with three managed server
Creation of And Configuring Machines in Weblogic Server
Administering Managed Server With Node Manager
The following depicts the automatic automatic migration of administration and managed server in case of failure
This concept is useful very useful in site failover as well as managed server failover
We have used the Virtual IP and Virtual Hostname concept
To learn the architecture of WebLogic Server especially in terms of machines, domains and
servers.
• Installation and Configuration of WebLogic Server.
• Handling routine Administration tasks.
• Performing Backups and recovery.
• Monitoring server with GUI and command line tools.
• Setting up a cluster and distributing the resources to the cluster.
• To configure Oracle HTTP Server as the Web-tier front end for WebLogic Server instances and
clusters.
• Deploying and managing JavaEE applications/ large-scale Java EE applications throughout the
development and production life cycle.
• Configuring resource and application security
Java EE 8 Presentation given at NYC Java SIG on May 4, 2017. This presentation provides the latest information on the forthcoming release of Java EE 8 in June.
Deep Dive: Alfresco Core Repository (... embedded in a micro-services style a...J V
Alfresco Summit 2014 (London)
Though best practice is to leverage Alfresco through the well defined API's, it can be useful to understand the internals of the repository so that your development efforts are the most effective. A deep understanding of the repository will help you to evaluate performance bottlenecks, look for bugs, or make contributions. This session provides an overview of the repository internals, including the major components, the key services, subsystems, and database. We then provide an example where we leverage the repository in a micro-service architecture while building Alfresco's future cloud products and show how the different parts of the repository interact to fulfill requests.
http://summit.alfresco.com/london/sessions/diving-deep-alfresco-repository
https://www.youtube.com/watch?v=TAE9UjC0xxc
A straight-forward explanation with an example of how JSR-88 aka Deployment Plans can be used in WebLogic Server to make changes to values in deployment descriptors without modifying application archives.
Have you ever used Oracle WebLogic Server? If the answer is no, this presentation is for you. We explain core WebLogic Server concepts and perform a live walkthrough of the console covering core administration areas that include managed servers, JVM servers, JMS resources, logs, data sources, application deployments, and more.
Weblogic 11g admin basic with screencastRajiv Gupta
Installation of weblogic 11g
Creation and configuration of Admin server with three managed server
Creation of And Configuring Machines in Weblogic Server
Administering Managed Server With Node Manager
The following depicts the automatic automatic migration of administration and managed server in case of failure
This concept is useful very useful in site failover as well as managed server failover
We have used the Virtual IP and Virtual Hostname concept
To learn the architecture of WebLogic Server especially in terms of machines, domains and
servers.
• Installation and Configuration of WebLogic Server.
• Handling routine Administration tasks.
• Performing Backups and recovery.
• Monitoring server with GUI and command line tools.
• Setting up a cluster and distributing the resources to the cluster.
• To configure Oracle HTTP Server as the Web-tier front end for WebLogic Server instances and
clusters.
• Deploying and managing JavaEE applications/ large-scale Java EE applications throughout the
development and production life cycle.
• Configuring resource and application security
Java EE 8 Presentation given at NYC Java SIG on May 4, 2017. This presentation provides the latest information on the forthcoming release of Java EE 8 in June.
Deep Dive: Alfresco Core Repository (... embedded in a micro-services style a...J V
Alfresco Summit 2014 (London)
Though best practice is to leverage Alfresco through the well defined API's, it can be useful to understand the internals of the repository so that your development efforts are the most effective. A deep understanding of the repository will help you to evaluate performance bottlenecks, look for bugs, or make contributions. This session provides an overview of the repository internals, including the major components, the key services, subsystems, and database. We then provide an example where we leverage the repository in a micro-service architecture while building Alfresco's future cloud products and show how the different parts of the repository interact to fulfill requests.
http://summit.alfresco.com/london/sessions/diving-deep-alfresco-repository
https://www.youtube.com/watch?v=TAE9UjC0xxc
A straight-forward explanation with an example of how JSR-88 aka Deployment Plans can be used in WebLogic Server to make changes to values in deployment descriptors without modifying application archives.
5 Skills To Force Multiply Technical Talents.pdfArun Gupta
This talk explains what are non-technical skills, why they are relevant, and what are some of the most important skills to master to force multiply your technical talent.
Software Delivery At the Speed of AI: Inflectra Invests In AI-Powered QualityInflectra
In this insightful webinar, Inflectra explores how artificial intelligence (AI) is transforming software development and testing. Discover how AI-powered tools are revolutionizing every stage of the software development lifecycle (SDLC), from design and prototyping to testing, deployment, and monitoring.
Learn about:
• The Future of Testing: How AI is shifting testing towards verification, analysis, and higher-level skills, while reducing repetitive tasks.
• Test Automation: How AI-powered test case generation, optimization, and self-healing tests are making testing more efficient and effective.
• Visual Testing: Explore the emerging capabilities of AI in visual testing and how it's set to revolutionize UI verification.
• Inflectra's AI Solutions: See demonstrations of Inflectra's cutting-edge AI tools like the ChatGPT plugin and Azure Open AI platform, designed to streamline your testing process.
Whether you're a developer, tester, or QA professional, this webinar will give you valuable insights into how AI is shaping the future of software delivery.
LF Energy Webinar: Electrical Grid Modelling and Simulation Through PowSyBl -...DanBrown980551
Do you want to learn how to model and simulate an electrical network from scratch in under an hour?
Then welcome to this PowSyBl workshop, hosted by Rte, the French Transmission System Operator (TSO)!
During the webinar, you will discover the PowSyBl ecosystem as well as handle and study an electrical network through an interactive Python notebook.
PowSyBl is an open source project hosted by LF Energy, which offers a comprehensive set of features for electrical grid modelling and simulation. Among other advanced features, PowSyBl provides:
- A fully editable and extendable library for grid component modelling;
- Visualization tools to display your network;
- Grid simulation tools, such as power flows, security analyses (with or without remedial actions) and sensitivity analyses;
The framework is mostly written in Java, with a Python binding so that Python developers can access PowSyBl functionalities as well.
What you will learn during the webinar:
- For beginners: discover PowSyBl's functionalities through a quick general presentation and the notebook, without needing any expert coding skills;
- For advanced developers: master the skills to efficiently apply PowSyBl functionalities to your real-world scenarios.
Slack (or Teams) Automation for Bonterra Impact Management (fka Social Soluti...Jeffrey Haguewood
Sidekick Solutions uses Bonterra Impact Management (fka Social Solutions Apricot) and automation solutions to integrate data for business workflows.
We believe integration and automation are essential to user experience and the promise of efficient work through technology. Automation is the critical ingredient to realizing that full vision. We develop integration products and services for Bonterra Case Management software to support the deployment of automations for a variety of use cases.
This video focuses on the notifications, alerts, and approval requests using Slack for Bonterra Impact Management. The solutions covered in this webinar can also be deployed for Microsoft Teams.
Interested in deploying notification automations for Bonterra Impact Management? Contact us at sales@sidekicksolutionsllc.com to discuss next steps.
Let's dive deeper into the world of ODC! Ricardo Alves (OutSystems) will join us to tell all about the new Data Fabric. After that, Sezen de Bruijn (OutSystems) will get into the details on how to best design a sturdy architecture within ODC.
Kubernetes & AI - Beauty and the Beast !?! @KCD Istanbul 2024Tobias Schneck
As AI technology is pushing into IT I was wondering myself, as an “infrastructure container kubernetes guy”, how get this fancy AI technology get managed from an infrastructure operational view? Is it possible to apply our lovely cloud native principals as well? What benefit’s both technologies could bring to each other?
Let me take this questions and provide you a short journey through existing deployment models and use cases for AI software. On practical examples, we discuss what cloud/on-premise strategy we may need for applying it to our own infrastructure to get it to work from an enterprise perspective. I want to give an overview about infrastructure requirements and technologies, what could be beneficial or limiting your AI use cases in an enterprise environment. An interactive Demo will give you some insides, what approaches I got already working for real.
PHP Frameworks: I want to break free (IPC Berlin 2024)Ralf Eggert
In this presentation, we examine the challenges and limitations of relying too heavily on PHP frameworks in web development. We discuss the history of PHP and its frameworks to understand how this dependence has evolved. The focus will be on providing concrete tips and strategies to reduce reliance on these frameworks, based on real-world examples and practical considerations. The goal is to equip developers with the skills and knowledge to create more flexible and future-proof web applications. We'll explore the importance of maintaining autonomy in a rapidly changing tech landscape and how to make informed decisions in PHP development.
This talk is aimed at encouraging a more independent approach to using PHP frameworks, moving towards a more flexible and future-proof approach to PHP development.
State of ICS and IoT Cyber Threat Landscape Report 2024 previewPrayukth K V
The IoT and OT threat landscape report has been prepared by the Threat Research Team at Sectrio using data from Sectrio, cyber threat intelligence farming facilities spread across over 85 cities around the world. In addition, Sectrio also runs AI-based advanced threat and payload engagement facilities that serve as sinks to attract and engage sophisticated threat actors, and newer malware including new variants and latent threats that are at an earlier stage of development.
The latest edition of the OT/ICS and IoT security Threat Landscape Report 2024 also covers:
State of global ICS asset and network exposure
Sectoral targets and attacks as well as the cost of ransom
Global APT activity, AI usage, actor and tactic profiles, and implications
Rise in volumes of AI-powered cyberattacks
Major cyber events in 2024
Malware and malicious payload trends
Cyberattack types and targets
Vulnerability exploit attempts on CVEs
Attacks on counties – USA
Expansion of bot farms – how, where, and why
In-depth analysis of the cyber threat landscape across North America, South America, Europe, APAC, and the Middle East
Why are attacks on smart factories rising?
Cyber risk predictions
Axis of attacks – Europe
Systemic attacks in the Middle East
Download the full report from here:
https://sectrio.com/resources/ot-threat-landscape-reports/sectrio-releases-ot-ics-and-iot-security-threat-landscape-report-2024/
DevOps and Testing slides at DASA ConnectKari Kakkonen
My and Rik Marselis slides at 30.5.2024 DASA Connect conference. We discuss about what is testing, then what is agile testing and finally what is Testing in DevOps. Finally we had lovely workshop with the participants trying to find out different ways to think about quality and testing in different parts of the DevOps infinity loop.
UiPath Test Automation using UiPath Test Suite series, part 3DianaGray10
Welcome to UiPath Test Automation using UiPath Test Suite series part 3. In this session, we will cover desktop automation along with UI automation.
Topics covered:
UI automation Introduction,
UI automation Sample
Desktop automation flow
Pradeep Chinnala, Senior Consultant Automation Developer @WonderBotz and UiPath MVP
Deepak Rai, Automation Practice Lead, Boundaryless Group and UiPath MVP
Builder.ai Founder Sachin Dev Duggal's Strategic Approach to Create an Innova...Ramesh Iyer
In today's fast-changing business world, Companies that adapt and embrace new ideas often need help to keep up with the competition. However, fostering a culture of innovation takes much work. It takes vision, leadership and willingness to take risks in the right proportion. Sachin Dev Duggal, co-founder of Builder.ai, has perfected the art of this balance, creating a company culture where creativity and growth are nurtured at each stage.
Connector Corner: Automate dynamic content and events by pushing a buttonDianaGray10
Here is something new! In our next Connector Corner webinar, we will demonstrate how you can use a single workflow to:
Create a campaign using Mailchimp with merge tags/fields
Send an interactive Slack channel message (using buttons)
Have the message received by managers and peers along with a test email for review
But there’s more:
In a second workflow supporting the same use case, you’ll see:
Your campaign sent to target colleagues for approval
If the “Approve” button is clicked, a Jira/Zendesk ticket is created for the marketing design team
But—if the “Reject” button is pushed, colleagues will be alerted via Slack message
Join us to learn more about this new, human-in-the-loop capability, brought to you by Integration Service connectors.
And...
Speakers:
Akshay Agnihotri, Product Manager
Charlie Greenberg, Host
"Impact of front-end architecture on development cost", Viktor TurskyiFwdays
I have heard many times that architecture is not important for the front-end. Also, many times I have seen how developers implement features on the front-end just following the standard rules for a framework and think that this is enough to successfully launch the project, and then the project fails. How to prevent this and what approach to choose? I have launched dozens of complex projects and during the talk we will analyze which approaches have worked for me and which have not.
Accelerate your Kubernetes clusters with Varnish CachingThijs Feryn
A presentation about the usage and availability of Varnish on Kubernetes. This talk explores the capabilities of Varnish caching and shows how to use the Varnish Helm chart to deploy it to Kubernetes.
This presentation was delivered at K8SUG Singapore. See https://feryn.eu/presentations/accelerate-your-kubernetes-clusters-with-varnish-caching-k8sug-singapore-28-2024 for more details.
3. The following 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.
3
4. Agenda
• Overview
• Ease of Development
• Dynamic registration
• Pluggability
• Asynchronous Support
• Security Enhancements
• Miscellaneous
4
5. Overview
• Final release done in December 2009.
• ~20 members in the expert group
– Good mix of representation from major Java EE
vendors, open source web container developers and
framework authors
• Main areas of focus
– Ease of Development
– Pluggability
– Asynchronous support
– Security 5
6. Ease of Development
• Focus on Ease of Development in the Servlet 3.0 API
• Enhanced APIs to use new Java SE language features
introduced since J2SE 5.0
• Annotations for declarative style of programming
– web.xml optional
• Generics for type safety in API where possible
• Better defaults
• Convention over configuration
6
7. Ease of Development
Use of annotations
• Annotations to declare Servlets, Filters, Listeners and
servlet security
– @WebServlet – Define a Servlet
– @WebFilter - Define a Filter
– @WebListener – Define a Listener
– @WebInitParam – Define init param
– @MultipartConfig – Define file upload properties
– @ServletSecurity – Define security constraints
• Can use web.xml to override values specified in
annotations 7
8. Ease of Development
Use of annotations (contd)
• @WebServlet for defining a Servlet
– Annotations MUST have at a minimum a URL pattern
for the Servlet
– All other attributes optional with reasonable defaults
– For example, the default name of the Servlet is the
fully qualified class name
– Class MUST still extend HttpServlet
– Method contracts for doGet, doPost (and others)
derived from HttpServlet
8
9. Servlet 2.5 example
At least 2 files
<!--Deployment /* Code in Java Class
descriptor web.xml */
-->
<web-app> package com.sun;
<servlet> public clas s
<servlet- MyServlet extend s
name>MyServlet HttpServlet
</servlet- {
name> public void
<servlet-
class> doGet(HttpServletRequ
9
12. Dynamic Registration
Register
• Performed during ServletContext initialization
• ServletContext#add[Servlet | Filter]
– Overloaded versions take [Servlet | Filter] name and
• Fully qualified [Servlet | Filter] class name or
• Class <? extends [Servlet | Filter]> or
• [Servlet | Filter] instance
– User returned Registration handle to configure all
aspects of [Servlet | Filter]
12
13. Dynamic Registration
Create and register
• ServletContext#create[Servlet | Filter]
– Takes Class<? Extends [Servlet | Filter]>
argument
– Supports resource injection by container
– Returned [Servlet | Filter] instance may be fully
customized before it is registered via the
• ServletContext.add[Servlet | Filter]
methods
13
14. Dynamic Registration
Lookup
• ServletContext#get[Servlet |
Filter]Registration
– Takes [Servlet | Filter] name as argument
– Returned Registration handle provides subset of
configuration methods
– May only be used to add initialization parameters and
mappings
– Conflict returned as
• java.util.Set
14
17. Pluggability
• Enable use of libraries and framework without boiler
plate configuration in deployment descriptors
– Put the burden on the framework developer
• Modularize web.xml to allow frameworks to be self-
contained within their own JAR file
• Programmatic configuration APIs
• Use of annotations
17
18. Pluggability
Motivation for web.xml modularization
• Use of framework requires (possibly complex)
configuration in web.xml
• For example
– Declare a controller Servlet
– Logging and security Filters
– Declare Listeners to perform actions at various points
in the lifecycle of the application
• Can get complex as dependencies increase
• Frameworks also need to document all the configuration
that needs to be done 18
19. Pluggability
web-fragment.xml
• web-fragment.xml is descriptor for framework / library
• Included in META-INF directory
• Container responsible for discovering fragments and
assembling the effective deployment descriptor
• Almost identical to web.xml
– Ordering related elements different
• Only JAR files in WEB-INF/lib considered as
fragments
19
21. Pluggability
Ordering
• Compatible with JavaServer™ Faces
• Fragments identified by <name>
• web.xml may declare absolute ordering of fragments
via <absolute-ordering>
• Fragments may declare ordering preferences relative to
other fragments via <ordering> with nested <before>
and <after>
– Ignored if <absolute-ordering> specified
• Special <others/> element moves fragment to
beginning or end of list of sorted fragments
21
22. Pluggability
Shared libraries
• Support plugging in of container installed JAR files
– Examples: JSF, JAX-WS, Spring
• Libraries may provide implementation of
ServletContainerInitializer
• Looked up via the JAR Services API in JDK 6
• Invoked before any Listeners during the initialization of
the application
22
23. Pluggability
Shared libraries (contd)
• ServletContainerInitializer expresses interest
in Classes via @HandlesTypes
• Container discovers classes that match
@HandlesTypes and passes them to
ServletContainerInitializer
• ServletContainerInitializer inspects passed in
Classes and may register Servlets and Filters based on
them
23
25. Pluggability
Resource sharing
• Static and JavaServer™ Pages (JSP) resources no
longer confined to web application's document root
• May be placed inside WEB-INF/lib/[*.jar]/META-
INF/resources
• Container must honor this new location when processing
HTTP requests and calls to
ServletContext#getResource[AsStream]
• Resources in document root take precedence over those
in bundled JAR files
25
26. Pluggability
Resource sharing example
mywebapp.war packaging:
/index.jsp
/WEB-INF/lib/shared.jar!/META-
INF/resources/shared.jsp
Request for:
http://localhost:8080/mywebapp/shared.jsp
will be served from:
/path/to/mywebapp/WEB-
INF/lib/shared.jar!/META-
INF/resources/shared.jsp 26
27. Why Asynchronous Servlets?
• Async Servlets are for:
– Waiting for resources (eg JDBC connection)
– Waiting for events (eg Chat)
– Waiting for responses (eg web services)
• Not for Async IO!
– Requests mostly small (single packet)
– Hard to asynchronously produce large responses
– Async IO support waiting for NIO2
27
28. Blocking waiting consumes resources
• Web Application using remote web services
– Handling 1000 requests / sec
– 50% requests call remote web service
– 500 threads in container thread pool
• If remote web service is slow (1000ms)
– Thread starvation in 1 second!
– 50% of requests use all 500 threads
28
29. Asynchronous API
Enable asynchronous support
• ServletRequest#isAsyncSupported()
– True if ALL [Filter|Servlet]s support async in
• the Filter chain
• the RequestDispatch chain
• Configured in
– web.xml
• <async-supported>true</async-
supported>
– With annotation
• @WebServlet(asyncSupported=true) 29
30. Asynchronous API
Start asynchronous processing
• AsyncContext ServletRequest#startAsync()
– Called by [Filter|Servlet]
– Response is NOT commited on return of:
• Servlet.service(request,response)
• Filter chain
• AsyncContext ServletRequest#startAsync
(ServletRequest
req,
ServletResponse
res)
30
31. Asynchronous API
AsyncContext
• AsyncContext#dispatch()
– Called by your asynchronous handler
– Schedule async dispatch:DispatcherType.ASYNC
– Response generated by [Filter|Servlet] using:
• container thread pool
• JSP, JSF or other frameworks usable
• JNDI, JTA, EJBs usable
• AsyncContext#dispatch(String path)
– Variation to async dispatch to specific Servlet 31
32. Asynchronous API
AsyncContext (contd)
• AsyncContext#complete()
– Called by your asynchronous handler
– Signals Response has been generated
• without [Filter|Servlet] dispatch
• without Servlet features
• Or with AsyncContext#start(Runnable r)
32
33. Asynchronous API usage styles
• startAsync() … dispatch()
– Retry request after async wait
– Filters re-applied if on DispatcherType.ASYNC
• startAsync() … dispatch(path)
– Use specific Servlet handling after async wait
• startAsync() … complete()
– Generate response asynchronously
33
34. Asynchronous API usage styles
• startAsync(req,res) … dispatch()
– Retry request after async wait
– Wrappers are kept
– RequestDispatcher#forward target used
• startAsync(req,res) … dispatch(path)
– Specific Servlet handling after async wait
• startAsync(req,res) … complete()
– Generate wrapped response asynchronously 34
35. Asynchronous API
Timeout
• Timeouts
– AsyncContext#setAsyncTimeout(long ms)
– By default error dispatch on timeout
• Listeners
– AsyncListener#OnTimeout
– AsyncListener#OnComplete
35
36. Security
Annotations to define security constraints
• @ServletSecurity used to define access control
constraints
• Can specify constraint for all HTTP methods via the
@HttpConstraint
• Or specify constraint for specific HTTP methods via the
@HttpMethodConstraint
• If both specified in the @ServletSecurity, the
@HttpConstraint applies to those methods not
specifically specified via the @HttpMethodConstraint
36
38. Security
Programmatic container authentication and logout
• HttpServletRequest#login(String username,
String password)
– Replacement for FBL
– Application supervises credential collection
• HttpServletRequest#authenticate(HttpServle
tResponse)
– Application initiates container mediated authentication
from a resource that is not covered by any
authentication constraints
– Application decides when authentication must occur
38
39. Security
Programmatic container authentication and logout
• Integration of additional container authentication
modules via Servlet Profile of JSR 196 recommended
• HttpServletRequest#logout
39
40. Miscellaneous Features / API enhancements
• Session tracking cookie configuration
– Via web.xml
– Programmatic via
javax.servlet.SessionCookieConfig
• Support for HttpOnly cookie attribute
– Example:
servletContext.getSessionCookieConfig().
setHttpOnly(true)
• Default error page
40
42. Miscellaneous Features / API (contd)
File upload
• ServletRequest#getParts
• ServletRequest#getPart
• @MultipartConfig
• Changes to web.xml
42
43. Summary
• Major revision since Servlet 2.4
• Comprehensive set of new features enable modern style
of web applications and greatly increases developer
productivity
• Simplifies assembly of large applications from reusable
components
43