1 JMH Associates © 2004, All rights reserved Chapter 11 Interprocess Communication.

Slides:



Advertisements
Similar presentations
Processes Management.
Advertisements

Remote Procedure Call (RPC)
©2009 Operačné systémy Procesy. 3.2 ©2009 Operačné systémy Process in Memory.
CCNA – Network Fundamentals
计算机系 信息处理实验室 Lecture 16 Networking
© 2007 Cisco Systems, Inc. All rights reserved.Cisco Public 1 Version 4.0 OSI Transport Layer Network Fundamentals – Chapter 4.
Interprocess Communications
1 Processes and Pipes COS 217 Professor Jennifer Rexford.
A CHAT CLIENT-SERVER MODULE IN JAVA BY MAHTAB M HUSSAIN MAYANK MOHAN ISE 582 FALL 2003 PROJECT.
1 Java Networking – Part I CS , Spring 2008/9.
Concurrency CS 510: Programming Languages David Walker.
Inter Process Communication:  It is an essential aspect of process management. By allowing processes to communicate with each other: 1.We can synchronize.
© 2007 Pearson Education Inc., Upper Saddle River, NJ. All rights reserved.1 Computer Networks and Internets with Internet Applications, 4e By Douglas.
TCP/IP Protocol Suite 1 Chapter 11 Upon completion you will be able to: User Datagram Protocol Be able to explain process-to-process communication Know.
02/01/2010CSCI 315 Operating Systems Design1 Interprocess Communication Notice: The slides for this lecture have been largely based on those accompanying.
1 JMH Associates © 2004, All rights reserved Chapter 2-3 Supplement Registry Programming.
Systems Architecture, Fourth Edition1 Internet and Distributed Application Services Chapter 13.
1 JMH Associates © 2004, All rights reserved Chapter 15 Asynchronous Input/Output.
1 JMH Associates © 2004, All rights reserved Chapter 1 Getting Started with Win32/64.
Chapter 4.1 Interprocess Communication And Coordination By Shruti Poundarik.
C++ fundamentals.
Process-to-Process Delivery:
Chapter 8 Windows Outline Programming Windows 2000 System structure Processes and threads in Windows 2000 Memory management The Windows 2000 file.
Agenda  Terminal Handling in Unix File Descriptors Opening/Assigning & Closing Sockets Types of Sockets – Internal(Local) vs. Network(Internet) Programming.
Chapter 9 Message Passing Copyright © Operating Systems, by Dhananjay Dhamdhere Copyright © Operating Systems, by Dhananjay Dhamdhere2 Introduction.
1 Chapter Client-Server Interaction. 2 Functionality  Transport layer and layers below  Basic communication  Reliability  Application layer.
Jozef Goetz, Application Layer PART VI Jozef Goetz, Position of application layer The application layer enables the user, whether human.
Group 1 Members: SMU CSE 8343 Wael Faheem Professor:Dr.M.KHALIL. Hazem Morsy Date: Poramate Ongsakorn Payal H Patel Samatha Devi Malka.
Chapter 3: Processes. 3.2 Silberschatz, Galvin and Gagne ©2005 Operating System Concepts - 7 th Edition, Feb 7, 2006 Process Concept Process – a program.
FTP Server and FTP Commands By Nanda Ganesan, Ph.D. © Nanda Ganesan, All Rights Reserved.
DISTRIBUTED COMPUTING PARADIGMS. Paradigm? A MODEL 2for notes
Windows Operating System Internals - by David A. Solomon and Mark E. Russinovich with Andreas Polze Unit OS3: Concurrency 3.4. Windows APIs for Synchronization.
The Socket Interface Chapter 21. Application Program Interface (API) Interface used between application programs and TCP/IP protocols Interface used between.
The Socket Interface Chapter 22. Introduction This chapter reviews one example of an Application Program Interface (API) which is the interface between.
CE Operating Systems Lecture 3 Overview of OS functions and structure.
CS162B: Pipes Jacob T. Chan. Pipes  These allow output of one process to be the input of another process  One of the oldest and most basic forms of.
Windows Operating System Internals - by David A. Solomon and Mark E. Russinovich with Andreas Polze Unit OS A: Windows Networking A.3. Microsoft-specific.
INFORMATION SYSTEM-SOFTWARE Topic: OPERATING SYSTEM CONCEPTS.
CE Operating Systems Lecture 13 Linux/Unix interprocess communication.
Hwajung Lee.  Interprocess Communication (IPC) is at the heart of distributed computing.  Processes and Threads  Process is the execution of a program.
Interprocess Communications
Processes CSCI 4534 Chapter 4. Introduction Early computer systems allowed one program to be executed at a time –The program had complete control of the.
Socket Programming Lab 1 1CS Computer Networks.
WINDOWS NT Network Architecture Amy, Mei-Hsuan Lu CML/CSIE/NTU August 19, 1998.
The Client-Server Model And the Socket API. Client-Server (1) The datagram service does not require cooperation between the peer applications but such.
 Wind River Systems, Inc Chapter - 7 Intertask Communication.
