SlideShare a Scribd company logo
The secret of Release story
SHIBATA Hiroshi / GMO Pepabo, inc.
2018.03.16 RubyConf.ph 2018
How to distribute Ruby to the
world
self.introduce
self.introduce
=> {
name: “SHIBATA Hiroshi”,
nickname: “hsbt”,
organizations: [“pepabo”, “ruby”, “rubygems”,
“asakusarb”],
commit_bits: [“ruby”, “rake”, “rubygems”, “bundler”,
“rdoc”, “psych”, “ruby-build”, “railsgirls”, “railsgirls-
jp”, …],
sites: [“hsbt.org”, “ruby-lang.org”, “rubyci.org”,
“railsgirls.com”, “railsgirls.jp”],
}
How to distribute Ruby to the world
How to distribute Ruby to the world
What’s Ruby core
team?
1.
Ruby Committer
Heroku
• matz
• n0kada
$ cat ~svn/.ssh/authorized_keys | awk '{print $5}' | sort | uniq | wc -l
97
Total 95 people + 2 bot
Money Forward
• shyouhei
Full-time commiters
Cookpad
• ko1
• mametter
Speee
• mrkn
Branch maintainers
trunk known as 2.6 and 2.5
@nurse: Release manager
2.4
@nagachika: Stable branch maintainer
2.3, 2.2
@unak: Old stable branch maintainer
Linux
• normalperson
• akr
• n0kada
and others
Windows
• unak
• n0kada
Platform maintainers
BSD
• nurse
Solaris
• ngoto
macOS
• n0kada
• mrkn
Ruby 2.6
2/24: 2.6.0preview1 release
It contained MJIT feature
see https://bugs.ruby-lang.org/issues/14235
5/?: 2.6.0preview2 release
RubyGems 3.0
Improve MJIT Performance
12/25: 2.6.0 final release
Ruby 2.6 timeframe
How to distribute Ruby to the world
How release the Ruby
language
2.
Version number and release cycle
We plan to release every Christmas day.
• 2.1.0: 2013/12/25
• 2.2.0: 2014/12/25
• 2.3.0: 2015/12/25
• 2.4.0: 2016/12/25
• 2.5.0: 2017/12/25
• 2.6.0: 2018/12/25(TBD)
• …
• 3.0.0: 2020/xx/xx
Backport
Ruby core backport model
trunk
ruby_2_4
ruby_2_3
trunk
ruby_2_4
ruby_2_3
We backport fixes to stable branch from trunk.
We do not merge fixes to trunk from stable branch
How do request to back port
We use to management
backport’s patch on
redmine with specific
rule.
• Write a revision
number to Title or
library version
• Set a status to
“close”
• Fill backport field to
“2.5:REQUIRED”
Ruby CI
What’s Ruby CI
Ruby CI is a CI results collector for alternative
platforms
• https://rubyci.org
• https://github.com/ruby/rubyci
• https://github.com/ruby/chkbuild
Ruby CI goal is entirely supports all of Ruby
platform.
How to distribute Ruby to the world
Ruby CI resources
Ruby CI goal is entirely supports all of Ruby
platform. Ruby CI built by a lot of cloud platforms.
• AWS
• Azure
• GCP
• DigitalOcean
• on-premise servers(macOS)
• opencsw(Solaris)
Packaging & Release
Release time
We build a tar packages from svn repository used
`tools/make-snapshot`. After that, We will put them
to ftp server.
We have announce following resources.
• https://www.ruby-lang.org (and RSS)
• Mailing-list: ruby-list (https://lists.ruby-lang.org)
• Twitter: @rubylangorg
Security release
3.
Security release
We received buffer overflow/underflow, memory
leak, escape string, directory traversal etc… every
week.
We hard to fix and release these security issue. so
all of release maintainer are volunteer work.
We have “security@ruby-lang.org” for security
report.
HackerOne
We’ve been use
https://hackerone.com/
ruby
It has bounty program
provided by IBB.
We accepts to security
report via hackerone
too.
Why security is hard
• We must to work with closed discussion for fixing
Open-Source vulnerability.
• We get a CVE identity from MITRE by ourselves.
• We should release all versions of Ruby at the
same timing.
This is most hard thing.
What’s *.ruby-lang.org?
4.
What does mean “official”?
“official” means “Matz controllable”
Un-controllable examples:
• ruby-doc.org
• rubygems.org
• bundler.io
• Ruby version manager(rvm/rbenv/chruby)
*.ruby-lang.org
www.ruby-lang.org
Official Website of Ruby language.
see http://github.com/ruby/www.ruby-lang.org
svn.ruby-lang.org
Main repository of Ruby source. (Not git !!!)
bugs.ruby-lang.org
Official issue tracker build by redmine.
*.ruby-lang.org
ftp.ruby-lang.org
Site of distribute official package
lists.ruby-lang.org
Site of Mailing-list
docs.ruby-lang.org
Hosted document generated from RDoc on Ruby
source code and rubima project. Rubima project is
a Japanese Documentation about ruby languages.
CDN
Our site and package distribution were supported by
fastly.
• www.ruby-lang.org
• cache.ruby-lang.org
• docs.ruby-lang.org
Statistics of our CDN:
• Access ratio: USA: 44.6%, EU: 18.0%, Asia:
31.0%, Australia: 2.1%, Latin America: 3.7%,
South Africa: 0.04%
• Bandwidth: 7,203 GB/month
Sponsors of the Ruby language
• heroku:
Unlimited dyno resources for websites
• fastly:
OSS plan of CDN for *.ruby-lang.org
• NaCl:
Network and Compute resources for
website
• Microsoft:
Provides Azure environment via MSDN
Enterprise
Sponsors of the Ruby language(2)
• Ruby Association:
Grant of development
• Nihon Ruby no Kai:
macOS Server * 2
Grant of development(Windows)
• Sugaya research laboratory:
Network resources for macOS Server
rbenv/ruby-build
5.
Source distributeion
Binary distribution
• Windows: RubyInstaller2
• Linux: apt/yum/dnf
brightbox/software collection/snapcraft
• macOS: System tools
Source distribution
• Package: cache.ruby-lang.org
• Source code: svn.ruby-lang.org or github
What’s difference source package and others
Package(*.tar.gz)
• Pre-build transcode
• Generate configure script
• Do not need gnu tools without complier like
autoconf, bison
Source
• Need to gnu tools
• Need to ruby :)
Start to build Ruby language from source
$ git clone https://github.com/ruby/ruby
$ cd ruby
$ autoconf
$ ./configure —disable-install-doc
$ make -j
$ make install
You can invoke language tests with the following
instructions:
Ruby package manager
RVM
• To support Binary installation
• Applied Custom patchset
• Automatic installation of latest rubygems and
bundler
rbenv/ruby-build
• Modify environment variables.
• I’m also maintain them
chruby/ruby-install
• Modify a few environment variables.
rbenv/ruby-build
You can get them from
• homebrew
• git clone
Basic instructions are:$ rbenv install 2.5.0
$ rbenv install 2.6.0-dev
$ RUBY_CONFIGURE_OPT=—disable-install-doc rbenv install 2.4.3
$ rbenv install jruby-9.1.16.0
$ RUBY_CONFIGURE_OPT= rbenv install rbx-3.89
git.ruby-lang.org
6.
git.ruby-lang.org
It’s available under the ruby-lang.org now!!!
https://git.ruby-lang.org
• It’s READONLY
• It’s built by cgit web interface,
• It’s still experimental status. I’m preparing to it
now.
What’s issues of migration of Git
Toolchain:
• Packaging script depends on Subversion
repository and API.
Issue Tracker:
• Redmine on Heroku couldn’t use git repository.
Strategy
• How migrate git or github from svn (now
resolved!)
How to distribute Ruby to the world
Where do we go from here?
1. We migrate a toolchain like package script to git
from svn.
2. We will ship ruby package from git.ruby-
lang.org.
3. We will accept write commit on git.ruby-
lang.org.
4. We will accept to merge pull-request on GitHub
and sync them to git.ruby-lang.org (final goal)
Executive Officer CPO(Chief Productivity Officer)
Director of Business Process Re-engineering Office
at GMO Pepabo, Inc. @pepabo
Hiroshi SHIBATA @hsbt
https://www.hsbt.org
Matz k0kubun
ko1
shyouhei
amatsuda
mrkn
akr
nalsh
n0kada
Towards Ruby 3.0

