5 minutes to enterprise javascript - lance ball...rhoar - red hat openshift application runtime for...

Post on 25-May-2020

10 Views

Category:

Documents

0 Downloads

Preview:

Click to see full reader

TRANSCRIPT

5 Minutes to Enterprise JavaScript With Red Hat OpenShift Application Runtimes

Lance BallPrincipal Software Engineer

Wednesday, May 9 2018

John ClinganProduct Manager RHOAR

NODE.JSIs a Thing at Red Hat

● RHOAR - Red Hat OpenShift Application Runtime for Node.js 8.x LTS

● Supported Node.js RPMs and Runtime containers for Node.js 8.x LTS

● Community Node.js RPMs and Runtime containers for Node.js 9.x and 10.x

● Node.js tools and utilities for containerized deployment

● Node.js Core Committers

● Node.js Technical Steering Committee

So What Do You Mean?

OK… But Why Node.js?

In the Beginning, there was the Monolith

My App

The Monolith Begat Microservices

µ svcA

µ svcB

µ svcC

µ svcD

µ svcJ

µ svcH

µ svcF

µ svcG

µ svcE

Small, discrete services that do one thing well - usually as REST over HTTP

This is what Node.js does well

But waitMy application is very complex!

Application complexity shifts from application code to the runtime platform

Logging

µ svcA

µ svcB

µ svcC

µ svcD

µ svcJ

µ svcH

µ svcF

µ svcG

µ svcE

Service Discovery

Routing Elasticity

Tracing

Authn/z Resilience

Service Mesh

Application logic should be simple

Demo: set up minishift$ minishift profile set 'summit-demo'

$ minishift config set cpus 2

$ minishift config set vm-driver virtualbox

$ minishift config set memory 4GB

$ minishift start

$ eval (minishift oc-env) # fish shell!

$ oc new-project summit-demo

Demo: create and deploy an application$ mkdir myapp; and cd myapp

$ npm install -g express-generator

$ express .

$ code-insiders package.json # fish shell!

$ npx nodeshift --strictSSL=false --expose

Yeah and… now what?

Didn’t you say “Enterprise”?

µ-Services are not a panacea

µ svcA

µ svcB

µ svcC

µ svcD

µ svcJ

µ svcH

µ svcF

µ svcG

µ svcE

Some services will fail

µ svcA

µ svcB

µ svcC

µ svcD

µ svcJ

µ svcH

µ svcF

µ svcG

µ svcE

Causing more services to fail

µ svcA

µ svcB

µ svcC

µ svcD

µ svcJ

µ svcH

µ svcF

µ svcG

µ svcE

eval(cascading failures) > dead application

µ svcA

µ svcB

µ svcC

µ svcD

µ svcJ

µ svcH

µ svcF

µ svcG

µ svcE

Let’s get enterpriseyWith RHOAR circuit breakers

RHOAR Demo

Logging

µ svcA

µ svcB

µ svcC

µ svcD

µ svcJ

µ svcH

µ svcF

µ svcG

µ svcE

Service Discovery

Routing Elasticity

Tracing

Authn/z Resilience

Service Mesh

Commercial Break

F7212-090617

DEVELOPERS DEMAND MORE OPTIONS

32

ENTERPRISES EXPAND USE OF LANGUAGES, FRAMEWORKS, & RUNTIMES

F7212-090617

Developers are Asked to Manage a Lot of Change

DevOps

Container-ization

Micro-Services

New Runtime

F7212-090617

Helping Developers find their Inner Peace

Support Services

> Smart Routing> API Management> Caching Service> Configuration> Messaging> SSO> Registry

35

Application Logic

> Client-side Load Balancing> Service Registration> Circuit Breaker> Distributed Tracing

Application Logic

> Client-side Load Balancing> Circuit Breaker

Support Services

> Distributed Tracing> API Management> Caching Service> Messaging> SSO

> Registry> Configuration> Server-side Load Balancing

EVOLUTION OF MICROSERVICES (2014 - FUTURE)

Support Services

> API Management> Caching Service> Messaging> SSO

Application Logic

> Registry> Configuration> Server-side Load Balancing> Client-side Load Balancing> Distributed Tracing> Circuit Breaker> Fault Injection

2014 Current Future

RED HAT OPENSHIFT APPLICATION RUNTIMESProviding curated set of integrated runtimes and frameworks that standardizes Cloud Native App Dev

36

RED HAT OPENSHIFT

RED HAT OPENSHIFT APPLICATION RUNTIMES

APPLICATIONS LIFECYCLE MANAGEMENT

CONTAINER ORCHESTRATION & MANAGEMENT (KUBERNETES)

Amazon Web Services Microsoft Azure Google CloudOpenStackDatacenterLaptop

YOUR INFRASTRUCTURE

YOUR APPS AND SERVICES

SUPPORTING MIDDLEWARE SERVICES

ReactiveVert.x

MicroProfile WildFly Swarm

Spring BootTomcat

JavaScript Node.js

Java EE JBoss EAP

Launch Service✓ Simplified

development

✓ Strategic flexibility

✓ DevOps automation

Optimized for Kubernetes and DevOps

• Reduce complexity of build cloud native applications• Supports kubernetes features that replace traditional standalone backing

services• Externalized Configuration: Kubernetes ConfigMap• Service Discovery: Kubernetes Services (DNS)• Load Balancing: Kubernetes Replication Controller• Auto-Restart: Kubernetes Health Check w/MicroProfile Health Check API• Metrics: MicroProfile Metrics API with CNCF Prometheus• Distributed Tracing: Istio & OpenTracing with CNCF Jaeger

RHOAR Node.js Support and Lifecycle

● Support LTS releases

● Align with Node.js lifecycle

● Developer builds of non-LTS releases

https://developers.redhat.com/launchhttps://github.com/bucharest-gold/node-rpmhttps://github.com/bucharest-gold/centos7-s2i-nodejs

THANK YOUplus.google.com/+RedHat

linkedin.com/company/red-hat

youtube.com/user/RedHatVideos

facebook.com/redhatinc

twitter.com/RedHat

top related