今がPython 2からPython 3へ移行するのにベストなタイミング:トークセッションレポートPythonイベント

Python 2のサポートが終了したら、今あるPython 2のコードはどうすればいいだろうか。悩ましい問題にさまざまな選択肢を与えてくれるセッションをレポート。

» 2019年09月27日 05時00分 公開
[かわさきしんじDeep Insider編集部]

この記事は会員限定です。会員登録(無料)すると全てご覧いただけます。

 2020年1月1日に、Python 2.7のオフィシャルなサポートが終了する。これに関連して、PyCon JP 2019ではセバスティアン・ヴィトヴスキ氏による「It’s 2019 and I’m still using Python 2. Should I be worried?」(2019年、まだPython 2を使っているんだ。心配する必要あるかな?)というトークセッションが開かれた。

YouTubeで配信されている本セッションの動画


 本稿では、その内容をかいつまんでご紹介していこう。セッションの資料はこちらから参照できる。

 ちなみに、本稿を掲載している@IT Deep Insiderフォーラム全体の指針としてはPython 3の使用を前提としており、セバスティアン・ヴィトヴスキ氏の意見と同様に、このタイミングでPython 2から3に移行するのを推奨する。

Python 2がまだ使われている理由

 ヴィトヴスキ氏からは、Python 2がまだ使われている理由としては以下の3つが挙げられた。

  • ビジネスの観点からは、Python 2からPython 3への移行にはコストがかかりすぎる
  • 移行よりも、新機能追加や緊急のバグフィックスが優先される
  • 古いコードベースの移行は非常な困難を伴うかもしれない
Python 2がまだ使われている理由(画像は、本セッションの資料スライドより。以下、同様) Python 2がまだ使われている理由(画像は、本セッションの資料スライドより。以下、同様)

 つまり、「Python 2のコードをPython 3に書き直しても会社にはお金は入ってこない」し、マネジャーは「リファクタリングに時間を費やしたり、動いているコードを書き直したりすること」に首を縦には振らないだろう。さらに「テストやドキュメントもなく、担当者がいなくなってからずいぶんとたつPython 2のコード」をPython 3へ移行するのは非常に難しい。こうしたことから、Python 2からPython 3への移行が進んでいないと彼はいう。

 その一方で、Python 3への移行にはメリットもある。以下はヴィトヴスキ氏によるPython 3へ移行することのメリットだ。

Python 3へ移行することのメリット Python 3へ移行することのメリット

 まず、Python 2のオフィシャルなサポートは近いうちに終了するので、Python 3に移行することで、オフィシャルなサポートが終了したバージョンのPythonを使い続けずに済む。そして、Python 3の方がPython 2よりも高速であり、便利な新機能も実装が続けられている。そして、現在では多くのフレームワークやライブラリがPython 3へと移行を済ませている。

 どれほどのフレームワークやライブラリがPython 3へ移行しているかはSunsetting Python 2 support(Moving to require Python 3)で確認できる。

Sunsetting Python 2 support Sunsetting Python 2 support

 こうしたことから、「Now is the best time to migrate!」(今が移行にはベストのタイミングだ!)と彼はいう。そのタイミングはもっと前からあったはずだが、なぜ今なのだろうか。その理由としてヴィトヴスキ氏は以下を挙げた。

  • 上述の通り、多くのフレームワークやライブラリが既にPython 3へ移行している(数年前だと、そうはなっていなかった)
  • Python 2からPython 3への自動以降ツールが多くの人の手でテストされている
  • 他者の移行事例から多くのノウハウが得られている
  • Python 2のEoL(End of Life)までまだまだ数カ月残っている
なぜ「今が移行にはベストのタイミング」なのか なぜ「今が移行にはベストのタイミング」なのか

Python 2のサポート終了後に取り得る手段

 では、Python 2のサポートが終了したときに、どんなことができるだろう。上から順に、手間がかからない方法を列挙する。

  • 何もしない
  • Dockerを使ってアプリケーションとその実行環境をコンテナ化する
  • Pythonインタプリターを変更する
  • 自分でCPython 2をメンテナンスする
  • Python 3に移行する
  • ゼロから書き直す
