60
lightweight SOA with web widgets Phillip Calçado http://fragmental.tw

lightweight SOA with web widgets

Embed Size (px)

DESCRIPTION

Presented at Australian Architecture Forum 2008: http://www.architectureforum.net.au/Pages/Agenda.aspx

Citation preview

Page 1: lightweight SOA  with web widgets

lightweight SOA with web widgets

Phillip Calçadohttp://fragmental.tw

Page 2: lightweight SOA  with web widgets

SOAP/WS-*vs.

REST

Page 3: lightweight SOA  with web widgets

SOAP/WS-*vs.

RESTX

Page 4: lightweight SOA  with web widgets
Page 5: lightweight SOA  with web widgets

15 tv channels8 radio stations19 magazines & newspapers

500+ web sites

Page 6: lightweight SOA  with web widgets
Page 7: lightweight SOA  with web widgets

800 videos900,000 visits

every day

Page 8: lightweight SOA  with web widgets

previous architecture

Page 9: lightweight SOA  with web widgets

Corporate Database

Media EncoderMedia EncoderMedia EncoderMedia EncoderMedia Encoder

video.globo.comxyz.globo.com

Internet

Movie Sound Picture

pretty picture

Page 10: lightweight SOA  with web widgets

Corporate Database

Internet

Media Encoder

SOAP

SQL

SQL SQL

SQL

HTML

HTML

SOAPvideo.globo.com

xyz.globo.com

Media Transfer Protocol

?SQL

real world

Page 11: lightweight SOA  with web widgets

two main problems

Page 12: lightweight SOA  with web widgets

1) audio and video production

2) integration with other sites

Page 13: lightweight SOA  with web widgets

1) audio and video production

Page 14: lightweight SOA  with web widgets

Corporate Database

Media Encoder

video.globo.com

Page 15: lightweight SOA  with web widgets

Corporate Database

Media Encoder

video.globo.com

Media Encoder

Page 16: lightweight SOA  with web widgets

Corporate Database

Media Encoder

video.globo.com

Media Encoder

multiple instances

managed by different companieswith different interests and schedules

Page 17: lightweight SOA  with web widgets

Corporate Database

Media Encoder

video.globo.com

Media Encoder

v1.0

v1.1.1

Page 18: lightweight SOA  with web widgets

Corporate Database

Media Encoder

video.globo.com

Media Encoder

v1.0

v1.1.1

multiple versions

hard to know who is using what

Page 19: lightweight SOA  with web widgets

2) integration with other sites

Page 20: lightweight SOA  with web widgets

Corporate Database

Media Encoder

video.globo.com

xyz.globo.com

?

Page 21: lightweight SOA  with web widgets

Corporate Database

mainintegrationpoint

Page 22: lightweight SOA  with web widgets

Corporate Database

xyz.globo.com

Table A

Table Bxyz.globo.com

xyz.globo.com

xyz.globo.com

Table D

Table C

video.globo.com

Page 23: lightweight SOA  with web widgets

Corporate Database

xyz.globo.com

Table A

Table Bxyz.globo.com

xyz.globo.com

xyz.globo.com

Table D

Table C

video.globo.com

X

Page 24: lightweight SOA  with web widgets

Corporate Database

View C

xyz.globo.com

Table A

Table Bxyz.globo.com

xyz.globo.com

xyz.globo.com

Table D

video.globo.com

Page 25: lightweight SOA  with web widgets

Corporate DatabaseView A

View B

View D

View C

xyz.globo.com

xyz.globo.com

xyz.globo.com

xyz.globo.com

Table E Table F

video.globo.com

Page 26: lightweight SOA  with web widgets

Corporate DatabaseView A

View B

View D

View C

xyz.globo.com

xyz.globo.com

xyz.globo.com

xyz.globo.com

video.globo.com

Table E Table F

no contracts

just get what you want from my tables

Page 27: lightweight SOA  with web widgets

Corporate Database

video.globo.com

Internet

xyz.globo.com

Video Show

Ratings

Video Show

Ratings

Page 28: lightweight SOA  with web widgets

Corporate Database

video.globo.com

Internet

xyz.globo.com

Video Show

Ratings

Video Show

Ratings

same logic

Page 29: lightweight SOA  with web widgets

Corporate Database

video.globo.com

Internet

xyz.globo.com

Video Show

Ratings

Video Show

Ratings

same logic

40% codeduplication

among different systemsdeveloped by different people

Page 30: lightweight SOA  with web widgets

the new architecture

Page 31: lightweight SOA  with web widgets

Corporate Database

Media EncoderMedia EncoderMedia EncoderMedia EncoderMedia Encoder

video.globo.comxyz.globo.com

Internet

Movie Sound Picture

pretty picture

Page 32: lightweight SOA  with web widgets

Media EncoderMedia EncoderMedia EncoderMedia EncoderMedia Encoder

video.globo.comxyz.globo.com

Internet

Movie Sound Picture

pretty picture

Media

Services

