A .NET Language for Safe and Scalable Concurrency

Slides:



Advertisements
Similar presentations
Powerpoint Templates Page 1 Powerpoint Templates.
Advertisements

Free Powerpoint Templates Page 1 Free Powerpoint Templates Name of Presentation by Mr X.
Insert Logo of sponsor HERE
Page 1 Powerpoint Templates Name of presentation by Mr X.
contents Part one add title here Part fore add title here Part two
Course Title |Sub-Title
WOW PRESENTATION SLIDES
INSERT YOUR EVENT TITLE HERE
Company or University Logo
Authors Names / Organization where the paper was developed
Department of Internal Medicine, Etc etc
Authors: Name, Name, Name
Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam,
Name of Recipe Ingredients Ingredient goes here Ingredient goes here
Presentation Subtitle.
Presentation Title - Subtitle
tsfx program name/year
WOW PRESENTATION SLIDES
WOW PRESENTATION SLIDES
Company Presentation Template
Human resources slide 1 HUMAN RESOURCES
Scientific Medical Research Conference Poster Title Goes Here
Your company informations
Course Title |This is the slide title
Introducción/Background
TITLE OF THE POSTER Poster ID: Authors Affiliations Abstract
Scientific Medical Research Conference Poster Title Goes Here
Department of Internal Medicine, Etc etc
Your company informations
WOW PRESENTATION SLIDES
Research Main subject Title to be placed here in large font, can be enlarged to fit accordingly to your liking Author title bar with titles Affiliation.
Your company informations
Your company informations
Title of the Research Study
Name of presentation by Mr X.
WOW Presentation 2 Theme
WOW Presentation 2 Theme
Your company informations
This is Template Presenter: Mr. Bla.
TITLE OF THE POSTER Authors Affiliations Poster ID: Abstract
WOW Presentation 2 Theme
Name(s) and surname(s)
Your company informations
Your company informations
WOW PRESENTATION SLIDES
Name of presentation by Mr X Powerpoint Templates Powerpoint Templates.
WOW Presentation 2 Theme
Your company informations
Your company informations
Your company informations
WOW PRESENTATION THEME
Name of Recipe Ingredients Directions Ingredient goes here
Your company informations
STUDENT POSTER SESSION 2019
Your company informations
Human resources slide 1 HUMAN RESOURCES
CUSTOM Presentation Theme
Your company informations
Recursos humanos slide 1
Instructions how to use this poster template
Your company informations
PRESENTATION SUBTITLE
Introducción/Background
Anne Frank Dates I learned...
CUSTOM PRESENTATION THEME
„Improving knowledge on NPS and opiates trafficking in Europe“
Your company informations
Your company informations
Your company informations
Presentation transcript:

A .NET Language for Safe and Scalable Concurrency VTL02 Axum A .NET Language for Safe and Scalable Concurrency Niklas Gustafsson Software Architect Parallel Computing Platform

The Parallel Glass Ceiling Practices not sustainable Complexity Performance Scalability Switching to new models Will require rethink: programmers + platform vendors Will take time Strong tool support needed to rein in costs

Shared Memory Sharing Basic model: Threads / tasks Common address space Exchange data in memory cells Synchronize via CAS in memory cells Take locks to protect data

Unpartitioned State A Huge Mess Performance Unstated, indirect, subtle data dependencies Documentation quickly out of sync with reality Requires enormous discipline Process scale Performance Overlapping working sets + false sharing Cache coherence traffic will dominate Technology scale

Shared Memory Implicit component dependencies 0x0001a3f0:

Shared Memory As core count grows…

Shared Memory … we have to add components

Shared Memory … and more…

Shared Memory … and more…

Shared Memory … and more…

Shared Memory … until all we see is a tangled mess…

Shared Memory … and how it’s going to hurt us…

Shared Memory … unless, of course, we’re blissfully unaware

Shared Memory However, the reality is likely this…

Shared Memory … so we document it… Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla pariatur? Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.. Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla pariatur? Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.. Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla pariatur? Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.. Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla pariatur? Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.. Lorem ipsum dolor sit amet, Consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.. Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum..