Lecture 4 Mechanisms & Kernel for NOSs. Mechanisms for Network Operating Systems  Network operating systems provide three basic mechanisms that support.
Chapter 7 - Interprocess Communication Patterns
 Process Concept  Process Scheduling  Operations on Processes  Cooperating Processes  Interprocess Communication  Communication in Client-Server.
Netprog: Client/Server Issues1 Issues in Client/Server Programming Refs: Chapter 27.
1 Kyung Hee University Chapter 11 User Datagram Protocol.
Channels. Models for Communications Synchronous communications – E.g. Telephone call Asynchronous communications – E.g. .
Distributed Computing, M. L. Liu 1 Interprocess Communications Mei-Ling L. Liu.
IST 201 Chapter 11 Lecture 2. Ports Used by TCP & UDP Keep track of different types of transmissions crossing the network simultaneously. Combination.
Window Threads Chapter 7 Windows Thread Management.
Redirection and Pipes ● Unix Philosophy ● Make each program do one thing well. To do a new job, build afresh rather than complicate old programs by adding.
Module 4 Remote Login.
OpenStorage API part II
Working at a Small-to-Medium Business or ISP – Chapter 7
Chapter 3: Windows7 Part 4.
Working at a Small-to-Medium Business or ISP – Chapter 7
Threads and Data Sharing
Working at a Small-to-Medium Business or ISP – Chapter 7
Windows APIs File Processing Copyright © 2016 Curt Hill.
Inter Process Communication (IPC)
Process-to-Process Delivery:
Operating Systems Chapter 5: Input/Output Management
Interprocess Communication
Process Synchronization
The CreateFile Function
Presentation transcript:

1 JMH Associates © 2004, All rights reserved Chapter 11 Interprocess Communication

2 JMH Associates © 2004, All rights reserved OBJECTIVESOBJECTIVES Upon completion of this chapter, you will be able to:  Describe the Windows interprocess communication mechanisms  Describe the different capabilities of anonymous pipes, named pipes, and mailslots  Use the Windows interprocess communication facilities to develop applications with cooperating processes  Be prepared to learn and use the synchronization mechanisms in the next module

3 JMH Associates © 2004, All rights reserved IPC ALTERNATIVES Byte- and message-oriented Windows objects  Pipes (anonymous and named)  Mailslots (subject of this chapter) Networking  Windows sockets (standard interface to TCP/IP)  Remote Procedure Calls (RPCs) Object-oriented  OLE; COM (Component Object Model) Some others  Shared memory with memory-mapped files  Files

4 JMH Associates © 2004, All rights reserved OVERVIEW (1 of 2) Interprocess Communication (IPC) is provided with byte- and message-based “pipes” Anonymous pipes  Well suited for redirecting the output of one program to the input of another  Anonymous pipes are stream oriented

5 JMH Associates © 2004, All rights reserved OVERVIEW (2 of 2) Named pipes  Allow networked communication  Multiple handles on the same pipe  Transaction-oriented named pipe functions  Ideal for creating simple client/server systems  Named pipes are message oriented Mailslots allow for one-to-many message broadcasting

