Hia 1689-techinical introduction-to_iib

33
A Technical Introduction to IBM Integration Bus Andrew Coleman Architect, IBM Integration Bus on Cloud Chair, W3C XML Query Working Group

Transcript of Hia 1689-techinical introduction-to_iib

Page 1: Hia 1689-techinical introduction-to_iib

A Technical Introduction to IBM Integration Bus Andrew Coleman Architect, IBM Integration Bus on Cloud Chair, W3C XML Query Working Group

Page 2: Hia 1689-techinical introduction-to_iib

Please Note:

2

•  IBM’s statements regarding its plans, directions, and intent are subject to change or withdrawal without notice at IBM’s sole discretion.

•  Information regarding potential future products is intended to outline our general product

direction and it should not be relied on in making a purchasing decision. •  The information mentioned regarding potential future products is not a commitment,

promise, or legal obligation to deliver any material, code or functionality. Information about potential future products may not be incorporated into any contract.

•  The development, release, and timing of any future features or functionality described for our

products remains at our sole discretion. •  Performance is based on measurements and projections using standard IBM benchmarks in a

controlled environment. The actual throughput or performance that any user will experience will vary depending upon many factors, including considerations such as the amount of multiprogramming in the user’s job stream, the I/O configuration, the storage configuration, and the workload processed. Therefore, no assurance can be given that an individual user will achieve results similar to those stated here.

Page 3: Hia 1689-techinical introduction-to_iib

Agenda

• What is IBM Integration Bus •  Key Concepts •  Product overview

– System design – User roles and environments – Some other useful features

• Getting Started

3

Page 4: Hia 1689-techinical introduction-to_iib

•  RichIDEwithunittestcapability•  DeveloperEdi9on•  IBMIntegra9onCommunity•  Pa@ernbaseddevelopment•  Openanextensible•  OT4IGitHubrepos

•  HeterogeneousIntegra9on•  Extensiveconnec9vityop9ons•  VersiontoVersioncompa9ble•  Scalable•  Available•  Failover•  Administra9onautoma9on•  Monitoring

•  Analysedatainreal-9me•  EmbeddedODM•  Analy9csengineintegra9on

•  RESTAPI•  SaaSJavaAcriptAPIs•  MQTTConnector•  JSONtransforma9on•  APIMintegra9on

•  IIBonCloud•  DeployonAWS,Azure,SoSLayer•  PureAppasaServiceIIBPa@erns•  CHEFscripts

Cloud

Mobile & APIs

Analytics•  Healthcare•  Retail•  Manufacturing•  Andmore..

Platforms

Open & Developer focussed

Industry

What is IBM Integration Bus

Page 5: Hia 1689-techinical introduction-to_iib

MQ

What is IBM Integration Bus

Page 6: Hia 1689-techinical introduction-to_iib

Output target Transform

Input source Output target

Output target (Failure)

Message flows

•  Reusable •  Scalable •  Transactional

6

Page 7: Hia 1689-techinical introduction-to_iib

7

Message flow example

Page 8: Hia 1689-techinical introduction-to_iib

Nodes

•  The building blocks of message flows

•  Each node type performs a different (input, output or processing) action

• Many different node types – Grouped into logical categories in the

editor

8

Page 9: Hia 1689-techinical introduction-to_iib

9

Lots of nodes are built in

Page 10: Hia 1689-techinical introduction-to_iib

input terminal

input connection

output connection

node

input message

tree output terminals

Failure terminal

output message

trees

10

Properties

Action

Node Anatomy

Page 11: Hia 1689-techinical introduction-to_iib

… d r a C s c i h p a r G , h t i m S d e r F

Input Message Bit-stream

… n / < h t i m S . r M > e m a n < > r e d r o <

Output Message Bit-stream

Parser converts bit-stream to logical tree

Model

Parser converts logical tree to bit-stream

Model

11

The Parser and Message Tree