Shared Memory … but a bug is fixed… Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla pariatur? Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.. Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla pariatur? Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.. Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla pariatur? Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.. Sed ut perspiciatis unde omnis iste natus error sit voluptatem accusantium doloremque laudantium, totam rem aperiam, eaque ipsa quae ab illo inventore veritatis et quasi architecto beatae vitae dicta sunt explicabo. Nemo enim ipsam voluptatem quia voluptas sit aspernatur aut odit aut fugit, sed quia consequuntur magni dolores eos qui ratione voluptatem sequi nesciunt. Neque porro quisquam est, qui dolorem ipsum quia dolor sit amet, consectetur, adipisci velit, sed quia non numquam eius modi tempora incidunt ut labore et dolore magnam aliquam quaerat voluptatem. Ut enim ad minima veniam, quis nostrum exercitationem ullam corporis suscipit laboriosam, nisi ut aliquid ex ea commodi consequatur? Quis autem vel eum iure reprehenderit qui in ea voluptate velit esse quam nihil molestiae consequatur, vel illum qui dolorem eum fugiat quo voluptas nulla pariatur? Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.. Lorem ipsum dolor sit amet, Consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum.. Lorem ipsum dolor sit amet, consectetur adipisicing elit, sed do eiusmod tempor incididunt ut labore et dolore magna aliqua. Ut enim ad minim veniam, quis nostrud exercitation ullamco laboris nisi ut aliquip ex ea commodo consequat. Duis aute irure dolor in reprehenderit in voluptate velit esse cillum dolore eu fugiat nulla pariatur. Excepteur sint occaecat cupidatat non proident, sunt in culpa qui officia deserunt mollit anim id est laborum..

The Answer? We all know of a system that… … runs on millions and millions of processors … is programmed by hundreds of thousands of developers in thousands of organizations often competing with each other … is known to scale … is remarkably robust … may have something to teach us

The Web Loosely coupled Low trust between “components” Partitioned state Message-passing (HTTP Get/Put)

Partitioned State Firm boundaries, explicit dependencies

Message-Passing Data exchange Synchronization Information passed via messages Data is sent by: Copy Reference to immutable data (in-process) Ownership transfer (in-process) Synchronization Data exchange ≡ synchronization

Asynchrony Data exchange needs to be asynchronous Removes inter-component dependencies in time Frees up components to do work in parallel Requires new ways of designing programs IAsyncResult Continuation-passing, e.g. CCR Promises Data-flow networks Events

Language Support New practices require new languages Libraries good at enabling, not constraining users Formalism of state partitioning Asynchrony

Axum Special-purpose language in incubation Partition data into domains Agents use shared state within domains Agents use message-passing between domains Support for asynchrony and data-flow

Axum Concepts Agent Domain Channel Schema

Channels Conduit for messages between two agents Support for in-process and distributed messaging Define ports as communication vocabulary channel PingPong { input bool Ping; output Signal Pong; } Input port ‘Ping,’ sending data from a client to an agent Output port ‘Pong,’ sending data from an agent to its client

Agents Active components, similar to threads but has limited access to shared mutable state Send and receive messages via channels agent PingAgent : channel PingPong { public PingAgent () while (receive(Ping)) Pong <-- Signal.Value; }

