[Pkg-samba-maint] Bug#492856: Panic or segfault in Samba

CORNU Frédéric fcornu at groupehelice.fr
Tue Jul 29 12:47:08 UTC 2008


Package: samba
Version: 3.0.24-6etch10

A few minutes after server startup and after a few successfull queries, I get :

The Samba 'panic action' script, /usr/share/samba/panic-action,
was called for PID 7391 (/usr/sbin/smbd).

This means there was a problem with the program, such as a segfault.
Below is a backtrace for this process generated with gdb, which shows
the state of the program at the time the error occurred.  The Samba log
files may contain additional information about the problem.

If the problem persists, you are encouraged to first install the
samba-dbg package, which contains the debugging symbols for the Samba
binaries.  Then submit the provided information as a bug report to
Debian.  For information about the procedure for submitting bug reports,
please see http://www.debian.org/Bugs/Reporting or the reportbug(1)
manual page.

Using host libthread_db library "/lib/tls/libthread_db.so.1".
[Thread debugging using libthread_db enabled]
[New Thread -1213172032 (LWP 7391)]
0xb7c15eee in waitpid () from /lib/tls/libc.so.6
#0  0xb7c15eee in waitpid () from /lib/tls/libc.so.6
#1  0xb7bbd699 in strtold_l () from /lib/tls/libc.so.6
#2  0xb7d4e56d in system () from /lib/tls/libpthread.so.0
#3  0x0822c52a in smb_panic (why=0x8321a5f "internal error") at lib/util.c:1608
#4  0x0821a69a in sig_fault (sig=11) at lib/fault.c:47
#5  <signal handler called>
#6  0xb7c85b0b in xdr_uint8_t () from /lib/tls/libc.so.6
#7  0xb7c85453 in xdr_uint8_t () from /lib/tls/libc.so.6
#8  0xb7c135a0 in fgetgrent () from /lib/tls/libc.so.6
#9  0xb7c136dd in initgroups () from /lib/tls/libc.so.6
#10 0x08246b3d in sys_getgrouplist (user=0x8418df0 "hcjava", gid=1001, 
    groups=0xb7972008, grpcnt=0xbf84c684) at lib/system_smbd.c:72
#11 0x08246ce0 in getgroups_unix_user (mem_ctx=0x841ad48, 
    user=0x8418df0 "hcjava", primary_gid=1001, ret_groups=0xbf84c778, 
    p_ngroups=0x841ad50) at lib/system_smbd.c:165
#12 0x081ea4b9 in pdb_default_enum_group_memberships (methods=0x83eb018, 
    mem_ctx=0x841ad48, user=0x8418f00, pp_sids=0x841ad4c, pp_gids=0xbf84c778, 
    p_num_groups=0x841ad50) at passdb/pdb_interface.c:1441
#13 0x081eb6ef in pdb_enum_group_memberships (mem_ctx=0x841ad48, 
    user=0x8418f00, pp_sids=0x841ad4c, pp_gids=0xbf84c778, 
    p_num_groups=0x841ad50) at passdb/pdb_interface.c:738
#14 0x0826c971 in make_server_info_sam (server_info=0x83ebca0, 
    sampass=0x8418f00) at auth/auth_util.c:588
#15 0x082667ae in check_sam_security (auth_context=0x83702f0, 
    my_private_data=0x0, mem_ctx=0x8418cd8, user_info=0x8418680, 
    server_info=0x83ebca0) at auth/auth_sam.c:348
#16 0x08266aeb in check_samstrict_security (auth_context=0x83702f0, 
    my_private_data=0x0, mem_ctx=0x8418cd8, user_info=0x8418680, 
    server_info=0x83ebca0) at auth/auth_sam.c:428
#17 0x08264392 in check_ntlm_password (auth_context=0x83702f0, 
    user_info=0x8418680, server_info=0x83ebca0) at auth/auth.c:257
#18 0x0826e93d in auth_ntlmssp_check_password (ntlmssp_state=0x841a420, 
    user_session_key=0xbf84cbf4, lm_session_key=0xbf84cbe8)
    at auth/auth_ntlmssp.c:111
#19 0x08124b29 in ntlmssp_server_auth (ntlmssp_state=0x841a420, request=
      {data = 0x8417600 "NTLMSSP", length = 182, free = 0x8229c10 <free_data_blob>}, reply=0xbf84db70) at libsmb/ntlmssp.c:723
#20 0x0812445f in ntlmssp_update (ntlmssp_state=0x841a420, in=
      {data = 0x8417600 "NTLMSSP", length = 182, free = 0x8229c10 <free_data_blob>}, out=0xbf84db70) at libsmb/ntlmssp.c:274
