Pythonの「GIL」廃止で“悪夢”がよみがえる? 代わりに台頭する言語はPython破滅への一歩か?【後編】

開発の制約を取り除くために、「Python」での「GIL」廃止が現実味を帯びてきた。ただしこの方針は、過去と同様の混乱を招くだけではなく、ユーザー流出の恐れもあると有識者は警告する。

2024年08月27日 05時00分 公開
[Darcy DeCluteTechTarget]

 プログラミング言語「Python」の成長に伴い、往年の課題である「GIL」(Global Interpreter Lock)の制約が顕在化してきた。GILはCPython(Pythonの標準実装)が持つ仕組みで、複数のスレッドが同時にPythonプログラムを実行することを妨げる。これはマルチコアCPUの効率的な活用を困難にする要因となっている。

 この問題に対処するため、Pythonの新機能や仕様に関する提案文書「PEP 703」は、GILを段階的に廃止することを提唱した。この変更によって、Pythonの並列処理能力が向上する可能性がある一方で、既存のソースコードやライブラリ(プログラム部品群)への影響も生じることになる。その影響は小さなものではなく、深刻になるというのが筆者の見方だ。どのような問題が起こり得るのかを考えてみよう。

「Python 3」の悪夢再び?

 一部のPythonライブラリの管理者は、こうした事態に既視感を覚えるはずだ。「Python 2」から「Python 3」へのアップデート時、両バージョン間での互換性が確保されなかったため、開発者はプログラムのアップデートを迫られることになった。GILの廃止は、開発者にこれと同様の経験を強いる恐れがある。

 Python 2からPython 3への移行において、開発者が互換性の問題に対処するための時間は限られていた。移行以外の代替手段がなく、Pythonに依存していたIT部門は、まとまったコストを投じて、Pythonのバージョンに取り組まざるを得なかった。

 こうした経験を持つPythonユーザーは、GILがあるバージョンからGILがないバージョンへの移行に際して、同じ経験を繰り返す気にはなれないのではないか。

 幸い、今回は状況が異なる。PEP 703が示す計画では、GILの廃止は2028~2030年になる見込みだ。開発者やアーキテクトには、この変更に対して計画を立てる時間があると言える。Python以外のプログラミング言語に乗り換える計画を立てることも可能だ。

救世主は「Mojo」

 PythonからGILが廃止されることになれば、プログラミング言語「Mojo」が移行先の候補になる。

 Mojoは原稿執筆時点で開発中だ。Mojoの開発チームはMojoがPythonとの完全互換性を持つように設計することを目指している。そのため基本的にはPythonで記述したソースコードをMojoの文法で書き直す必要はない。

 AI(人工知能)技術に関するさまざまなプログラムの開発で活躍が見込めるのもMojoの利点だ。PCのCPUで動作するPythonプログラムから、GPU(グラフィックス処理装置)を用いたプログラミング向けの開発者ツール群「CUDA」(Compute Unified Device Architecture)を使用するプログラムまでを開発できる。Pythonで並列処理が可能になることで修正が必要になる「C」「C++」といったプログラミング言語の関数も、Mojoで書き直すことが可能だ。オープンソースの機械学習ライブラリの幾つかは、既にMojoに移植されている。

 筆者はこれまで「Mojoの正式バージョンが公開されたら、AI関連の新規プロジェクトはPythonではなくMojoで開発される」と主張してきた。Mojoでの開発は、CPythonを前提にしなくてもよいからだ。PythonでGILが廃止された場合も同様に、ソースコードの書き直しやコードベース(ソースコード群)の長期的な保守性を考えなければならなくなったプロジェクトリーダーが、Mojoに移行する可能性がある。

筆者からの忠告

 Pythonの進化が遅いことに不満を感じているPythonコミュニティーの開発者は一定数いる印象だ。一部の開発者はGIL廃止の提案文書を見て、「ようやくGILがなくなる」と沸き立っているが、筆者からすれば彼らは全体像を見失っている。

 GILをPythonから取り除くことは“もろ刃の剣”だと筆者は考える。Mojoをはじめとする他のプログラミング言語へのユーザー流出が起きるだろう。Mojoが高速かつ効率的なプログラミング言語であり続け、専門家によるメンテナンスが続く限り、PythonコミュニティーはGILに手を付けるべきではない。

