LAN内でSambaで認証なしファイル共有するための秘伝のsmb.conf

Ubuntu 12.04で動作を確認しました。

要求事項としては、

– LAN内でのみ使う
– セキュリティはゆるゆるでOK (自宅内を想定)
– Windows 7、Macからマウントできて、読み書き可能

あたりです。Sambaはたいていどこかで躓くと思います、私も何十時間も費やしてきました。以下の設定で今のところは安定しているので、備忘録として残しておきます。内容は、

– Linuxの設定 (Sambaを動かすマシン)
– Windows 7からのアクセス方法
– Macからのアクセス方法

です。

ただ、頑張ってLinuxのSambaと格闘するよりは、素直にQNAPとかのNAS買ったほうが良いと思います、私が最近購入したのはTS-131というものです。あっさり繋がりました。ただ機能が豊富すぎて全容が把握できていませんが。。。

– Linuxの設定

以下はUbuntuで動いた例ですが、他のディストリでも同じだと思います。

$ sudo apt-get install samba
# ↓smb.confを編集。具体的な中身は下に書いてあります
$ sudo vi /etc/samba/smb.conf

/etc/samba/smb.conf
[global]
	dos charset = CP932
	unix charset = UTF8
	display charset = UTF8
	server string = %h server
	map to guest = Bad User
	obey pam restrictions = Yes
	pam password change = Yes
	passwd program = /usr/bin/passwd %u
	passwd chat = *Enter\snew\s*\spassword:* %n\n *Retype\snew\s*\spassword:* %n\n *password\supdated\ssuccessfully* .
	unix password sync = Yes
	syslog = 0
	log file = /var/log/samba/log.%m
	max log size = 1000
	load printers = No
	disable spoolss = Yes
	dns proxy = No
	panic action = /usr/share/samba/panic-action %d
	idmap config * : backend = tdb
	printing = bsd
	print command = lpr -r -P'%p' %s
	lpq command = lpq -P'%p'
	lprm command = lprm -P'%p' %j

[share]
	comment = this is a samba storage.
        # ↓ path はディレクトリを作ってから chmod -R 666 しておくこと!
        # ↓の例であれば、cd /; mkdir storage; chmod -R 666 /storage
	path = /storage
	force user = root
	read only = No
	guest only = Yes
	guest ok = Yes
	vfs objects = recycle
	recycle:maxsize = 0
	recycle:touch = no
	recycle:versions = yes
	recycle:keeptree = yes
	recycle:repository = .recycle

nmbdとsmbdを再起動
$ sudo /etc/init.d/nmbd restart
$ sudo /etc/init.d/smbd restart

↑これでLinuxの設定は終わりです。

– Windows 7からのアクセス方法

左下のウィンドウズボタンを押す

「コンピュータ」をクリック

上の方にある「ネットワークドライブの割り当て」をクリック

「ドライブ」はなんでも良い、フォルダを「\\192.168.1.144\share」(\は円文字)を選択(↓画像の参照。もちろんIPアドレスはそのsambaのIPアドレスを指定すること。このときの「\share」は、smb.confの[share]を参照している意味のようで、たとえばsmb.confで[hoge]などとして設定を書いたら、\hoge を参照する必要がある)。「ログオン時に再接続する」にチェックを入れる、「別の資格情報を使用して接続する」には*チェックを入れない*。そして「完了」ボタンを押す
2015年11月09日月曜日、認証なしのsambaにwindows7から接続する場合の設定

するとマウントされて、sambaのディレクトリが見えるはず。通常のディレクトリやファイルと同じように扱える。

– Macからのアクセス方法

finderを開いて、メニューの「移動」→「サーバーへ接続」、「smb://192.168.1.144/share」と打ち込む

マウントされる

以上です。時が経過してクライアントやSambaのバージョン等変わるとまた異なってくるかもですが、少なくとも2015年11月9日の時点では動いています。

grepでファイルからシャープ(#)とセミコロン(;)と空白行を除いたものを取り出す

コメント(#や;)と空白を除いて出力したい場合があります。

$ grep -v -e '^;' -e '^#' -e '^\s*$' /etc/samba/smb.conf 
[global]
   workgroup = WORKGROUP
	server string = %h server (Samba, Ubuntu)
   dns proxy = no
   log file = /var/log/samba/log.%m
   max log size = 1000
   syslog = 0
   panic action = /usr/share/samba/panic-action %d
   server role = standalone server
   passdb backend = tdbsam
   obey pam restrictions = yes
   unix password sync = yes
   passwd program = /usr/bin/passwd %u
   passwd chat = *Enter\snew\s*\spassword:* %n\n *Retype\snew\s*\spassword:* %n\n *password\supdated\ssuccessfully* .
   pam password change = yes
   map to guest = bad user
   usershare allow guests = yes
[printers]
   comment = All Printers
   browseable = no
   path = /var/spool/samba
   printable = yes
   guest ok = no
   read only = yes
   create mask = 0700
[print$]
   comment = Printer Drivers
   path = /var/lib/samba/printers
   browseable = yes
   read only = yes
   guest ok = no

こんな感じで↑いけます。

– 「’^;’」はセミコロンの行にマッチ
– 「’^#’」はシャープの行にマッチ
– 「’^\s*$’」は空白行にマッチ

です。