Mozilla Flux

Mozilla関係の情報に特化したブログです。

FirefoxのFlashサポートがいつまで続くか予想してみる

段階的に減らされるFlashのサポート

MozillaがFirefox 52でNPAPI(Netscape Plug-in API)プラグインのサポートを原則として打ち切る中、例外的にAdobe Flashプラグインだけはサポートが続く。プラグインが最新版であれば初期設定で「常に有効化する」扱いになるという優遇ぶりだ。この扱いはいつまで続くのだろうか。また、Flashプラグインのサポートが廃止されるのは、どの程度先のことなのだろうか。

Chrome 55以降でHTML5版コンテンツがデフォルトになるとか、Safari 10はHTML5版コンテンツを優先してプラグイン版コンテンツの有効化にはユーザーのクリックが必要といった話を耳にすると、Mozillaがすぐにでも追随しそうに感じるかもしれない。だが、かなり保守的な計画が立てられているのが実情だ。

Reducing Adobe Flash Usage in Firefox | Future Releases和訳)で述べられているように、Mozillaは2017年中にFlashコンテンツをすべて「実行時に確認する」扱いにし、再生・実行時にはユーザーのクリックまたはタップを要求する(以下CtP:クリック・トゥ・プレイ)。他のブラウザが同年中にFlashのサポートを全廃する勢いなのに比べると、穏健な態度といえそうだ。ゆっくりと、しかし着実に有効化するFlashの数を減らしていく、というのがMozillaの方針なのである。

完全廃止は数年先

過去を振り返ってみると、MozillaがFlash以外のプラグインのサポートを廃止するまでに、ずいぶんと時間がかかった。2013年9月に原則CtP化の方針を打ち出したときは、急進的な印象を受けたものだが、2014年2月にはホワイトリストに掲載されたものは例外とされることになった。実際にリリース版でこの機能が有効化されたのは、同年6月のFirefox 30からだ。そして、ようやくFirefox 47になってこのホワイトリストが削除された。そこからさらにバージョンを5つ重ねて、上記のサポート廃止に至るわけだ。

しかも、ことFlashに関しては、ユーザーに与える影響の大きさからMozillaは慎重な姿勢を示すのが通例である。つい最近も、Firefox 49.0.2で非同期プラグインレンダリング(Asynchronous Plugin Rendering)の設定を有効化したところ、Flashコンテンツの表示が異様に遅くなる、Flashベースのゲームがプレイできないといった問題があちこちで発生したため、Mozillaはシステムアドオンを投入して、Windows向け32bit版では設定を再度無効化することにした。Flashのサポート廃止がMozillaの目標とはいっても、そこに到達するまでの道のりはたぶん長いものになるだろう。

2016年9月末にアナウンスされたMortarプロジェクトの存在も、Mozillaが近いうちにFlashのサポート廃止を打ち出すことはないだろうとの推測を裏付ける。このプロジェクトは、Googleが開発するPPAPI(Pepper Plug-in API)をFirefoxが内部的にサポートし、PDFiumライブラリとPPAPI版Flashプラグインを移植するというものだ*1。PPAPIはChromeのプロセス分離を前提に実装されているため、Firefoxのマルチプロセス機能(e10s)が完全に有効化されてからでなければ、Mortarプロジェクトの成果をNightlyチャンネルに投入することは難しいとみられる。

たとえば、Firefox Nightly 53にPPAPI版Flashが投入されるとして、バグを潰した後にAuroraチャンネルで有効化されるのは、早くてもFirefox 54だろう。そのままリリース版まで進むという最短コースを辿っても、ユーザーの手元に届くのは2017年6月だ。仮にMozillaが2世代先のESRのベースとなるFirefox 59(2018年3月リリース)でFlashのサポートを廃止するつもりなら、せっかく導入した技術がわずか9か月間しか利用されないことになってしまう。少なくともプラス1年はサポートを延ばすと考えるべきだろう。

想定されるプロセス

MozillaはFlashのサポート廃止に向け、大きく分けて2つの手段を採用する。1つはコンテンツの自動的な置き換えやブロックで、ユーザーが接触するFlashコンテンツを減らす試みだ。もう1つは既に述べた全面CtP化で、1つ目の手段でふるいにかけられたFlashコンテンツがユーザーのアクションなしに動作するのを防ぐ。

