| Napster | multiple threads of control that can be concurrently executed to implement concurrent operations, otherwise when the client is waiting for one kind of input, it will not be able to respond to the other kind of input | each program to function as both a client and a server | clients and servers | which is then implemented by a collection of components | developers of clients are frequently forced to upgrade their clients whenever the server is changed if clients and servers are developed by different organizations | at least one server and one client | forward-compatible and backward-compatible with other versions of clients and servers by designing the client-server protocols to be very general and flexible | even if its components change over the course of time, or are replaced by equivalent components | subsystem | software components that are distributed over several hosts and that can each be both a server and a client | encryption, firewalls and similar methods of ensuring security | The server starts runningThe server listens for clients wanting to connectClients start running and perform various operations, some of which require connecting to the server to request a serviceWhen a client attempts to connect, the server accepts the connection if it is willingThe server waits for messages to arrive from connected clientsWhen a message from a client arrives, the server takes some action in response, such as sending a message back to the client, then resumes waitingClients and servers continue functioning in this manner until one of them decides to shut down 
 |  | peer-to-peer system |