ebook img

Akka Concurrency PDF

515 Pages·2013·7.505 MB·English
Save to my drive
Quick download
Download
Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.

Preview Akka Concurrency

Building reliable software in a multi-core world Akka Concurrency > m o c k. o o b e w o w w. w w < k o o B e w! o artima W Derek Wyatt m o r d f a o nl w o Cover·Overview·Contents·Discuss·Suggest·Glossary·Index D Akka Concurrency PrePrint™Edition > m o c k. o o b e w o w w. w w < k o o B e w! o W m o r d f a o nl w o Cover·Overview·Contents·Discuss·Suggest·Glossary·Index D iii ThankyouforpurchasingthePrePrint™EditionofAkkaConcurrency. A PrePrint™ is a work-in-progress, a book that has not yet been fully written, reviewed, edited, or formatted. We are publishing this book as a PrePrint™ for two main reasons. First, even though this book is not quite finished,theinformationcontainedinitspagescanalreadyprovidevalueto many readers. Second, we hope to get reports of errata and suggestions for improvementfromthosereaderswhilewestillhavetimetoincorporatethem intothefirstprinting. As a PrePrint™ customer, you’ll be able to download new PrePrint™ versions from Artima as the book evolves, as well as the final PDF of the book once finished. You’ll have access to the book’s content prior to its printpublication,andcanparticipateinitscreationbysubmittingfeedback. PleasesubmitbyclickingontheSuggestlinkatthebottomofeachpage. Thanks for your participation. We hope you find the book useful and enjoyable. BillVenners President,Artima,Inc. > m o c k. o o b e w o w w. w w < k o o B e w! o W m o r d f a o nl w o Cover·Overview·Contents·Discuss·Suggest·Glossary·Index D Akka Concurrency PrePrint™Edition Derek Wyatt > m o c k. o o b e w o w w. w w < k o o B w! e artima o W m ARTIMAPRESS ro WALNUTCREEK,CALIFORNIA d f a o nl w o Cover·Overview·Contents·Discuss·Suggest·Glossary·Index D v AkkaConcurrency FirstEditionPrePrint™EditionVersionFebruary15,2013 DerekWyattisaSoftwareArchitectandDeveloperspecializinginlarge-scale, real-timeapplicationsfortheWorldWideWeb. ArtimaPressisanimprintofArtima,Inc. P.O.Box305,WalnutCreek,California94597 Copyright©2012-2013DerekWyatt. Allrightsreserved. FirsteditionpublishedasPrePrint™eBook2012 Version2publishedFebruary15,2013 BuilddateofthisimpressionFebruary15,2013 ProducedintheUnitedStatesofAmerica Nopartofthispublicationmaybereproduced,modified,distributed,storedina retrievalsystem,republished,displayed,orperformed,forcommercialor noncommercialpurposesorforcompensationofanykindwithoutpriorwritten permissionfromArtima,Inc. ThisPDFeBookispreparedexclusivelyforitspurchaser. Thepurchaserofthis PrePrintEditionmaydownload,viewon-screen,andprintitforpersonal, noncommercialuseonly,providedthatallcopiesincludethefollowingnoticeina clearlyvisibleposition: “Copyright©2012DerekWyatt. Allrightsreserved.” The purchasermaystoreoneelectroniccopyandoneelectronicbackup,andmayprint onecopy,forpersonal,noncommercialuseonly. Allinformationandmaterialsinthisbookareprovided“asis”andwithout warrantyofanykind. > m o Theterm“Artima”andtheArtimalogoaretrademarksorregisteredtrademarksof c k. o Artima,Inc. Allothercompanyand/orproductnamesmaybetrademarksor o b e registeredtrademarksoftheirowners. w o w w. w w < k o o B e w! o W m o r d f a o nl w o Cover·Overview·Contents·Discuss·Suggest·Glossary·Index D Overview Contents vii ListofFigures xiii Introduction xvi 1. WhyAkka? 23 2. ConcurrencyandParallelism 32 3. SettingUpAkka 57 4. AkkaDoesConcurrency 60 5. Actors 88 6. AkkaTesting 126 7. Systems,Contexts,Paths,andLocations 151 8. SupervisionandDeathWatch 176 9. BeingStateful 225 10. RoutingMessages 275 11. DispatchersandMailboxes 307 12. CodingintheFuture 322 13. NetworkingwithIO 369 14. GoingMulti-NodewithRemoteActors 379 15. SharingDatawithAgents 414 16. GranularConcurrencywithDataflow 429 17. PatternsforAkkaProgramming 438 18. AntipatternsforAkkaProgramming 469 19. GrowingYourAppwithAdd-OnModules 482 20. UsingAkkafromJava 491 21. NowthatYou’reanAkkaCoder 509 Bibliography 511 Abouttheauthor 512 Index 513 > m o c k. o o b e w o w w. w w < k o o B e w! o W m o r d f a o nl w o Cover·Overview·Contents·Discuss·Suggest·Glossary·Index D Contents Contents vii ListofFigures xiii Introduction xvi 1 WhyAkka? 23 1.1 Concurrentchallenges . . . . . . . . . . . . . . . . . . 24 1.2 Akkaisconcurrency . . . . . . . . . . . . . . . . . . . 26 1.3 Concurrencymethodologies . . . . . . . . . . . . . . . 26 1.4 TheAkkaconcurrencytoolkit . . . . . . . . . . . . . . 28 1.5 So,whyAkka? . . . . . . . . . . . . . . . . . . . . . . 31 2 ConcurrencyandParallelism 32 2.1 Parallelismversusconcurrency . . . . . . . . . . . . . 32 2.2 Acriticallookatshared-stateconcurrency . . . . . . . 33 2.3 Immutability . . . . . . . . . . . . . . . . . . . . . . . 44 > 2.4 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . 56 m o c ok. 3 SettingUpAkka 57 o b we 3.1 InstallationusingtheTypesafestack . . . . . . . . . . . 57 o w 3.2 That’sit? . . . . . . . . . . . . . . . . . . . . . . . . . 59 w. w w k < 4 AkkaDoesConcurrency 60 o Bo 4.1 Theactor . . . . . . . . . . . . . . . . . . . . . . . . . 60 e w! 4.2 Thefuture . . . . . . . . . . . . . . . . . . . . . . . . 77 o W 4.3 Theotherstuff . . . . . . . . . . . . . . . . . . . . . . 83 m ro 4.4 Yougrabbedtherighttoolkit. . . . . . . . . . . . . . . 87 d f a o nl w o Cover·Overview·Contents·Discuss·Suggest·Glossary·Index D Contents viii 5 Actors 88 5.1 Thecomponentsofanactor . . . . . . . . . . . . . . . 90 5.2 Propertiesofanactor . . . . . . . . . . . . . . . . . . 92 5.3 Howtotalktoanactor . . . . . . . . . . . . . . . . . . 96 5.4 Creatingactors . . . . . . . . . . . . . . . . . . . . . . 100 5.5 Actorsintheclouds . . . . . . . . . . . . . . . . . . . 101 5.6 Tyingittogether . . . . . . . . . . . . . . . . . . . . . 116 5.7 Howmessagesendingreallyworks . . . . . . . . . . . 118 5.8 TheActorSystemrunstheshow . . . . . . . . . . . . 122 5.9 Conclusion . . . . . . . . . . . . . . . . . . . . . . . . 124 6 AkkaTesting 126 6.1 Makingchangestosbt . . . . . . . . . . . . . . . . . . 126 6.2 Abitofrefactoring . . . . . . . . . . . . . . . . . . . . 127 6.3 TestingtheEventSource . . . . . . . . . . . . . . . . 129 6.4 TheinteractionbetweenImplicitSenderandtestActor 133 6.5 TestKit,ActorSystem,andScalaTest . . . . . . . . . . 134 6.6 Testingthealtimeter . . . . . . . . . . . . . . . . . . . 139 6.7 Akka’sothertestingfacilities . . . . . . . . . . . . . . 146 6.8 AbouttestprobesandthetestActor . . . . . . . . . . 148 6.9 Chaptersummary . . . . . . . . . . . . . . . . . . . . 150 7 Systems,Contexts,Paths,andLocations 151 7.1 TheActorSystem . . . . . . . . . . . . . . . . . . . . 151 7.2 Actorpaths . . . . . . . . . . . . . . . . . . . . . . . . 153 7.3 Staffingtheplane . . . . . . . . . . . . . . . . . . . . . 155 7.4 TheActorContext . . . . . . . . . . . . . . . . . . . 165 > 7.5 Relatingthepath,context,andsystem . . . . . . . . . . 172 m o c 7.6 Chaptersummary . . . . . . . . . . . . . . . . . . . . 174 k. o o b we 8 SupervisionandDeathWatch 176 o w w. 8.1 Whatmakesactorsfail? . . . . . . . . . . . . . . . . . 176 w w 8.2 Theactorlifecycle . . . . . . . . . . . . . . . . . . . . 177 < k 8.3 Whatisasupervisor? . . . . . . . . . . . . . . . . . . 180 o o B 8.4 Watchingfordeath . . . . . . . . . . . . . . . . . . . . 188 e w! 8.5 Theplanethathealeditself . . . . . . . . . . . . . . . 194 o W m 8.6 Deadpilots . . . . . . . . . . . . . . . . . . . . . . . . 216 o d fr 8.7 Chaptersummary . . . . . . . . . . . . . . . . . . . . 223 a o nl w o Cover·Overview·Contents·Discuss·Suggest·Glossary·Index D Contents ix 9 BeingStateful 225 9.1 Changingbehaviour . . . . . . . . . . . . . . . . . . . 225 9.2 Thestatefulflightattendant . . . . . . . . . . . . . . . 230 9.3 Abetterflyer . . . . . . . . . . . . . . . . . . . . . . . 237 9.4 Thenaughtypilot . . . . . . . . . . . . . . . . . . . . 258 9.5 Somechallenges . . . . . . . . . . . . . . . . . . . . . 269 9.6 TestingFSMs. . . . . . . . . . . . . . . . . . . . . . . 270 9.7 Testingthepilot . . . . . . . . . . . . . . . . . . . . . 272 9.8 Chaptersummary . . . . . . . . . . . . . . . . . . . . 273 10 RoutingMessages 275 10.1 Routersarenotactors . . . . . . . . . . . . . . . . . . 275 10.2 Akka’sstandardrouters . . . . . . . . . . . . . . . . . 275 10.3 Routersandchildren . . . . . . . . . . . . . . . . . . . 282 10.4 Routersonaplane . . . . . . . . . . . . . . . . . . . . 285 10.5 Magicallyappearingflightattendants . . . . . . . . . . 298 10.6 Sectioningoffflightattendantterritory . . . . . . . . . 300 10.7 Moreyoucandowithrouters . . . . . . . . . . . . . . 304 10.8 Withthatsaid... . . . . . . . . . . . . . . . . . . . . . 305 10.9 Chaptersummary . . . . . . . . . . . . . . . . . . . . 305 11 DispatchersandMailboxes 307 11.1 Dispatchers . . . . . . . . . . . . . . . . . . . . . . . . 307 11.2 Dispatchertweaking . . . . . . . . . . . . . . . . . . . 311 11.3 Mailboxes . . . . . . . . . . . . . . . . . . . . . . . . 313 11.4 Whentochooseadispatchingmethod . . . . . . . . . . 320 11.5 Chaptersummary . . . . . . . . . . . . . . . . . . . . 321 > m o 12 CodingintheFuture 322 c k. oo 12.1 Whatisthefuture? . . . . . . . . . . . . . . . . . . . . 322 b we 12.2 Don’twaitforthefuture . . . . . . . . . . . . . . . . . 325 o w w. 12.3 Promisesandfutures . . . . . . . . . . . . . . . . . . . 328 w w 12.4 Functionalfutures . . . . . . . . . . . . . . . . . . . . 330 < k 12.5 Side-effecting . . . . . . . . . . . . . . . . . . . . . . 349 o o B 12.6 Futuresandactors . . . . . . . . . . . . . . . . . . . . 354 e w! 12.7 Planefutures . . . . . . . . . . . . . . . . . . . . . . . 364 o W m 12.8 Chaptersummary . . . . . . . . . . . . . . . . . . . . 367 o r d f a o nl w o Cover·Overview·Contents·Discuss·Suggest·Glossary·Index D Contents x 13 NetworkingwithIO 369 13.1 Theplane’sTelnetserver. . . . . . . . . . . . . . . . . 369 13.2 Iteratees . . . . . . . . . . . . . . . . . . . . . . . . . 377 13.3 Chaptersummary . . . . . . . . . . . . . . . . . . . . 377 14 GoingMulti-NodewithRemoteActors 379 14.1 Manyactors,manystages . . . . . . . . . . . . . . . . 379 14.2 Simplebuildtool(sbt) . . . . . . . . . . . . . . . . . . 380 14.3 RemoteAirports . . . . . . . . . . . . . . . . . . . . 380 14.4 Goingremote . . . . . . . . . . . . . . . . . . . . . . . 386 14.5 FlyingtotheAirport . . . . . . . . . . . . . . . . . . 390 14.6 Programmaticremotedeployment . . . . . . . . . . . . 398 14.7 Configuredremotedeployment . . . . . . . . . . . . . 401 14.8 Routersacrossmultiplenodes . . . . . . . . . . . . . . 403 14.9 Serialization . . . . . . . . . . . . . . . . . . . . . . . 404 14.10 Remotesystemevents . . . . . . . . . . . . . . . . . . 408 14.11 Onthesubjectoflostmessages . . . . . . . . . . . . . 411 14.12 Clustering . . . . . . . . . . . . . . . . . . . . . . . . 412 14.13 Chaptersummary . . . . . . . . . . . . . . . . . . . . 412 15 SharingDatawithAgents 414 15.1 sbt . . . . . . . . . . . . . . . . . . . . . . . . . . . . 415 15.2 Agentsascounters . . . . . . . . . . . . . . . . . . . . 415 15.3 Workingwithagents . . . . . . . . . . . . . . . . . . . 421 15.4 TheAPI . . . . . . . . . . . . . . . . . . . . . . . . . 422 15.5 Chaptersummary . . . . . . . . . . . . . . . . . . . . 427 > 16 GranularConcurrencywithDataflow 429 m o 16.1 Caveats . . . . . . . . . . . . . . . . . . . . . . . . . . 429 c k. oo 16.2 Withthatsaid... . . . . . . . . . . . . . . . . . . . . . 430 b we 16.3 Gettingdataflowintothebuild . . . . . . . . . . . . . . 430 o w w. 16.4 Dataflowvalues . . . . . . . . . . . . . . . . . . . . . 431 w w 16.5 Flow . . . . . . . . . . . . . . . . . . . . . . . . . . . 431 < k 16.6 Anotherwaytogetinstrumentstatus . . . . . . . . . . 436 o o B 16.7 Whentousedataflow . . . . . . . . . . . . . . . . . . 437 e w! 16.8 Chaptersummary . . . . . . . . . . . . . . . . . . . . 437 o W m ro 17 PatternsforAkkaProgramming 438 d f a o nl w o Cover·Overview·Contents·Discuss·Suggest·Glossary·Index D

See more

The list of books you might like

Most books are stored in the elastic cloud where traffic is expensive. For this reason, we have a limit on daily download.