#21 0x0826e68b in auth_ntlmssp_update (auth_ntlmssp_state=0x83ebc98, request=
      {data = 0x8417600 "NTLMSSP", length = 182, free = 0x8229c10 <free_data_blob>}, reply=0xbf84db70) at auth/auth_ntlmssp.c:204
#22 0x080c1475 in reply_sesssetup_and_X (conn=0x0, inbuf=0xb7a33008 "", 
    outbuf=0xb79bd008 "", length=360, bufsize=131072) at smbd/sesssetup.c:625
#23 0x080ea674 in switch_message (type=115, inbuf=0xb7a33008 "", 
    outbuf=0xb79bd008 "", size=360, bufsize=131072) at smbd/process.c:992
#24 0x080eb83d in smbd_process () at smbd/process.c:1019
#25 0x082c384f in main (argc=1, argv=0x68) at smbd/server.c:1024


...with a few dozen smbd processes eating up 100% cpu.

A fix for this is :
===================

1) stopping samba deamon : /etc/init.d/samba stop
2) killing all smbd processes with 'kill -9 ...'. 'killall smbd' doesn't will them.
3) starting samba deamon : /etc/init.d/samba start


More infos on the system :
==========================

Libc6 version : 2.3.6.ds1-13etch7
Linux SRV025 2.6.20.1-1-686 #1 SMP Sun Mar 4 12:44:55 UTC 2007 i686 GNU/Linux


Content of /etc/samba/smb.conf :
================================

#
# Sample configuration file for the Samba suite for Debian GNU/Linux.
#
#
# This is the main Samba configuration file. You should read the
# smb.conf(5) manual page in order to understand the options listed
# here. Samba has a huge number of configurable options most of which 
# are not shown in this example
#
# Any line which starts with a ; (semi-colon) or a # (hash) 
# is a comment and is ignored. In this example we will use a #
# for commentary and a ; for parts of the config file that you
# may wish to enable
#
# NOTE: Whenever you modify this file you should run the command
# "testparm" to check that you have not many any basic syntactic 
# errors. 
#

#======================= Global Settings =======================

[global]

## Browsing/Identification ###

# Change this to the workgroup/NT-domain name your Samba server will part of
   workgroup = etudes.groupehelice.local

client signing = yes

# server string is the equivalent of the NT Description field
   server string = %h server (Samba %v)

# Windows Internet Name Serving Support Section:
# WINS Support - Tells the NMBD component of Samba to enable its WINS Server
;   wins support = no

# WINS Server - Tells the NMBD components of Samba to be a WINS Client
# Note: Samba can be either a WINS Server, or a WINS Client, but NOT both
;   wins server = w.x.y.z

# This will prevent nmbd to search for NetBIOS names through DNS.
   dns proxy = no

# What naming service and in what order should we use to resolve host names
# to IP addresses
;   name resolve order = lmhosts host wins bcast


#### Debugging/Accounting ####

# This tells Samba to use a separate log file for each machine
# that connects
   log file = /var/log/samba/log.%m

# Put a capping on the size of the log files (in Kb).
   max log size = 1000

# If you want Samba to only log through syslog then set the following
# parameter to 'yes'.
;   syslog only = no

# We want Samba to log a minimum amount of information to syslog. Everything
# should go to /var/log/samba/log.{smbd,nmbd} instead. If you want to log
# through syslog you should set the following parameter to something higher.
   syslog = 0

# Do something sensible when Samba crashes: mail the admin a backtrace
   panic action = /usr/share/samba/panic-action %d


####### Authentication #######

# "security = user" is always a good idea. This will require a Unix account
# in this server for every user accessing the server. See
# /usr/share/doc/samba-doc/htmldocs/ServerType.html in the samba-doc
# package for details.
;   security = user

# You may wish to use password encryption.  See the section on
# 'encrypt passwords' in the smb.conf(5) manpage before enabling.
   encrypt passwords = true

# If you are using encrypted passwords, Samba will need to know what
# password database type you are using.  
   passdb backend = tdbsam 

   obey pam restrictions = yes

;   guest account = nobody
   invalid users = root

# This boolean parameter controls whether Samba attempts to sync the Unix
# password with the SMB password when the encrypted SMB password in the
# passdb is changed.
;   unix password sync = no

# For Unix password sync to work on a Debian GNU/Linux system, the following
# parameters must be set (thanks to Augustin Luton <aluton at hybrigenics.fr> for
# sending the correct chat script for the passwd program in Debian Potato).
   passwd program = /usr/bin/passwd %u
   passwd chat = *Enter\snew\sUNIX\spassword:* %n\n *Retype\snew\sUNIX\spassword:* %n\n .