Page 12: Hia 1689-techinical introduction-to_iib

<order> <name> <first>John</first> <last>Smith</last> </name> <item>Graphics Card</item> <quantity>32</quantity> <price>200</price> <date>2007-11-14</date> </order>

Order

Name Item Qty Price Date

First Last String

String

String Integer Integer Date

Physical Logical

12

XM

L

{“order”: {“name”: {“first”:”John”, “last”:”Smith”}, “item”:”Graphics Card”, “quantity”:32, “price”:200, “date”:”2007-11-14”}} JS

ON

John,Smith,Graphics Card, 32,200,07/11/14 C

SV

John Smith............ Graphics Card......... 3220020071114......... C

BL

.XSD .DFDL .DFDL

Message Model

Page 13: Hia 1689-techinical introduction-to_iib

Message Model

C Header

XML Schema

COBOL Copybook

WSDL

Import

Discover

(e.g. SAP, Siebel,

PeopleSoft, Database)

Standard SOAP, MIME,

CSV EDIFACT, SWIFT X12,

HL7, ISO8583, TLOG, FIXML,

ARTS ….

Define your own DFDL Editor and Tester XSD editor

Parsers

IBM Integration Bus

13

Creating Message Models

Page 14: Hia 1689-techinical introduction-to_iib

•  Graphical, easy to use •  Drag and Drop fields,

apply functions

•  XML to XML Transformation

•  Uses standard XSL Stylesheets

•  Describe powerful transformations quickly

•  Uses SQL-based language (ESQL)

•  Uses Java programming language

•  Ability to use XPath, JAXB

Powerful transformation and programming options

14

•  Invoke general purpose logic in any .NET supported language

•  Windows only

Page 15: Hia 1689-techinical introduction-to_iib

public class jcn extends MbJavaComputeNode { public void evaluate(MbMessageAssembly assembly) throws MbException { ... String lastName = (String)assembly.getMessage().evaluateXPath(“/Body/Order/Name/Last”); ... } }

IF Body.Order.Date < ‘2008/01/01’ THEN INSERT INTO Database.OldOrders (LastName,Item,Quantity) VALUES (Body.Order.Name.Last, Body.Order.Item, Body.Order.Quantity); ENDIF;

15

Easily address message elements

Page 16: Hia 1689-techinical introduction-to_iib

16

Easily address message elements

Page 17: Hia 1689-techinical introduction-to_iib

IBM and third-party extensions

• Many other nodes and features available through product extensions • Write your own User-Defined Nodes or Connectors

– Native node framework available in C and Java – OT4i connector framework provides means to implement full lifecycle,

including endpoint discovery 17

V4.0.0.0!June 2015!

V1.0.0.0!Jun 2014!

V1.0.0.1!Oct 2014!

Page 18: Hia 1689-techinical introduction-to_iib

•  Containers to develop, deploy and manage your integration solutions.

Applications and Libraries Integration Services and REST APIs

•  Application – Group resources for a specific integration solution – Applications can reference libraries

•  Library – Group common resources for reuse – Shared libraries provide full resource reuse – deploy and manage one copy of those resources

•  Integration Service – Specialised application – Implement a Web Service described

by a WSDL

•  REST API – Specialised application - Implement a REST API described by a

swagger document.

Page 19: Hia 1689-techinical introduction-to_iib

19

Shared Libraries

Architected for performance and scalability

Page 20: Hia 1689-techinical introduction-to_iib

•  Integration Developer – Develops message flows,

message models etc. – Unit Tests on local machine – Creates Broker Archive (BAR)

files containing required artefacts

•  Administrator – Customizes BAR for target

environment – Deploys BAR to target node – Node and Server management

and operational control – Monitoring

Development Test QA Production

User roles and environments

Page 21: Hia 1689-techinical introduction-to_iib

IBM Integration Bus on Cloud

•  A fully managed Integration Bus service

21

Page 22: Hia 1689-techinical introduction-to_iib