6 JMH Associates © 2004, All rights reserved TOPICSTOPICS Topic IAnonymous Pipes Lab 6–A Topic IINamed Pipes Topic IIIMailslots Lab 6–B

7 JMH Associates © 2004, All rights reserved TOPIC I Anonymous Pipes

8 JMH Associates © 2004, All rights reserved ANONYMOUS PIPES  Allow for one-way (half-duplex), character-based IPC  Two handles: a read handle and a write handle  Specify the suggested buffer size for the pipe  Usually you want the pipes to be inheritable

9 JMH Associates © 2004, All rights reserved IPC USING AN ANONYMOUS PIPE pipe Program2Program1 CreatePipe (&hRead, &hWrite) StartUp.hStdOutput = hWrite CreateProcess ("Program1") StartUp.hStdInput = hRead CreateProcess ("Program2") WaitForMultipleObjects hIn = CreateFile (argv [1]) while ( ) { ReadFile (hIn) WriteFile (hWrite) } ExitProcess (0) hOut = CreateFile (argv [2]) while ( ) { ReadFile (hRead) } WriteFile (hOut) Pipe

10 JMH Associates © 2004, All rights reserved ANONYMOUS PIPE MANAGEMENT (1 of 2) BOOL CreatePipe (PHANDLE phRead, PHANDLE phWrite, LPSECURITY_ATTRIBUTES lpsa, DWORD cbPipe)

11 JMH Associates © 2004, All rights reserved ANONYMOUS PIPE MANAGEMENT (2 of 2) cbPipe  The pipe byte size; use zero to get the default value phRead  Address of a HANDLE  CreatePipe will set *phRead  phWrite is used for the write handle to the new pipe Reading blocks if pipe is empty; otherwise read will accept as many bytes as are in the pipe, up to the number specified in the ReadFile call Writing to a full pipe will block

12 JMH Associates © 2004, All rights reserved LAB 6–A (1 of 2) We now have a collection of command line utilities, including cat, ls (with options for file size and security), grep, and sort (several versions)  Write a program, pipe, which will take two commands and connect them with anonymous pipes (assigned to standard input and output)  Use the = sign to separate the two program names  Use the model in the anonymous pipe figure. The original input is standard input and the results are to go to standard output.

13 JMH Associates © 2004, All rights reserved LAB 6–A (2 of 2) Command form: pipe Program1 = Program2 An additional utility, the wc word count program, is included with the solutions  It is useful in the role of Program2

14 JMH Associates © 2004, All rights reserved TOPIC II Named Pipes

15 JMH Associates © 2004, All rights reserved NAMED PIPES (1 of 2) Good mechanism for implementing IPC-based applications, including limited networked client/server systems  Use WinSockets for serious networked IPC  Use named pipes primarily for single-system IPC Message-oriented, so the reading process can read varying length messages precisely as sent by the writing process

16 JMH Associates © 2004, All rights reserved NAMED PIPES (2 of 2) Bi-directional, so two processes can exchange messages over the same pipe You can create multiple, independent instances of a named pipe  Several clients can communicate with a single server using the same pipe  Server can respond to a client using the same instance Pipe name can be accessed by systems on a network

17 JMH Associates © 2004, All rights reserved CLIENTS AND SERVER USING NAMED PIPES Server /* Create N instances */ for (i = 0; i < N, i++) h [i] = CreateNamedPipe (PipeName, N); /* Poll each pipe instance, get request, return response */ i = 0; while ( ) { if PeekNamedPipe (h [i]) { ReadFile (h [i], &Request); /* Create response */ WriteFile (h [i], &Response); } i = i++ % N; } ········ Up to N Clients Client 0 h = CreateFile (PipeName); while ( ) { WriteFile (h, &Request); ReadFile (h, &Response) /* Process Response */ } CloseHandle (h); Pipe Instance 0 Client (N-1) h = CreateFile (PipeName); while ( ) { WriteFile (h, &Request); ReadFile (h, &Response) /* Process Response */ } CloseHandle (h); Pipe Instance N-1