Python 2のサポート終了後に取り得る手段 Python 2のサポート終了後に取り得る手段

 その中で最も一般的な選択肢となるのが「Python 3に移行する」だ。ただし、その作業量は多くなる。

 Python 2のコードをPython 3へと移行するには大きく分けて次の2つの方法が考えられる。

  • Python 2とPython 3の両者で動作するコードにする
  • Python 2のコードをPython 3のコードに書き換える

 セッションでは、それぞれの方法の作業の進め方や、それぞれのメリット/デメリットなどについても触れているので、興味のある方は動画をご覧いただきたい。

Python 2のコードをPython 3のコードへ移行する Python 2のコードをPython 3のコードへ移行する

 前者は既存のコードをPython 2とPython 3の両方で動作するように書き換えていく(もちろん、そのためにはテストが必要になる)。移行が終わるまではPython 2を実行環境として使用し、移行できた時点でインタプリターをPython 3に切り替える(可能なら、その後、Python 2は削除する)。

 この方法では、現在動いているプロダクションコードを反復的に少しずつ置き換えていくことになる。その間に(両方のバージョンをサポートしたコードを書くことで)機能を追加することも可能だ。現在動いているアプリケーションを大々的に停止させる必要がないことはメリットといえる。

 後者の方法では、移行が完了するまではPython 2バージョンを動かしながら、別途、Python 3で動くコードにアプリケーションを書き直していく。Python 2のことを考慮しなくてよいので、作業量は前者よりも少なくなると思われる。そして、Python 3バージョンが完成した時点でPython 2バージョンからPython 3バージョンへ切り替える。このときにはテストの不備などで失敗する可能性もあるし、前者の方法とは異なり、開発時に同じ機能を両者に追加するのも難しい(両方のコードベースにそれぞれにコードを追加する必要があるだろう)。

 他の選択肢についても簡単に触れておこう。

 「Dockerを使ってアプリケーションとその実行環境をコンテナ化する」というのは、既に動作しているアプリケーションとその実行環境をコンテナ化することで、現状のプログラムをそのままの形で使い続けられるようにすることだ。Python自身やフレームワークなどに脆弱性があったときには、それを解決できるわけではないが、組織内部で使用するアプリケーションには適した対処といえる。この方法を取るのであれば、2020年を待たずに今すぐやることも勧められていた。

 「Pythonインタプリターを変更する」というのは、Python Software Foundation(PSF)がオフィシャルに開発/サポートを行っている、いわゆる「CPython」ではないPythonを使うようにするということだ。「2020年1月1日にサポートが終了するPython」とはこのCPythonのことであり、これ以外にも配布されているPython処理系はある。

 そうした代替のPythonインタプリターとしては、例えばPyPy、Intelが配布している「Intel Distribution for Python*」、Red Hat Enterprise Linux 7(RHEL 7)などが候補となる。

 「自分でCPython 2をメンテナンスする」というのは、CPython 2のレポジトリをフォークして、自分でCPython 2をビルドして、それを自身のプロダクトで使うという意味だ。日々の運用の中で脆弱性が発見されたら、自分でパッチを当て(て、ビルドをして、……という手間暇をかけ)なければならない。聞くだけでも、これは避けたいと思う選択肢ではある。

 最後がPython 3(または別の言語)を使って「ゼロから書き直す」となる。作業量はもちろん多くなるし、これが意味を持つのはPython 2バージョンのアプリケーションをプロトタイプとして捉えられるときかもしれない。いずれにせよ、設計もゼロから行うことになるだろう。

移行に必要な手順

 では、移行すると決まったら、どうすればよいだろう。ヴィトヴスキ氏によると次の「4つ」が必要になる。これらの要素はPython 3への移行に限らず、Python 2.7からPyPyや他のPython 2.7インタプリターへの移行においても同様とのことだ。

  • テスト
  • テスト!
  • 依存性のチェック
  • 移行作業
