HOME - RADIO - LOGIN - AIDE
KNAROU#
Post-it Technique
>>http://www.knar.info

novembre 2018
<<< RETOUR <<<

Lecture de l'article Qmail : cname lookup failed temporarily. 4.4.3
Qmail : cname lookup failed temporarily. 4.4.3
de Fabrice Mounin - le vendredi 25 février 2011 16:26:43

Pour info, Qmail ne sait lire que 512 octets de msg quand il fait une requete DNS
Resultat, si un domaine à beaucoup de MX, qmail ne sait pas faire la résolution du nom et mettra votre message en queue pendant au moins 4 jours avant de vous avertir du message d'erreur : cname lookup failed temporarily. 4.4.3

Le problème est connu et il existe un patch pour ça

Le patch qmail pour supporter jusqu'à 65536 octets
http://www.ckdhr.com./ckd/qmail-103.patch

Pour pouvoir correctement lancer le patch, vous devez disposer des sources

Cette exemple à été fait sur un serveur OVH en release 2 (Gentoo)

copier le patch (qmail-103.patch) dans /home/ovh/src

Mettez vous dans votre dossier source de qmail
cd /home/ovh/src/qmail-1.03

Appliquer la patch au sources
patch -p1 < ../qmail-103.patch

Si vous avez une architecture basée autour d'un OS 64 bits, il est nécessaire de modifier le fichier conf-cc et y retirer le -O2.
vi /home/ovh/src/qmail-1.03/conf-cc


a ce point, si vous relancer la compilation, vous risquez d'avoir un problème
./load auto-str substdio.a error.a str.a
substdio.a(substdo.o)(.text+0x43): In function `allwrite':

Pour fixer cette erreur, vous devez editer le fichier error.h  dans les sources du dossier qmail
vous devez rajouter #include "errno.h" dans la 2eme ligne du fichier juste avant la ligne "extern int errno;"

vi /home/ovh/src/qmail-1.03/error.h
Ajout :
#include "errno.h" (dans la 2eme ligne)


Relancer l'installation de qmail
make setup check
./config


Et roule ma poule, ton qmail sait maintenant lire des msg DNS supérieur à 65000 octets
Knarou




----Source du patch-------------
--- qmail-1.03/dns.c.103 Mon Aug 17 16:06:58 1998
+++ qmail-1.03/dns.c Wed Aug 26 16:28:56 1998
@@ -21,10 +21,12 @@
static unsigned short getshort(c) unsigned char *c;
{ unsigned short u; u = c[0]; return (u << 8) + c[1]; }

-static union { HEADER hdr; unsigned char buf[PACKETSZ]; } response;
+static struct { unsigned char *buf; } response;
+static int responsebuflen = 0;
static int responselen;
static unsigned char *responseend;
static unsigned char *responsepos;
+static u_long saveresoptions;

static int numanswers;
static char name[MAXDNAME];
@@ -45,18 +47,33 @@
errno = 0;
if (!stralloc_copy(&glue,domain)) return DNS_MEM;
if (!stralloc_0(&glue)) return DNS_MEM;
- responselen = lookup(glue.s,C_IN,type,response.buf,sizeof(response));
+ if (!responsebuflen)
+ if (response.buf = (unsigned char *)alloc(PACKETSZ+1))
+ responsebuflen = PACKETSZ+1;
+ else return DNS_MEM;
+
+ responselen = lookup(glue.s,C_IN,type,response.buf,responsebuflen);
+ if ((responselen >= responsebuflen) ||
+ (responselen > 0 && (((HEADER *)response.buf)->tc)))
+ {
+ if (responsebuflen < 65536)
+ if (alloc_re(&response.buf, responsebuflen, 65536))
+ responsebuflen = 65536;
+ else return DNS_MEM;
+ saveresoptions = _res.options;
+ _res.options |= RES_USEVC;
+ responselen = lookup(glue.s,C_IN,type,response.buf,responsebuflen);
+ _res.options = saveresoptions;
+ }
if (responselen <= 0)
{
if (errno == ECONNREFUSED) return DNS_SOFT;
if (h_errno == TRY_AGAIN) return DNS_SOFT;
return DNS_HARD;
}
- if (responselen >= sizeof(response))
- responselen = sizeof(response);
responseend = response.buf + responselen;
responsepos = response.buf + sizeof(HEADER);
- n = ntohs(response.hdr.qdcount);
+ n = ntohs(((HEADER *)response.buf)->qdcount);
while (n-- > 0)
{
i = dn_expand(response.buf,responseend,responsepos,name,MAXDNAME);
@@ -66,7 +83,7 @@
if (i < QFIXEDSZ) return DNS_SOFT;
responsepos += QFIXEDSZ;
}
- numanswers = ntohs(response.hdr.ancount);
+ numanswers = ntohs(((HEADER *)response.buf)->ancount);
return 0;
}



Votre nom :
Commentaire :

Recopiez le code svp :


COMMENTAIRES :
Un(e) certain(e): rebuil cdb en date du mercredi 16 novembre 2011 vers 11:46:00 à ecrit :
...cat /etc/tcp.smtp | tcprules /etc/tcp.smtp.cdb ~/tcp.smtp.tmp...

Un(e) certain(e): dd en date du lundi 10 septembre 2012 vers 09:26:03 à ecrit :
...dd...