[Samba] CTDB 50.samba: ERROR: smb.conf cache create failed

Achim Gottinger achim at ag-web.biz
Sat Aug 23 13:13:39 MDT 2014


Am 23.08.2014 15:49, schrieb steve:
> Ubuntu 14.04, ctdb 2.5.1 from the ubuntu package. samba 4.1.11 with
> cluster support from source.
>
> Error upon startup only. Restarting ctdb on that node clears the error.
> The other node with the same config is OK. Any ideas?
> Cheers,
> Steve
>
> smb.conf
> [global]
> workgroup = ALTEA
> realm = ALTEA.SITE
> security = ADS
> kerberos method = secrets and keytab
> netbios name = SMBCLUSTER
> disable netbios = Yes
> clustering = Yes
> ctdbd socket = /var/lib/run/ctdb/ctdbd.socket
> pid director = /var/run/samba
> [users]
> path = /cluster/users
> read only = No
> [profiles]
> path = /cluster/profiles
> read only = No
> [shared]
> path = /cluster/shared
> force create mode = 0770
> read only = No
Added an modification, so it shows the full path for the file causing 
the error.
> 50.samba
> #!/bin/sh
> # ctdb event script for Samba
>
> [ -n "$CTDB_BASE" ] || \
>      export CTDB_BASE=$(cd -P $(dirname "$0") ; dirname "$PWD")
>
> . $CTDB_BASE/functions
>
> detect_init_style
>
> case $CTDB_INIT_STYLE in
> 	suse)
> 		CTDB_SERVICE_SMB=${CTDB_SERVICE_SMB:-smb}
> 		CTDB_SERVICE_NMB=${CTDB_SERVICE_NMB:-nmb}
> 		;;
> 	debian)
> 		CTDB_SERVICE_SMB=${CTDB_SERVICE_SMB:-samba}
> 		CTDB_SERVICE_NMB=${CTDB_SERVICE_NMB:-""}
> 		;;
> 	*)
> 		# Use redhat style as default:
> 		
> 		CTDB_SERVICE_SMB=${CTDB_SERVICE_SMB:-smb}
> 		CTDB_SERVICE_NMB=${CTDB_SERVICE_NMB:-""}
> 		;;
> esac
>
> service_name="samba"
>
> loadconfig
>
> ctdb_setup_service_state_dir
>
> service_start ()
> {
>      # make sure samba is not already started
>      service "$CTDB_SERVICE_SMB" stop > /dev/null 2>&1
>      if [ -n "$CTDB_SERVICE_NMB" ] ; then
> 	service "$CTDB_SERVICE_NMB" stop > /dev/null 2>&1
>      fi
>      killall -0 -q smbd && {
> 	sleep 1
> 	# make absolutely sure samba is dead
> 	killall -q -9 smbd
>      }
>      killall -0 -q nmbd && {
> 	sleep 1
> 	# make absolutely sure samba is dead
> 	killall -q -9 nmbd
>      }
>
>      # start Samba service. Start it reniced, as under very heavy load
>      # the number of smbd processes will mean that it leaves few cycles
>      # for anything else
>      net serverid wipe
>
>      if [ -n "$CTDB_SERVICE_NMB" ] ; then
> 	nice_service "$CTDB_SERVICE_NMB" start || die "Failed to start nmbd"
>      fi
>
>      service "$CTDB_SERVICE_SMB" start || die "Failed to start samba"
> }
>
> service_stop ()
> {
>      service "$CTDB_SERVICE_SMB" stop
>      if [ -n "$CTDB_SERVICE_NMB" ] ; then
> 	service "$CTDB_SERVICE_NMB" stop
>      fi
> }
>
> ######################################################################
> # Show the testparm output using a cached smb.conf to avoid delays due
> # to registry access.
>
> smbconf_cache="$service_state_dir/smb.conf.cache"
>
> testparm_foreground_update ()
> {
>      _timeout="$1"
>
>      if ! _out=$(timeout $_timeout testparm -v -s 2>/dev/null) ; then
> 	if [ -f "$smbconf_cache" ] ; then
> 	    echo "WARNING: smb.conf cache update failed - using old cache file"
> 	    return 1
> 	else
> 	    die "ERROR: smb.conf cache create failed"

die "ERROR: smb.conf cache create failed at $smbconf_cache"

> 	fi
>      fi
>
>      _tmpfile="${smbconf_cache}.$$"
>      # Patterns to exclude...
>      pat='^[[:space:]]+(registry[[:space:]]+shares|include|copy|
> winbind[[:space:]]+separator)[[:space:]]+='
>      echo "$_out" | grep -Ev "$pat" >"$_tmpfile"
>      mv "$_tmpfile" "$smbconf_cache" # atomic
>
>      return 0
> }
>
> testparm_background_update ()
> {
>      _timeout="$1"
>
>      testparm_foreground_update $_timeout >/dev/null 2>&1 </dev/null &
> }
>
> testparm_cat ()
> {
>      testparm -s "$smbconf_cache" "$@" 2>/dev/null
> }
>
> list_samba_shares ()
> {
>      testparm_cat |
>      sed -n -e 's@^[[:space:]]*path[[:space:]]*=[[:space:]]@@p' |
>      sed -e 's/"//g'
> }
>
> list_samba_ports ()
> {
>      testparm_cat --parameter-name="smb ports" |
>      sed -e 's@,@ @g'
> }
>
> ###########################
>
> ctdb_start_stop_service
>
> is_ctdb_managed_service || exit 0
>
> ###########################
>
> case "$1" in
>       startup)
> 	ctdb_service_start
> 	;;
>
>       shutdown)
> 	ctdb_service_stop
> 	;;
>
>       monitor)
> 	testparm_foreground_update 10
> 	ret=$?
>
> 	smb_ports="$CTDB_SAMBA_CHECK_PORTS"
> 	if [ -z "$smb_ports" ] ; then
> 	    smb_ports=$(list_samba_ports)
> 	    [ -n "$smb_ports" ] || die "Failed to set smb ports"
> 	fi
> 	ctdb_check_tcp_ports $smb_ports || exit $?
>
> 	if [ "$CTDB_SAMBA_SKIP_SHARE_CHECK" != "yes" ] ; then
> 	    list_samba_shares | ctdb_check_directories || exit $?
> 	fi
>
> 	if [ $ret -ne 0 ] ; then
> 	    testparm_background_update 10
> 	fi
> 	;;
>
>      *)
> 	ctdb_standard_event_handler "$@"
> 	;;
> esac
> exit 0
>
>
>



More information about the samba mailing list