1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76 77 78 79 80 81 82 83
|
%%
%% %CopyrightBegin%
%%
%% Copyright Ericsson AB 2020-2020. All Rights Reserved.
%%
%% Licensed under the Apache License, Version 2.0 (the "License");
%% you may not use this file except in compliance with the License.
%% You may obtain a copy of the License at
%%
%% http://www.apache.org/licenses/LICENSE-2.0
%%
%% Unless required by applicable law or agreed to in writing, software
%% distributed under the License is distributed on an "AS IS" BASIS,
%% WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
%% See the License for the specific language governing permissions and
%% limitations under the License.
%%
%% %CopyrightEnd%
%%
%% ---------------------------------------------------------------------
%%
%% Reads small messages to a socket, until counters wrap!
%%
%% ---------------------------------------------------------------------
-module(esock_iow_server).
-export([start/0]).
-define(LIB, esock_iow_lib).
-define(LIMIT, 100000).
%% ---------------------------------------------------------------------
start() ->
Domain = inet,
?LIB:iprint("open"),
{ok, LSock} = socket:open(Domain, stream, tcp),
?LIB:iprint("iow"),
ok = socket:setopt(LSock, otp, iow, true),
?LIB:iprint("bind"),
LocalSA = #{family => Domain,
addr => {147,214,93,147}},
{ok, LAddr} = socket:bind(LSock, LocalSA),
?LIB:iprint("listen addr: ~p", [LAddr]),
?LIB:iprint("make listen socket"),
ok = socket:listen(LSock),
?LIB:iprint("accept"),
{ok, CSock} = socket:accept(LSock),
ok = socket:send(CSock, <<"begin">>),
loop(CSock, 0).
loop(S, N) ->
case socket:recv(S) of
{ok, _} when (N < ?LIMIT) ->
flush(S),
loop(S, N+1);
{ok, _} ->
?LIB:iprint("Counters:"
"~s", [?LIB:format_counters(cnts(S))]),
flush(S),
loop(S, 0);
{error, Reason} ->
?LIB:eprint("failed receive: ~p", [Reason])
end.
cnts(S) ->
#{counters := Cnts} = socket:info(S),
Cnts.
flush(S) ->
receive
{'$socket', S, counter_wrap, Cnt} ->
?LIB:iprint("Counter ~w wrapped", [Cnt]);
Any ->
?LIB:iprint("Received: ~n ~p~n", [Any])
after 0 ->
ok
end.
|