aboutsummaryrefslogblamecommitdiffstats
path: root/doc/src/manual/ranch_tcp.asciidoc
blob: bee73a780ce96ad4d67440950fe765436b97a85a (plain) (tree)
1
2
3
4
5
6
7
8
9



              
                         


              
                                                        
 






                                                        







                                    








                                                
                                                      













                                                             



               

                                                       






                                                              
                                           

                


                                               
        



                                                     
                    



                                                       
                   


                                                                
                      


                                                              
    


                                                           
                            



                                                              
                       



                                                               
      


                           
       


                           
    
 



                                                                    
 
                     



                                                       
                   


                                      
                     



                                                              
                           



                                                           
                      



                                                        
                


                              
          


                                                                 
              


                                                         
        



                                            
                      


                                                                  
                           


                                                                  
        



                                         
     

                                                       





                                                                 









                       
 




                                                
= ranch_tcp(3)

== Name

ranch_tcp - TCP transport

== Description

The module `ranch_tcp` implements a TCP Ranch transport.

The function `sendfile` may not work correctly when used
against files stored in a VirtualBox shared folder.

== Exports

The module `ranch_tcp` implements the interface defined
by link:man:ranch_transport(3)[ranch_transport(3)].

== Types

=== opt()

[source,erlang]
----
opt() = {backlog, non_neg_integer()}
      | {buffer, non_neg_integer()}
      | {delay_send, boolean()}
      | {dontroute, boolean()}
      | {exit_on_close, boolean()}
      | {fd, non_neg_integer()}
      | {high_msgq_watermark, non_neg_integer()}
      | {high_watermark, non_neg_integer()}
      | inet
      | inet6
      | {ip, inet:ip_address() | inet:local_address()}
      | {ipv6_v6only, boolean()}
      | {keepalive, boolean()}
      | {linger, {boolean(), non_neg_integer()}}
      | {low_msgq_watermark, non_neg_integer()}
      | {low_watermark, non_neg_integer()}
      | {nodelay, boolean()}
      | {port, inet:port_number()}
      | {priority, integer()}
      | {raw, non_neg_integer(), non_neg_integer(), binary()}
      | {recbuf, non_neg_integer()}
      | {send_timeout, timeout()}
      | {send_timeout_close, boolean()}
      | {sndbuf, non_neg_integer()}
      | {tos, integer()}
----

Listen options.

Note that additional options may be set by the protocol
module using `Transport:setopts/2`.

None of the options are required.

Please consult the `gen_tcp` and `inet` manuals for a more
thorough description of these options. This manual only aims
to provide a short description along with what the defaults
are. Defaults may be different in Ranch compared to `gen_tcp`.
Defaults are given next to the option name:

backlog (1024)::

Max length of the queue of pending connections.

buffer::

Size of the buffer used by the Erlang driver. Default
is system-dependent.

delay_send (false)::

Always queue data before sending, to send fewer, larger
packets over the network.

dontroute (false)::

Don't send via a gateway, only send to directly connected hosts.

exit_on_close (true)::

Disable to allow sending data after a close has been detected.

fd::

File descriptor of the socket, if it was opened externally.

high_msgq_watermark (8192)::

Limit in the amount of data in the socket message queue before
the queue becomes busy.

high_watermark (8192)::

Limit in the amount of data in the ERTS socket implementation's
queue before the socket becomes busy.

inet::

Set up the socket for IPv4.

inet6::

Set up the socket for IPv6.

ip::

Interface to listen on. Listen on all network interfaces by default.

On UNIX systems, it is also possible to use a UNIX Domain
socket file by specifying `{local, SocketFile}`.

ipv6_v6only (false)::

Listen on IPv4 and IPv6 (false) or only on IPv6 (true).
Use with inet6.

keepalive (false)::

Enable sending of keep-alive messages.

linger ({false, 0})::

Whether to wait and how long to flush data sent before closing
the socket.

low_msgq_watermark (4096)::

Amount of data in the socket message queue before the queue
leaves busy state.

low_watermark (4096)::

Amount of data in the ERTS socket implementation's queue
before the socket leaves busy state.

nodelay (true)::

Whether to enable TCP_NODELAY.

port (0)::

TCP port number to listen on. 0 means a random port will be used.

priority (0)::

Priority value for all packets to be sent on this socket.

recbuf::

Minimum size of the socket's receive buffer.
Default is system-dependent.

send_timeout (30000)::

How long the send call may wait for confirmation before returning.

send_timeout_close (true)::

Whether to close the socket when the confirmation wasn't received.

sndbuf::

Minimum size of the socket's send buffer.
Default is system-dependent.

tos::

Value for the IP_TOS IP level option. Use with caution.

In addition, the `raw` option can be used to set system-specific
options by specifying the protocol level, the option number and
the actual option value specified as a binary. This option is not
portable. Use with caution.

=== opts()

[source,erlang]
----
opts() :: [opt()]
----

List of listen options.

== See also

link:man:ranch(7)[ranch(7)],
link:man:ranch_transport(3)[ranch_transport(3)],
link:man:ranch_ssl(3)[ranch_ssl(3)],
gen_tcp(3),
inet(3)