More Related Content

PDF
Gemification for Ruby 2.5/3.0
PDF
How to distribute Ruby to the world
PDF
The Future of Bundled Bundler
PDF
The Future of Dependency Management for Ruby
PDF
How to develop the Standard Libraries of Ruby?
PDF
Gems on Ruby
PDF
Dependency Resolution with Standard Libraries
PDF
What's new in RubyGems3
Gemification for Ruby 2.5/3.0
How to distribute Ruby to the world
The Future of Bundled Bundler
The Future of Dependency Management for Ruby
How to develop the Standard Libraries of Ruby?
Gems on Ruby
Dependency Resolution with Standard Libraries
What's new in RubyGems3

What's hot (20)

PDF
The Future of library dependency manageement of Ruby
PDF
OSS Security the hard way
PDF
Gems on Ruby
PDF
RubyGems 3 & 4
PDF
Roadmap for RubyGems 4 and Bundler 3
KEY
tDiary annual report 2009 - Sapporo Ruby Kaigi02
PDF
Ruby Security the Hard Way
PDF
20140925 rails pacific
PDF
20140425 ruby conftaiwan2014
PDF
20140918 ruby kaigi2014
PDF
The details of CI/CD environment for Ruby
PDF
20140419 oedo rubykaigi04
PDF
The Future of library dependency management of Ruby
PDF
Gemification for Ruby 2.5/3.0
PDF
Middleware as Code with mruby
PDF
From 'Legacy' to 'Edge'
PDF
How to Begin to Develop Ruby Core
PDF
Gemification plan of Standard Library on Ruby
PDF
20141210 rakuten techtalk
PDF
Large-scaled Deploy Over 100 Servers in 3 Minutes
The Future of library dependency manageement of Ruby
OSS Security the hard way
Gems on Ruby
RubyGems 3 & 4
Roadmap for RubyGems 4 and Bundler 3
tDiary annual report 2009 - Sapporo Ruby Kaigi02
Ruby Security the Hard Way
20140925 rails pacific
20140425 ruby conftaiwan2014
20140918 ruby kaigi2014
The details of CI/CD environment for Ruby
20140419 oedo rubykaigi04
The Future of library dependency management of Ruby
Gemification for Ruby 2.5/3.0
Middleware as Code with mruby
From 'Legacy' to 'Edge'
How to Begin to Develop Ruby Core
Gemification plan of Standard Library on Ruby
20141210 rakuten techtalk
Large-scaled Deploy Over 100 Servers in 3 Minutes
Ad

