Unix-sockets-socket-server-example
提供:Dev Guides
Unixソケット-サーバーの例
プロセスをTCPサーバーにするには、以下の手順に従う必要があります-
- _socket()_システムコールでソケットを作成します。
- _bind()_システムコールを使用して、ソケットをアドレスにバインドします。 インターネット上のサーバーソケットの場合、アドレスはホストマシンのポート番号で構成されます。
- _listen()_システムコールで接続をリッスンします。
- _accept()_システムコールで接続を受け入れます。 通常、この呼び出しは、クライアントがサーバーに接続するまでブロックします。 *_read()_および_write()_システムコールを使用してデータを送受信します。
次に、これらの手順をソースコードの形式で説明します。 このコードをファイル_server.c_に入れて、_gcc_コンパイラーでコンパイルします。
複数の接続を処理する
サーバーが複数の同時接続を処理できるように、上記のコードで次の変更を行います-
- _accept_ステートメントと次のコードを無限ループに入れます。
- 接続が確立されたら、_fork()_を呼び出して新しいプロセスを作成します。
- 子プロセスは、_sockfd_を閉じ、_doprocessing_関数を呼び出して、新しいソケットファイル記述子を引数として渡します。 _doprocessing()_が返すように、2つのプロセスが会話を完了すると、このプロセスは単に終了します。 *親プロセスは_newsockfd_を閉じます。 このコードはすべて無限ループにあるため、acceptステートメントに戻り、次の接続を待機します。
次のコードシーケンスは、_doprocessing_関数の簡単な実装を示しています。