.\" -*- coding: UTF-8 -*- .\" Copyright, the authors of the Linux man-pages project .\" .\" SPDX-License-Identifier: Linux-man-pages-copyleft .\" .\" .\" Other portions are from the 6.9 (Berkeley) 3/10/91 man page: .\" .\" Copyright 1983, The Regents of the University of California. .\" .\" SPDX-License-Identifier: BSD-4-Clause-UC .\" .\"******************************************************************* .\" .\" This file was generated with po4a. Translate the source file. .\" .\"******************************************************************* .TH bind 2 "17 Mayo 2025" "Páginas de Manual de Linux 6.15" .SH NOMBRE bind \- enlaza un nombre a un conector (socket) .SH BIBLIOTECA Biblioteca Estándar C (\fIlibc\fP,\ \fI\-lc\fP) .SH SINOPSIS .nf \fB#include \fP .P \fBint bind(int \fP\fIsockfd\fP\fB, const struct sockaddr *\fP\fIaddr\fP\fB,\fP \fB socklen_t \fP\fIaddrlen\fP\fB);\fP .fi .SH DESCRIPCIÓN Cuando se crea un socket con \fBsocket\fP(2), existirá en un espacio de nombres (familia de direcciones), pero no tiene una dirección asignada. \fBbind\fP() asigna la dirección especificada por \fIaddr\fP al socket al que hace referencia el descriptor de archivo \fIsockfd\fP. \fIaddrlen\fP especifica el tamaño, en bytes, de la estructura de dirección a la que apunta \fIaddr\fP. Esta operación se suele llamar \[lq]asignar un nombre a un socket\[rq]. .P Normalmente, es necesario asignar una dirección local usando \fBbind\fP() a un conector \fBSOCK_STREAM\fP antes de que éste pueda recibir conexiones (vea \fBaccept\fP(2)). .P Las reglas usadas en el enlace de nombres varían entre familias de direcciones. Consulte las entradas de manual de la Sección 7 para obtener una información más detallada. Para \fBAF_INET\fP vea \fBip\fP(7), para \fBAF_INET6\fP vea \fBipv6\fP(7), para \fBAF_UNIX\fP vea \fBunix\fP(7), para \fBAF_APPLETALK\fP vea \fBddp\fP(7), para \fBAF_PACKET\fP vea \fBpacket\fP(7), para \fBAF_X25\fP vea \fBx25\fP(7) y para \fBAF_NETLINK\fP vea \fBnetlink\fP(7). .P La estructura real que se pase para el argumento \fIaddr\fP dependerá de la familia de direcciones. La estructura \fIsockaddr\fP se define de la siguiente manera: .P .in +4n .EX struct sockaddr { sa_family_t sa_family; char sa_data[14]; } .EE .in .P El único propósito de esta estructura es convertir el puntero de estructura que se pasó en \fIaddr\fP para evitar advertencias del compilador. Consulte los ejemplos a continuación. .SH "VALOR DEVUELTO" En caso de éxito se devuelve cero. En caso de error se devuelve \-1, y \fIerrno\fP se configura para indicar el error. .SH ERRORES .TP \fBEACCES\fP .\" e.g., privileged port in AF_INET domain La dirección está protegida y el usuario no es el superusuario. .TP \fBEADDRINUSE\fP La dirección dada ya está en uso. .TP \fBEADDRINUSE\fP (Sockets de dominio de Internet) El número de puerto se definió «0» en la estructura de dirección del socket, pero, al intentar vincularlo a un puerto efímero, se determinó que todos los números de puerto en el rango de puertos efímeros están actualmente en uso. Consulte la explicación de \fI/proc/sys/net/ipv4/ip_local_port_range\fP \fBip\fP(7). .TP \fBEBADF\fP \fIsockfd\fP no es un descriptor de archivo válido. .TP \fBEINVAL\fP .\" This may change in the future: see .\" .I linux/unix/sock.c for details. El socket ya está vinculado a una dirección. .TP \fBEINVAL\fP \fIaddrlen\fP es incorrecto o \fIaddr\fP no es una dirección válida para el dominio de este socket. .TP \fBENOTSOCK\fP El descriptor de archivo \fIsockfd\fP no se refiere a un conector. .TP \fBEADDRNOTAVAIL\fP Se requirió una interfaz inexistente o una dirección no local. .P Los siguientes errores son específicos a los conectores del dominio UNIX (\fIAF_UNIX\fP): .TP \fBEACCES\fP El permiso de búsqueda ha sido denegado en uno de los componentes de la ruta. Consulte \fBpath_resolution\fP(7). .TP \fBEFAULT\fP \fIaddr\fP señala fuera del espacio de direcciones accesible por el usuario. .TP \fBELOOP\fP Se han encontrado demasiados enlaces simbólicos al resolver \fIaddr\fP. .TP \fBENAMETOOLONG\fP \fIaddr\fP es demasiado larga. .TP \fBENOENT\fP No existe algún componente del prefijo del directorio del nombre de ruta del conector. .TP \fBENOMEM\fP No hay disponible suficiente memoria del núcleo. .TP \fBENOTDIR\fP Un componente del prefijo de la ruta no es un directorio. .TP \fBEROFS\fP El nodo\-i del conector reside en un sistema de ficheros de `sólo lectura'. .P Los módulos de protocolo subyacentes pueden generar otros errores. .SH ESTÁNDARES POSIX.1\-2008. .SH HISTORIAL .\" SVr4 documents an additional .\" .B ENOSR .\" general error condition, and .\" additional .\" .B EIO .\" and .\" .B EISDIR .\" UNIX-domain error conditions. POSIX.1\-2001, SVr4, 4.4BSD (\fBbind\fP() apareció por primera vez en 4.2BSD). .SH ERRORES .\" FIXME Document transparent proxy options No están descritas las opciones de proxy transparente. .SH EJEMPLOS Un ejemplo del uso de \fBbind\fP() con sockets de dominio de Internet se puede encontrar en \fBgetaddrinfo\fP(3). .P .\" listen.7 refers to this example. .\" accept.7 refers to this example. .\" unix.7 refers to this example. El siguiente ejemplo muestra cómo enlazar un socket de flujo en el dominio UNIX (\fBAF_UNIX\fP) y aceptar conexiones: .P .\" SRC BEGIN (bind.c) .EX #include #include #include #include #include #include \& #define MY_SOCK_PATH "/somepath" #define LISTEN_BACKLOG 50 \& #define handle_error(msg) \[rs] do { perror(msg); exit(EXIT_FAILURE); } while (0) \& int main(void) { int sfd, cfd; socklen_t peer_addr_size; struct sockaddr_un my_addr, peer_addr; \& sfd = socket(AF_UNIX, SOCK_STREAM, 0); if (sfd == \-1) handle_error("socket"); \& memset(&my_addr, 0, sizeof(my_addr)); my_addr.sun_family = AF_UNIX; strncpy(my_addr.sun_path, MY_SOCK_PATH, sizeof(my_addr.sun_path) \- 1); \& if (bind(sfd, (struct sockaddr *) &my_addr, sizeof(my_addr)) == \-1) handle_error("bind"); \& if (listen(sfd, LISTEN_BACKLOG) == \-1) handle_error("listen"); \& /* Now we can accept incoming connections one at a time using accept(2). */ \& peer_addr_size = sizeof(peer_addr); cfd = accept(sfd, (struct sockaddr *) &peer_addr, &peer_addr_size); if (cfd == \-1) handle_error("accept"); \& /* Code to deal with incoming connection(s)... */ \& if (close(sfd) == \-1) handle_error("close"); \& if (unlink(MY_SOCK_PATH) == \-1) handle_error("unlink"); } .EE .\" SRC END .SH "VÉASE TAMBIÉN" \fBaccept\fP(2), \fBconnect\fP(2), \fBgetsockname\fP(2), \fBlisten\fP(2), \fBsocket\fP(2), \fBgetaddrinfo\fP(3), \fBgetifaddrs\fP(3), \fBip\fP(7), \fBipv6\fP(7), \fBpath_resolution\fP(7), \fBsocket\fP(7), \fBunix\fP(7) .PP .SH TRADUCCIÓN La traducción al español de esta página del manual fue creada por Miguel Angel Sepulveda , Juan Piernas y Marcos Fouces . .PP Esta traducción es documentación libre; lea la .UR https://www.gnu.org/licenses/gpl-3.0.html GNU General Public License Version 3 .UE o posterior con respecto a las condiciones de copyright. No existe NINGUNA RESPONSABILIDAD. .PP Si encuentra algún error en la traducción de esta página del manual, envíe un correo electrónico a .MT debian-l10n-spanish@lists.debian.org .ME .