# This boolean controls whether PAM will be used for password changes
# when requested by an SMB client instead of the program listed in
# 'passwd program'. The default is 'no'.
;   pam password change = no


########## Printing ##########

# If you want to automatically load your printer list rather
# than setting them up individually then you'll need this
;   load printers = yes

# lpr(ng) printing. You may wish to override the location of the
# printcap file
;   printing = bsd
;   printcap name = /etc/printcap

# CUPS printing.  See also the cupsaddsmb(8) manpage in the
# cupsys-client package.
;   printing = cups
;   printcap name = cups

# When using [print$], root is implicitly a 'printer admin', but you can
# also give this right to other users to add drivers and set printer
# properties
;   printer admin = @ntadmin


######## File sharing ########

# Name mangling options
;   preserve case = yes
;   short preserve case = yes


############ Misc ############

# Using the following line enables you to customise your configuration
# on a per machine basis. The %m gets replaced with the netbios name
# of the machine that is connecting
;   include = /home/samba/etc/smb.conf.%m

# Most people will find that this option gives better performance.
# See smb.conf(5) and /usr/share/doc/samba-doc/htmldocs/speed.html
# for details
# You may want to add the following on a Linux system:
#         SO_RCVBUF=8192 SO_SNDBUF=8192
   socket options = TCP_NODELAY

# The following parameter is useful only if you have the linpopup package
# installed. The samba maintainer and the linpopup maintainer are
# working to ease installation and configuration of linpopup and samba.
;   message command = /bin/sh -c '/usr/bin/linpopup "%f" "%m" %s; rm %s' &

# Domain Master specifies Samba to be the Domain Master Browser. If this
# machine will be configured as a BDC (a secondary logon server), you
# must set this to 'no'; otherwise, the default behavior is recommended.
;   domain master = auto

# Some defaults for winbind (make sure you're not using the ranges
# for something else.)
;   idmap uid = 10000-20000
;   idmap gid = 10000-20000
;   template shell = /bin/bash

#======================= Share Definitions =======================

[homes]
   comment = Home Directories
   browseable = no

# By default, the home directories are exported read-only. Change next
# parameter to 'yes' if you want to be able to write to them.
   writable = no

# File creation mask is set to 0700 for security reasons. If you want to
# create files with group=rw permissions, set next parameter to 0775.
   create mask = 0700

# Directory creation mask is set to 0700 for security reasons. If you want to
# create dirs. with group=rw permissions, set next parameter to 0775.
   directory mask = 0700

# Un-comment the following and create the netlogon directory for Domain Logons
# (you need to configure Samba to act as a domain controller too.)
[HC_JAVA]
   comment = xxxxxxxxxxxxxxxx
   path = /opt/samba
   guest ok = yes
   writable = yes
   share modes = no

[CENTRAL]
   comment = ATTENTION FOREST !
   path = /opt/samba
   valid users = central
   force user = root
   writeable = Yes

[PILOTAGE]
   path = /var/www/pilotage
   valid users = central
   #force user = root
   writeable = Yes

[CDS]
   path = /opt/samba/PROJETS/xxxx
   guest ok = no
   writable = yes

# Un-comment the following and create the netlogon directory for Domain Logons
# (you need to configure Samba to act as a domain controller too.)
;[netlogon]
;   comment = Network Logon Service
;   path = /home/samba/netlogon
;   guest ok = yes
;   writable = no
;   share modes = no

[printers]
   comment = All Printers
   browseable = no
   path = /tmp
   printable = yes
   public = no
   writable = no
   create mode = 0700

# Windows clients look for this share name as a source of downloadable
# printer drivers
[print$]
   comment = Printer Drivers
   path = /var/lib/samba/printers
   browseable = yes
   read only = yes
   guest ok = no
# Uncomment to allow remote administration of Windows print drivers.
# Replace 'ntadmin' with the name of the group your admin users are
# members of.
;   write list = root, @ntadmin

# A sample share for sharing your CD-ROM with others.
;[cdrom]
;   comment = Samba server's CD-ROM
;   writable = no
;   locking = no
;   path = /cdrom
;   public = yes

# The next two parameters show how to auto-mount a CD-ROM when the
#	cdrom share is accesed. For this to work /etc/fstab must contain
#	an entry like this:
#
#       /dev/scd0   /cdrom  iso9660 defaults,noauto,ro,user   0 0
#
# The CD-ROM gets unmounted automatically after the connection to the
#
# If you don't want to use auto-mounting/unmounting make sure the CD
#	is mounted on /cdrom
#
;   preexec = /bin/mount /cdrom
;   postexec = /bin/umount /cdrom



More information about the Pkg-samba-maint mailing list