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
Carton 1.0 at OSCON 2013
Search
Tatsuhiko Miyagawa
July 25, 2013
Technology
11
2.3k
Carton 1.0 at OSCON 2013
Introducing what's new in Carton at O'Reilly Open Source Convention 2013.
Tatsuhiko Miyagawa
July 25, 2013
Tweet
Share
More Decks by Tatsuhiko Miyagawa
See All by Tatsuhiko Miyagawa
Carmel at YAPC::EU 2015
miyagawa
0
530
Carton at London Perl Workshop 2013
miyagawa
0
270
Managing CPAN dependencies with Carton
miyagawa
0
320
What's new in Carton and cpanm at YAPC::Asia 2013
miyagawa
6
1.3k
cpanm 1.6 at OSDC.TW
miyagawa
6
1.3k
10 more things to be ripped off
miyagawa
7
1.4k
Ruby; Exported
miyagawa
1
1k
10 Years: LL, you and me
miyagawa
2
200
Plack 1.0 announcement at OSCON
miyagawa
1
280
Other Decks in Technology
See All in Technology
Wasm元年
askua
0
110
Create a Rails8 responsive app with Gemini and RubyLLM
palladius
0
140
Amazon Bedrockで実現する 新たな学習体験
kzkmaeda
1
410
データプラットフォーム技術におけるメダリオンアーキテクチャという考え方/DataPlatformWithMedallionArchitecture
smdmts
5
570
低レイヤを知りたいPHPerのためのCコンパイラ作成入門 完全版 / Building a C Compiler for PHPers Who Want to Dive into Low-Level Programming - Expanded
tomzoh
1
400
本部長の代わりに提案書レビュー! KDDI営業が毎日使うAIエージェント「A-BOSS」開発秘話
minorun365
PRO
14
2.3k
成立するElixirの再束縛(再代入)可という選択
kubell_hr
0
950
PHP開発者のためのSOLID原則再入門 #phpcon / PHP Conference Japan 2025
shogogg
2
420
AIにどこまで任せる?実務で使える(かもしれない)AIエージェント設計の考え方
har1101
3
1.3k
BigQuery Remote FunctionでLooker Studioをインタラクティブ化
cuebic9bic
2
230
プロダクトエンジニアリング組織への歩み、その現在地 / Our journey to becoming a product engineering organization
hiro_torii
0
110
~宇宙最速~2025年AWS Summit レポート
satodesu
1
1.4k
Featured
See All Featured
[RailsConf 2023 Opening Keynote] The Magic of Rails
eileencodes
29
9.5k
Rebuilding a faster, lazier Slack
samanthasiow
81
9k
Why Our Code Smells
bkeepers
PRO
337
57k
StorybookのUI Testing Handbookを読んだ
zakiyama
30
5.8k
Building Flexible Design Systems
yeseniaperezcruz
328
39k
Evolution of real-time – Irina Nazarova, EuRuKo, 2024
irinanazarova
8
790
Exploring the Power of Turbo Streams & Action Cable | RailsConf2023
kevinliebholz
32
5.9k
Easily Structure & Communicate Ideas using Wireframe
afnizarnur
194
16k
[Rails World 2023 - Day 1 Closing Keynote] - The Magic of Rails
eileencodes
35
2.3k
The Pragmatic Product Professional
lauravandoore
35
6.7k
It's Worth the Effort
3n
184
28k
4 Signs Your Business is Dying
shpigford
184
22k
Transcript
Carton 1.0 managing CPAN deps the right way Tatsuhiko Miyagawa
@miyagawa O'Reilly OSCON 2013 Wednesday, July 24, 13
Me • Tatsuhiko Miyagawa • Lives in San Francisco •
{github,twitter,CPAN}/miyagawa Wednesday, July 24, 13
Managing CPAN Dependencies Wednesday, July 24, 13
How many CPAN modules your app depends on? Wednesday, July
24, 13
When is the last time upgrading a CPAN module broke
your app? Wednesday, July 24, 13
Case Study: Web App Development Wednesday, July 24, 13
You’re writing a new web app using as many CPAN
modules. Wednesday, July 24, 13
Get them from CPAN, install on your machine. Wednesday, July
24, 13
john@local> cpanm Web::Framework installed LWP-‐5.912 installed Plack-‐0.9980 installed Web-‐Framework-‐1.10 Wednesday,
July 24, 13
Test it... Wednesday, July 24, 13
Works? Ship it! Wednesday, July 24, 13
What if ... Wednesday, July 24, 13
• Jul 2nd: Started working on project • using Web::Framework
1.1 • Jul 9th: Finished version 1.0 • Jul 10-15th: internal beta, QA • Jul 16th: Deploy to the production Wednesday, July 24, 13
• Jul 2nd: Started working on project • using Web::Framework
1.1 • Jul 9th: Finished version 1.0 • Jul 10-15th: internal beta, QA • Jul 15th: Web::Framework 1.2 is released • Jul 16th: Deploy to the cloud/production Wednesday, July 24, 13
root@prod> cpanm Web::Framework installed LWP-‐5.912 installed Plack-‐0.9980 installed Web-‐Framework-‐1.20 Wednesday,
July 24, 13
Web::Framework 1.2 API changes! Wednesday, July 24, 13
Wednesday, July 24, 13
Wednesday, July 24, 13
“Upgrading CPAN modules broke my app” Wednesday, July 24, 13
Dependencies are part of your app. Wednesday, July 24, 13
a solution cpanm 1.6 Wednesday, July 24, 13
> cpanm Web::
[email protected]
installed Web-‐Framework-‐1.10 Wednesday, July 24, 13
> cpanm Web::Framework~">= 1.0, < 1.2" installed Web-‐Framework-‐1.19 Wednesday, July
24, 13
♥ MetaCPAN Wednesday, July 24, 13
a solution cpanfile + cpanm 1.6 Wednesday, July 24, 13
> cat cpanfile requires 'Web::Framework', '== 1.10'; > cpanm -‐-‐installdeps
. installed Web-‐Framework-‐1.10 Wednesday, July 24, 13
cpanfile DSL to describe prereqs Wednesday, July 24, 13
requires 'Catalyst', '5.8000'; recommends 'JSON::XS', '2.0'; on 'test' =>
sub { requires 'Test::More', '>= 0.96' }; on 'develop' => sub { recommends 'Devel::NYTProf'; }; feature 'sqlite' => sub { requires 'DBD::SQLite'; }; Wednesday, July 24, 13
inspired by: gemfile(5) Wednesday, July 24, 13
Backward compatible to: Module::Install(::DSL) Wednesday, July 24, 13
Converted to to: CPAN::Meta::Prereqs Wednesday, July 24, 13
Toolset Module::CPANfile Module::Install::CPANfile Dist::Zilla plugins Wednesday, July 24, 13
Supported by dzil, Milla & cpanm 1.6 Wednesday, July 24,
13
cpanfile + cpanm • Simple • Yet powerful and flexible
way to describe dependencies and version requirements • Version control cpanfile Wednesday, July 24, 13
caveats • Locking each dependency with specific version is tedious
work • Can only lock direct dependencies • MetaCPAN as SPOF • No easy/reliable way to fallback Wednesday, July 24, 13
Many other solutions Needs servers, Needs databases Too simple, Too
complicated, etc. Wednesday, July 24, 13
the Solution Wednesday, July 24, 13
Carton https://github.com/miyagawa/carton Wednesday, July 24, 13
Inspired by... Wednesday, July 24, 13
Wednesday, July 24, 13
Basic idea: Describe CPAN dependencies snapshot tarball pathnames Wednesday, July
24, 13
Built on top of: cpanfile + cpanm 1.6 Wednesday, July
24, 13
• App-specific local environment • Fast and safe install with
caches • Dep-tree analysis, including versions • Freezing module versions • Conservative updates • Easy Redeployment, Rollback • Single-file, VCS friendly Wednesday, July 24, 13
Local perl environment Using local::lib and cpanm -L Each app
has an isolated local library path Wednesday, July 24, 13
Fast and safe install Saves MYMETA.json and install meta info
Wednesday, July 24, 13
Dep tree analysis Rebuild the dependency tree from snapshot Checks
if anything is missing/superfluous Wednesday, July 24, 13
Freezing versions Versions are saved in snapshots including dependencies Wednesday,
July 24, 13
Easy Redeployment Reinstall exactly the same set of modules on
another prod/development machines. Wednesday, July 24, 13
Conservative Update Modules won't be upgraded unless it is required,
or manually updated. Wednesday, July 24, 13
Single-file, VCS friendly You can add cpanfile.snapshot to git update
whenever you update modules "Dependencies are part of your app." Wednesday, July 24, 13
Safe and easy rollback revert the lock file and redeploy
Wednesday, July 24, 13
DEMO Wednesday, July 24, 13
Deployment with Carton Wednesday, July 24, 13
@local> carton install @local> git commit cpanfile.snapshot @local> git push
@remote> carton install -‐-‐deployment @remote> carton exec plackup ... Wednesday, July 24, 13
Example: github.com/miyagawa/cpanmetadb-perl capistrano, Server::Starter, carton, plackup (twiggy) Wednesday, July 24,
13
PaaS/Cloud github.com/miyagawa/heroku-buildpack-perl Wednesday, July 24, 13
Wednesday, July 24, 13
http://weblog.bulknews.net Wednesday, July 24, 13
Support to come! Dokku, DotCloud, Travis CI, Cloud Foundry etc.
Wednesday, July 24, 13
carton 1.0 later this week Wednesday, July 24, 13
> cpanm -‐-‐dev Carton Wednesday, July 24, 13
Towards 1.1 • Inject patched versions (DarkPAN) • Install from
github • bootstrap with fatpack Wednesday, July 24, 13
github.com/miyagawa/carton irc.perl.org #carton Wednesday, July 24, 13
speakerdeck.com /miyagawa Wednesday, July 24, 13
Questions? Wednesday, July 24, 13