Page 33: lightweight SOA  with web widgets

Internet

Media Encoder

HTTP

HTTP

HTTP

HTML

HTMLSOAP

Media Transfer Protocol

video.globo.com

xyz.globo.com

?

real worldMedia

Services

Page 34: lightweight SOA  with web widgets

1) audio and video production

Page 35: lightweight SOA  with web widgets

Corporate Database

Media Encoder

video.globo.com

Media Encoder

v1.0

v1.1.1

multiple versions

multiple instances +

Page 36: lightweight SOA  with web widgets

Corporate Database

Media Encoder

video.globo.com

Media Encoder

v1.0

v1.1.1

multiple versions

multiple instances +

versioned services

Page 37: lightweight SOA  with web widgets

Corporate Database

Media Encoder

video.globo.com

Media Encoder

v1.0

v1.1.1

http://mediaservices/v1/media/135

http://mediaservices/v2/media/135

http://mediaservices/v3/media/135

Page 38: lightweight SOA  with web widgets

Corporate Database

Media Encoder

video.globo.com

Media Encoder

v1.0

v1.1.1

Page 39: lightweight SOA  with web widgets

Media Encoder

Media Encoder

v1.0

v1.1.1

Media

Services

POST media/v1.0

POST media/v1.1.1

HTTP

HTTP

Page 40: lightweight SOA  with web widgets

2) integration with other sites

Page 41: lightweight SOA  with web widgets

Corporate DatabaseView A

View B

View D

View C

xyz.globo.com

xyz.globo.com

xyz.globo.com

xyz.globo.com

video.globo.com

Table E Table F

code duplication

no contracts +

Page 42: lightweight SOA  with web widgets

Corporate DatabaseView A

View B

View D

View C

xyz.globo.com

xyz.globo.com

xyz.globo.com

xyz.globo.com

video.globo.com

Table E Table F

code duplication

no contracts +

web sites as service clients

Page 43: lightweight SOA  with web widgets

Corporate Database

video.globo.com

Internet

xyz.globo.com

Video Show

Ratings

Video Show

Ratings

same logic

Page 44: lightweight SOA  with web widgets

video.globo.com

Internet

xyz.globo.com

Media

Services

Video Show

Ratings

logic

Page 45: lightweight SOA  with web widgets

0%

5%

10%

15%

20%

25%

30%

35%

40%

Database Integration Web Services

Code Duplication

Page 46: lightweight SOA  with web widgets

evolving

Page 47: lightweight SOA  with web widgets

video.globo.com xyz.globo.com

<set>

<video id="1"/>

<video id="2"/>

<video id="3"/>

</set>

<set>

<video id="1"/>

<video id="2"/>

<video id="3"/>

</set>

<div>

<h2>video title</h2>

<p>description

description</p>

</div>

<div>

<h2>video title</h2>

<p>description

description</p>

</div>

xml

?

html

Page 48: lightweight SOA  with web widgets

<set>

<video id="1"/>

<video id="2"/>

<video id="3"/>

</set>

<div>

<h2>video title</h2>

<p>description

description</p>

</div>

json/xml

html

JavaScriptWidgets

Page 49: lightweight SOA  with web widgets

Internet

HTTP

HTTP

HTML

HTMLvideo.globo.com

xyz.globo.com

?

real worldMedia

Services

Page 50: lightweight SOA  with web widgets

Internet

HTTP

HTMLvideo.globo.com

xyz.globo.com

?

real worldMedia

Services

Widgets

JavaScript

JavaScript

Page 51: lightweight SOA  with web widgets
Page 52: lightweight SOA  with web widgets

<script type="text/javascript" src="http://video.globo.com//Wdgts/9461.html"></script><script type="text/javascript">var c = new WidgetContext({'id':'4413','type':'show'},{});var a = new CalendarBox(c,false);a.render;</script>

Page 53: lightweight SOA  with web widgets

0%

5%

10%

15%

20%

25%

30%

35%

40%

Database Integration Web Services

Code Duplication

Page 54: lightweight SOA  with web widgets

0%

5%

10%

15%

20%

25%

30%

35%

40%

Database Integration Web Services Widgets API

Code Duplication

Page 55: lightweight SOA  with web widgets
Page 56: lightweight SOA  with web widgets
Page 57: lightweight SOA  with web widgets

•managing Service Versioning is still hard, keep just the previous version and only if needed

•URI versioning can be problematic, we made it optional and added an http header

• it’s very hard to be fully RESTful, be pragmatic

• strong primitives are flexible

some problems

Page 58: lightweight SOA  with web widgets

Thank you!

Phillip Calçadohttp://fragmental.tw

Page 59: lightweight SOA  with web widgets

This work is licensed under a Creative Commons Attribution-Share Alike 2.5 Australia License

http://creativecommons.org/licenses/by-sa/2.5/au/

Page 60: lightweight SOA  with web widgets

TV Globo and Globo.com are trademarks in Brazil and

other countries.Used by permission.