Similar to How to distribute Ruby to the world (20)

PDF
The story of language development
KEY
Ruby v cpp_preso
PDF
RubyStack: the easiest way to deploy Ruby on Rails
PDF
The secret of programming language development and future
PDF
Ruby Presentation
PDF
RubyGems 3 & 4
DOCX
Page List & Sample Material (Repaired)
PDF
An introduction to the ruby ecosystem
PPTX
Ruby and Security
PDF
One RubyStack to Rule them All
PPTX
Chennai.rb feb 2016
KEY
Week6
PPTX
Ruby And Ruby On Rails
ODP
How to be productive with Rails... even on Windows
PDF
Create your-own-gem-with-github-jeweler-rubygems
DOCX
PPTX
Toolbox of a Ruby Team
PDF
Tricking Bundler
The story of language development
Ruby v cpp_preso
RubyStack: the easiest way to deploy Ruby on Rails
The secret of programming language development and future
Ruby Presentation
RubyGems 3 & 4
Page List & Sample Material (Repaired)
An introduction to the ruby ecosystem
Ruby and Security
One RubyStack to Rule them All
Chennai.rb feb 2016
Week6
Ruby And Ruby On Rails
How to be productive with Rails... even on Windows
Create your-own-gem-with-github-jeweler-rubygems
Toolbox of a Ruby Team
Tricking Bundler
Ad

