Upgrade to Pro
— share decks privately, control downloads, hide ads and more …
Speaker Deck
Features
Speaker Deck
PRO
Sign in
Sign up for free
Search
Search
2014-06-11_gotanda.pm
Search
Sponsored
·
SiteGround - Reliable hosting with speed, security, and support you can count on.
→
SUZUKI Masashi
June 11, 2014
Technology
2.3k
1
Share
2014-06-11_gotanda.pm
とある企業のPerlモジュール管理の歴史
SUZUKI Masashi
June 11, 2014
More Decks by SUZUKI Masashi
See All by SUZUKI Masashi
2026-04-14 Jagu'e'r Cloud Native分科会 Terraform Stateにおけるシークレットの平文保存という課題とその解決
masasuzu
1
49
2026-03-27 #terminalnight 変数展開とコマンド展開でターミナル作業をスマートにする方法
masasuzu
0
390
2026-03-23 Ops-JAWS Meetup39 Session Managerを使った セキュアなサーバーアクセス
masasuzu
2
140
2026-03-11 JAWS-UG 茨城 #12 改めてALBを便利に使う
masasuzu
3
470
2026-03-03 Jagu'e'r Tech Writer Meetup #19 登壇のネタ作りについて
masasuzu
0
190
2026-02-24 月末 Tech Lunch Online #10 Cloud Runのデプロイの課題から考えるアプリとインフラの境界線
masasuzu
0
170
2025-11-21 社内エンジニア勉強会 改めて理解するVPC Endpoint
masasuzu
0
390
2025-11-08 Security JAWS TerraformによるIAM Policy記述ガイド
masasuzu
2
1.4k
2025-09-25 SRETT #13 ConftestによるTerraformのPolicy as Codeを試してみる
masasuzu
0
540
Other Decks in Technology
See All in Technology
Dynamic Workersについて
yusukebe
1
420
組織の中で自分を経営する技術
shoota
0
220
ビジュアルプログラミングIoTLT vol.23
1ftseabass
PRO
0
150
TROCCOで始めるクラウドコストを民主化するためのFinOps
tk3fftk
1
280
エンジニアは生成AIと どのように向き合うべきか? ことばの意味という観点から
verypluming
3
290
最低限これだけ押さえれ大丈夫_Claude Enterprise/Team企業展開ガバナンス入門
tkikuchi
1
500
【ハノーバーメッセ振り返りイベントat名古屋】データは集約からAI起点の収集に ~組織内・組織間でのデータ連携~
tanakaseiya
0
140
NFLコンペ2026 解法
lycorptech_jp
PRO
0
130
個人AIからチームAIへ:開発における品質と生産性の再設計
moongift
PRO
0
290
Oracle AI Database@Azure:サービス概要のご紹介
oracle4engineer
PRO
6
1.8k
Oracle AI Database@Google Cloud:サービス概要のご紹介
oracle4engineer
PRO
6
1.5k
Databricks 月刊サービスアップデート 2026年05月号
tyosi1212
0
110
Featured
See All Featured
30 Presentation Tips
portentint
PRO
1
300
The World Runs on Bad Software
bkeepers
PRO
72
12k
Prompt Engineering for Job Search
mfonobong
0
320
The Limits of Empathy - UXLibs8
cassininazir
1
340
Crafting Experiences
bethany
1
160
Test your architecture with Archunit
thirion
1
2.3k
No one is an island. Learnings from fostering a developers community.
thoeni
21
3.7k
Visualization
eitanlees
152
17k
Beyond borders and beyond the search box: How to win the global "messy middle" with AI-driven SEO
davidcarrasco
3
140
Navigating the Design Leadership Dip - Product Design Week Design Leaders+ Conference 2024
apolaine
1
330
Believing is Seeing
oripsolob
1
130
Agile Leadership in an Agile Organization
kimpetersen
PRO
0
160
Transcript
とある企業のPerl もじゅーる管理 すずきまさし / @masasuz 1
おまえだれよ すずきまさし / @masasuz 五反田の辺りにある中小web企業 6月1日で5年目らしい アプリケーションとインフラの中間エン ジニア(最近アプリよりに戻された) zsh /
perl / mysql / Ubuntu / Debian 2
とある企業のPerl もじゅーるかんり 3
注意 3年ちょい前に入社したのでそれ以前の ことは歴史書(git)からひもといている ので正確で無いです。 git (+ git-svn)の歴史に刻まれていな い、先史時代のことは分かりません。 4
おおまかな歴史 先史時代 丸ごとrsync期 Debian Package期 carton期 5
先史時代 知りません 2006年より前はさかのぼれません FreeBSDが使われていたようです 6
丸ごとrsync期 Debian 32bit Apache + mod_perl + Sledge system perl
Archer 7
丸ごとrsync期 cont.. CPANプロジェクトをrsync バイナリ含む 8
プロジェクト数が少ない 全て同じOS/arch 全サーバで同じモジュールを使える! 9
問題 ディストリビューションのメンテ切れ archの差異 64bit バージョン管理が煩雑 10
Debian Package期 Debian 32/64bit混在 Apache + mod_perl + (Sledge or
Splite) cpan-packagerでCPANモジュールをdeb化 arch / dist 毎に作る Archer => Watch2::Deployer 11
apt-localとapt-proxyサーバ xx-cpan-perlというパッケージの依存 パッケージに全perl deb packageを突っ 込む deploy時にapt-localのインデックス生 成 各サーバにssh =>
aptitude update && aptitude safe-upgrade 12
複数 dist/arch混在環境 バージョン管理ができるように 全プロジェクト同じモジュール!? 13
問題 カジュアルにパッケージ足しすぎ。カオス 依存関係地獄 全プロジェクトに影響 プロジェクト数が増えてきた 簡単にバージョン上げられない 古のモジュールがはびこることに。。 14
問題 cont.. OS自動インストール時に全モジュールを インストールしてるのでOSインストール に超時間かかる 全サーバに対してデプロイするので、台 数に比例してデプロイに時間がかかる system のdeb packageとかぶる
バージョンにepochを付与して回避(ダ ウングレード!) 15
問題 cont.. ディストリビューションをアップデー トするたびに検証作業が必要。。 特定のプロジェクトで新しいバージョ ンを使うことができない プロジェクト同居の可能性があるの でextlibに突っ込めない 16
carton期 Ubuntu Server 64bit carton (Upstart +) Server::Starter + Starlet
+ Amon2 OrePAN2::Server not system perl 独自ビルドしたdeb package 17
cpanfile(.snapshot)に依存モジュールを記 述 carton install —deployment プロジェクト毎に独自のモジュールが使える 社内モジュールはOrePAN2に上げる system perlに依存しない dist変えやすい
18
おおまかな歴史 先史時代 丸ごとrsync期 Debian Package期 carton期 <= イマココ 19
正しい歴史 先史時代 丸ごとrsync期 丸ごと(ry + Debian Package期 丸(ry+Deb(ry or carton期<=イマココ
20
CPANプロジェクトは最後の最後まで消 えなかった 更新が速い(設定系)モジュールが残り 続けた 社内モジュール置き場になった。 21
新しいプロジェクトじゃないとcarton 化しにくい Apache + mod_perlからの移行が。。 新規プロジェクトなら楽なので、そ こから 古(いにしえ)のモジュールの関係 というか実際依存関係ぶっ壊れてる 22
とはいえ、 どのスキームも当時のコンテキストに はあっていた。 レガシーなスキームが悪いのでは無く、 コンテキストが変わってしまったのに、 レガシーなスキームを使い続けるのが 悪。 23
なので、 すぐには全部変えられないけど、少し ずつ、時代に合わないものを消して行っ ている途中。 大事なのは、問題は問題と認識して解 決の方向に進めること。 エンジニアだもの文句じゃ無く技術で 解決しよう。 24
おしまい 25