22

Page 23: Hia 1689-techinical introduction-to_iib

Hybrid cloud deployment

•  IIB ‘Switch’ agent makes secure outbound connection to IIB on Cloud – Mutually authenticated TLS – Each customer has dedicated switch server

in the cloud – No need to open ports in on-prem firewall

• MQ (client) and database connections can be made from flow in cloud to on-prem queue manager or database – Without any changes to IIB flow, or BAR file

23

DB2 MQ

On-prem systems of record

IIB Switch secure connection

Page 24: Hia 1689-techinical introduction-to_iib

Hybrid cloud deployment

•  ‘Callable flows’ – A flow running on-prem can directly

invoke flow running in the cloud – And vice-versa – Routed through IIB Switch – Dynamic routing

•  New nodes – Flow invoke, Callable input/output

•  Also supports invocation between multiple on-prem IIB nodes – For distributed processing

24 24

IIB Switch secure connection

On-prem Integration Bus v10

Page 25: Hia 1689-techinical introduction-to_iib

IBM Integration Bus on Cloud

• Find out more…

• HIA-2717 – Breaking down the barriers to rapid ROI with IBM Integration Bus on Cloud

• This room, next session!

25

Page 26: Hia 1689-techinical introduction-to_iib

26

MyVar = Cache.Value; IIB Node 1 IIB Node 2

Cache.Value = 42;

Cache.Value = 42;

v7 v8

v9

v10

Some other useful features

Page 27: Hia 1689-techinical introduction-to_iib

Getting started

27

Page 28: Hia 1689-techinical introduction-to_iib

Tutorials Gallery

Page 29: Hia 1689-techinical introduction-to_iib

Summary

•  Universal connectivity from anywhere, to anywhere •  Comprehensive protocols, transports, data formats and processing

– Connect to applications, services, systems and devices – Understands the broadest range of data formats

•  Simple programming with patterns and graphical data flows – Patterns for top-down, parameterized connectivity of common use cases – Graphical data flows represent application and service connectivity

•  Extensive management, performance and scalability •  New IBM Integration Bus on Cloud fully managed service

– Sign up for a free trial

•  Download and use Developer Edition – Fully functional and free (for dev / test)

29

Page 30: Hia 1689-techinical introduction-to_iib

IIB Sessions at InterConnect 2016

30

Session Time

6380B: IBM Integration Bus Futures and Strategy Sunday 16:00 – 17:00

1689A: Technical Introduction to IBM Integration Bus Monday 10:30 – 11:30

4530A: IBM Integration Bus Customer Roundtable Tuesday 08:30 – 09:30

1685A: What’s New in IBM Integration Bus Tuesday 13:15 – 14:15

1702A: IIB Hands on Lab Tuesday 14:30 – 15:30

1706A: Meet The Experts for IBM Integration Bus Tuesday 17:00 – 18:00

1695A: Effective Administration in IBM Integration Bus Wednesday 08:30 – 09:30

6380A: IBM Integration Bus Futures and Strategy Wednesday 13:15 – 14:00

4530B: IBM Integration Bus Customer Roundtable Wednesday 15:45 – 16:30

1693A: Effective Application Development in IBM Integration Bus Thursday 08:30 – 09:15

1699A: Connectors for Integration Thursday 09:30 – 10:15

1691A: Using IBM Integration to Support the API Economy Thursday 11:30 – 12:15

Page 31: Hia 1689-techinical introduction-to_iib

Notices and Disclaimers

31

Copyright © 2016 by International Business Machines Corporation (IBM). No part of this document may be reproduced or transmitted in any form without written permission from IBM.

U.S. Government Users Restricted Rights - Use, duplication or disclosure restricted by GSA ADP Schedule Contract with IBM.