More from Hiroshi SHIBATA (11)

PDF
Introduction of Cybersecurity with Ruby at RedDotRubyConf 2024
PDF
Introduction of Cybersecurity with OSS at Code Europe 2024
PDF
Long journey of Ruby Standard library at RubyKaigi 2024
PDF
Long journey of Ruby standard library at RubyConf AU 2024
PDF
Deep dive into Ruby's require - RubyConf Taiwan 2023
PDF
How resolve Gem dependencies in your code?
PDF
How resolve Gem dependencies in your code?
PDF
Ruby コミッターと歩む Ruby を用いたプロダクト開発
PDF
Why ANDPAD commit Ruby and RubyKaigi?
PDF
RailsGirls から始める エンジニアリングはじめの一歩
PDF
Productive Organization with Ruby
Introduction of Cybersecurity with Ruby at RedDotRubyConf 2024
Introduction of Cybersecurity with OSS at Code Europe 2024
Long journey of Ruby Standard library at RubyKaigi 2024
Long journey of Ruby standard library at RubyConf AU 2024
Deep dive into Ruby's require - RubyConf Taiwan 2023
How resolve Gem dependencies in your code?
How resolve Gem dependencies in your code?
Ruby コミッターと歩む Ruby を用いたプロダクト開発
Why ANDPAD commit Ruby and RubyKaigi?
RailsGirls から始める エンジニアリングはじめの一歩
Productive Organization with Ruby

Recently uploaded (20)

PPTX
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
PDF
KodekX | Application Modernization Development
PPTX
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
PDF
Reach Out and Touch Someone: Haptics and Empathic Computing
PPTX
Cloud computing and distributed systems.
PDF
Machine learning based COVID-19 study performance prediction
PDF
Agricultural_Statistics_at_a_Glance_2022_0.pdf
PDF
Electronic commerce courselecture one. Pdf
PPTX
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
PDF
Building Integrated photovoltaic BIPV_UPV.pdf
PPTX
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
PDF
Empathic Computing: Creating Shared Understanding
DOCX
The AUB Centre for AI in Media Proposal.docx
PDF
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
PDF
cuic standard and advanced reporting.pdf
PDF
Encapsulation theory and applications.pdf
PDF
NewMind AI Monthly Chronicles - July 2025
PPTX
Digital-Transformation-Roadmap-for-Companies.pptx
PDF
Modernizing your data center with Dell and AMD
PDF
Diabetes mellitus diagnosis method based random forest with bat algorithm
Detection-First SIEM: Rule Types, Dashboards, and Threat-Informed Strategy
KodekX | Application Modernization Development
KOM of Painting work and Equipment Insulation REV00 update 25-dec.pptx
Reach Out and Touch Someone: Haptics and Empathic Computing
Cloud computing and distributed systems.
Machine learning based COVID-19 study performance prediction
Agricultural_Statistics_at_a_Glance_2022_0.pdf
Electronic commerce courselecture one. Pdf
VMware vSphere Foundation How to Sell Presentation-Ver1.4-2-14-2024.pptx
Building Integrated photovoltaic BIPV_UPV.pdf
PA Analog/Digital System: The Backbone of Modern Surveillance and Communication
Empathic Computing: Creating Shared Understanding
The AUB Centre for AI in Media Proposal.docx
How UI/UX Design Impacts User Retention in Mobile Apps.pdf
cuic standard and advanced reporting.pdf
Encapsulation theory and applications.pdf
NewMind AI Monthly Chronicles - July 2025
Digital-Transformation-Roadmap-for-Companies.pptx
Modernizing your data center with Dell and AMD
Diabetes mellitus diagnosis method based random forest with bat algorithm

