Provided by: manpages-fr-dev_4.27.0-1_all bug

NOM

       rtime - Lire l'heure sur un serveur distant

BIBLIOTHÈQUE

       Bibliothèque C standard (libc, -lc)

SYNOPSIS

       #include <rpc/auth_des.h>

       int rtime(struct sockaddr_in *addrp, struct rpc_timeval *timep,
                 struct rpc_timeval *timeout);

DESCRIPTION

       Cette fonction utilise le protocole Time Serveur décrit dans la RFC 868 pour lire l'heure sur une machine
       distante.

       Le  protocole  Time Serveur donne l'heure en secondes écoulées depuis le 1er janvier 1900 à 00:00:00 UTC,
       et cette fonction soustrait la constante nécessaire pour  convertir  le  résultat  en  secondes  écoulées
       depuis l'époque, 1er janvier 1970 à 00:00:00 (UTC).

       Si timeout est non NULL, le port UDP/time (37) est utilisé, sinon le port TCP/time (37) est utilisé.

VALEUR RENVOYÉE

       Si  elle  réussit,  cette  fonction  renvoie  0  et  la  valeur de temps 32 bits obtenue est stockée dans
       timep->tv_sec. En cas d'échec, elle renvoie -1 et errno est défini pour indiquer l'erreur.

ERREURS

       Toutes les erreurs  pour  les  fonctions  sous-jacentes  (sendto(2),  poll(2),  recvfrom(2),  connect(2),
       read(2)) peuvent se produire, avec en outre :

       EIO    Le nombre d'octets reçus n'est pas 4.

       ETIMEDOUT
              Le délai indiqué en second argument a expiré.

ATTRIBUTS

       Pour une explication des termes utilisés dans cette section, consulter attributes(7).
       ┌──────────────────────────────────────────────────────────────────────┬──────────────────────┬─────────┐
       │ InterfaceAttributValeur  │
       ├──────────────────────────────────────────────────────────────────────┼──────────────────────┼─────────┤
       │ rtime()                                                              │ Sécurité des threads │ MT-Safe │
       └──────────────────────────────────────────────────────────────────────┴──────────────────────┴─────────┘

NOTES

       Seul IPv4 est supporté.

       Certaines  versions  de  in.timed  supportent uniquement TCP. Essayez le programme d'exemple avec use_tcp
       définie à 1.

BOGUES

       rtime() dans la glibc 2.2.5 et les précédentes ne fonctionne pas correctement sur les machines 64 bits.

EXEMPLES

       Cet exemple demande que le port 37 soit ouvert et actif. Vérifiez que l'entrée time dans  /etc/inetd.conf
       ne soit pas commentée.

       Le  programme  se  connecte  sur  un  hôte  nommé « linux ». Utiliser « localhost » ne fonctionne pas. Le
       résultat est l'heure locale de l'ordinateur « linux ».

       #include <errno.h>
       #include <netdb.h>
       #include <stdio.h>
       #include <stdlib.h>
       #include <string.h>
       #include <time.h>

       #include <rpc/auth_des.h>

       static int use_tcp = 0;
       static const char servername[] = "linux";

       int
       main(void)
       {
           int                 ret;
           time_t              t;
           struct hostent      *hent;
           struct rpc_timeval  time1 = {0, 0};
           struct rpc_timeval  timeout = {1, 0};
           struct sockaddr_in  name;

           memset(&name, 0, sizeof(name));
           sethostent(1);
           hent = gethostbyname(servername);
           memcpy(&name.sin_addr, hent->h_addr, hent->h_length);

           ret = rtime(&name, &time1, use_tcp ? NULL : &timeout);
           if (ret < 0)
               perror("rtime error");
           else {
               t = time1.tv_sec;
               printf("%s\n", ctime(&t));
           }

           exit(EXIT_SUCCESS);
       }

VOIR AUSSI

       ntpdate(1), inetd(8)

TRADUCTION

       La  traduction  française   de   cette   page   de   manuel   a   été   créée   par   Christophe   Blaess
       <https://www.blaess.fr/christophe/>,   Stéphan   Rafin   <stephan.rafin@laposte.net>,   Thierry   Vignaud
       <tvignaud@mandriva.com>, François Micaux, Alain Portal  <aportal@univ-montp2.fr>,  Jean-Philippe  Guérard
       <fevrier@tigreraye.org>,   Jean-Luc   Coulon   (f5ibh)   <jean-luc.coulon@wanadoo.fr>,   Julien   Cristau
       <jcristau@debian.org>,     Thomas     Huriaux      <thomas.huriaux@gmail.com>,      Nicolas      François
       <nicolas.francois@centraliens.net>,     Florentin     Duneau    <fduneau@gmail.com>,    Simon    Paillard
       <simon.paillard@resel.enst-bretagne.fr>,    Denis    Barbier    <barbier@debian.org>,    David     Prévot
       <david@tilapin.org> et Jean-Pierre Giraud <jean-pierregiraud@neuf.fr>

       Cette  traduction  est  une  documentation libre ; veuillez vous reporter à la GNU General Public License
       version 3 concernant les conditions de copie et de distribution. Il n'y a aucune RESPONSABILITÉ LÉGALE.

       Si vous découvrez un bogue dans la traduction de cette page de manuel,  veuillez  envoyer  un  message  à
       debian-l10n-french@lists.debian.org.

Pages du manuel de Linux 6.9.1                    15 juin 2024                                          rtime(3)