1つ目の手段は、一部が既に実装済みである。たとえば、Firefox 47では、Webサイト内に埋め込まれたYouTubeのFlash版動画プレイヤーを、HTML5版プレイヤーへと自動的に置き換えるようになった(Bug 769117)。この機能は、HTML5版コンテンツをプラグイン版コンテンツに優先させるという、より一般的な機能へと拡大される予定だ(Bug 1277346)。

また、Firefox 49では、トラッキングに用いられる不可視のプラグインが初期設定で無効化された(Bug 1268120)。この機能も、サードパーティーのドメインがFlashプラグインを起動させようとする場合、そのドメインがMozillaの管理するブロックリストに掲載されているときは起動を無効化するという、より一般的な機能へと拡大されていく(Bug 1277876)。Windows向け32bit版におけるwindowedモードの廃止(Bug 1296400*2もこの流れに位置づけられるだろう。

2つ目の手段である全面CtP化は、今のところ手がかりがないので推測に頼るしかないのだが、まずは単純に既存の「実行時に確認する」を初期設定にするのではないか。この場合、ユーザーはアドオンマネージャで「常に有効化する」へと設定を変更することができるし、クリックしてFlashを有効化する際、特定のドメインでは「常に許可する」こともできる。

だが、おそらくMozillaが2017年中に目指しているのは、こうした常時有効化の設定を排除したCtP化だろう。つまり自動的に再生・実行されるFlashコンテンツはなくなり、ユーザーが積極的に有効化のアクションをとったコンテンツに限って、Flashが起動するわけだ。

さらにその先、2018年に入ると、「実行時に確認する」の設定を残しつつ「無効化する」が初期設定になっていくとみられる。タイミングとしてはFirefox 59のリリース時点で、ESRにおいては「実行時に確認する」が初期設定のままという形で分岐する可能性が高い。もっとも、Flash以外のプラグインがそうであったように、CtPから一足飛びに廃止という流れも考えられる。ただ、前述のMortarプロジェクトがESRだけを念頭に置いたものとは思われないので、やはり通常版でも有効化の余地は残すのではないか。

以上の推測が正しいとすると、FirefoxにおけるFlashのサポートが完全に廃止されるのは、通常版で2018年半ばから後半にかけて、ESRで2019年第1四半期以降になると予想される。

*1:ちなみに、JavaScriptアプリによるFlashプラグインの代替を目指したShumwayは、開発が事実上中止され、Firefox 47時点で本体からコードが削除された

*2:64bit版では廃止済みBug 1248821参照)。

Firefox 52以降はFlash以外のプラグインが使用不可に こっそり使い続ける方法とは

MozillaはFirefox 52でプラグインのサポートを大幅に縮小する。具体的には、自動的にインストールされるもの(OpenH264 Video CodecやWidevine Content Decryption Module)を除くと、サポートされるのはAdobe Flashプラグインだけとなり、他のプラグインは使用できなくなる(Bug 1269807)。*1

アドオンマネージャの〔プラグイン〕の項目を見ると、あっさりした表示になっているのが分かる。Firefox 51までは有効・無効にかかわらず列挙されていたプラグインが、きれいさっぱり無くなっている。

f:id:Rockridge:20161016222612p:plain

Firefox 52以降もFlash以外のプラグインを使い続けたければ、延長サポート版(ESR)を利用してください、というのがMozillaのスタンスだ。この場合、Firefox 53以降に本体に追加される新機能は利用できなくなるため、ユーザーは(Flash以外の)プラグインを取るか新機能を取るかの二者択一を迫られることになる。

Flash以外のプラグインをこっそりと使い続ける方法を以下に紹介しよう。もっとも、今後のFirefoxはこれらのプラグインが動いていないことを前提に開発が進むため、Flash以外のプラグインがクラッシュの原因になっても修正されることはない点に注意してほしい。

上で述べたように、FirefoxのESRではFlash以外のプラグインもサポートが続いているわけだが、それを実現するのがplugin.load_flash_onlyの設定だ。about:configの画面で設定の欄を右クリックし、「新規作成」から真偽値の項目を選ぶ。そして、plugin.load_flash_onlyをfalseに設定する。

これで本体を再起動すればプラグインが無事復活……とはいかない。プラグイン用のキャッシュファイルが書き換えられており(Bug 1307501)、設定を変えても復活しないからだ。本体を再起動する前にこのキャッシュファイルを削除し、改めて作成するよう促す必要がある。

