bind
enlaza un nombre a un conector (socket)
- Provided by: manpages-es-dev (Version: 4.29.1-1)
- Source: manpages-l10n
- Report a bug
enlaza un nombre a un conector (socket)
Biblioteca Estándar C (libc, -lc)
#include <sys/socket.h>
int bind(int sockfd, const struct sockaddr *addr,
socklen_t addrlen);
Cuando se crea un socket con socket(2), existirá en un espacio de nombres (familia de direcciones), pero no tiene una dirección asignada. bind() asigna la dirección especificada por addr al socket al que hace referencia el descriptor de archivo sockfd. addrlen especifica el tamaño, en bytes, de la estructura de dirección a la que apunta addr. Esta operación se suele llamar “asignar un nombre a un socket”.
Normalmente, es necesario asignar una dirección local usando bind() a un conector SOCK_STREAM antes de que éste pueda recibir conexiones (vea accept(2)).
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 AF_INET vea ip(7), para AF_INET6 vea ipv6(7), para AF_UNIX vea unix(7), para AF_APPLETALK vea ddp(7), para AF_PACKET vea packet(7), para AF_X25 vea x25(7) y para AF_NETLINK vea netlink(7).
La estructura real que se pase para el argumento addr dependerá de la familia de direcciones. La estructura sockaddr se define de la siguiente manera:
struct sockaddr {
sa_family_t sa_family;
char sa_data[14];
}
El único propósito de esta estructura es convertir el puntero de estructura que se pasó en addr para evitar advertencias del compilador. Consulte los ejemplos a continuación.
En caso de éxito se devuelve cero. En caso de error se devuelve -1, y errno se configura para indicar el error.
Los siguientes errores son específicos a los conectores del dominio UNIX (AF_UNIX):
Los módulos de protocolo subyacentes pueden generar otros errores.
Los programas portables deben garantizar que `addr.sun_path` sea una cadena terminada en nulo para los sockets `AF_UNIX`.
POSIX.1-2024.
POSIX.1-2001, SVr4, 4.2BSD.
No están descritas las opciones de proxy transparente.
Un ejemplo del uso de bind() con sockets de dominio de Internet se puede encontrar en getaddrinfo(3).
El siguiente ejemplo muestra cómo enlazar un socket de flujo en el dominio UNIX (AF_UNIX) y aceptar conexiones:
#include <err.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <unistd.h>
#define MY_SOCK_PATH "/somepath"
#define LISTEN_BACKLOG 50
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)
err(EXIT_FAILURE, "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)
err(EXIT_FAILURE, "bind");
if (listen(sfd, LISTEN_BACKLOG) == -1)
err(EXIT_FAILURE, "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)
err(EXIT_FAILURE, "accept");
/* Code to deal with incoming connection(s)... */
if (close(sfd) == -1)
err(EXIT_FAILURE, "close");
if (unlink(MY_SOCK_PATH) == -1)
err(EXIT_FAILURE, "unlink");
}
#include <stdio.h>
#include <stdlib.h>
#include <string.h>
#include <sys/socket.h>
#include <sys/un.h>
#include <unistd.h>
#define MY_SOCK_PATH "/somepath"
#define LISTEN_BACKLOG 50
#define handle_error(msg) \
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");
/* Código para gestionar conexiones entrantes... */
if (close(sfd) == -1)
handle_error("close");
if (unlink(MY_SOCK_PATH) == -1)
handle_error("unlink");
}
accept(2), connect(2), getsockname(2), listen(2), socket(2), getaddrinfo(3), getifaddrs(3), ip(7), ipv6(7), path_resolution(7), socket(7), unix(7)
La traducción al español de esta página del manual fue creada por Miguel Angel Sepulveda <angel@vivaldi.princeton.edu>, Juan Piernas <piernas@ditec.um.es> y Marcos Fouces <marcos@debian.org>
Esta traducción es documentación libre; lea la GNU General Public License Version 3 o posterior con respecto a las condiciones de copyright. No existe NINGUNA RESPONSABILIDAD.
Si encuentra algún error en la traducción de esta página del manual, envíe un correo electrónico a debian-l10n-spanish@lists.debian.org.