Information in these presentations (including information relating to products that have not yet been announced by IBM) has been reviewed for accuracy as of the date of initial publication and could include unintentional technical or typographical errors. IBM shall have no responsibility to update this information. THIS DOCUMENT IS DISTRIBUTED "AS IS" WITHOUT ANY WARRANTY, EITHER EXPRESS OR IMPLIED. IN NO EVENT SHALL IBM BE LIABLE FOR ANY DAMAGE ARISING FROM THE USE OF THIS INFORMATION, INCLUDING BUT NOT LIMITED TO, LOSS OF DATA, BUSINESS INTERRUPTION, LOSS OF PROFIT OR LOSS OF OPPORTUNITY. IBM products and services are warranted according to the terms and conditions of the agreements under which they are provided.

Any statements regarding IBM's future direction, intent or product plans are subject to change or withdrawal without notice.

Performance data contained herein was generally obtained in a controlled, isolated environments. Customer examples are presented as illustrations of how those customers have used IBM products and the results they may have achieved. Actual performance, cost, savings or other results in other operating environments may vary.

References in this document to IBM products, programs, or services does not imply that IBM intends to make such products, programs or services available in all countries in which IBM operates or does business.

Workshops, sessions and associated materials may have been prepared by independent session speakers, and do not necessarily reflect the views of IBM. All materials and discussions are provided for informational purposes only, and are neither intended to, nor shall constitute legal or other guidance or advice to any individual participant or their specific situation.

Page 32: Hia 1689-techinical introduction-to_iib

Notices and Disclaimers Con’t.

32

It is the customer’s responsibility to insure its own compliance with legal requirements and to obtain advice of competent legal counsel as to the identification and interpretation of any relevant laws and regulatory requirements that may affect the customer’s business and any actions the customer may need to take to comply with such laws. IBM does not provide legal advice or represent or warrant that its services or products will ensure that the customer is in compliance with any law

Information concerning non-IBM products was obtained from the suppliers of those products, their published announcements or other publicly available sources. IBM has not tested those products in connection with this publication and cannot confirm the accuracy of performance, compatibility or any other claims related to non-IBM products. Questions on the capabilities of non-IBM products should be addressed to the suppliers of those products. IBM does not warrant the quality of any third-party products, or the ability of any such third-party products to interoperate with IBM’s products. IBM EXPRESSLY DISCLAIMS ALL WARRANTIES, EXPRESSED OR IMPLIED, INCLUDING BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE.

The provision of the information contained h erein is not intended to, and does not, grant any right or license under any IBM patents, copyrights, trademarks or other intellectual property right.

IBM, the IBM logo, ibm.com, Aspera®, Bluemix, Blueworks Live, CICS, Clearcase, Cognos®, DOORS®, Emptoris®, Enterprise Document Management System™, FASP®, FileNet®, Global Business Services ®, Global Technology Services ®, IBM ExperienceOne™, IBM SmartCloud®, IBM Social Business®, Information on Demand, ILOG, Maximo®, MQIntegrator®, MQSeries®, Netcool®, OMEGAMON, OpenPower, PureAnalytics™, PureApplication®, pureCluster™, PureCoverage®, PureData®, PureExperience®, PureFlex®, pureQuery®, pureScale®, PureSystems®, QRadar®, Rational®, Rhapsody®, Smarter Commerce®, SoDA, SPSS, Sterling Commerce®, StoredIQ, Tealeaf®, Tivoli®, Trusteer®, Unica®, urban{code}®, Watson, WebSphere®, Worklight®, X-Force® and System z® Z/OS, are trademarks of International Business Machines Corporation, registered in many jurisdictions worldwide. Other product and service names might be trademarks of IBM or other companies. A current list of IBM trademarks is available on the Web at "Copyright and trademark information" at: www.ibm.com/legal/copytrade.shtml.

Page 33: Hia 1689-techinical introduction-to_iib

Thank You Your Feedback is

Important!

Access the InterConnect 2016 Conference Attendee Portal to complete

your session surveys from your smartphone,

laptop or conference kiosk.