20
A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw)

A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

  • Upload
    others

  • View
    0

  • Download
    0

Embed Size (px)

Citation preview

Page 1: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

A Scalable Stack for Modular Web Applications

Gunnar Wagenknecht (@guw)

Page 2: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

In This Session

• LEARN what modern server applications need to feature

• UNDERSTAND Eclipse Gyrex and selected technologies of this stack

• EXPLORE a web application based on Eclipse Gyrex

Page 3: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Modern Server Application

Page 4: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

High Traffic

https://www.flickr.com/photos/davidedamico/

Page 5: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Frontendsweb, apps & devices

https://www.flickr.com/photos/raffaespo/

Page 6: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Modulardevelopment & deployment

https://www.flickr.com/photos/russellstreet/

Page 7: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Simpledeployment & operation

https://www.flickr.com/photos/jar0d/

Page 8: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Opentechnologies & architectures

https://www.flickr.com/photos/roborodent/

Page 9: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Eclipse Gyrex

Page 10: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

A lightweight application stack for building server applications using EclipseRT technologies.

Page 11: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

EclipseRT

„EclipseRT is the collection of OSGi-based runtimes and frameworks built by the Eclipse open source

projects. “

RunTime

Page 12: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Equinox• OSGi reference implementation

• Foundation of EclipseRT

• Component Oriented Development and Assembly

Page 13: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Jetty• Asynchronous HTTP Server and Client

• Standards based Servlet Container

• Web Sockets server

• OSGi, JNDI, JMX, JASPI, AJP support

• Small foot print

• Excellent scalability

• Runs in

• Apache Hadoop and many, many more software

• Google AppEngine

Page 14: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Gyrex

• Clustering

• Web-based administration

• Multi-tenancy

• Operational enhancements

Page 15: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Gyrex Features• lightweight application stack

• fast 100% OSGi runtime

• central cluster configuration through Apache ZooKeeper

• cluster aware job scheduling

• automated deployment through p2

• support for cluster node roles, e.g. “job worker node” and “api node”

Page 16: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Gyrex Components

Equinox

Multi-tenant Runtime Cloud

Monitoring Admin

Logging Metrics

Debug/Trace

Web

SSH

Repositories(JDBC, JPA, NoSQL)

HTTP Applications(Jetty, OSGi HttpService)

Configuration

Provisioning

Clustering & Coord.

Batch Processing

Page 17: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Sample Production Deployment

Load Balancer

Web App IoT Device Native

AppiPad AppMobile Apps

Web Node

Web Node

Web Node

Web Node

Web Node

Web Node

ZooKeeper Cluster

REST API

REST API

REST API

REST API

REST API

Batch Node

Batch Node

Batch Node

Batch Node

RedisAnsible

KibanaLogstash Elastic Search

Jenkins

Page 18: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Example Applicationhttps://github.com/eclipseguru/gyrex-timezones-example

Page 19: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

Q & A

• Gyrex Newsgroup / Forum athttp://www.eclipse.org/forums/

• Information hub athttp://www.eclipse.org/gyrex/

• Session feedback / questions@guw

Page 20: A Scalable Stack for Modular Web Applications › wp-content › uploads › 2015 › 08 › A... · A Scalable Stack for Modular Web Applications Gunnar Wagenknecht (@guw) In This

–Gunnar Wagenknecht

„Thank you!“