18 JMH Associates © 2004, All rights reserved USING NAMED PIPES (1 of 2) The model above has two significant shortcomings:  The server polls the named pipe handles rather than waiting for a connection or a request. This will be fixed in the next lab.  It can only process one client request at a time. This will be fixed using threads in the next module. Also, a suggested extension in this module’s lab shows how to use multiple processes.

19 JMH Associates © 2004, All rights reserved USING NAMED PIPES (2 of 2)  CreateNamedPipe creates the first instance of a named pipe and returns a handle  The creating process is regarded as the server  Client processes, possibly on other systems, open the pipe with CreateFile

20 JMH Associates © 2004, All rights reserved CREATING NAMED PIPES (1 of 5) HANDLE CreateNamedPipe (LPCTSTR lpszPipeName, DWORD fdwOpenMode, DWORD fdwPipeMode, DWORD nMaxInstances, DWORD cbOutBuf, DWORD cbInBuf, DWORD dwTimeOut, LPSECURITY_ATTRIBUTES lpsa)  lpszPipeName indicates the pipe name  Must be of the form \\.\pipe\[path]pipename  You cannot create a pipe on a remote machine

21 JMH Associates © 2004, All rights reserved CREATING NAMED PIPES (2 of 5) fdwOpenMode specifies one of:  PIPE_ACCESS_DUPLEX  Equivalent to GENERIC_READ | GENERIC_WRITE  PIPE_ACCESS_INBOUND — Data flow is from the client to the server only  Equivalent to GENERIC_READ  PIPE_ACCESS_OUTBOUND The mode can also specify FILE_FLAG_WRITE_THROUGH (not used with message pipes) and FILE_FLAG_OVERLAPPED

22 JMH Associates © 2004, All rights reserved CREATING NAMED PIPES (3 of 5) fdwPipeMode has three mutually exclusive flag pairs indicating whether writing is message- or byte-oriented, whether reading is by messages or blocks, and whether read operations block  PIPE_TYPE_BYTE and PIPE_TYPE_MESSAGE  Mutually exclusive  Writing stream of bytes or messages  Use the same type value for all pipe instances

23 JMH Associates © 2004, All rights reserved CREATING NAMED PIPES (4 of 5)  PIPE_READMODE_BYTE and PIPE_READMODE_MESSAGE  Reading stream of bytes or messages  PIPE_READMODE_MESSAGE requires PIPE_TYPE_MESSAGE  PIPE_WAIT and PIPE_NOWAIT determine whether ReadFile will block  Use PIPE_WAIT as there are better ways to achieve asynchronous I/O

24 JMH Associates © 2004, All rights reserved CREATING NAMED PIPES (5 of 5) nMaxInstances — the number of pipe instances and, therefore, the number of simultaneous clients  Specify this same value for every CreateNamedPipe call for a given pipe  PIPE_UNLIMITED_INSTANCES allows the OS to base the number on available system resources cbOutBuf and cbInBuf advise the OS on the required size of input and output buffers dwTimeOut — default time-out period (in milliseconds) for the WaitNamedPipe function lpsa is as in all the other “ Create ” functions

25 JMH Associates © 2004, All rights reserved POLLINGPOLLING BOOL PeekNamedPipe (HANDLE hPipe, LPVOID lpvBuffer, DWORD cbBuffer, LPDWORD lpcbRead, LPDWORD lpcbAvail, LPDWORD lpcbMessage)  Nondestructively reads any bytes or messages in the pipe  Does not block  Returns immediately  Test *lpcbAvail to determine whether there is data in the pipe

26 JMH Associates © 2004, All rights reserved NAMED PIPE CLIENT CONNECTIONS A client can “connect” to a named pipe using CreateFile with the named pipe name  In many cases, the client and server are on the same machine, and the name would be of the form: \\.\pipe\[path]pipename  If the server is on a different machine, the name would be: \\servername\pipe\[path]pipename  Using the name “.” when the server is local, rather than the local machine name (this is faster)

27 JMH Associates © 2004, All rights reserved NAMED PIPE STATUS FUNCTIONS (1 of 2) Two functions are provided to interrogate pipe status information  GetNamedPipeHandleState returns information, given an open handle, on whether the pipe is in blocking or non- blocking mode, whether it is message- or byte-oriented, the number of pipe instances, and so on  SetNamedPipeHandleState allows you to set the same state attributes

