Page 1. Goals for Today" Remote Procedure Call" Raw messaging is a bit too low-level for programming! RPC Details"

Similar documents
CS162 Operating Systems and Systems Programming Lecture 24. Distributed File Systems. Review: Distributed Applications

Page 1. Goals for Today" Remote Procedure Call" Distributed Systems Message Passing" CS162 Operating Systems and Systems Programming Lecture 23

CS162 Operating Systems and Systems Programming Lecture 24. Network Communication Abstractions / Distributed Programming

CS 162 Operating Systems and Systems Programming Professor: Anthony D. Joseph Spring Lecture 22: Remote Procedure Call (RPC)

CS162 Operating Systems and Systems Programming Lecture 23. Network Communication Abstractions / Distributed Programming

Distributed Systems are Everywhere!" CS162 Operating Systems and Systems Programming Lecture 22 Client-Server" Client-Server" Message Passing"

CS162 Operating Systems and Systems Programming Lecture 24. Testing Methodologies/ Distributed File Systems. Review: Distributed Applications

416 Distributed Systems. Distributed File Systems 2 Jan 20, 2016

Network. CS Advanced Operating Systems Structures and Implementation Lecture 13. File Systems (Con t) RAID/Journaling/VFS.

Distributed Systems are Everywhere!" CS162 Operating Systems and Systems Programming Lecture 22 Client-Server" Client-Server" Message Passing"

CS162 Operating Systems and Systems Programming Lecture 23

Distributed File Systems. CS 537 Lecture 15. Distributed File Systems. Transfer Model. Naming transparency 3/27/09

CS162 Operating Systems and Systems Programming Lecture 23. Network Communication Abstractions / Distributed Programming

416 Distributed Systems. Distributed File Systems 1: NFS Sep 18, 2018

Communication. Distributed Systems Santa Clara University 2016

CHAPTER - 4 REMOTE COMMUNICATION

Remote Procedure Call (RPC) and Transparency

CS454/654 Midterm Exam Fall 2004

Lecture 15: Network File Systems

RMI & RPC. CS 475, Spring 2019 Concurrent & Distributed Systems

Chapter 4 Communication

MODELS OF DISTRIBUTED SYSTEMS

Operating Systems Design Exam 3 Review: Spring Paul Krzyzanowski

Two Phase Commit Protocol. Distributed Systems. Remote Procedure Calls (RPC) Network & Distributed Operating Systems. Network OS.

MODELS OF DISTRIBUTED SYSTEMS

Distributed Systems. Lec 9: Distributed File Systems NFS, AFS. Slide acks: Dave Andersen

Remote Procedure Call

C 1. Recap: Finger Table. CSE 486/586 Distributed Systems Remote Procedure Call. Chord: Node Joins and Leaves. Recall? Socket API

Distributed File Systems

Page 1. Review: Storage Performance" SSD Firmware Challenges" SSD Issues" CS162 Operating Systems and Systems Programming Lecture 14

Distributed Systems Theory 4. Remote Procedure Call. October 17, 2008

How do modules communicate? Enforcing modularity. Modularity: client-server organization. Tradeoffs of enforcing modularity

COMMUNICATION IN DISTRIBUTED SYSTEMS

CS 162 Operating Systems and Systems Programming Professor: Anthony D. Joseph Spring Lecture 21: Network Protocols (and 2 Phase Commit)

Advanced Distributed Systems

Network File System (NFS)

CS 537: Introduction to Operating Systems Fall 2015: Midterm Exam #4 Tuesday, December 15 th 11:00 12:15. Advanced Topics: Distributed File Systems

Middleware. Adapted from Alonso, Casati, Kuno, Machiraju Web Services Springer 2004

Background. 20: Distributed File Systems. DFS Structure. Naming and Transparency. Naming Structures. Naming Schemes Three Main Approaches

DISTRIBUTED COMPUTER SYSTEMS

