Click here to Skip to main content
Licence 
First Posted 26 Jul 2001
Views 74,214
Bookmarked 18 times

Communication Pipe Classes

By | 26 Jul 2001 | Article
Simple and fast communication between all types of MFC Applications on a single or multiple computers in Windows NT.

Client Server

1. Purpose


Simple and fast communication between all types of MFC Applications on a single or multiple computers in Windows NT.

2. Main features

  • Data transmission from Clients to Server, their processing and results return, if needed.
  • Data transmission from Server to Clients informing them about any event.
  • Different schemes of buffer allocations.
  • Automatic Server loading.
  • Automatic Server termination without Clients, if needed.
  • Utilities for registration, automatic loading, tracing and Wizard.

3. Introduction

Several years ago I wrote classes using Mailslots for communication between Clients and Server. According to the project requirements these classes had to work in Windows 95. In spite of numerous problems and limitations of Mailslots these classes work properly in Windows 95 and Windows NT.

The problems were that there is an 8-byte limitation for Mailslots names in Windows95 and numerous data transmissions across Mailslots between Computers if they have several identical installed communication protocols. Microsoft considers this "by design". In other words, it is not an error, but I don't agree with it.

In these classes the Server has the receiving thread and Clients send data with identification of the Client (Computer name and Client name) to this thread. It increases the summary data that Clients transmit across Mailslots and it is the disadvantage of this method.

I took a course in COM and ATL. After that it was evident that there were very many undocumented things in that technology.
ATL is a convenient tool, but I have discovered several limitations, e.g. it is impossible to make ATL-Server from an existing MFC application.

DCOM implementation needs great effort too. For example, I wrote my first program with DCOM in almost 2 weeks and had to ask Microsoft for numerous consultations. That's why in spite of my wish to use COM/DCOM in my new project I had to give up this idea.

The new project that I have begun to work at had high requirements for the speed of data processing. This factor had to be taken into account in the design of the new communication tool. Fortunately, unlike COM, there were no requirements to the design of the universal tool and this made the development easier.

For the new project I have chosen the protocol Named Pipes working only in Windows NT. In literature this protocol is defined as following:

An inter-process communication mechanism that allows one process to communicate with another local or remote process.

I have tried to implement the ideas that I used in my first project with Mailslots as well as the ideas of COM. In the next section you'll learn the Client-Server architecture, based on the Named Pipes protocol.

4. Client-Server Architecture

These are following variants of connections Client and Server.
  • Client and Server are on a single computer.
  • Client and Server are on multiple computers.

Schemes

When a Server is loaded, the Client tries to get into a connection with Server.

If Server is not loaded and Client and Server are on a single computer, Client gets information about Server from Registry of this computer (see Computer 4).

If Server is not loaded and Client and Server are on multiple computers, Client gets information about Server from Registry of the remote Server computer across utility AgentCP (see Computers 1 and 2). This program searches Server information in Registry of Server Computer and loads it.

As seen from Figure 1, for successful functioning of the above-mentioned process it is necessary:

  • To write information about Server in Registry of Server Computer.
  • To run the AgentCP utility on the remote computer previously.

Thus the Server automatic loading is carried out. Process-Server may be terminated automatically, if Clients are not connected.

There is a User's guide in DemoConnectionPipe.zip

Here you may see Wizard Application:

WizardCP

License

This article has no explicit license attached to it but may contain usage terms in the article text or the download files themselves. If in doubt please contact the author via the discussion board below.

A list of licenses authors might use can be found here

About the Author

Ion Tichy



United States United States

Member



Sign Up to vote   Poor Excellent
Add a reason or comment to your vote: x
Votes of 3 or less require a comment

Comments and Discussions

 
You must Sign In to use this message board. (secure sign-in)
 
Search this forum  
 FAQ
    Noise  Layout  Per page   
  Refresh
GeneralConnectionPipe.dll PinmemberH49212:42 1 Mar '04  
GeneralConnectionPipe.dll Pinmembermohsen mahdiyeh0:28 25 Jan '03  
GeneralRe: ConnectionPipe.dll PinsussAnonymous5:32 23 Feb '03  
GeneralConnectionPipe.dll Pinmembermohsen mahdiyeh0:25 25 Jan '03  
GeneralNo source PinmemberTodd C. Wilson3:04 13 Jun '02  
GeneralRe: No source PinmemberTodd C. Wilson16:57 17 Jun '02  
GeneralRe: No source PinmemberEdouard Griffiths1:55 11 Nov '03  
GeneralConnectionPipe.dll PinmemberJokec0:32 17 Jan '02  
GeneralRe: ConnectionPipe.dll PinsussJose Luis Rochas4:55 20 Sep '05  

General General    News News    Suggestion Suggestion    Question Question    Bug Bug    Answer Answer    Joke Joke    Rant Rant    Admin Admin   

Use Ctrl+Left/Right to switch messages, Ctrl+Up/Down to switch threads, Ctrl+Shift+Left/Right to switch pages.

Permalink | Advertise | Privacy | Mobile
Web01 | 2.5.120517.1 | Last Updated 27 Jul 2001
Article Copyright 2001 by Ion Tichy
Everything else Copyright © CodeProject, 1999-2012
Terms of Use
Layout: fixed | fluid