+ All Categories
Home > Technology > Data Migration at Scale with RabbitMQ and Spring Integration

Data Migration at Scale with RabbitMQ and Spring Integration

Date post: 05-Dec-2014
Category:
Upload: alvaro-videla
View: 558 times
Download: 2 times
Share this document with a friend
Description:
Presentation about RabbitMQ given at SpringOne 2GX
53
Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/ Data Migration at Scale with RabbitMQ and Spring Integration By Álvaro Videla and Félix López
Transcript
Page 1: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Data Migration at Scale with RabbitMQ and Spring Integration

By Álvaro Videla and Félix López

Page 2: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Álvaro Videla

• Developer Advocate at Pivotal / RabbitMQ • Co-Author of RabbitMQ in Action • Creator of the RabbitMQ Simulator • Blogs about RabbitMQ Internals: http://videlalvaro.github.io/

internals.html • @old_sound — [email protected] — github.com/videlalvaro

2

Page 3: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Álvaro Videla

3

Co-authored !

RabbitMQ in Action

http://bit.ly/rabbitmq

Page 4: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

What is RabbitMQ

4

Page 5: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

RabbitMQ

5

Page 6: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

RabbitMQ

• Multi Protocol Messaging Server

6

Page 7: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

RabbitMQ

• Multi Protocol Messaging Server • Open Source (MPL)

7

Page 8: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

RabbitMQ

• Multi Protocol Messaging Server • Open Source (MPL) • Polyglot

8

Page 9: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

RabbitMQ

• Multi Protocol Messaging Server • Open Source (MPL) • Polyglot • Written in Erlang/OTP

9

Page 10: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Multi Protocol

10

http://bit.ly/rmq-protocols

Page 11: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Polyglot

11

Page 12: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Polyglot

• Java

12

Page 13: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Polyglot

• Java • node.js

13

Page 14: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Polyglot

• Java • node.js • Erlang

14

Page 15: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Polyglot

• Java • node.js • Erlang • PHP

15

Page 16: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Polyglot

• Java • node.js • Erlang • PHP • Ruby

16

Page 17: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Polyglot

• Java • node.js • Erlang • PHP • Ruby • .Net

17

Page 18: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Polyglot

• Java • node.js • Erlang • PHP • Ruby • .Net • Haskell

18

Page 19: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Polyglot

19

Even COBOL!!!11

Page 20: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

http://www.rabbitmq.com/download.html

20

Unix - Mac - Windows

Page 21: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Messaging with RabbitMQ

21

A demo with the RabbitMQ Simulator

https://github.com/RabbitMQSimulator

Page 22: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

RabbitMQ Simulator

22

Page 23: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

http://www.rabbitmq.com/blog/2012/05/11/some-queuing-theory-throughput-latency-and-bandwidth/

23

Page 24: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

RabbitMQ Basic Qos Simulator

24

Page 25: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Prevent Unbound Buffers

25

λ = mean arrival time

µ = mean service rate

if λ > µ what happens?

Page 26: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Prevent Unbound Buffers

26

λ = mean arrival time

µ = mean service rate

if λ > µ what happens?

Queue length goes to infinity over time.

Page 27: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Prevent Unbound Buffers

27

https://www.rabbitmq.com/blog/2014/01/23/preventing-unbounded-buffers-with-rabbitmq/

λ = mean arrival time

µ = mean service rate

if λ > µ what happens?

Queue length goes to infinity over time.

Page 28: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Recommended Reading

28

Performance Modeling and Design of Computer Systems:

Queueing Theory in Action

Page 29: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

What you get out of the box

29

Page 30: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

30

Page 31: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

• Persistent Messages

31

Page 32: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

• Persistent Messages • Publisher Confirms

32

Page 33: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

• Persistent Messages • Publisher Confirms • Message Acknowledgment

33

Page 34: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

• Persistent Messages • Publisher Confirms • Message Acknowledgment • Mirrored Queues

34

Page 35: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

• Persistent Messages • Publisher Confirms • Message Acknowledgment • Mirrored Queues • Message Ordering

35

Page 36: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

36

Page 37: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

• Dead Letter Exchanges

37

Page 38: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

• Dead Letter Exchanges • Alternate Exchanges

38

Page 39: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

• Dead Letter Exchanges • Alternate Exchanges • Message and Queues TTLs

39

Page 40: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

• Dead Letter Exchanges • Alternate Exchanges • Message and Queues TTLs • Consumer Priorities

40

Page 41: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

• Dead Letter Exchanges • Alternate Exchanges • Message and Queues TTLs • Consumer Priorities • Federation

41

Page 42: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

• Dead Letter Exchanges • Alternate Exchanges • Message and Queues TTLs • Consumer Priorities • Federation • Shovel

42

Page 43: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

43

Page 44: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

44

• SSL Connections

Page 45: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

45

• SSL Connections • User Authentication

Page 46: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

46

• SSL Connections • User Authentication • Per resource authorisation

Page 47: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

47

• SSL Connections • User Authentication • Per resource authorisation • Different kinds of users

Page 48: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Some RabbitMQ Features

48

• SSL Connections • User Authentication • Per resource authorisation • Different kinds of users • Various authentication mechanisms via plugins (LDAP)

Page 49: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Management Interface / REST API

49

Page 50: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

RabbitMQ

50

Page 51: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

RabbitMQ

51

Flexibility

Page 52: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/

Questions?

52

Page 53: Data Migration at Scale with RabbitMQ and Spring Integration

Unless otherwise indicated, these slides are © 2013-2014 Pivotal Software, Inc. and licensed under a Creative Commons Attribution-NonCommercial license: http://creativecommons.org/licenses/by-nc/3.0/ 53

Learn More. Stay Connected

@old_sound @flopezluis

@springcentral | spring.io/video


Recommended