How to distribute Ruby to the world

  • 1. The secret of Release story SHIBATA Hiroshi / GMO Pepabo, inc. 2018.03.16 RubyConf.ph 2018 How to distribute Ruby to the world
  • 3. self.introduce => { name: “SHIBATA Hiroshi”, nickname: “hsbt”, organizations: [“pepabo”, “ruby”, “rubygems”, “asakusarb”], commit_bits: [“ruby”, “rake”, “rubygems”, “bundler”, “rdoc”, “psych”, “ruby-build”, “railsgirls”, “railsgirls- jp”, …], sites: [“hsbt.org”, “ruby-lang.org”, “rubyci.org”, “railsgirls.com”, “railsgirls.jp”], }
  • 7. Ruby Committer Heroku • matz • n0kada $ cat ~svn/.ssh/authorized_keys | awk '{print $5}' | sort | uniq | wc -l 97 Total 95 people + 2 bot Money Forward • shyouhei Full-time commiters Cookpad • ko1 • mametter Speee • mrkn
  • 8. Branch maintainers trunk known as 2.6 and 2.5 @nurse: Release manager 2.4 @nagachika: Stable branch maintainer 2.3, 2.2 @unak: Old stable branch maintainer
  • 9. Linux • normalperson • akr • n0kada and others Windows • unak • n0kada Platform maintainers BSD • nurse Solaris • ngoto macOS • n0kada • mrkn
  • 11. 2/24: 2.6.0preview1 release It contained MJIT feature see https://bugs.ruby-lang.org/issues/14235 5/?: 2.6.0preview2 release RubyGems 3.0 Improve MJIT Performance 12/25: 2.6.0 final release Ruby 2.6 timeframe
  • 13. How release the Ruby language 2.
  • 14. Version number and release cycle We plan to release every Christmas day. • 2.1.0: 2013/12/25 • 2.2.0: 2014/12/25 • 2.3.0: 2015/12/25 • 2.4.0: 2016/12/25 • 2.5.0: 2017/12/25 • 2.6.0: 2018/12/25(TBD) • … • 3.0.0: 2020/xx/xx
  • 16. Ruby core backport model trunk ruby_2_4 ruby_2_3 trunk ruby_2_4 ruby_2_3 We backport fixes to stable branch from trunk. We do not merge fixes to trunk from stable branch
  • 17. How do request to back port We use to management backport’s patch on redmine with specific rule. • Write a revision number to Title or library version • Set a status to “close” • Fill backport field to “2.5:REQUIRED”
  • 19. What’s Ruby CI Ruby CI is a CI results collector for alternative platforms • https://rubyci.org • https://github.com/ruby/rubyci • https://github.com/ruby/chkbuild Ruby CI goal is entirely supports all of Ruby platform.
  • 21. Ruby CI resources Ruby CI goal is entirely supports all of Ruby platform. Ruby CI built by a lot of cloud platforms. • AWS • Azure • GCP • DigitalOcean • on-premise servers(macOS) • opencsw(Solaris)
  • 23. Release time We build a tar packages from svn repository used `tools/make-snapshot`. After that, We will put them to ftp server. We have announce following resources. • https://www.ruby-lang.org (and RSS) • Mailing-list: ruby-list (https://lists.ruby-lang.org) • Twitter: @rubylangorg
  • 25. Security release We received buffer overflow/underflow, memory leak, escape string, directory traversal etc… every week. We hard to fix and release these security issue. so all of release maintainer are volunteer work. We have “security@ruby-lang.org” for security report.
  • 26. HackerOne We’ve been use https://hackerone.com/ ruby It has bounty program provided by IBB. We accepts to security report via hackerone too.
  • 27. Why security is hard • We must to work with closed discussion for fixing Open-Source vulnerability. • We get a CVE identity from MITRE by ourselves. • We should release all versions of Ruby at the same timing. This is most hard thing.
  • 29. What does mean “official”? “official” means “Matz controllable” Un-controllable examples: • ruby-doc.org • rubygems.org • bundler.io • Ruby version manager(rvm/rbenv/chruby)
  • 30. *.ruby-lang.org www.ruby-lang.org Official Website of Ruby language. see http://github.com/ruby/www.ruby-lang.org svn.ruby-lang.org Main repository of Ruby source. (Not git !!!) bugs.ruby-lang.org Official issue tracker build by redmine.
  • 31. *.ruby-lang.org ftp.ruby-lang.org Site of distribute official package lists.ruby-lang.org Site of Mailing-list docs.ruby-lang.org Hosted document generated from RDoc on Ruby source code and rubima project. Rubima project is a Japanese Documentation about ruby languages.
  • 32. CDN Our site and package distribution were supported by fastly. • www.ruby-lang.org • cache.ruby-lang.org • docs.ruby-lang.org Statistics of our CDN: • Access ratio: USA: 44.6%, EU: 18.0%, Asia: 31.0%, Australia: 2.1%, Latin America: 3.7%, South Africa: 0.04% • Bandwidth: 7,203 GB/month
  • 33. Sponsors of the Ruby language • heroku: Unlimited dyno resources for websites • fastly: OSS plan of CDN for *.ruby-lang.org • NaCl: Network and Compute resources for website • Microsoft: Provides Azure environment via MSDN Enterprise
  • 34. Sponsors of the Ruby language(2) • Ruby Association: Grant of development • Nihon Ruby no Kai: macOS Server * 2 Grant of development(Windows) • Sugaya research laboratory: Network resources for macOS Server
  • 36. Source distributeion Binary distribution • Windows: RubyInstaller2 • Linux: apt/yum/dnf brightbox/software collection/snapcraft • macOS: System tools Source distribution • Package: cache.ruby-lang.org • Source code: svn.ruby-lang.org or github
  • 37. What’s difference source package and others Package(*.tar.gz) • Pre-build transcode • Generate configure script • Do not need gnu tools without complier like autoconf, bison Source • Need to gnu tools • Need to ruby :)
  • 38. Start to build Ruby language from source $ git clone https://github.com/ruby/ruby $ cd ruby $ autoconf $ ./configure —disable-install-doc $ make -j $ make install You can invoke language tests with the following instructions:
  • 39. Ruby package manager RVM • To support Binary installation • Applied Custom patchset • Automatic installation of latest rubygems and bundler rbenv/ruby-build • Modify environment variables. • I’m also maintain them chruby/ruby-install • Modify a few environment variables.
  • 40. rbenv/ruby-build You can get them from • homebrew • git clone Basic instructions are:$ rbenv install 2.5.0 $ rbenv install 2.6.0-dev $ RUBY_CONFIGURE_OPT=—disable-install-doc rbenv install 2.4.3 $ rbenv install jruby-9.1.16.0 $ RUBY_CONFIGURE_OPT= rbenv install rbx-3.89
  • 42. git.ruby-lang.org It’s available under the ruby-lang.org now!!! https://git.ruby-lang.org • It’s READONLY • It’s built by cgit web interface, • It’s still experimental status. I’m preparing to it now.
  • 43. What’s issues of migration of Git Toolchain: • Packaging script depends on Subversion repository and API. Issue Tracker: • Redmine on Heroku couldn’t use git repository. Strategy • How migrate git or github from svn (now resolved!)
  • 45. Where do we go from here? 1. We migrate a toolchain like package script to git from svn. 2. We will ship ruby package from git.ruby- lang.org. 3. We will accept write commit on git.ruby- lang.org. 4. We will accept to merge pull-request on GitHub and sync them to git.ruby-lang.org (final goal)
  • 46. Executive Officer CPO(Chief Productivity Officer) Director of Business Process Re-engineering Office at GMO Pepabo, Inc. @pepabo Hiroshi SHIBATA @hsbt https://www.hsbt.org