Data Migration at Scale with RabbitMQ and Spring Integration

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

description

Presentation about RabbitMQ given at SpringOne 2GX

Transcript of Data Migration at Scale with RabbitMQ and Spring Integration

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