pluginreg.datという名のキャッシュファイルは、プロファイルフォルダ内に存在する。プロファイルフォルダへの移動は、Firefoxのヘルプメニューからトラブルシューティング情報(about:support)のページを呼び出し、〔アプリケーション基本情報〕のプロファイルフォルダ欄から「フォルダを開く」のが手っ取り早い。

まとめると、plugin.load_flash_onlyの設定をfalseの値にした状態で追加し、プロファイルフォルダ内のpluginreg.datというファイルを削除してから、Firefox本体を再起動する。これでFlash以外のプラグインは復活する。

(17/01/23追記)
同一プロファイルでESRと非ESRを切り替えた場合に混乱が生じないようにするため、plugin.load_flash_onlyの設定を追加して値をfalseにし、再起動するだけで、Flash以外のプラグインが復活するようになった(Bug 1330998)。もっとも、将来的に設定による切り替えはできなくしていく方針が示されており(Comment 17参照)、本記事の方法がいつまで通用するかはわからない。

なお、注に書いたAdobe Primetime CDMは、Firefox 52でアドオンマネージャに表示されなくなり(Bug 1329538)、Firefox 53でサポートが廃止される(Bug 1329543)。

*1:ちなみに、このバージョンから、Adobe提供のPrimetime Content Decryption Moduleはオンデマンドでのインストールとなる(Bug 1304899)。

Firefox 52からWindows XPはESRでのサポートへ移行 Vistaもやや遅れて追随か(追記あり)

Firefoxが通常版でWindows XPをサポートするのはバージョン51までであることが明らかになった。バージョン52以降は法人向け延長サポート版(ESR)でのみサポートされる(Bug 1303827)。

もともとこの話はFirefox 46のリリース前からあって、XP上のFirefoxユーザーの数に配慮した結果、先送りになっていた。Mozilla Corp.の従業員からも、サポートを変更するタイミングとしてはFirefox ESR 52のリリース時という観測が出ていたので、意外感は全くない。

Firefox 52のリリース(2017年3月7日予定)と同時なのか、それとも多少遅れるのかは定かでないものの、XP上のFirefox 51ユーザーに対してはESR 52の自動アップデートが提供されることになりそうだ。2016年3月時点で既に、そうした措置は技術的に十分可能だとされており、そこに1年分のリリースエンジニアリングの進歩が加われば、ますます簡単だろう。

Firefoxは変則的なリリース間隔を採用しているが、これは要するにESRのベースとなるバージョンのリリース時期を毎年同じくらいの時期にするものなので、ESRのサポート終了時期の予測は立てやすい。ESR 45.8のサポートが2017年6月12日まで続くことからすると、ESR 52.8のサポートが終了するのは、2018年6月のどこかになるはずだ。Microsoftのサポートが2014年4月8日に終了していることを考えると、かなり手厚い措置といえるのではないか。

XPのサポートがESRに移行すると決まったことで、俄然注目されるのはWindows Vistaの扱いである。こちらは2017年4月11日にMicrosoftのサポートが切れる。Firefox 52のリリース後だが、Firefox 53のリリース(2017年4月18日予定)よりは前なので、Vista上のFirefox 52ユーザーにESR 52.1を提供すれば、ダウングレードにはならない。

サポートするOSを減らせば、Mozillaとしては製品版リリースまでに行われる各種テストを絞り込めるだけでなく、外部から取り入れているオープンソースのコードが、FirefoxのサポートしているOSに合わないといった問題も避けられる。たとえば、プロセスのサンドボックス化にChromiumのコードを使おうとすると、GoogleがXP/Vistaのサポートを打ち切っているので古いバージョンしか選べないという状況は、FirefoxのサポートOSをChrome(Chromium)と同じにしてしまえば解決するわけだ。

しかも、最近Mozillaは64bit版Firefoxの本格提供に向けて動き出したが、64bit版はWindows 7以降しかサポートしていないため、64bit版が主流になると32bit版だけVistaのサポートを追加する格好になる。また、Firefoxの基盤にあたるGeckoにServoという新開発のブラウザエンジンの技術を取り入れていく話についても、ServoがやはりWindows 7以降しかサポートしないので、Vistaのサポートを残し続けると移植の障害になりかねない。

そのうえ、VistaのマーケットシェアはXPよりもはるかに小さいので、ESRへの移行がFirefoxユーザー全体の中で与えるインパクトも限定的だ。Vista上のユーザーにとっても、Chromeがさっさと撤収する中、MicrosoftのOSサポートが切れてから1年以上もブラウザのサポートを受けられるのは、決して悪い話ではない。

