The sendmail program can also produce debugging output.
The sendmail program is placed in debugging mode by using the
-d
command-line switch.
That switch produces far more information than -v
.
To see for yourself, enter the following command line, but substitute
your own login name in place of the you
:
%/usr/lib/sendmail -d
you
< /dev/null
This command line produces a great deal of output. We won't explain this output, because it is explained in Chapter 37, Debugging with -d. For now just remember that the sendmail program's debugging output can produce a great deal of information.
In addition to producing lots of debugging information, the -d
switch can be modified to display specific debugging
information. By adding a numeric argument to the -d
switch, output
can be limited to one specific aspect of the sendmail program's
behavior.
Type in this command line, but change you
to your own login name.
%
/usr/lib/sendmail -d40
you
< /dev/null
Here, the -d40
is the debugging switch with
a category of 40
. That category limits sendmail's
program output to information about the queue.
The following output shows you some information about how your
mail message was
queued.
A detailed explanation of this output is covered in
Section 37.5.138, -d40.1.
>>>>> queueing GAA14008 (new id) queueall=1 >>>>> queueing 95688=you: mailer 4 (local), host `' user `you', ruser `<null>' next=0, alias 95460, uid 0, gid 0 flags=6008<QPRIMARY,QPINGONFAILURE,QPINGONDELAY> owner=(none), home="/home/you", fullname="Your FullName" orcpt="(none)", statmta=(none), rstatus=(none) <<<<< done queueing GAA14008 <<<<<
In addition to a category, a level may also be specified. The
level adjusts the amount of output produced. A low level produces
little output; a high level produces greater and more complex
output. The string following the -d
has the form
category.level
For example, enter the following command line:
%
/usr/lib/sendmail -d0.1 -bp
The -d0
instructs sendmail to produce general
debugging information. The level .1
limits sendmail
to its minimal output. That level could have been omitted, because
a level .1
is the default. Recall that -bp
causes sendmail to print the contents of its queue.
The output produced looks something like the following:
Version 8.8.4 Compiled with: LOG NAMED_BIND NDBM NETINET NETUNIX NIS SCANF XDEBUG ============ SYSTEM IDENTITY (after readcf) ============ (short domain name) $w = here (canonical domain name) $j = here.us.edu (subdomain name) $m = us.edu (node name) $k = here ======================================================== Mail queue is empty
Here, the -d0.1
switch causes sendmail to print
its version, some information about how it was compiled, and
how it interpreted your host (domain) name.
Now run the same command line again, but change the level
from .1
to .11
:
%
/usr/lib/sendmail -d0.11 -bp
The increase in the level causes sendmail to print more information:
Version 8.8.4 Compiled with: LOG NAMED_BIND NDBM NETINET NETUNIX NIS SCANF XDEBUG OS Defines: HASFLOCK HASGETUSERSHELL HASINITGROUPS HASLSTAT HASSETREUID HASSETSID HASSETVBUF HASUNAME IDENTPROTO IP_SRCROUTE Config file: /etc/sendmail.cf Pid file: /etc/sendmail.pid canonical name: here.us.edu UUCP nodename: here a.k.a.: [123.45.67.89] ============ SYSTEM IDENTITY (after readcf) ============ (short domain name) $w = here (canonical domain name) $j = here.us.edu (subdomain name) $m = us.edu (node name) $k = here ======================================================== Mail queue is empty