Connecting to an Agent Connections are made in one of two ways: var tble = provider.Connect<TableAccess>(“http://localhost/foo”); var tble = Table.TableAgent.CreateInNewDomain(); A factory for channels A channel type An agent address An agent type A factory method for in-process agents

Ping Pong channel PingPong { input bool Ping; output Signal Pong; } agent PingAgent : channel PingPong public PingAgent() while (receive(Ping)) Pong <-- Signal.Value; agent MainAgent : channel Microsoft.Axum.Application { public MainAgent() var pp = PingAgent.CreateInNewDomain(); for (int i = 0; i < 100; i++) pp::Ping <-- true; receive(pp::Pong); } pp::Ping <-- false; Done <-- Signal.Value;

Domains Define state shared by several agent instances Isolate agents in different domains from each other Foundation for seamless distribution of agents Agents are “hosted” within domains domain Table { Dictionary<string, string> dict = new Dictionary<string,string>(); public Table() Host<TableAgent>(“TableAgentAddress"); } public agent TableAgent : channel TableAccess ...

Domains + Agents = ♥ ♥ ♥ Agents declared as Writer – allowed to modify state Reader – allowed to read mutable state N/A – no access to mutable state Agent code is scheduled in parallel based on classification Agents in different domains run in parallel “One writer, many readers” within each domain No-access agents run completely in parallel

Schema Payload definition Guaranteed to serialize Efficient in-process copying schema TableEntry { required String Key; required String Value; rules { require !String.IsNullOrEmpty(Key); require !String.IsNullOrEmpty(Value); } }

Protocols Define legal order of messages Place constraints on payload values channel TableAccess { input KeyValuePair <String,String> Put; input String Get : String; input Signal Done; Start: { Put $ (!String.IsNullOrEmpty(value.Key)) -> Start; Get $ (!String.IsNullOrEmpty(value)) -> Start; Done -> End; } }

Dataflow Networks Propagate data between Operators Operands Computations (methods) Buffers Channel ports Operators forward, forward once, broadcast, alternate, multiplex, join Operands buffer, single-assignment, transforms, sinks chan::Request ==> TranformString ==> chan::Reply; buffer -<< { TransformString ==> sink, PrintString };

Ping Pong agent PingAgent : channel PingPong { public PingAgent() Ping ==> (b => Signal.Value) ==> Pong; }

Ping Pong agent PingAgent : channel PingPong { public PingAgent() Ping ==> Trace ==> Pong; } private Signal Trace(bool inpt) Console.WriteLine("{0}",inpt); return Signal.Value;

Asynchrony Blocking a thread is costly 1MB (or more) stack space Thread context Context switching via ‘syscall’ Asynchronous APIs (APM, EAP, CCR, etc.) Runtime efficient, state in heap Complex to use in program code Axum: let the compiler do the work!

Other Languages with Agents Functional Mostly pure message-passing Dedicated virtual machine Isolation through immutability Transparent support for distribution Support for asynchrony (receive) Scala Runs on JVM No isolation, but some immutable types Distribution a separate model Basic support for asynchrony (react) F# Functional Runs on .NET No isolation, but some immutable types Distribution a separate model Support for asynchrony (async + let!)

F# and Axum Axum model a closer fit with F# than C++/C# Immutable collection types Support for asynchrony In-process agent API available Add channels, isolation, schema and you have Axum Check out Luke Hoban’s F# session next

Summary Shared Memory Pure Message Passing Axum Complexity hard to rein in Performance suffers as cache coherence dominates memory system Pure Message Passing Separation of components High overhead Does not leverage existing know-how Axum Balances shared memory and message-passing Reduce complexity Leverage existing patterns and libraries

Try it out! http://msdn.microsoft.com/devlabs http://blogs.msdn.com/maestroteam

Parallel Computing at PDC09 Overview FT07: The State of Parallel Programming WKSP08: Patterns of Parallel Programming Managed code in Visual Studio 2010 FT03: Manycore and .NET 4: A Match Made in Visual Studio 2010 FT21: PLINQ: LINQ, but Faster! FT20: F# for Parallel and Asynchronous Programming Native code in Visual Studio 2010 SVR18: Developing Applications for Scale-Up Servers Running Windows Server 2008 R2 SVR10: Lighting up Windows Server 2008 R2 Using the ConcRT on UMS FT19: C++ Forever: Interactive Applications in the Age of Manycore HPC Server SVR01: Accelerating Applications Using Windows HPC Server 2008 Research and Incubation VTL02: Axum: A .NET Language for Safe and Scalable Concurrency VTL32: Concurrency Fuzzing & Data Races SVR17: Data-Intensive Computing on Windows HPC Server with DryadLINQ VTL04: Rx: Reactive Extensions for .NET FT36: Future of Garbage Collection

YOUR FEEDBACK IS IMPORTANT TO US! Please fill out session evaluation forms online at MicrosoftPDC.com

channel9.msdn.com/learn 11/18/2018 10:23 AM Learn More On Channel 9 Expand your PDC experience through Channel 9 Explore videos, hands-on labs, sample code and demos through the new Channel 9 training courses channel9.msdn.com/learn Built by Developers for Developers…. © 2007 Microsoft Corporation. All rights reserved. Microsoft, Windows, Windows Vista and other product names are or may be registered trademarks and/or trademarks in the U.S. and/or other countries. The information herein is for informational purposes only and represents the current view of Microsoft Corporation as of the date of this presentation. Because Microsoft must respond to changing market conditions, it should not be interpreted to be a commitment on the part of Microsoft, and Microsoft cannot guarantee the accuracy of any information provided after the date of this presentation. MICROSOFT MAKES NO WARRANTIES, EXPRESS, IMPLIED OR STATUTORY, AS TO THE INFORMATION IN THIS PRESENTATION.