こうして見てくると、MozillaがWindows XPに引き続きVistaも同様の扱いとする可能性は非常に高いといえるだろう。

(16/09/29追記)
やはりVistaもESRでのサポートに移行する模様である。米国時間の2016年9月26日に登録されたBug 1305453では、「XP/Vista上のユーザーをESR 52に移行させる」と表現されている。XPとVistaを区別しない書きぶりは、Vista上のFirefox 51ユーザーに対しても、Firefox ESR 52の自動アップデートが提供されるという趣旨にも読める。なお、Firefox Nightly 53の開発サイクル冒頭でインストーラに手が加えられ、XP/Vista上にはインストールできなくなるという。

ESRチャンネルに移行した場合、本当に2018年6月までサポートが続くのか疑問に思う向きがあるかもしれない。だが、ユーザー数が少ないOS X 10.6~10.8でさえ、Firefox 48を最後に通常のチャンネルではサポートが打ち切られた後も、ESRチャンネルでは52.2(サポート終了日:2017年8月7日)までサポートが継続されることになっている(Bug 1293777)。それよりもはるかにユーザー数が多いXP/Vistaについて、ESRのサポート期間の途中でOSのサポートが打ち切られる可能性はまずないと考えてよいだろう。

(16/10/25追記)
Mozillaの技術者から、XPおよびVistaユーザーは自動的にESR 52チャンネルに切り替わるというコメントが出た。本文に記載したとおり自動アップデートが提供されることになる。

(16/11/27追記)
当初の話からは若干変わって、ESRへの切り替えはFirefox 53のリリース時点で行われるようだ(Bug 1315083)。とはいえ、もともと通常版Firefox 52とESR 52.0は、若干の設定の違いを除けば同じものなので、この計画変更がユーザーに与える影響はごく小さい。なお、この時点で通常版のサポートは、Windows XP/Vistaだけでなく、サーバ向けのWindows 2003/2008(R2を除く)でも終了する(Bug 1317780)。

Windows向けFirefox 52で64bit版が主役に 2017年後半には自動アップデートも提供へ(追記あり)

Windows向け64bit版Firefoxは、2014年11月に発表されたプランからすると提供がかなり遅れており、Mozillaとしても慎重ならざるを得なかったのか、これまで新たな計画が明らかにされることはなかった。だが、ここにきてFirefox/Win64 - MozillaWikiに具体的なスケジュールが掲載されるようになり、本腰を入れてきた感がある。

上記のスケジュールは、1つひとつが簡潔な記載になっているため、読み解くには様々な情報と突き合わせる必要がある。現在判明しているところでは、まず、2016年9月下旬から10月上旬にかけて、新しいダウンロードページのテストが実施される。Firefox 50のリリース予定日が11月8日(米国時間。以下同じ)であることを踏まえたものとみられ、おそらくそのリリースに合わせて、MozillaのWebサイトのトップページから64bit版Firefoxのスタンドアローン型インストーラ(フルインストーラ)への導線が強化される。

次のステップはFirefox 52で、適格性のあるユーザーに対しては、軽量インストーラ(スタブインストーラ)が初期設定で64bit版をインストールするようになる(Bug 797208)。ここで、適格性のあるユーザーとは、搭載メモリが4GB以上のPCでWindows 7以降のOSを使用しているユーザーを指す*1。軽量インストーラはMozillaのWebサイト以外でも広く公開されており、多くのユーザーがこの時点で64bit版に触れる機会を持つことになるはずだ。脇役だった64bit版は、ついに32bit版を押しのけて主役となるわけだ。ちなみに、かつてのプランでは、軽量インストーラに64bit版が統合され、ユーザーが選択できるようになるのがフェーズ2とされていた。今回のスケジュールは、64bit版を初期設定にした点が目新しい。

最後に、2017年後半には、適格性のあるユーザーが32bit版を使用している場合、64bit版が自動アップデートで提供される(Bug 1274659)。かつてのプランでフェーズ3と呼ばれていた段階であり、ここまできてようやく、2014年11月に発表されたプランが完遂されたことになる。Firefoxのリリーススケジュールを見ると、2017年の後半にリリースされるのは3バージョン。すなわち、8月8日リリースのFirefox 55、10月3日リリースのFirefox 56、11月28日リリースのFirefox 57だ。MozillaWikiの改版履歴をチェックするとわかるが、当初は2017年第2・第3四半期となっていたものが、単に第3四半期とせず、後半に変更されている。つまり第4四半期にずれ込むことを考慮したわけで、Firefox 56が暫定的なターゲットではないか。*2