以降に必要な手順 以降に必要な手順

 テストコード(とドキュメント)が欠如していることで、Python 3への移行が進まないプロジェクトは数多い。十分な量のテストコードがなければ、自分たちが正しいことをしていることを確信できない以上、そうなるのは当然だ。そうしたプロジェクトをPython 3に移行するには、テストコードを書くところから始める必要がある。その場合、テストコードをPython 2とPython 3の両者で実行できる必要がある。

 だが、Python 2バージョン用のテストコードを書いて、それを今度はPython 3に移行するのでは手間がかかりすぎる。そこで、ヴィトヴスキ氏は「Python 2でもPython 3でも実行できるテストを書く」「Webアプリの場合、テストを書く時間がなければ、SeleniumやPuppeteerなどのツールを使って機能テストを行い、それを記録しておく」ことを勧めている。

 Python 2からPython 3への移行に当たっては重要なポイントがある。1つはPython 2と3での文字列の扱いが大きく変わったこと、もう1つは除算演算子の振る舞いが変更されていることだ。そのため、これら2つの点についても注意深くテストを行うことが推奨されている。

 テストコードを手に入れた後は、複数のPythonバージョンの環境でテストを自動的に行うことが可能なtoxを導入して、Python 2とPython 3の両方の環境でのテストを行えるようにしたい。

 3つ目の要素である「依存性のチェック」では、caniusepython3ツールを使える。これを使って、自分が作成しているアプリケーションに含まれている依存性をチェックして、Python 3への移行の妨げになるものを発見できる。問題が発見されたら、そのパッケージやモジュールの代替となるものを見つけ出そう。

 テストコードを手に入れ、依存性を解決したら、最後に移行を行う。このときには自動化ツールを使って、ある程度は自動的にコードをPython 3へ移行して、残りは手作業で移行を行うことになる。

 自動化ツールは退屈な置き換え処理を自動的に行ってくれるが、最後にはチェックが必要だ。こうした作業を行ってくれるツールとしては2to3FuturizeModernizeがある。このうちFuturizeとModernizeはPython 2との後方互換性についても考慮したツールとなっている。そのため、先ほど述べた「Python 2とPython 3の両方で動作するコードに書き直す」方式の移行を行う際には役に立つだろう。詳細についてはセッションの動画をご覧いただきたい。

 これらのツールを使って、自動的な変換を行った後には、残りを自分で書き換える。こうした手順を経ることで、Python 3への移行が可能になる。

 移行の手順についての話を終えると、セッションのまとめとして、ヴィトヴスキ氏は「Dockerによるコンテナ化、PyPyやその他の代替インタプリターの利用」が可能なので、「Python 3にどうしても移行する必要はない」としつつも、「多くのフレームワークやライブラリがPython 3に移行済み」であるとともに、「移行ツールが成熟」ことと「Python 2のオフィシャルなサポートが終了するまでにはもう少しだけ時間がある」ことを理由として「今が移行を始めるにはベストなタイミング」であるとして、セッションは終了した。


 Python 2.7のサポート終了が間近になった段階で、既存のPython 2コードをどうするか。「移行しないという選択肢」「移行するとしたら、どんな手順を踏めばよいか」を明確に示してくれたセッションだった。Python 2のコードをどうしたらよいかを検討している方はぜひ本セッションの動画を参考にしてほしい。

Copyright© Digital Advantage Corp. All Rights Reserved.

スポンサーからのお知らせPR

注目のテーマ

Microsoft & Windows最前線2025
AI for エンジニアリング
ローコード/ノーコード セントラル by @IT - ITエンジニアがビジネスの中心で活躍する組織へ
Cloud Native Central by @IT - スケーラブルな能力を組織に
システム開発ノウハウ 【発注ナビ】PR
あなたにおすすめの記事PR

RSSについて

アイティメディアIDについて

メールマガジン登録

@ITのメールマガジンは、 もちろん、すべて無料です。ぜひメールマガジンをご購読ください。