DLL 地獄(ディーエルエルじごく)とは、DLL や COM コンポーネントなどのバージョンアップなどに伴い、それ以前のバージョンの DLL/COM コンポーネントなどに依存して動作するアプリケーションが動作しなくなる現象のことである。コンピュータ業界においては "DLL HELL" と呼ばれる場合が多い。Windows 以外の オペレーティングシステム (OS) で発生するものについては "Dependency Hell" の名称がよく使われる。

概要

編集

原理的には動的リンクするライブラリを利用する OS 全てにおいて発生する可能性がある。

Windows では以前は、プログラマのミスやインストーラの不具合により発生することが多かった(特にCOMコンポーネントに関しては、マイクロソフトが厳密なバージョン管理規約を規定している[1]にもかかわらず、このバージョン管理の仕組みを理解しないままエンドユーザーシステムにインストールさせてしまう開発者が少なくない)。最近[いつ?]ではシステム保護機能やサイドバイサイド (Side-by-Side, SxS) と呼ばれる仕組みにより減ってきているが、全面解決には至っていない。

また、Linux において対象ディストリビューションが異なるパッケージを使用したり、サードパーティのパッケージ管理システムレポジトリを使用することによりライブラリの依存関係が壊れ、同様の事象が発生することが多い。

起因

編集

この現象が起きる理由としてさまざまなことを挙げることが出来るが、最大の問題は「共有ライブラリに対し互換性を失うような変更が行われた場合に、ライブラリを呼び出すプログラム側がそれを区別することができない」という点に起因する。

プログラムの保守・可読性の向上や、セキュリティ問題等に起因するやむをえない仕様変更等により、あるプログラムにおいて旧バージョンとの互換性が失われてしまうことは、本来は極力避けるべき行為であるが、実際にはよく起こる現象である。これが動的にリンクされる共有ライブラリの場合、その互換性が失われた部分の機能を利用するアプリケーションにとっては、アプリケーション自体の動作に支障をきたすことになる。特に OS 本体に同梱されるライブラリにおいてこのような変更が行われると、その影響範囲は極めて広い範囲に及ぶ。

また、ソフトウェアのインストーラがシステムの共有ライブラリのバージョンチェックを行わず、古いバージョンに置換してしまうことでも発生する。

サードパーティーのアプリケーションにおいては、アプリケーションが利用するライブラリをアプリケーション本体と同じディレクトリに配置することでこの問題を回避するといった試みがなされることも多い。しかし実際には、ファイル名が同一のライブラリが複数ハードディスク内に存在する場合にどのライブラリを最初に呼び出すかという選択は OS 側の設定(主に環境変数PATHの設定)によって変化することが多く、自分が意図したライブラリとは別のライブラリが優先的に呼び出されてしまうケースも少なくなかった。この問題に対処するため、Windows 2000 サービスパック4で、PATHの設定が優先されないようライブラリの検索順序が変更された (Safe DLL search mode)[2]

マイクロソフトは .NET Framework において、同じライブラリの異なる複数のバージョンを同時にインストールできるようにした上で、アプリケーション側は必要に応じて自分の使用したいライブラリのバージョンを明示的に指定できるサイドバイサイドを提供するなど、この問題を OS レベルで解消することを狙っている。

Linuxを含めたUNIXでは共有ライブラリ名にバージョン番号を埋め込む事により、バージョン番号が重ならない範囲であれば問題が発生しなかった。ただし、バージョン番号に現れない変更や、同じ共有ライブラリでも異なるバージョンが同時に必要となってしまった場合は問題が発生した。

対処

編集

Windows ME/Windows XP 以降の Windows であれば、誤ってシステムフォルダのライブラリファイルを書き換えてしまった場合でも、「システムの復元」機能を使用することでほとんどすべての場合において復旧が可能である。

また、上記以外の OS や「システムの復元」が無効になっている場合であっても、システムのスナップショットやイメージバックアップが存在する場合はリストアを実施することにより復旧可能である。

この両者のいずれの復旧方法共に使用できない場合、原因となったソフトウェアのアンインストールやライブラリの再インストールあるいは手動置換などで復旧できる場合もあるが、確実ではなくかえって事態を悪化させることも多い。また、この方法で復旧できた場合でも、システム内に不整合が起きている場合が多いので、すぐにユーザーデータを退避させ、OS インストーラでシステムの修復やリカバリを実施する方がよい。

LinuxではOS側の共有ライブラリへ依存する代わりに、コンテナ仮想化によりアプリケーションの提供側が動作確認済の共有ライブラリや設定ファイルなどを全てコンテナへ納め、これを配布およびインストールする代替手段が広まっている。代表例としてDockerがある。

脚注

編集
  1. ^ The Versioning Theory for RPC and COM (Windows)
  2. ^ Dynamic-Link Library Search Order” (英語). MSDNライブラリ. マイクロソフト (2011年11月15日). 2011年12月30日閲覧。

関連項目

編集

外部リンク

編集