So-net無料ブログ作成

NetatalkとSambaの統合 [Netatalk and Samba]

最近はNetatalkとSambaを相互運用できるようになりました。
以下の環境で、実際に相互運用が可能なことを確認しています。

以下の環境では、Sambaのバージョンが古いので相互運用できないことを確認しています。
Sambaパッケージを削除してtarballで最新版を入れれば可能と思われます。
  • Debian 8 Jessie (Samba 4.2.14)
  • Debian 7 Wheezy (Samba 3.6.6)
  • CentOS 6 (Samba 3.6.23)

Netatalk 3.1.8でオプションea =が追加されています。
ea = samba

これを利用すると以下の機能が有効になります。
  • 拡張属性(代替データストリーム)の保存方法をSambaと同じにする

Samba 4.2.xでvfs_fruitが追加されています。
ea support = yes
vfs objects = catia fruit streams_xattr
; fruit:locking = netatalk
fruit:encoding = native
streams_xattr:prefix = user.
streams_xattr:store_stream_type = no

これを利用すると以下の機能が有効になります。
  • macOSによるSMBの拡張が使える
  • メタデータの保存をNetatalk 3.x方式にする
  • ファイルロックの方法をNetatalkと同じにする (バグあり)


fruit:locking = netatalkはバグがあるのでコメントアウトする必要があります。(Samba 4.6.1と4.5.4で直ってるのを確認。4.4系は確認中)
[Samba] vfs_fruit: cannot remove any file

今までは様々な互換性問題により、macOSからはNetatalk、WindowsからはSambaという使い分けをするしかありませんでした。
これからは、Netatalkのea = sambaとSambaのvfs_fruitを使えば、Netatalk繋いでもSambaに繋いでも結果的に同じということになります。

現在のmacOSはSMB上でファイルを扱う場合、FinderInfo、リソースフォーク、拡張属性等を代替データストリームに変換して扱います。今までのSambaはこれに対応していなかったので、色々と面倒が発生しました。特にリソースフォークはサイズが大きいので、Solaris系OS上のZFSを除いては、それをうまく扱えません。
また、macOSはWindows禁止文字を私用領域の文字に置き換えてSMB上で扱うという手法を取るので、これも互換性がありませんでした。
vfs_fruitは、これらのmacOS独自仕様を上手に扱うためにNetatalk 3.x方式に変換します。
また、Sambaはファイルの排他処理の方法がNetatalkと異なるので、Netatalkで先に開いているファイルをSambaで開くとロックしませんでした。vfs_fruitはSambaのロック方式をNetatalkに合わせるので問題がなくなります。

vfs_fruitのバグ一覧はコチラ。
The Samba-Bugzilla – Bug List

ただし、Time Machineに関しては、Sambaでは無理なので当面Netatalkを使うことになります。
AppleがSMBを独自拡張して、Time Machine対応にする仕様はすでに公開されています。
macOS Sierra: Time Machine に使用できるディスク
Time Machine Over SMB Specification
しかし、現在のSambaはまだこれを実装していません。
実装する動きはありますし、無理矢理実施している人もいます。対応済のNASもあります。
vfs_fruit: Add capability to advertise FULLSYNC by kevinanderson1 · Pull Request #64 · samba-team/samba
SambaでTime Machineのバックアップ環境を構築する (Sierra以降) - Qiita
Time Machine を使い、Mac を SMB 経由で QNAP NAS にバックアップする - QNAP

結論
通常のファイル共有ならばNetatalkとSambaを統合できる。
Time MachineはまだNetatalkのみ。

コメント(2)  トラックバック(0) 
共通テーマ:パソコン・インターネット

コメント 2

marvelph

こんにちは。
Time Machine機能にSMBが使えるようになるという話題ですが、QNAPのNASで既にサポートがあるようです。

https://www.qnap.com/ja-jp/how-to/tutorial/article/time-machine-を使い-mac-を-smb-経由で-qnap-nas-にバックアップする

恐らく、QTS内部ではSambaが使われていると思います。

by marvelph (2017-06-17 18:59) 

コメントを書く

お名前:[必須]
URL:[必須]
コメント:
画像認証:
下の画像に表示されている文字を入力してください。

※ブログオーナーが承認したコメントのみ表示されます。

トラックバック 0