title
Please take a moment to fill out this form. We will get back to you as soon as possible.
All fields marked with an asterisk (*) are mandatory.
Mastering Microservices with Spring Boot and Spring Cloud
Course Description
Overview
This Mastering Microservices with Spring Boot and Spring Cloud Training course introduces Spring Boot, Spring Cloud and the Netflix OSS suite as a way of deploying highly resilient and scalable RESTful services and web applications.
Spring Boot is a technology stack that builds on the popular Spring Framework to allow Spring-based applications as stand-alone jar files that host their own web servers. This approach works nicely with deployment automation and rapid scaling.
Cloud-based, highly-distributed applications face additional challenges in supporting a dynamic environment – especially around configuration, service discovery, service resilience and monitoring. Spring Cloud embraces and extends the popular suite of open source cloud tools published by Netflix (Eureka, Hystrix, Ribbon, etc).
This course is one step in the following Learning Journey:
Objectives
- Create Spring Boot projects
- Use databases and JPA in Spring Boot
- Create RESTful services with Spring Boot
- Deploy services that use Netflix Eureka, Hystrix and Ribbon to create resilient and scalable services
Audience
- IT Developers
Prerequisites
- Students should have experience with Java development
Topics
- What is the Spring Framework?
- Spring Philosophies
- Why Spring?
- Spring Modules
- Requirements and Supported Environments
- Using Spring with Servers
- Role of Spring Container
- Spring Example
- Avoiding Dependency on Spring
- Additional Spring Projects/Frameworks
- Summary
- Spring Containers
- Annotation-based Spring Bean Definition
- Scanning for Annotation Components
- Defining Component Scope Using Annotations
- JSR-330 @Named Annotation
- JSR-330 @Scope
- Annotation-based Dependency Injection
- Wiring Bean using @Inject
- @Autowired - Constructor
- @Autowired – Field
- @Autowired - method
- @Autowired – Collection
- @Autowired – Maps
- @Autowired & @Qualifier with Constructors, Fields, and Methods
- @Autowired & Custom Qualifiers
- @Autowired & Simple Custom Qualifier Field
- @Autowired & Simple Custom Qualifier Method
- @Autowired & CustomAutowireConfigurer
- Dependency Injection Validation
- @Resource
- @PostConstruct and @PreDestroy
- Summary
- Java @Configuration Classes
- Defining @Configuration Classes
- Loading @Configuration Classes
- Modularizing @Configuration Classes
- Qualifying @Bean Methods
- Trouble with Prototype Scope
- Configuration with Spring Expression Language
- Resolving Text Messages
- Spring Property Conversion
- Spring Converter Interface
- Using Custom Converters
- Spring PropertyEditors
- Registering Custom PropertyEditors
- Summary
- What is Spring Boot?
- Spring Boot Main Features
- Spring Boot on the PaaS
- Understanding Java Annotations
- Spring MVC Annotations
- Example of Spring MVC-based RESTful Web Service
- Spring Booting Your RESTful Web Service
- Spring Boot Skeletal Application Example
- Converting a Spring Boot Application to a WAR File
- Externalized Configuration
- Starters
- The 'pom.xml' File
- Spring Boot Maven Plugin
- HOWTO: Create a Spring Boot Application
- Summary
- Spring MVC
- Spring Web Modules
- Spring MVC Components
- DispatcherServlet
- Template Engines
- Spring Boot MVC Example
- Spring MVC Mapping of Requests
- Advanced @RequestMapping
- Composed Request Mappings
- Spring MVC Annotation Controllers
- Controller Handler Method Parameters
- Controller Handler Method Return Types
- View Resolution
- Spring Boot Considerations
- Summary
- DAO Support in Spring
- Spring Data Access Modules
- Spring JDBC Module
- Spring ORM Module
- DataAccessException
- @Repository Annotation
- Using DataSources
- DAO Templates
- DAO Templates and Callbacks
- ORM Tool Support in Spring
- Summary
- Spring JPA
- Benefits of Using Spring with ORM
- Spring @Repository
- Using JPA with Spring
- Configure Spring Boot JPA EntityManagerFactory
- Application JPA Code
- 'Classic' Spring ORM Usage
- Spring JpaTemplate
- Spring JpaCallback
- JpaTemplate Convenience Features
- Spring Boot Considerations
- Spring Data JPA Repositories
- Summary
- MongoDB
- MongoDB Features
- MongoDB's Logo
- Positioning of MongoDB
- MongoDB Applications
- MongoDB Data Model
- MongoDB Limitations
- MongoDB Use Cases
- MongoDB Query Language (QL)
- The CRUD Operations
- The
- find
- Method
- The
- findOne
- Method
- A MongoDB QL Example
- Data Inserts
- MongoDB vs Apache CouchDB
- Summary
- Reading Data in MongoDB
- The Query Interface
- Query Syntax is Driver-Specific
- Projections
- Query and Projection Operators
- MongoDB Query to SQL Select Comparison
- Cursors
- Cursor Expiration
- Writing Data in MongoDB
- An Insert Operation Example
- The Update Operation
- An Update Operation Example
- A Remove Operation Example
- Limiting Return Data
- Data Sorting
- Aggregating Data
- Aggregation Stages
- Accumulators
- An Example of an Aggregation Pipe-line
- Map-Reduce
- Summary
- Why MongoDB?
- MongoDB in Spring Boot
- Pom.xml
- Application Properties
- MongoRepository
- Custom Query Methods
- Supported Query Keywords
- Complex Queries
- Create JavaBean for Data Type
- Using the Repository
- Summary
- Many Flavors of Services
- Understanding REST
- RESTful Services
- REST Resource Examples
- REST vs SOAP
- REST Services With Spring MVC
- Spring MVC @RequestMapping with REST
- Working With the Request Body and Response Body
- @RestController Annotation
- Implementing JAX-RS Services and Spring
- JAX-RS Annotations
- Java Clients Using RestTemplate
- RestTemplate Methods
- Summary
- Securing Web Applications with Spring Security 3.0
- Spring Security 3.0
- Authentication and Authorization
- Programmatic v Declarative Security
- Getting Spring Security from Maven
- Spring Security Configuration
- Spring Security Configuration Example
- Authentication Manager
- Using Database User Authentication
- LDAP Authentication
- Summary
- Spring JMS
- JmsTemplate
- Connection and Destination
- JmsTemplate Configuration
- Transaction Management
- Example Transaction Configuration
- Producer Example
- Consumer Example
- Converting Messages
- Message Listener Containers
- Message-Driven POJO's Async Receiver Example
- Message-Driven POJO's Async Receiver Configuration
- Spring Boot Considerations
- Summary
- What is a 'Microservice'?
- One Helpful Analogy
- SOA - Microservices Relationship
- ESB - Microservices Relationship
- Traditional Monolithic Designs and Their Role
- Disadvantages of Monoliths
- Moving from a Legacy Monolith
- When Moving from a Legacy Monolith
- The Driving Forces Behind Microservices
- How Can Microservices Help You?
- The Microservices Architecture
- Utility Microservices at AWS
- Microservices Inter-connectivity
- The Data Exchange Interoperability Consideration
- Managing Microservices
- Implementing Microservices
- Embedding Databases in Java
- Microservice-Oriented Application Frameworks and Platforms
- Summary
- The Spring Cloud Configuration Server
- Why Configuration Management is Important
- Configuration Management Challenges in Microservices
- Separation of Configuration from Code
- Configuration Service
- How the Configuration Service Works
- Cloud Config Server Properties File
- Git Integration
- Properties
- Configuration Client
- Sample Client Config File
- Sample Client Application
- Dynamic Property Updates – Server
- Dynamic Property Update – Client
- Dynamic Property Update – Execute
- Summary
- Service Discovery in Microservices
- Load Balancing in Microservices
- Netflix Eureka
- Eureka Architecture
- Communications in Eureka
- Time Lag
- Eureka Deployment
- Peer Communication Failure between Servers
- Eureka Server Configuration
- Eureka Client/Service
- Eureka Client Properties
- Spring Cloud DiscoveryClient Interface
- ServiceInstance JSON
- ServiceInstance Interface
- What about Services
- Eureka and the AWS Ecosystem
- Summary
- Load Balancing in Microservices
- Netflix Ribbon
- Server-side load balance
- Client-side Load Balance
- Architecture
- Load Balance Rules
- RoundRobinRule
- AvailabilityFilteringRule
- WeightedResponseTimeRule
- RandomRule
- ZoneAvoidanceRule
- IPing Interface (Failover)
- Using Ribbon
- YAML Configuration
- Configuration Class
- Client Class
- Client Class Implementation
- Integration with Eureka (Service Discovery)
- Using Ribbon in the Amazon AWS Cloud
- Summary
- Netflix Hystrix
- Design Principles
- Design Principles (continued)
- Cascading Failures
- Bulkhead Pattern
- Circuit Breaker Pattern
- Thread Pooling
- Request Caching
- Request Collapsing
- Fail-Fast
- Fallback
- Using Hystrix
- Circuit Breaker Configuration
- Fallback Configuration
- Collapser Configuration
- Rest Controller and Handler
- Collapser Service (Part 1)
- How the Collapser Works
- Hystrix Monitor
- Enable Monitoring
- Turbine
- The Monitor
- Monitor details
- Summary
- Zuul is the Gatekeeper
- Request Handling
- Filters
- Filter Architecture
- Filter Properties
- filterType()
- filterOrder()
- shouldFilter()
- Run()
- Cancel Request
- Dynamic Filter Loading
- Filter Communications
- Routing with Eureka and Ribbon
- Summary
- Zipkin
- Zipkin Features
- Architecture
- The Collector
- Storage
- API
- GUI Console
- Zipkin Console Homepage
- View a Trace
- Trace Details
- Dependencies
- Dependency Details
- Zipkin in Spring Boot
- Zipkin Configuration
- Summary
- Lab 1. A Simple RESTful API in Spring Boot
- Lab 2. Use the Spring Web MVC Web Framework under Spring Boot
- Lab 3. Use the Spring JDBCTemplate under Spring Boot
- Lab 4. Use the Spring Data JPA under Spring Boot
- Lab 5. Learning the MongoDB Lab Environment
- Lab 6. Spring Data with MongoDB
- Lab 7. Create a RESTful API with Spring Boot
- Lab 8. Create a RESTful Client with Spring Boot
- Lab 9. Enable Basic Security
- Lab 10. Use AMQP Messaging with Spring Boot
- Lab 11. Use Netflix Eureka for Service Discovery
- Lab 12. Use Netflix Ribbon for Client-Side Load Balancing
- Lab 13. Use Netflix Hystrix for the Circuit Breaker Pattern
- Lab 14. EdgeComponents with Zuul
- Lab 15. Distributed tracing with Zipkin
- Lab 16. Spring Boot Project
Related Courses
-
Core Spring Quick Start | Introduction to Spring Essentials, Spring Boot, AOP, Persistence & More
TT3320- Duration: 2
- Delivery Format: Classroom Training, Online Training
- Price: 1,400.00 USD
-
Spring Developer Boot Camp | Mastering Spring 5.x
TT3335- Duration: 4
- Delivery Format: Classroom Training, Online Training
- Price: 2,800.00 USD
Self-Paced Training Info
Learn at your own pace with anytime, anywhere training
- Same in-demand topics as instructor-led public and private classes.
- Standalone learning or supplemental reinforcement.
- e-Learning content varies by course and technology.
- View the Self-Paced version of this outline and what is included in the SPVC course.
- Learn more about e-Learning
Course Added To Shopping Cart
bla
bla
bla
bla
bla
bla
Self-Paced Training Terms & Conditions
Exam Terms & Conditions
Sorry, there are no classes that meet your criteria.
Please contact us to schedule a class.
STOP! Before You Leave
Save 0% on this course!
Take advantage of our online-only offer & save 0% on any course !
Promo Code skip0 will be applied to your registration
Purchase Information
title
Please take a moment to fill out this form. We will get back to you as soon as possible.
All fields marked with an asterisk (*) are mandatory.