TechTarget発 エンジニア虎の巻

米国TechTargetの豊富な記事の中から、開発のノウハウや技術知識など、ITエンジニアの問題解決に役立つ情報を厳選してお届けします。

Copyright © ITmedia, Inc. All Rights Reserved.

髫エ�ス�ス�ー鬨セ�ケ�つ€驛「譎擾スク蜴・�。驛「�ァ�ス�、驛「譎冗樟�ス�ス驛「譎「�ス�シ驛「譏懶スサ�」�ス�ス

製品資料 グーグル・クラウド・ジャパン合同会社

標準のPostgreSQLより4倍以上も高速、高性能&高可用性で注目のデータ基盤とは

リアルタイム性や生成AI対応などデータベースに対する期待が急速に高まっている。そこで従来のPostgreSQLでは対応が難しかったスピードやスケーラビリティの課題を解消したデータ基盤が注目されている。本資料で詳細を解説する。

製品資料 グーグル・クラウド・ジャパン合同会社

生成AIアプリの開発を容易に、オペレーショナルデータベース×RAGのメリット

生成AIを業務に生かすには、回答の正確性やセキュリティなど、多くの課題を解決する必要がある。そこで注目したいのが、オペレーショナルデータベースと、検索拡張生成(RAG)技術を組み合わせるアプローチだ。

製品資料 株式会社ベリサーブ

大規模化するアジャイル開発、3つの課題の解決に向けたアプローチとは

多くの企業でアジャイル開発の手法が取り入れられるようになった一方、欧米企業を中心にアジャイル開発の大規模化が普及している。これに伴い、「テストの工数やコストの増大」「製品全体像の把握の難しさ」といった課題が出てきた。

比較資料 株式会社ベリサーブ

表計算ソフトでの管理は限界、開発のテスト工程を効率化する「TestOps」実践術

開発のテスト工程を効率化するためのキーワードとして注目される「TestOps」。だが従来の表計算ソフトを用いたテスト管理では、その実現は難しかった。その理由と、TestOpsの実践を成功させるための秘訣とは?

事例 SUSE ソフトウエア ソリューションズ ジャパン株式会社

Linux管理を一元化しコストを削減、製造メーカーの継続的発展を支えた技術とは

イノベーションを最優先事項とし、研究開発に継続的な投資を行っていたWEG。しかし、開発スピードの低下やKubernetes環境の管理負担増加、Linux運用の複雑化といった課題に直面していた。同社はこの問題をどう一掃したのか。

驛「譎冗函�趣スヲ驛「謨鳴€驛「譎「�ス�シ驛「�ァ�ス�ウ驛「譎「�ス�ウ驛「譎「�ソ�ス�趣スヲ驛「譎「�ソ�スPR

From Informa TechTarget

お知らせ
米国TechTarget Inc.とInforma Techデジタル事業が業務提携したことが発表されました。TechTargetジャパンは従来どおり、アイティメディア(株)が運営を継続します。これからも日本企業のIT選定に役立つ情報を提供してまいります。

Pythonの「GIL」廃止で“悪夢”がよみがえる? 代わりに台頭する言語は:Python破滅への一歩か?【後編】 - TechTargetジャパン システム開発 髫エ�ス�ス�ー鬨セ�ケ�つ€鬮ォ�ェ陋滂ソス�ス�コ�ス�ス

TechTarget驛「�ァ�ス�ク驛「譎「�ス�」驛「譏懶スサ�」�趣スヲ 髫エ�ス�ス�ー鬨セ�ケ�つ€鬮ォ�ェ陋滂ソス�ス�コ�ス�ス

ITmedia マーケティング新着記事

news046.png

「ECプラットフォーム」売れ筋TOP10(2025年4月)
今週は、ECプラットフォーム製品(ECサイト構築ツール)の国内売れ筋TOP10を紹介します。

news026.png

「パーソナライゼーション」&「A/Bテスト」ツール売れ筋TOP5(2025年4月)
今週は、パーソナライゼーション製品と「A/Bテスト」ツールの国内売れ筋各TOP5を紹介し...

news130.jpg

Cookieを超える「マルチリターゲティング」 広告効果に及ぼす影響は?
Cookieレスの課題解決の鍵となる「マルチリターゲティング」を題材に、AI技術によるROI向...