A Comparison of Two Distributed Systems: Amoeba & Sprite. By: Fred Douglis, John K. Ousterhout, M. Frans Kaashock, Andrew Tanenbaum Dec.

416 Distributed Systems. RPC Day 2 Jan 11, 2017

Distributed Systems - III

CS 425 / ECE 428 Distributed Systems Fall Indranil Gupta (Indy) Nov 28, 2017 Lecture 25: Distributed File Systems All slides IG

Today: Distributed File Systems

Announcements. P4: Graded Will resolve all Project grading issues this week P5: File Systems

CSci Introduction to Distributed Systems. Communication: RPC

Chapter 11: File System Implementation

NFS: Naming indirection, abstraction. Abstraction, abstraction, abstraction! Network File Systems: Naming, cache control, consistency

Chapter 11: Implementing File Systems

416 Distributed Systems. RPC Day 2 Jan 12, 2018

Today: Distributed Objects. Distributed Objects

Remote Invocation. Today. Next time. l Overlay networks and P2P. l Request-reply, RPC, RMI

Today: Distributed File Systems!

CS162 Operating Systems and Systems Programming Lecture 23. Distributed Storage, Key-Value Stores, Security. Recall: Two Phase (2PC) Commit

Network File Systems

RPC flow. 4.3 Remote procedure calls IDL. RPC components. Procedure. Program. sum (j,k) int j,k; {return j+k;} i = sum (3,7); Local procedure call

Dr. Robert N. M. Watson

REMOTE PROCEDURE CALLS EE324

Lecture 5: RMI etc. Servant. Java Remote Method Invocation Invocation Semantics Distributed Events CDK: Chapter 5 TVS: Section 8.3

Chapter 17: Distributed Systems (DS)

Network File System (NFS)

Network File System (NFS)

a. Under overload, whole network collapsed iii. How do you make an efficient high-level communication mechanism? 1. Similar to using compiler instead

Today: Distributed File Systems. Naming and Transparency

Remote Procedure Call. Tom Anderson


Chapter 10: File System Implementation

CSCI-1680 RPC and Data Representation. Rodrigo Fonseca

RPC. Remote Procedure Calls. Robert Grimm New York University

Distributed Objects and Remote Invocation. Programming Models for Distributed Applications

Lecture 5: Object Interaction: RMI and RPC

Page 1. Goals for Today" Virtualizing Resources" Important Aspects of Memory Multiplexing" CS162 Operating Systems and Systems Programming Lecture 20

Distributed File Systems. Directory Hierarchy. Transfer Model

RMI: Design & Implementation

DISTRIBUTED FILE SYSTEMS & NFS

Distributed Systems. The main method of distributed object communication is with remote method invocation

EI 338: Computer Systems Engineering (Operating Systems & Computer Architecture)

A Report on RMI and RPC Submitted by Sudharshan Reddy B

Send me up to 5 good questions in your opinion, I ll use top ones Via direct message at slack. Can be a group effort. Try to add some explanation.

Announcements. Reading: Chapter 16 Project #5 Due on Friday at 6:00 PM. CMSC 412 S10 (lect 24) copyright Jeffrey K.

Implementing Remote Procedure Calls*

Chapter 11: Implementing File Systems

CSCI-1680 RPC and Data Representation. Rodrigo Fonseca

Distributed Systems. Definitions. Why Build Distributed Systems? Operating Systems - Overview. Operating Systems - Overview

Section 14: Distributed Storage