28 JMH Associates © 2004, All rights reserved NAMED PIPE STATUS FUNCTIONS (2 of 2) Another function is provided to set state information  GetNamedPipeInfo determines whether the handle is for a client or server instance, buffer sizes, and so on

29 JMH Associates © 2004, All rights reserved NAMED PIPE CONVENIENCE FUNCTIONS (1 of 7) Given a “long-lived” connection, you can combine the WriteFile, ReadFile client sequence  There are also performance advantages as a connection is not required

30 JMH Associates © 2004, All rights reserved NAMED PIPE CONVENIENCE FUNCTIONS (2 of 7) BOOL TransactNamedPipe (HANDLE hNamedPipe, LPVOID lpvWriteBuf, DWORD cbWriteBuf, LPVOID lpvReadBuf, DWORD cbReadBuf, LPDWORD lpcbRead, LPOVERLAPPED lpa)  Both output and input buffers are specified  *lpcbRead — The message length

31 JMH Associates © 2004, All rights reserved NAMED PIPE CONVENIENCE FUNCTIONS (3 of 7) BOOL CallNamedPipe (LPCTSTR lpszPipeName, LPVOID lpvWriteBuf, DWORD cbWriteBuf, LPVOID lpvReadBuf, DWORD cbReadBuf, LPDWORD lpcbRead, DWORD dwTimeOut)

32 JMH Associates © 2004, All rights reserved NAMED PIPE CONVENIENCE FUNCTIONS (4 of 7) Synchronous: Create/Write/Read/Clos e client “short- lived” connection  Minimizes instance use but increases connection overhead Specifies time-out period for the connection, in milliseconds or one of:  NMPWAIT_NOWAIT  NMPWAIT_WAIT_FOREVER  NMPWAIT_USE_DEFAULT_WAIT

33 JMH Associates © 2004, All rights reserved NAMED PIPE CONVENIENCE FUNCTIONS (5 of 7) BOOL WaitNamedPipe (LPCTSTR lpszPipeName, DWORD dwTimeOut) The client can wait for an instance of the named pipe to become available

34 JMH Associates © 2004, All rights reserved NAMED PIPE CONVENIENCE FUNCTIONS (6 of 7) BOOL ConnectNamedPipe (HANDLE hNamedPipe, LPOVERLAPPED lpo) BOOL DisconnectNamedPipe (HANDLE hNamedPipe) With lpo set to NULL, ConnectNamedPipe will return as soon as the server has a connection from a client

35 JMH Associates © 2004, All rights reserved NAMED PIPE CONVENIENCE FUNCTIONS (7 of 7)  Normal return value is TRUE  Return value is FALSE if the client connected between the server’s CreateNamedPipe call and the ConnectNamedPipe call  In this case, GetLastError returns ERROR_PIPE_CONNECTED  Perform ReadFile, WriteFile operations between connect and disconnect

36 JMH Associates © 2004, All rights reserved NAMED PIPE SECURITY  The important security rights for named pipes are:  GENERIC_READ  GENERIC_WRITE  SYNCHRONIZE (allowing a thread to wait on the pipe)  You normally get the appropriate rights depending on the access (duplex, inbound, outbound)  All three require SYNCHRONIZE

37 JMH Associates © 2004, All rights reserved CLIENT-SERVER NAMED PIPES USING A SHORT-LIVED CONNECTION ClientServer WaitNamedPipe CreateFile WriteFile ReadFile CloseHandle CreateNamedPipe ConnectNamedPipe ReadFile WriteFile DisconnectNamedPipe

38 JMH Associates © 2004, All rights reserved TOPIC III Mailslots

39 JMH Associates © 2004, All rights reserved MAILSLOTS (1 of 3)  Have names, so unrelated processes can use them for communication  Broadcast mechanisms which behave differently from named pipes  One-directional  Can have multiple readers and writers but often used in one-to-many configurations  A writer (“client”) does not know whether readers (“servers”) actually received a message

