samba 3.5.1 を試してみる。 [Samba]
sambaとMacの「エラーコード -36」問題で、sambaのバージョンを
3.4.0から最新の3.5.1に上げるとどうなるか試してみました。
$ tar zxvf /usr/local/src/samba-3.5.1.tar.gz
$ cd /usr/local/src/samba-3.5.1/source3
$ ./autogen.sh
$ ./configure
$ make
# make install
samba 3.4.0の設定ファイルを3.5.1の設定ファイルに流用します。
# cp /etc/samba/smb.conf /usr/local/samba/lib/
いろいろとファイルの場所が違うので 起動ファイルを書き換えます。
書き換えた /etc/init.d/samba
--------------------------------------------ここから
#!/bin/sh
### BEGIN INIT INFO
# Provides: samba
# Required-Start: $network $local_fs $remote_fs
# Required-Stop: $network $local_fs $remote_fs
# Default-Start: 2 3 4 5
# Default-Stop: 0 1 6
# Should-Start: slapd
# Should-Stop: slapd
# Short-Description: start Samba daemons (nmbd and smbd)
### END INIT INFO
# Defaults
RUN_MODE="daemons"
# Reads config file (will override defaults above)
[ -r /etc/default/samba ] && . /etc/default/samba
PIDDIR=/usr/local/samba/var/locks
NMBDPID=$PIDDIR/nmbd.pid
SMBDPID=$PIDDIR/smbd.pid
# clear conflicting settings from the environment
unset TMPDIR
# See if the daemons are there
test -x /usr/local/samba/sbin/nmbd -a -x /usr/local/samba/sbin/smbd || exit 0
. /lib/lsb/init-functions
case "$1" in
start)
log_daemon_msg "Starting Samba daemons"
# Make sure we have our PIDDIR, even if it's on a tmpfs
install -o root -g root -m 755 -d $PIDDIR
NMBD_DISABLED=`testparm -s --parameter-name='disable netbios' 2>/dev/null`
if [ "$NMBD_DISABLED" != 'Yes' ]; then
log_progress_msg "nmbd"
if ! start-stop-daemon --start --quiet --oknodo --exec /usr/local/samba/sbin/nmbd -- -D
then
log_end_msg 1
exit 1
fi
fi
if [ "$RUN_MODE" != "inetd" ]; then
log_progress_msg "smbd"
if ! start-stop-daemon --start --quiet --oknodo --exec /usr/local/samba/sbin/smbd -- -D; then
log_end_msg 1
exit 1
fi
fi
log_end_msg 0
;;
stop)
log_daemon_msg "Stopping Samba daemons"
log_progress_msg "nmbd"
start-stop-daemon --stop --quiet --pidfile $NMBDPID
# Wait a little and remove stale PID file
sleep 1
if [ -f $NMBDPID ] && ! ps h `cat $NMBDPID` > /dev/null
then
# Stale PID file (nmbd was succesfully stopped),
# remove it (should be removed by nmbd itself IMHO.)
rm -f $NMBDPID
fi
if [ "$RUN_MODE" != "inetd" ]; then
log_progress_msg "smbd"
start-stop-daemon --stop --quiet --pidfile $SMBDPID
# Wait a little and remove stale PID file
sleep 1
if [ -f $SMBDPID ] && ! ps h `cat $SMBDPID` > /dev/null
then
# Stale PID file (nmbd was succesfully stopped),
# remove it (should be removed by smbd itself IMHO.)
rm -f $SMBDPID
fi
fi
log_end_msg 0
;;
reload)
log_daemon_msg "Reloading /usr/local/samba/lib/smb.conf" "smbd only"
start-stop-daemon --stop --signal HUP --pidfile $SMBDPID
log_end_msg 0
;;
restart|force-reload)
$0 stop
sleep 1
$0 start
;;
status)
status="0"
NMBD_DISABLED=`testparm -s --parameter-name='disable netbios' 2>/dev/null`
if [ "$NMBD_DISABLED" != "Yes" ]; then
status_of_proc -p $NMBDPID /usr/local/samba/sbin/nmbd nmbd || status=$?
fi
if [ "$RUN_MODE" != "inetd" ]; then
status_of_proc -p $SMBDPID /usr/local/samba/sbin/smbd smbd || status=$?
fi
if [ "$NMBD_DISABLED" = "Yes" -a "$RUN_MODE" = "inetd" ]; then
status="4"
fi
exit $status
;;
*)
echo "Usage: /etc/init.d/samba {start|stop|reload|restart|force-reload|status}"
exit 1
;;
esac
exit 0
--------------------------------------------ここまで
そして、
Finderからファイルサーバーにコピーすると。。。
こんどは
一部の項目へのアクセス権がないため、操作は完了できません。
と。。。
EA対応していないnetatalkで出るエラーと同じですね。
さて、
samba3.4.0の時には、エラーコード -36で、拡張属性付き0byteのファイルが
できあがっていたのですが、今度はデータフォークもコピーされています。
そして、
このエラーの出たファイルをgetfattrすると、、
$ getfattr -d test.txt
# file: test.txt
user.DosStream.AFP_AfpInfo:$DATA=0sQUZQAAAAAQAAAAAAAAAAgGJyb2t
NQUNTAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAAA==
user.DosStream.com.apple.metadata\357\200\242kMDItemFinderComment:
$DATA=0sYnBsaXN0MDBWdGV0ZXRlCAAAAAAAAAEBAAAAAAAAAAEAAAAAAA
AAAAAAAAAAAAAPAA==
一方、ターミナルからコピーしたファイルをgetfatterすると
getfattr -d test.txt
# file: test.txt
user.DosStream.com.apple.metadata\357\200\242kMDItemFinderComment:
$DATA=0sYnBsaXN0MDBWdGV0ZXRlCAAAAAAAAAEBAAAAAAAAAAEAAAAAAA
AAAAAAAAAAAAAPAA==
一部欠損してそうです
状況はかわりましたが、エラーが出るという点では相変わらずです