Linux |
CentOS 5.3 |
|
rtime(3) |
rtime − Lire l’heure sur un serveur distant. |
#include <rpc/des_crypt.h> int rtime(struct sockaddr_in *addrp, struct rpc_timeval *timep, struct rpc_timeval *timeout); |
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 à minuit, et cette fonction soustrait la constante nécessaire pour convertir le résultat en secondes écoulées depuis l’Ãre Unix (01/01/1970 à minuit). Si timeout est non-NULL, le port UDP/time (37) est utilisé, sinon le port TCP/time (37) est utilisé. |
Si elle réussit, cette fonction renvoie zéro et la valeur 32 bits obtenue est stockée dans timep->tv_sec. En cas d’échec, elle renvoie −1 et errno contient le code d’erreur. |
Toutes les erreurs pour les fonctions sous-jacentes (sendto(), poll(), recvfrom(), connect(), read()) 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é. |
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. #include <stdio.h> #include <errno.h> #include <string.h> #include <time.h> #include <rpc/auth_des.h> #include <netdb.h> int use_tcp = 0; char *servername = "linux"; int main() { struct sockaddr_in name; struct rpc_timeval time1 = {0,0}; struct rpc_timeval timeout = {1,0}; struct hostent *hent; int ret; memset((char *)&name, 0, sizeof(name)); sethostent(1); hent = gethostbyname(servername); memcpy((char *)&name.sin_addr, hent->h_addr, hent->h_length); ret = rtime(&name, &time1, use_tcp ? NULL : &timeout); if (ret < 0) perror("rtime error"); else printf("%s", ctime((time_t *)&time1.tv_sec)); return 0; } |
Seul IPV4 est supporté. Certaines versions de in.timed supportent uniquement TCP. Essayez l’exemple précédent avec use_tcp fixé à 1. La libc5 utilise le prototype |
rtime() dans les glibc <= 2.2.5 ne fonctionne pas correctement sur les machines 64 bits. |
netdate(1), ntpdate(1), rdate(1), inetd(8) |
Ce document est une traduction réalisée par Christophe Blaess <http://www.blaess.fr/christophe/> le 21 juillet 1996 et révisée le 10 juillet 2006. L’équipe de traduction a fait le maximum pour réaliser une adaptation française de qualité. La version anglaise la plus à jour de ce document est toujours consultable via la commande : « LANG=en man 3 rtime ». N’hésitez pas à signaler à l’auteur ou au traducteur, selon le cas, toute erreur dans cette page de manuel. |
rtime(3) |