Server Message Block

通信プロトコル

Server Message Block (SMB) は、主にWindowsを中心とした環境でLANを通じてファイル共有やプリンタ共有などに使用される通信プロトコルの総称。OSI参照モデルでは第7層アプリケーション層に該当する。認証つきプロセス間通信機構としても動作する。

下位層のプロトコルとしてNetBEUIを使用していた時代には、サブネットを越えるルーティングはできず、中大規模のネットワークには向かないとされたが、NetBIOS over TCP/IP英語版や、NetBIOSも必要としないCIFSCommon Internet File System)により、大規模ネットワークでも使用可能となっている。

歴史

編集

SMB/CIFS/SMB1

編集

2015年現在では、SMB 1.0以前のものを明確には区別せずにダイアレクト(方言)として扱うことが一般的である[1][2]。「SMB1/CIFS」などとまとめて表記することも多い。また、下記のSMB 1.0以前の説明は2015年現在のマイクロソフトの説明に従って記載しているが、マイクロソフトは過去には下記とは矛盾する説明をしていたこともあったため[3]、注意が必要である。

初期のSMB

編集

SMBは1982年か1983年にIBMのBarry Feigenbaumが設計した[4][5]DOSのローカルファイルアクセス用「割り込み 33」(INT 21h) をネットワーク上のファイルシステム向けに変えることを目標としていた。IBMは1984年、PC-DOSにSMBを搭載した[4]

マイクロソフトは、1985年発売のMicrosoft Networks (MS-NET)にSMBを搭載し[6]、1988年頃にはスリーコムと共同開発していた LAN Managerに搭載[4]、1992年にはWindows for Workgroupsに搭載と、多くの製品に搭載し、普及していった。

マイクロソフトは1996年にSMBをCommon Internet File System (CIFS) と改称し[4]、Windows NT 3.51、Windows NT 4.0、Windows 98に搭載した[7]

クロスプラットフォームでトランスポートから独立したファイル共有プロトコルとして定義を整理し、TCP/IP上での実装方法として「NetBIOS Transport over TCP」と「TCP Transport」を例示するなど、NetBIOSに依存しない定義へと更新した[7]。「TCP Transport」はこの時点ではまだ実験的な試みであり実際に搭載されなかったが、のちにSMB1.0で改善され、Windows 2000では「Microsoft Direct Hosting of SMB」として採用されている[1]

また、マイクロソフトはさらなる機能追加を行った。例えば、シンボリックリンクハードリンク、より大きなファイルの操作、認証プロトコルNTLMv2(暗号強度は米国輸出規制に準じる)、などへの対応である。[要出典]

ダイアレクトは「NT LM 0.12」を使用する。

サン・マイクロシステムズWebNFS英語版を発表したことに対抗するように、1997年、マイクロソフトは部分的仕様をいくつかインターネットドラフトとしてIETFに提出した[8]が、いずれも1998年までに有効期限切れとなっている。

SMB 1.0

編集

2000年、マイクロソフトは名称をSMBに戻し[4]、SMB 1.0(SMB1)としてWindows 2000で導入した。Kerberos認証やActive Directoryに対応した[1]。また、ダイレクトホスティングSMBと呼ばれるTCP上で直接動作させる機能も導入された(その場合サーバがTCPポート445番で待機[1])。ダイアレクトはCIFSと同じ「NT LM 0.12」を使用するため、技術的にはCIFSと区別されない。

終焉

編集

その後の技術の進化の結果、SMB1は暗号化強度の面や通信効率の面からも好ましくないとされるようになる。

2012年、マイクロソフトはStorage Developer ConferenceでSMB1を無効化することを技術者たちに提案した[9]

2013年、マイクロソフトはWindows Server 2012 R2以降のOSではSMB1を使用することを非推奨と定義し[10]、速やかに新しい技術への移行を促した。

2014年、マイクロソフトは期限を明確にはしていないものの、将来のWindowsでは機能を削除する方針であることを公表した。

2016年、マイクロソフトは改めて速やかにSMB1の使用を停止するよう呼び掛けた[11]

2017年1月、アメリカ国土安全保障省の配下組織US-CERTは、セキュリティ対策のベストプラクティスとして、SMB1の無効化を呼び掛けた[12]

2017年9月5日、Linux kernel 4.13において既定のプロトコルをSMB3とし、SMB1を無効化した[13][14]

2017年9月、マイクロソフトはWindows 10 Version1709でSMB1を初期状態では無効とした[15]。ただし、セキュリティ上推奨されていないものの、必要であれば設定を変更することで有効化できる[16]

