Socket's local address

When implementing servers, for both TCP and UDP, it is important to bind the listening socket to a local address and port. If the socket isn't bound, then clients can't know where to connect.

It is also possible to use bind() on the client side to associate a socket with a particular address and port. It is sometimes useful to use bind() in this manner on machines that have multiple network interfaces. The use of bind() can allow the selection of which network address to use for the outgoing connection.

Sometimes, bind() is used to set the local port for an outgoing connection. This is usually a bad idea for a few reasons. First, it very seldom serves any purpose. The port number presented to the connected server is likely to be different because of network address translation regardless. Binding to a local port also invites the error of selecting a port that is already in use. Usually, the operating system takes care of selecting a free port. This use of bind() also raises the issue with TIME-WAIT, which would prevent a new connection from being established after a closed one without a substantial delay.

We have used bind() in this book mostly for binding servers to a particular port number. It can also be used to associate servers to a particular address. If a server has multiple network interfaces, it may be the case that you only care to listen on connections at one address. In this case, bind() can easily be used to limit the connections to that address. It can also be used to limit connections to the local machine by binding sockets to 127.0.0.1. This can be an important security measure for some applications.

We have employed the select() function for many purposes—timing out connect(), signaling when data is available, and preventing send() from blocking. However, select() is only suitable for monitoring a limited number of sockets. Let's look at this limitation, and how to circumvent it, next.