
A 回答 (3件)
- 最新から表示
- 回答順に表示
No.3
- 回答日時:
すいません、補足を見逃してました。
もう解決済みかな?クライアントの上限を超えたら、accept() してそのまま close() すれば OK です。クライアント側では connect() が失敗してきます。 accept() ではコネクトしてきた相手の IP アドレス等がチェックできるようになってますよね?もしそうしたいなら、チェックしてダメな相手だったら close() してしまえば OK です。
これは一見おかしいようにも思えますが、ソケットのコネクションの本当の完了は、実際の通信が行われる時まで遅延されているので、上記の方法で大丈夫なのです。
No.2
- 回答日時:
No.1 さんのだと、最初の N 接続だけを可能とする、というようになりかねません。
もし「仕様」が接続しているクライアントの最大数を制限する、というのであれば、処理はもう少し複雑になります。ここで、普通のクライアント、サーバ型の処理形態だとすると、接続要求をサーバが受け付けた時には子プロセスを fork() しますよね。で、処理が終わったら子プロセスは終了しますよね。
つまり接続している数だけ子プロセスが存在することになるので、子プロセスの数を制限すれば良いことになります。つまり、子プロセス生成時にカウンタをインクリメントし、子プロセスの終了時にカウンタをデクリメントし、カウンタの上限を超えたかどうかをチェックすれば実現できることになります。
このためには子プロセスの終了をサーバが感知する必要があります。これには wait*() を WNOHANG オプション付きで定期的に呼び出すか、シグナルハンドラを設定して、SIGCHLD シグナルを拾うとかする必要があります。
この回答への補足
>カウンタの上限を超えたかどうかをチェックすれば実現できることになります。
具体的にはカウンタの上限を超えたら、どのように記述すればいいのでしょうか?サーバ側ではただ単にaccept行を飛ばすようにすればいいんでしょうか?クライアント側ではconnectをノンブロッキングにする必要もありますか?

No.1
- 回答日時:
クライアント側で接続拒否の理由を知る必要がないなら、クライアント側は、ふつうにコネクトすれば、良いと思います。
サーバ側が、アクセプト時に、アクセプトしたソケットの数を数えて、それが上限に達していれば、直ちにそのソケットをクローズすれば、良いと思います。
お探しのQ&Aが見つからない時は、教えて!gooで質問しましょう!
このQ&Aを見た人はこんなQ&Aも見ています
-
ソケット通信で同時受信の制限?
C言語・C++・C#
-
socket: recvはいつ,どれだけ受け取るのか?
C言語・C++・C#
-
エディットボックスで改行
その他(プログラミング・Web制作)
-
-
4
ネットワーク切断を検出するには?
C言語・C++・C#
-
5
ソケットのクローズについて
C言語・C++・C#
-
6
CStringをwchar_tに変換したい
C言語・C++・C#
-
7
非ブロッキングソケットのrecvについて
C言語・C++・C#
-
8
エディットコントロールでEnter押した時の動作
C言語・C++・C#
-
9
CStringからchar*への型変換について教えてください。
C言語・C++・C#
-
10
Winsockで接続待ちタイムアウトを設定する方法
C言語・C++・C#
-
11
LRESULTとHRESULT
C言語・C++・C#
-
12
SocketのSend関数でのCLOSEの検知 [Linux]
C言語・C++・C#
-
13
ConnectNamedPipeの接続待ち
C言語・C++・C#
-
14
EDITコントロールで入力できる文字を制限するには?
C言語・C++・C#
-
15
acceptをalarmでタイムアウトさせる処理がうまくいきません
C言語・C++・C#
-
16
Enterキーを押されたら次の処理に移るという事をしたい。
C言語・C++・C#
-
17
エディットボックスの入力制限について
C言語・C++・C#
-
18
CString から LPCTSTRの型に変換
C言語・C++・C#
-
19
非同期のプロセス間通信(パイプ)で全データ受信する
C言語・C++・C#
-
20
ソケットでクライアントのipアドレスを取得できるそうですが・・・
C言語・C++・C#
関連するカテゴリからQ&Aを探す
おすすめ情報
このQ&Aを見た人がよく見るQ&A
デイリーランキングこのカテゴリの人気デイリーQ&Aランキング
-
ソケット通信で接続クライアン...
-
SIDとSERVICE_NAMEの違いとは?
-
異なる文字コードの環境にイン...
-
DB2で SQL1032N start databas...
-
Excel2000アンインスト-ル時内...
-
SQLサーバー認証でログインを作...
-
正しいSQLなのに「ORA-00936: ...
-
クラスタリングとレプリケーシ...
-
ORAー12560:TNS:protocol adap...
-
データソース名および指定され...
-
oracleのメモリ使用量が97%ほど...
-
CloverをインストールしたUSBメ...
-
QNDを使うとクライアント側の情...
-
OraOps10.dllのエラーについて
-
ObjectBrowserでエクスポート
-
突然オラクルへ接続できなくな...
-
ストアドプロシジャからデータ...
-
SQL Server のシャットダウンの...
-
ORA-01092 ORACLEインスタンス...
-
ORA-12170のエラーについて
マンスリーランキングこのカテゴリの人気マンスリーQ&Aランキング
-
ソケット通信で接続クライアン...
-
SIDとSERVICE_NAMEの違いとは?
-
Fate/hollow ataraxiaの追加パ...
-
CloverをインストールしたUSBメ...
-
突然オラクルへ接続できなくな...
-
ORA-12170のエラーについて
-
DB2で SQL1032N start databas...
-
正しいSQLなのに「ORA-00936: ...
-
Oracle11g SQLPlusログインにつ...
-
倒産した18禁ゲーム会社のパ...
-
OraOps10.dllのエラーについて
-
.NET Frameworkがコントロール...
-
データソース名および指定され...
-
PCゲーム Hard☆Love☆Life
-
SQL 全角半角混在の文字列から...
-
ObjectBrowserでエクスポート
-
WiFi環境があればTikTokLiteは...
-
異なる文字コードの環境にイン...
-
SQL*PLUSにてデータベース名表示
-
Oracle10g・・ODBCで接続できない
おすすめ情報