2018年8月、FreeNAS 11.1-U6においてSMB1が初期状態では無効にした[17]

2019年9月、Samba 4.11においてSMB1が既定で無効化された[18]

再設計された新たなSMBである。SMB 2.0.0以降のバージョンがSMB2のダイアレクト(方言)として定義されている[19]。SMB 3.xもSMB2のひとつである点は間違いやすく注意が必要である[20]

SMB2では、コマンド/サブコマンドの種類が100以上あったものを19にまとめ、プロトコルのやりとりを集約した[21]

パイプライン化機構があり、前の要求への応答を受け取る前に次の要求を送信できる。複雑な動作を1つの要求にまとめることができ、クライアントとサーバ間のやり取りの回数を劇的に減らすことができ、結果として性能が向上する[22]。従来のSMB1プロトコルにも同様な機能がありAndXと呼ばれていたが、マイクロソフト製のクライアントはほとんどAndXを使っていなかった。

また、SMB2ではより大きなバッファをサポートしており、大きなファイルの転送や高速なネットワークでの性能向上が見込まれる[22]

また、「永続性ファイルハンドル」と呼ばれるものを導入している。これは、ネットワーク接続が切れてもSMBサーバとのコネクションが継続できるようにするもので、無線LANなど接続が切れやすい環境で新たなセッションを構築する必要をなくす。

SMB2はシンボリックリンクもサポートしている。他にもファイル属性のキャッシング、HMAC SHA-256ハッシュアルゴリズムによるメッセージ署名強化、ユーザー数・共有ファイル数などが増加した際のスケーラビリティ強化などの拡張がなされている[23]

従来のSMBプロトコルは16ビットで各種サイズを表していた。SMB2ではそれらの多くを32ビットや64ビットに拡張しており、ファイルハンドルの場合は16バイトとしている。

SMB2はマイクロソフトにとって具体的に次のような利益をもたらした。

  1. 知的財産権の明確化。従来のSMBはIBMがもともと設計したもので、Windows以外にもXENIXOS/2VMS (Pathworks) などにも採用されている。X/Openが部分的に標準化したり、IETFにもインターネットドラフトとして提出された。このため、知的財産所有権の所在は曖昧だった[4]。SMB2.0以降はすべてMicrosoftが作成している。
  2. 過去の資産との決別。従来のSMBのコードは非常に様々なSMBクライアントやサーバに対応する必要があった。このためプロトコルにはオプション部分が多数存在する(長いファイル名を扱えるか否かなど)。また、コマンドの応答として様々なレベルの情報を扱う。さらにUnicode対応は後から追加されている。SMB2のコードは従来のものより大幅に単純化されている(例えば、Unicodeサポートが前提なので、Unicodeでない場合を扱うコードは不要)。

SMB 2.0.0

編集

2006年、SMBの新バージョン SMB 2.0.0をWindows Vistaで導入した[24]。しかし相互運用性に問題があり、後述の2.0.2に置き換えて廃止された。

SMB 2.0.2

編集

Windows Vista SP1とWindows Server 2008で搭載された。2.0.0の相互運用性に問題を解消したものである。

SMB 2.1

編集

Windows 7とWindows Server 2008 R2で搭載された。SMB 2.0.2と比べてさらにファイル転送の速度が向上、特に複数のクライアントから同時にアクセスされた際は約3.5倍の向上が図られている[25]

SMB 3.0

編集

Windows 8とWindows Server 2012で搭載された。SMB ダイレクト、SMB マルチチャネル、SMB 暗号化などの機能が追加された[26]。開発段階ではSMB2.2と呼ばれていた[27]

SMB 3.0.2

編集

Windows 8.1とWindows Server 2012 R2で搭載された。透過フェイルオーバー使用時の自動リバランス、SMB ダイレクトの性能向上などの更新にとどまる[28]

SMB 3.1.1

編集

Windows 10で搭載された。認証の耐タンパー性能の向上とSMB暗号化使用時のAES-128-GCMの追加が含まれる。

ダイアレクトは3.1.1のまま、その後いくつかの機能追加が行われている[20][29]

構造

編集

クライアント-サーバ方式

編集

SMBはPeer to Peer方式の動作をし、クライアントが何らかの要求を送ると、サーバがそれに対応して応答する。SMBプロトコルの一部は特にファイルシステムへのアクセスを扱っており、クライアントはファイルサーバとの通信にその部分を使う。しかし、SMBプロトコルにはプロセス間通信 (IPC) に特化した部分もある。SMBプロトコルはローカルなサブネットでの使用に最適化したが、インターネット経由で他のサブネットとの間でSMBを使うこともできる。Windowsのファイル共有やプリンタ共有に関わるエクスプロイトは、そのような使用法を主なターゲットとしている。

