class TCPSocket
TCPSocket 代表一个 TCP/IP 客户端套接字。
一个简单的客户端可能如下所示
require 'socket' s = TCPSocket.new 'localhost', 2000 while line = s.gets # Read lines from socket puts line # and print them end s.close # close socket when done
公共类方法
源
static VALUE
tcp_s_gethostbyname(VALUE obj, VALUE host)
{
    rb_warn("TCPSocket.gethostbyname is deprecated; use Addrinfo.getaddrinfo instead.");
    struct rb_addrinfo *res =
        rsock_addrinfo(host, Qnil, AF_UNSPEC, SOCK_STREAM, AI_CANONNAME);
    return rsock_make_hostent(host, res, tcp_sockaddr);
}
          请改用 Addrinfo.getaddrinfo。 此方法由于以下原因已被弃用:
- 
结果的第三个元素是第一个地址的地址族。其余地址的地址族未返回。 
- 
gethostbyname() 可能需要很长时间,并且可能会阻塞其他线程。(由于 gethostbyname() 不是线程安全的,因此无法释放 GVL。) 
- 
此方法使用已从 POSIX 中删除的 gethostbyname() 函数。 
此方法通过主机名查找主机信息。
TCPSocket.gethostbyname("localhost") #=> ["localhost", ["hal"], 2, "127.0.0.1"]
源
static VALUE
tcp_init(int argc, VALUE *argv, VALUE sock)
{
    VALUE remote_host, remote_serv;
    VALUE local_host, local_serv;
    VALUE opt;
    static ID keyword_ids[4];
    VALUE kwargs[4];
    VALUE resolv_timeout = Qnil;
    VALUE connect_timeout = Qnil;
    VALUE fast_fallback = Qnil;
    VALUE test_mode_settings = Qnil;
    if (!keyword_ids[0]) {
        CONST_ID(keyword_ids[0], "resolv_timeout");
        CONST_ID(keyword_ids[1], "connect_timeout");
        CONST_ID(keyword_ids[2], "fast_fallback");
        CONST_ID(keyword_ids[3], "test_mode_settings");
    }
    rb_scan_args(argc, argv, "22:", &remote_host, &remote_serv,
                        &local_host, &local_serv, &opt);
    if (!NIL_P(opt)) {
        rb_get_kwargs(opt, keyword_ids, 0, 4, kwargs);
        if (kwargs[0] != Qundef) { resolv_timeout = kwargs[0]; }
        if (kwargs[1] != Qundef) { connect_timeout = kwargs[1]; }
        if (kwargs[2] != Qundef) { fast_fallback = kwargs[2]; }
        if (kwargs[3] != Qundef) { test_mode_settings = kwargs[3]; }
    }
    if (fast_fallback == Qnil) {
        fast_fallback = rb_ivar_get(rb_cSocket, tcp_fast_fallback);
        if (fast_fallback == Qnil) fast_fallback = Qtrue;
    }
    return rsock_init_inetsock(sock, remote_host, remote_serv,
                               local_host, local_serv, INET_CLIENT,
                               resolv_timeout, connect_timeout, fast_fallback,
                               test_mode_settings);
}
          在 remote_port 上打开到 remote_host 的 TCP 连接。如果指定了 local_host 和 local_port,则在本地端使用这些参数建立连接。
从 Ruby 3.4 开始,此方法默认按照 Happy Eyeballs Version 2 (RFC 8305) 算法运行,但在 Windows 上除外。
有关 Happy Eyeballs Version 2 的详细信息,请参阅 Socket.tcp_fast_fallback=。
要使其行为与 Ruby 3.3 及更早版本相同,请显式指定选项 fast_fallback:false。 或者,设置 Socket.tcp_fast_fallback=false 将禁用 Happy Eyeballs Version 2,不仅对此方法,还会对所有 Socket 全局禁用。
在 Windows 上使用 TCPSocket.new 时,不提供 Happy Eyeballs Version 2,其行为与 Ruby 3.3 及更早版本相同。
- :resolv_timeout
- 
指定从主机名解析开始的超时秒数。 
- :connect_timeout
- 
此方法依次尝试连接到所有候选目标地址。 connect_timeout指定从连接尝试开始到最后一个候选地址的超时秒数。
 默认情况下,所有连接尝试都会持续到超时发生。
 当显式指定fast_fallback:false时,
 将为每次连接尝试设置超时时间,并且任何超出其超时的连接尝试都将被取消。
- :fast_fallback
- 
启用 Happy Eyeballs Version 2 算法(默认启用)。