スケジュール通り進められるかどうかは、前提条件を確保できるか否かにかかっている。MozillaはFirefox 52でFlash以外のNPAPIプラグインのサポートを廃止することにしているが、この予定が延びてしまうと、64bit版を主役にするという計画にも狂いが生じる。また、FlashプラグインについてMozillaは自前でサンドボックス化を実現していくが、これに関連するバグを潰しきれるかという問題がある。さらにいえば、バイナリベースの拡張機能に関し、XPCOMによるものは既にFirefox 41で廃止されたが、js-ctypesによるものの廃止にあたっては、WebExtensionsによる代替機能の提供を考慮する必要があるかもしれない

64bit版への移行は、ポインタサイズが倍になる関係で消費メモリが25%増しになるというデメリットもあるが、処理の高速化に加えて、アドレス空間消尽の問題がなく、アドレス空間配置のランダム化(ASLR)が強化されてセキュリティが向上するなど、メリットも大きい。今回のスケジュールのまま開発が進むことを期待したい。

(17/02/12追記)
本記事執筆後に動きがあり、本文の内容は最新ではない。2017年10月上旬までにWindows向け64bit版Firefoxの自動アップデートが開始 - Mozilla Fluxを参照してほしい。

*1:Windows向け64bit版FirefoxはWindows 7以降でしか動作しない。

*2:ちなみに、OS X向けFirefox 53では、Windows向けに先んじてビルドがIntel 64bit版に一本化される見込み(Bug 1295375)。

Firefoxは2017年も変則的なリリース間隔を採用

2016年に入ってから、Firefoxのメジャーアップデートのリリース間隔は6週間に固定されなくなったが、この方針は2017年も継続される。RapidRelease/Calendar - MozillaWikiに記載されているとおり、6週間から8週間の変則的なスケジュールが採用され、年に7回のメジャーアップデートが行われる。

以下がその内容だ(米国時間ベース)。なお、2017年のクリスマス付近にリリース予定日が重ならないため、50.0.1(修正後50.1.0)のような特殊なスケジュールは組まれていない。

リリース予定日 正式版 ESR
2016-11-15 Firefox 50 Firefox 45.5
2016-12-13 Firefox 50.1.0 Firefox 45.6
2017-01-24 Firefox 51 Firefox 45.7
2017-03-07 Firefox 52 Firefox 45.8; 52.0
2017-04-19 Firefox 53 Firefox 45.9; 52.1
2017-06-13 Firefox 54 Firefox 52.2
2017-08-08 Firefox 55 Firefox 52.3
2017-09-26 Firefox 56 Firefox 52.4
2017-11-14 Firefox 57 Firefox 52.5
2018-01-16 Firefox 58 Firefox 52.6

変則的なスケジュールの場合、過去のように年8回のメジャーアップデートを行うことができなくなる一方、Update on 2016 Firefox Release Schedule | Future Releasesで指摘されているように、OSの大型アップデートなどのイベントに合わせてリリースのタイミングを柔軟に調整できる。また、今回、Firefox 49のリリースはバグ潰しのために1週間遅れたわけだが、こうしたことがあってもFirefox 50のリリース予定日を維持できるのは、スケジュールに余裕をもたせてあるからだ。

ESR(延長サポート版)についても、正式版のリリースサイクルが延びることは延長サポート期間が延びることを意味する。安定した環境を求めるユーザーにとって、サイクルが6週間固定でないことの恩恵は大きいといえるだろう。

2年続けて同様のスケジュールを採用し、しかも早々とこの時期(正確には2016年8月末)に2017年の予定を打ち出しているところをみると、Mozillaは今後もこのリリース間隔を維持していくと思われる。

(16/10/29追記)
RapidRelease/Calendarの修正に合わせて記載を更新した。

(16/11/15追記)
RapidRelease/Calendarの修正に合わせて記載を更新した。

(17/02/13追記)
RapidRelease/Calendarの修正に合わせて記載を更新した。

(17/04/20追記)
RapidRelease/Calendarの修正に合わせて記載を更新した。