SMBサーバはファイルシステムや他のリソースに、ネットワーク上のクライアントがアクセスできるようにする。クライアントはサーバ上の共有ファイルシステムやプリンタにアクセスする。このような用法・機能としてはSMBは最も有名で最も広く使われている。しかし、SMBのファイルサーバとしての面には、NTドメインを構成するプロトコル群が重要であり、それらによって少なくともNT式のドメインベースの認証を提供している。NTドメインプロトコルはSMBのIPCである名前付きパイプのためだけにMSRPCサービスを提供し、SMBサーバの実装のほとんどはリソースへのユーザーアクセスの妥当性を検証するのにNTドメインの認証を使う。

性能問題

編集

SMBプロトコルでは、各クライアントが自身の存在を知らせるためにサブネット全体にブロードキャストするため、ネットワークの帯域幅を占有しすぎると思われている。しかし、実はSMB自体はブロードキャストを使わない。SMBと結び付けられているブロードキャスト問題は、実際にはNetBIOSのサービス・ロケーション・プロトコルのせいである。デフォルトでは、WindowsのサーバはNetBIOSを使ってサービスの告知と発見を行う。NetBIOSは特定ホスト上で利用可能なサービスを一定間隔でブロードキャストすることで機能する。ホストが20台以下のネットワークではそのような設定でも十分だが、それ以上にホスト台数が増えるとブロードキャストのトラフィックが問題を生じるようになる。NetBIOS Name Server (NBNS) を適切に実装すると、この問題を緩和できる。例えばWindows Internet Naming Service (WINS) はマイクロソフトのネットワーク環境では適切な解決策を提供する。WINSはサービス要求の集中管理と登録のためのシステムを提供するが、ネットワークの設計と保守がより複雑化する。マイクロソフトは、Active Directory環境でのダイナミックDNSの利用を推奨している。

ネットワークを設計する際には、SMBプロトコルの性能はレイテンシに大きく影響されることを考慮しなければならない。SMBを使ってディレクトリを渡り歩いてファイルを探すような操作をしたとき、このレイテンシの影響が見た目にも明らかになる。例えばインターネット経由のVPNコネクションではレイテンシが大きくなることが多く、そのような環境ではディレクトリの中身(ファイル一覧)がなかなか表示されないということになる。

実装

編集

以下の一覧は、SMBクライアント、SMBサーバ、SMBプロトコルの各種拡張(Network Neighborhood スイートやNTドメインスイートなど)である。以下に示したのは主なもので、拡張版、再実装版、移植版などは省いている。

  • Sambaは、SMBプロトコルとマイクロソフトの拡張をフリーソフトウェアとして再実装したもの。SMBサーバ機能とコマンドラインのSMBクライアント機能がある。
  • Linuxカーネルには仮想ファイルシステム (VFS) を使ったSMBクライアントの実装が2つあり(smbfsとcifs)、SMBサーバ上のファイルに標準のファイルシステムAPI経由でアクセスできる。fuseカーネルモジュールとユーザー空間のfusesmbを使ってSMBクライアント機能を実現することもできる。
  • NetWare version 6以降では、CIFSサーバ機能を実装している。
  • FreeBSDにはVFSを使ったSMBクライアント実装としてsmbfsがある。
  • NetBSDmacOSにはそれぞれのVFSを使ったSMBクライアント実装としてsmbfsがある(元はFreeBSDのsmbfsを移植)。
  • Solarisには、macOSのsmbfsを基にしたCIFS client for Solarisというプロジェクトがある。
  • OpenSolarisは2007年10月、カーネル内にCIFSサーバ機能を実装した[30]
  • 小型NASサーバTrueNASは、FreeBSDベースで、CIFS/Sambaもサポートしている。EMCコーポレーションネットアップといったストレージ企業各社もSMBサーバの実装を行っている。
  • Advanced Server for Unix (AS/U) はUNIX向けにWindows NT 3.51のSMBサーバ機能を移植したもので、AT&Tがマイクロソフトからライセンス提供を受け、主なUNIXベンダーにライセンス提供した。サン・マイクロシステムズは、Advanced Server for UnixをSolarisに移植した Solaris PC NetLink(コード名 Cascade)を製品化している。
  • コンテンツ管理システムAlfrescoには、SMBサーバのJavaによる実装JLANが含まれている。
  • JCIFSはJavaによるSMBクライアント実装
  • RTSMB組み込みシステム用のCIFS/SMB実装。
  • Visuality Systems NQ CIFS組み込みシステム用のCIFS/SMB実装。SMB1.0/SMB2.0/SMB3.0対応。LinuxVxWorks、 Integrity、 iOSAndroidといった多くのRTOSに移植されている。
  • AzSmbは、組み込みシステム用の小型SMBサーバである。GPLもしくは商用ライセンスで提供されている。
  • File System for SMB/CIFS/Windows(R)はChromeOS向けのSMBクライアント実装。JavaScriptで書かれている。

