source: trunk/server/docs-xml/Samba3-Developers-Guide/Tracing.xml@ 1009

Last change on this file since 1009 was 414, checked in by Herwig Bauernfeind, 16 years ago

Samba 3.5.0: Initial import

File size: 4.5 KB
Line 
1<?xml version="1.0" encoding="iso-8859-1"?>
2<!DOCTYPE chapter PUBLIC "-//Samba-Team//DTD DocBook V4.2-Based Variant V1.0//EN" "http://www.samba.org/samba/DTD/samba-doc">
3<chapter id="tracing">
4<chapterinfo>
5 <author>
6 <firstname>Andrew</firstname><surname>Tridgell</surname>
7 <affiliation>
8 <orgname>Samba Team</orgname>
9 </affiliation>
10 </author>
11</chapterinfo>
12
13<title>Tracing samba system calls</title>
14
15<para>
16This file describes how to do a system call trace on Samba to work out
17what its doing wrong. This is not for the faint of heart, but if you
18are reading this then you are probably desperate.
19</para>
20
21<para>
22Actually its not as bad as the the above makes it sound, just don't
23expect the output to be very pretty :-)
24</para>
25
26<para>
27Ok, down to business. One of the big advantages of unix systems is
28that they nearly all come with a system trace utility that allows you
29to monitor all system calls that a program is making. This is
30extremely using for debugging and also helps when trying to work out
31why something is slower than you expect. You can use system tracing
32without any special compilation options.
33</para>
34
35<para>
36The system trace utility is called different things on different
37systems. On Linux systems its called strace. Under SunOS 4 its called
38trace. Under SVR4 style systems (including solaris) its called
39truss. Under many BSD systems its called ktrace.
40</para>
41
42<para>
43The first thing you should do is read the man page for your native
44system call tracer. In the discussion below I'll assume its called
45strace as strace is the only portable system tracer (its available for
46free for many unix types) and its also got some of the nicest
47features.
48</para>
49
50<para>
51Next, try using strace on some simple commands. For example, <command>strace
52ls</command> or <command>strace echo hello</command>.
53</para>
54
55<para>
56You'll notice that it produces a LOT of output. It is showing you the
57arguments to every system call that the program makes and the
58result. Very little happens in a program without a system call so you
59get lots of output. You'll also find that it produces a lot of
60"preamble" stuff showing the loading of shared libraries etc. Ignore
61this (unless its going wrong!)
62</para>
63
64<para>
65For example, the only line that really matters in the <command>strace echo
66hello</command> output is:
67</para>
68
69<para><programlisting>
70write(1, "hello\n", 6) = 6
71</programlisting></para>
72
73<para>all the rest is just setting up to run the program.</para>
74
75<para>
76Ok, now you're familiar with strace. To use it on Samba you need to
77strace the running smbd daemon. The way I tend ot use it is to first
78login from my Windows PC to the Samba server, then use smbstatus to
79find which process ID that client is attached to, then as root I do
80<command>strace -p PID</command> to attach to that process. I normally redirect the
81stderr output from this command to a file for later perusal. For
82example, if I'm using a csh style shell:
83</para>
84
85<para><command>strace -f -p 3872 &gt;&amp; strace.out</command></para>
86
87<para>or with a sh style shell:</para>
88
89<para><command>strace -f -p 3872 > strace.out 2&gt;&amp;1</command></para>
90
91<para>
92Note the "-f" option. This is only available on some systems, and
93allows you to trace not just the current process, but any children it
94forks. This is great for finding printing problems caused by the
95"print command" being wrong.
96</para>
97
98<para>
99Once you are attached you then can do whatever it is on the client
100that is causing problems and you will capture all the system calls
101that smbd makes.
102</para>
103
104<para>
105So how do you interpret the results? Generally I search through the
106output for strings that I know will appear when the problem
107happens. For example, if I am having touble with permissions on a file
108I would search for that files name in the strace output and look at
109the surrounding lines. Another trick is to match up file descriptor
110numbers and "follow" what happens to an open file until it is closed.
111</para>
112
113<para>
114Beyond this you will have to use your initiative. To give you an idea
115of what you are looking for here is a piece of strace output that
116shows that <filename>/dev/null</filename> is not world writeable, which
117causes printing to fail with Samba:
118</para>
119
120<para><programlisting>
121[pid 28268] open("/dev/null", O_RDWR) = -1 EACCES (Permission denied)
122[pid 28268] open("/dev/null", O_WRONLY) = -1 EACCES (Permission denied)
123</programlisting></para>
124
125<para>
126The process is trying to first open <filename>/dev/null</filename> read-write
127then read-only. Both fail. This means <filename>/dev/null</filename> has
128incorrect permissions.
129</para>
130
131</chapter>
Note: See TracBrowser for help on using the repository browser.