40 JMH Associates © 2004, All rights reserved MAILSLOTS (2 of 3)  Can be located over a network domain  Message lengths are limited  Each mailslot server (don’t confuse with the application or named pipe server) creates a mailslot handle with Creat slot  The server waits to receive a mailslot message with a ReadFile call  A write-only client should open the mailslot with CreateFile and write messages with WriteFile

41 JMH Associates © 2004, All rights reserved MAILSLOTS (3 of 3)  The open will fail (name not found) if there are no waiting readers  A client’s message can be read by all servers  They all receive the same message  The client, in performing the CreateFile, can use the form \\*\mailslot\mailslotname to connect to all mailslots with the name

42 JMH Associates © 2004, All rights reserved USING A MAILSLOT ······ Mailslot Client Application Server while (...) { Sleep (...); hMS = CreateFile ("\\*\mailslot\status"); · · · WriteFile (hMS, &StatusInformation) } Application Client 0 hMS = Creat slot ("\\.\mailslot\status"); ReadFile (hMS, &ServerStatus) /* Connect to this Server */ Application Client N hMS = Creat slot ("\\.\mailslot\status"); ReadFile (hMS, &ServerStatus) /* Connect to this Server */ Mailslot Servers This Message is Sent Periodically

43 JMH Associates © 2004, All rights reserved USING MAILSLOTS (1 of 2) One scenario: An application server, such as a database server, acting as a mailslot client, periodically broadcasts its name, named pipe name, and status information  Any application client that wants to find a server can receive this name by being a mailslot server  Note how the “client” and “server” terms are used An application server can periodically broadcast its status (utilization, database size, etc.) to the application clients

44 JMH Associates © 2004, All rights reserved USING MAILSLOTS (2 of 2) As shown, there is a single mailslot client (writer) and multiple readers (servers)  With multiple application servers, you would have multiple mailslot readers and writers  A bulletin board service might have a single mailslot reader and multiple writers  Alternative: The application client also acts as the MS client and broadcasts a pipe name to mailslot (and application) servers

45 JMH Associates © 2004, All rights reserved CREATING AND OPENING A MAILSLOT (1 of 3) HANDLE Creat slot (LPCTSTR lpszName, DWORD cbMaxMsg, DWORD dwReadTimeout, LPSECURITY_ATTRIBUTES lpsa) lpszName — Points to a mailslot name of the form: \\.\mailslot\[path]name cbMaxMsg  Maximum size (in bytes) for messages a client can write  0 means no limit

46 JMH Associates © 2004, All rights reserved CREATING AND OPENING A MAILSLOT (2 of 3) dwReadTimeout — Number of milliseconds a read operation will wait  0 causes an immediate return  MAILSLOT_WAIT_FOREVER is an infinite wait (no timeout) The client must specify the FILE_SHARE_READ flag Functions GetMailslotInfo and SetMailslotInfo are similar to their named pipe counterparts

47 JMH Associates © 2004, All rights reserved CREATING AND OPENING A MAILSLOT (3 of 3) The client (writer), when opening a mailslot with CreateFile, uses the following name forms:  \\.\mailslot\[path]name  To retrieve a handle for a local mailslot  \\computername\mailslot\[path]name  To retrieve a handle for a mailslot on a specified machine  \\domainname\mailslot\[path]name  To return a handle representing all mailslots on machines in the domain  \\*\mailslot\[path]name  To return a handle representing mailslots on machines in the system’s primary domain

48 JMH Associates © 2004, All rights reserved LAB 6–B (1 of 2) Use named pipes to connect clients (the client program) to a “command line server”  The clients take a command line and send it to a known server for execution  The server returns the results to the client over the named pipe  Design your named pipe model carefully; there are several alternatives

49 JMH Associates © 2004, All rights reserved LAB 6–B (2 of 2) The solution consists of several components:  Client.c is built with locsrver.c  Run Client.exe in its own window  Server.c is built as Server.exe and runs in its own window or is controlled with the job management commands. Place the commands to be executed in the same directory as Server.exe.  Server.exe runs SrvrBcst.exe as a process that broadcasts the pipe name over a mailslot  Use SrvrBcst.c to build this executable  The header file, ClntSrvr.h, contains definitions used in the various programs