Distributed Systems Lecture 2 1. External Data Representation and Marshalling (Sec. 4.3) Request reply protocol (failure modes) (Sec. 4.

Operating System Support

MTAT Enterprise System Integration. Lecture 2: Middleware & Web Services

CS555: Distributed Systems [Fall 2017] Dept. Of Computer Science, Colorado State University

Chapter 12: File System Implementation. Operating System Concepts 9 th Edition

Chapter 7: File-System

ò Server can crash or be disconnected ò Client can crash or be disconnected ò How to coordinate multiple clients accessing same file?

Chapter 11: Implementing File

Last Class: RPCs. Today:

SAI/ST course Distributed Systems

NFS. Don Porter CSE 506

Chapter 11: Implementing File Systems. Operating System Concepts 9 9h Edition

Chapter 11: File System Implementation

Communication in Distributed Systems

Transcription:

Goals for Today" CS162 Operating Systems and Systems Programming Lecture 23 Remote Procedure Call" Remote Procedure Call Examples using RPC and caching Distributed File Systems World-Wide Web April 24, 2013 Anthony D. Joseph http://inst.eecs.berkeley.edu/~cs162 Note: Some slides and/or pictures in the following are" adapted from slides 2005 Silberschatz, Galvin, and Gagne. Many slides generated from my lecture notes by Kubiatowicz." 23.2 Remote Procedure Call" Raw messaging is a bit too low-level for programming Another option: Remote Procedure Call (RPC) Looks like a local procedure call on client: file.read(1024); Translated automatically into a procedure call on remote machine (server) Implementation: Uses request/response message passing under the covers RPC Details" Client and server use stubs to glue pieces together Client stub is responsible for marshalling arguments and unmarshalling the return values Server-side stub is responsible for unmarshalling arguments and marshalling the return values Marshalling involves (depending on system) converting values to a canonical form, serializing objects, copying arguments passed by reference, etc. Needs to account for cross-language and cross-platform issues Technique: compiler generated stubs Input: interface definition language (IDL)» Contains, among other things, types of arguments/return Output: stub code in the appropriate source language 23.3 23.4 Page 1

RPC Information Flow" RPC Binding" Machine A" Machine B" (caller)" (callee)" call" return" return" call" bundle" args" Stub" unbundle" ret vals" bundle" ret vals" Stub" unbundle" args" send" receive" send" receive" Packet" Handler" Network" Network" Packet" Handler" How does client know which machine to send RPC? Need to translate name of remote service into network endpoint (e.g., host:port) Binding: the process of converting a user-visible name into a network endpoint» This is another word for naming at network level» Static: fixed at compile time» Dynamic: performed at runtime Dynamic Binding Most RPC systems use dynamic binding via name service Why dynamic binding?» Access control: check who is permitted to access service» Fail-over: If server fails, use a different one 23.5 23.6 Cross-Domain Communication/Location Transparency" How do address spaces communicate with one another? Shared Memory with Semaphores, monitors, etc File System Pipes (1-way communication) Remote procedure call (2-way communication) RPCʼs can be used to communicate between address spaces on different machines or the same machine Services can be run wherever itʼs most appropriate Access to local and remote services looks the same Examples of modern RPC systems: CORBA (Common Object Request Broker Architecture) DCOM (Distributed COM) RMI (Java Remote Method Invocation) Microkernel Operating Systems" Example: split kernel into application-level servers using RPC File system looks remote, even though on same machine App App App file system Windowing VM Networking Threads App File sys windows RPC address spaces threads Monolithic Structure Microkernel Structure Why split the OS into separate domains? Fault isolation: bugs are more isolated (build a firewall) Enforces modularity: allows incremental upgrades of pieces of software (client or server) Location transparent: service can be local or remote» For example in the X windowing system: Each X client can be on a separate machine from X server; Neither has to run on the machine with the frame buffer 23.7 23.8 Page 2

Problems with RPC" Handling failures Different failure modes in distributed system than on a single machine Without RPC a failure within a procedure call usually meant whole application would crash/die With RPC a failure within a procedure call means remote machine crashed, but local one could continue working Answer? Distributed transactions can help Performance Cost of Procedure call «same-machine RPC «network RPC Means programmers must be aware they are using RPC (so much for transparency)» Caching can help, but may make failure handling even more complex 23.9 Distributed File Systems" Read File" Network" Data" Distributed File System: Transparent access to files stored on a remote disk Naming choices (always an issue): Hostname:localname: Name files explicitly» No location or migration transparency Mounting of remote file systems» System manager mounts remote file system by giving name and local mount point» Transparent to user: all reads and writes look like local reads and writes to user e.g. /users/sue/foo /sue/foo on server A single, global name space: every file in the world has unique name» Location Transparency: servers can change and files can move without involving user mount" coeus:/sue" mount" adj:/jane" mount" adj:/prog" 23.10 Simple Distributed File System" Read (RPC)" Return (Data)" Write (RPC)" ACK" EVERY read and write gets forwarded to server Advantage: Server provides completely consistent view of file system to multiple clients Problems? Performance Going over network is slower than going to local memory Server can be a bottleneck Use Caching to Reduce Network Load" read(f1)" V1" read(f1) V1" read(f1) V1" read(f1) V1" write(f1)" OK" read(f1) V2" F1:V1" F1:V2" Read (RPC)" Return (Data)" Write (RPC)" ACK" F1:V1" F1:V2" Advantage: if open/read/write/close can be done locally, donʼt need to do any network traffic fast Problems: Failure:» Client caches have data not committed at server Cache consistency» Client caches not consistent with server/each other 23.11 23.12 Page 3

Failures" Crash" What if server crashes? Can client wait until server comes back up and continue as before? Any data in server memory but not on disk can be lost Shared state across RPC: What if server crashes after seek? Then, when client does read, it will fail Message retries: suppose server crashes after it does UNIX rm foo, but before acknowledgment?» Message system will retry: send it again» How does it know not to delete it again? (could solve with twophase commit protocol, but NFS takes a more ad hoc approach) Stateless protocol: A protocol in which all information required to process a request is passed with request Server keeps no state about client, except as hints to help improve performance (e.g. a cache) Thus, if server crashes and restarted, requests can continue where left off (in many cases) What if client crashes? Might lose modified data in client cache Network File System (NFS)" Three Layers for NFS system UNIX file-system interface: open, read, write, close calls + file descriptors VFS layer: distinguishes local from remote files» Calls the NFS protocol procedures for remote requests NFS service layer: bottom layer of the architecture» Implements the NFS protocol NFS Protocol: RPC for file operations on server Reading/searching a directory Manipulating links and directories Accessing file attributes/reading and writing files Write-through caching: Modified data committed to serverʼs disk before results are returned to the client Lose some of the advantages of caching Time to perform write() can be long Need some mechanism for readers to eventually notice changes (more on this later) 23.13 23.14 NFS Continued" NFS servers are stateless; each request provides all arguments require for execution E.g. reads include information for entire operation, such as ReadAt(inumber,position), not Read(openfile) No need to perform network open() or close() on file each operation stands on its own Idempotent: Performing requests multiple times has same effect as performing it exactly once Example: Server crashes between disk I/O and message send, client resend read, server does operation again Example: Read and write file blocks: just re-read or re-write file block no side effects Example: What about remove? NFS does operation twice and second time returns an advisory error Failure Model: Transparent to client system Is this a good idea? What if you are in the middle of reading a file and server crashes? Options (NFS Provides both):» Hang until server comes back up (next week?)» Return an error. (Of course, most applications donʼt know they are talking over network) 23.15 Schematic View of NFS Architecture " 23.16 Page 4

NFS protocol: weak consistency Client polls server periodically to check for changes» Polls server if data hasnʼt been checked in last 3-30 seconds (exact timeout it tunable parameter).» Thus, when file is changed on one client, server is notified, but other clients use old version of file until timeout. F1:V1" F1:V2" NFS Cache consistency" F1 still ok?" No: (F1:V2)" Write (RPC)" ACK" F1:V2" What if multiple clients write to same file?» In NFS, can get either version (or parts of both)» Completely arbitrary F1:V2" 23.17 NFS Pros: Simple, Highly portable NFS Pros and Cons" NFS Cons: Sometimes inconsistent Doesnʼt scale to large # clients» Must keep checking to see if caches out of date» Server becomes bottleneck due to polling traffic 23.18 Administrivia" Updated Project 4 spec and skeleton will be posted by Friday Final Exam Review Monday 5/6, 2-5pm in 100 Lewis Hall Final Exam Friday 5/17, 8-11am in 1 Pimentel All material from the course» With slightly more focus on second half, but you are still responsible for all the material Two sheets of notes, both sides Dumb calculator allowed 23.19 Q1: True _ False _ RPC requires special networking support and functionality Q2: True _ False _ The client and server for RPC must use the same hardware architecture (e.g., little endian) Q3: True _ False _ Local procedure call << same-machine RPC << remote machine RPC Q4: True _ False _ NFS provides weak client-server data consistency Quiz 23.1: RPC and NFS" 23.20 Page 5

Quiz 23.1: RPC and NFS" 5min Break" Q1: True _ False _ X RPC requires special networking support and functionality Q2: True _ False _ X The client and server for RPC must use the same hardware architecture (e.g., little endian) Q3: True X _ False _ Local procedure call << same-machine RPC << remote machine RPC Q4: True X _ False _ NFS provides weak client-server data consistency 23.21 23.22 Andrew File System" Andrew File System (AFS, late 80ʼs) DCE DFS (commercial product) Callbacks: Server records who has copy of file On changes, server immediately tells all with old copy No polling bandwidth (continuous checking) needed Write through on close Changes not propagated to server until close() Session semantics: updates visible to other clients only after the file is closed» As a result, do not get partial writes: all or nothing» Although, for processes on local machine, updates visible immediately to other programs who have file open In AFS, everyone who has file open sees old version Donʼt get newer versions until reopen file Andrew File System (conʼt)" Data cached on local disk of client as well as memory On open with a cache miss (file not on local disk):» Get file from server, set up callback with server On write followed by close:» Send copy to server; tells all clients with copies to fetch new version from server on next open (using callbacks) What if server crashes? Lose all callback state Reconstruct callback information from client: go ask everyone who has which files cached? AFS Pro: Relative to NFS, less server load: Disk as cache more files can be cached locally Callbacks server not involved if file is read-only For both AFS and NFS: central server is bottleneck Performance: all writes server, cache misses server Availability: Server is single point of failure Cost: server machineʼs high cost relative to workstation 23.23 23.24 Page 6

World Wide Web" Key idea: graphical front-end to RPC protocol What happens when a web server fails? System breaks Solution: Transport or network-layer redirection» Invisible to applications» Can also help with scalability (load balancers)» Must handle sessions (e.g., banking/e-commerce) Initial version: no caching Didnʼt scale well easy to overload servers WWW Caching" Use client-side caching to reduce number of interactions between clients and servers and/or reduce the size of the interactions: Time-to-Live (TTL) fields HTTP Expires header from server Client polling HTTP If-Modified-Since request headers from clients Server refresh HTML META Refresh tag causes periodic client poll What is the polling frequency for clients and servers? Could be adaptive based upon a pageʼs age and its rate of change Server load is still significant 23.25 23.26 WWW Proxy Caches" Place caches in the network to reduce server load But, increases latency in lightly loaded case Caches near servers called reverse proxy caches» Offloads busy server machines Caches at the edges of the network called content distribution networks» Offloads servers and reduce client latency Challenges: Caching static traffic easy, but only ~40% of traffic Dynamic and multimedia is harder» Multimedia is a big win: Megabytes versus Kilobytes Same cache consistency problems as before Caching is changing the Internet architecture Places functionality at higher levels of comm. protocols 23.27 Conclusion" Remote Procedure Call (RPC): Call procedure on remote machine Provides same interface as procedure Automatic packing and unpacking of arguments without user programming (in stub) Distributed File System: Transparent access to files stored on a remote disk» NFS uses caching for performance Cache Consistency: Keeping contents of client caches consistent with one another If multiple clients, some reading and some writing, how do stale cached copies get updated? NFS: check periodically for changes WWW: Caching to load balance, reduce latency/costs Server and edge caches 23.28 Page 7