向 Erlang 中的gen_tcp服务器发送大型消息



我正在尝试实现客户端服务器程序。服务器使用以下代码设置侦听套接字:

gen_tcp:listen(Port, [binary, {active, true}])

问题是,当客户端向服务器发送一条大消息(元组列表)时,服务器会收到几条消息。TCP似乎将长消息拆分为几条消息。

我们如何处理一次获得整个长消息?

我不认为 TCP 包是拆分的,我使用以下程序对其进行测试。

client.erl

-module(client).
-compile(export_all).
send(Message) ->
    {ok, Socket} = gen_tcp:connect("localhost", 1234, [binary, {packet, 4}]),
    ok = gen_tcp:send(Socket, list_to_binary(Message)),
    gen_tcp:close(Socket).

main() ->
    Message = ["atom" ++ integer_to_list(X) || X <- lists:seq(1, 1000)],
    send(Message).

server.erl

-module(server).
-compile(export_all).
start()->
    {ok, ListenSocket} = gen_tcp:listen(1234, [binary, {packet, 4}, 
                     {active, true}, {reuseaddr, true}]),
    spawn(fun() -> per_connect(ListenSocket) end).
per_connect(ListenSocket) ->
    {ok, Socket} = gen_tcp:accept(ListenSocket),
    spawn(fun() -> per_connect(ListenSocket) end),
    loop(Socket).
loop(Socket) ->
    receive
        {tcp, Socket, Data} ->
            io:format("~p~n", [binary_to_list(Data)]),
            loop(Socket);
        {tcp_closed, Socket} ->
            io:format("closed~n"),
            gen_tcp:close(Socket)
    end.

您可以先运行server:start().,然后运行client:main(),可以看到结果。

最新更新