脚注・出典

編集
  1. ^ a b c d 第7回 ファイル共有プロトコルSMBの概要”. @IT. 2021年5月6日閲覧。
  2. ^ Microsoft SMB Protocol Dialects”. Microsoft Corp.. 2015年12月16日閲覧。
  3. ^ ファイル共有プロトコル、SMBとCIFSの違いを正しく理解できていますか?(前編)”. @IT. 2019年2月2日閲覧。
  4. ^ a b c d e f SMB|CIFS NQ|製品情報|アイティアクセス株式会社”. IT Access. 2020年1月29日時点のオリジナルよりアーカイブ。2018年7月10日閲覧。
  5. ^ SMB3 Multi-Channel in Samba”. 2021年5月6日閲覧。
  6. ^ Early Microsoft Networks | OS/2 Museum” (英語). www.os2museum.com. 2021年5月6日閲覧。
  7. ^ a b ファイル共有プロトコル、SMBとCIFSの違いを正しく理解できていますか?(前編):その知識、ホントに正しい? Windowsにまつわる都市伝説(23) - @IT
  8. ^ * Common Internet File System Protocol (CIFS/1.0)
  9. ^ SMB 3.0”. 2019年2月2日閲覧。
  10. ^ Archiveddocs. “Features Removed or Deprecated in Windows Server 2012 R2” (英語). learn.microsoft.com. 2023年1月14日閲覧。
  11. ^ NedPyle. “Stop using SMB1” (英語). blogs.technet.microsoft.com. 2019年2月2日閲覧。
  12. ^ Windowsの通信プロトコルに脆弱性報告、SMB v1は無効化を”. ITmedia NEWS. 2019年2月23日閲覧。
  13. ^ 2017年9月4日 Linux 4.13がリリース,SMB 3.0がデフォルトCIFSに”. gihyo.jp. 2019年2月23日閲覧。
  14. ^ WannaCry対策にLinux 4.13でもSMB 1.0が無効に”. マイナビニュース (2017年9月6日). 2019年2月23日閲覧。
  15. ^ Deland-Han. “SMBv1 is not installed by default in Windows 10 version 1709, Windows Server version 1709 and later versions” (英語). learn.microsoft.com. 2023年1月14日閲覧。
  16. ^ Windows 10 の SMB 1.0 を有効にする”. 2019年2月2日閲覧。
  17. ^ FreeNAS 11.1-U6” (英語). iXsystems, Inc. - Enterprise Storage & Servers. 2020年7月16日閲覧。
  18. ^ Samba 4.11.0 Available for Download”. 2019年10月25日閲覧。
  19. ^ [MS-SMB2]: Appendix A: Product Behavior” (英語). learn.microsoft.com. 2023年1月14日閲覧。
  20. ^ a b WindowsのSMB v3はSMB v2より新しいが、SMB v3はSMB2である”. @IT. 2023年1月14日閲覧。
  21. ^ Vistaの目指すネットワークの姿(2)- NetBIOSなしでWindowsネットを実現”. ITPro. 2010年3月30日閲覧。
  22. ^ a b マイクロソフト、VistaとServer 2008で実現するメリットを解説
  23. ^ SMB2, a complete redesign of the main remote file protocol for Windows
  24. ^ Navjot Virk and Prashanth Prahalad (2006年3月10日). “What's new in SMB in Windows Vista” (英語). Chk Your Dsks. MSDN. 2006年5月1日閲覧。
  25. ^ @IT 編集部. “「ファイルサーバー、小型NASは安いのを選べ」 本当にそれでいい?”. 2011年2月10日閲覧。
  26. ^ サーバー メッセージ ブロックの概要”. 2013年8月8日閲覧。
  27. ^ SMB 2.2 is now SMB 3.0”. 2012年5月12日時点のオリジナルよりアーカイブ。2013年8月8日閲覧。
  28. ^ What's New in SMB in Windows Server 2012 R2”. 2014年7月2日閲覧。
  29. ^ JasonGerend. “Windows Server の SMB 3 プロトコルを使用したファイル共有の概要”. learn.microsoft.com. 2023年1月14日閲覧。
  30. ^ Project CIFS Server - Introduction

関連項目

編集

外部リンク

編集