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
SUZUKI Masashi
June 11, 2014
Technology
1
2.1k
2014-06-11_gotanda.pm
とある企業のPerlモジュール管理の歴史
SUZUKI Masashi
June 11, 2014
Tweet
Share
More Decks by SUZUKI Masashi
See All by SUZUKI Masashi
2025-08-05 Google Cloud Next Tokyo 2025 Cloud RunとCloud SQLの接続方式と事例
masasuzu
0
13
2025-06-20 PrivateLinkがNLBなしで作れるようになり便利になった
masasuzu
2
380
2025-01-31 吉祥寺.pm 37 初めての海外カンファレンス
masasuzu
0
530
2025-01-24-SRETT11-OpenTofuについてそろそろ調べてみるか
masasuzu
0
1.4k
2024-03-29 SRETT9 Cloud SQLの可用性について
masasuzu
0
500
2023-12-18 SRETT8 Terraform使いがPulumiに入門する
masasuzu
0
2.5k
2023-12-01 吉祥寺.pm ベストプラクティスと組織とIaC
masasuzu
1
1.7k
SRETT#6_Terraformのtfstateについて考える
masasuzu
2
3.8k
SRETT#4黒い画面をもっと効率的に(使って自動化の時間を捻出)
masasuzu
2
460
Other Decks in Technology
See All in Technology
AIエージェント開発用SDKとローカルLLMをLINE Botと組み合わせてみた / LINEを使ったLT大会 #14
you
PRO
0
130
新規プロダクトでプロトタイプから正式リリースまでNext.jsで開発したリアル
kawanoriku0
1
160
AWSを利用する上で知っておきたい名前解決のはなし(10分版)
nagisa53
10
3.2k
Terraformで構築する セルフサービス型データプラットフォーム / terraform-self-service-data-platform
pei0804
1
190
これでもう迷わない!Jetpack Composeの書き方実践ガイド
zozotech
PRO
0
1k
Platform開発が先行する Platform Engineeringの違和感
kintotechdev
4
580
dbt開発 with Claude Codeのためのガードレール設計
10xinc
2
1.3k
250905 大吉祥寺.pm 2025 前夜祭 「プログラミングに出会って20年、『今』が1番楽しい」
msykd
PRO
1
980
AIをプライベートや業務で使ってみよう!効果的な認定資格の活かし方
fukazawashun
0
100
Webアプリケーションにオブザーバビリティを実装するRust入門ガイド
nwiizo
7
860
大「個人開発サービス」時代に僕たちはどう生きるか
sotarok
20
10k
品質視点から考える組織デザイン/Organizational Design from Quality
mii3king
0
210
Featured
See All Featured
Fantastic passwords and where to find them - at NoRuKo
philnash
52
3.4k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
8
920
Building Applications with DynamoDB
mza
96
6.6k
Into the Great Unknown - MozCon
thekraken
40
2k
Rebuilding a faster, lazier Slack
samanthasiow
83
9.2k
Balancing Empowerment & Direction
lara
3
620
Unsuck your backbone
ammeep
671
58k
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
46
7.6k
個人開発の失敗を避けるイケてる考え方 / tips for indie hackers
panda_program
113
20k
StorybookのUI Testing Handbookを読んだ
zakiyama
31
6.1k
VelocityConf: Rendering Performance Case Studies
addyosmani
332
24k
Code Reviewing Like a Champion
maltzj
525
40k
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