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
How GitHub Works
Search
Zach Holman
March 09, 2012
Business
176
220k
How GitHub Works
How GitHub Works.
Hint: it's pretty cool.
Zach Holman
March 09, 2012
Tweet
Share
More Decks by Zach Holman
See All by Zach Holman
Firing People
holman
40
6.4k
Even More Emoji Abuse 🚧🚨
holman
17
10k
Move Fast and Break Nothing
holman
68
180k
The Talk on Talks
holman
66
32k
How GitHub (no longer) Works
holman
310
140k
More Git and GitHub Secrets
holman
183
110k
Keeping People
holman
64
62k
If Only I Knew This Shit in College
holman
98
100k
GitHub: Behind the Feature
holman
41
15k
Other Decks in Business
See All in Business
“難しい”をもっと楽に簡単に♪ 届出ダンジョンからの脱出
tokyo_metropolitan_gov_digital_hr
0
290
IT 未経験者をVue.js で開発できる IT コンサルタントに育てあげる秘訣/ Future's New Employee Training
yut0naga1_fa
0
290
定期券WEB予約システムの導入
tokyo_metropolitan_gov_digital_hr
0
300
東京都ツキノワグマ目撃等情報マップ
tokyo_metropolitan_gov_digital_hr
0
270
株式会社Beer and Tech/HitoHana(ひとはな) 採用資料 2024.11
beerandtech_recruiter
1
460
株式会社kubellストレージ 会社説明資料
kubell_storage
2
240
パーキング・チケット 発給設備のキャッシュレス化
tokyo_metropolitan_gov_digital_hr
0
260
akippa株式会社 - 会社紹介資料
akippa
3
58k
スタートアップのマネージャーに役立つ視座/A useful perspective for startup managers
dskst
6
1.2k
株式会社CINC 会社案内/Company introduction
cinchr
6
45k
ノーコード・ローコストで進めるDX
tokyo_metropolitan_gov_digital_hr
0
380
Recruiting Deck_株式会社HACHI
hachi_hiring
1
530
Featured
See All Featured
The Pragmatic Product Professional
lauravandoore
31
6.3k
Embracing the Ebb and Flow
colly
84
4.5k
Building Applications with DynamoDB
mza
90
6.1k
Build The Right Thing And Hit Your Dates
maggiecrowley
33
2.4k
Making the Leap to Tech Lead
cromwellryan
133
8.9k
Reflections from 52 weeks, 52 projects
jeffersonlam
346
20k
Raft: Consensus for Rubyists
vanstee
136
6.6k
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
232
17k
Fontdeck: Realign not Redesign
paulrobertlloyd
82
5.2k
Automating Front-end Workflow
addyosmani
1366
200k
CoffeeScript is Beautiful & I Never Want to Write Plain JavaScript Again
sstephenson
159
15k
The Success of Rails: Ensuring Growth for the Next 100 Years
eileencodes
44
6.8k
Transcript
HoW WORKS GITHUB
the story begins with
4 FOUNDERS IN A coffee shop
4 FOUNDERS IN A BAR
4 FOUNDERS IN A restaurant
4 FOUNDERS IN A plane
4 FOUNDERS IN A JAIL CELL
4 FOUNDERS IN A SOMEWHERE
None
no office had other jobs
None
this was the start of
distributed happy flexible github was forced to be
turns out, great way to work
this talk is kind of about github
but it’s really about improving your company
@holman
None
works howgithub zachholman.com/posts/how-github-works
BULLSHIT HOURS Are
9 to 5 DOES not wORK W O R K
I N G
crafting code is a hugely creative endeavor
you can’t force creativity to happen between 9 and 5.
the best solutions happen when you’re in the zone
our early birds night owls nine-to-fivers traveling employees international employees
office
embraceflexiBility
90 hours/week and loving it! x
working long hours isn’t a badge of honor ...it’s a
badge of foolishness
all-nighters are a recipe for redoing everything again later
marathon code sessions drain you mentally lead to poor code
quality impact future code
WE LET GITHUbbers work WHEREver AND WHENever THEY WANT TO
WORK
we want to get the best work from our employees
that happens when they are happy, fresh, and creative
FAMILIES
@MADDOX NEW DAD, May 26 @MOJOMBO NEW DAD, SOON @xpaulbettsx
NEW DAD LATE 2012 @bethnewland NEW MOM 2012ish
family github
BE A FAMILY COMPANY
being less hour-centric = more family-friendly
happy families, happy coworkers productive companies happy coworkers,
trust your employees
you hired them, after all
trust employees, help them out, then verify they’re doing the
work.
this requires communication are they committing? are they participating? what’s
their code look like?
bullshit hours w o r r y a b o
u t g o o d w o r k are
BE ASYNCHRONOUS
asynchronous a distributed way of getting things done
attention-aware J geographically-distributed G team-oriented g minimal process \
G @ sanfrancisco S githubhq
G turns out, the world is larger than just san
francisco.
G we want to hire the best S S S
S S S S S S S
G distributed work needs to be a priority for us
G flexible hours help with flexible location T
chat G limit required in-person contact beer:30 facetime recorded talks
summit 2010 G encourage structured team building summit 2011 get
people meeting in real-life! github summit 2012
attention-aware J team-oriented g minimal process \ geographically-distributed G
J we want developers in the zonetm
J minimize distractions the zone is difficult to re-enter
J no technical meetings no standup, daily, or planning meetings
J no in-person distractions instead, ping over chat
J no managers they just distract
J we can work this way because:
J dogfood product company full ownership profitable
J each company is different find out what works best
for yours
G geographically-distributed attention-aware J team-oriented g minimal process \ G
g G [ redacted ] [ redacted ] teams
g G small teams let you move quickly&independently
g G the danger room the serious room the enterprise
room the design room the support room the internal room the native room the (redacted) roo the mobile room the ops room e notices room o 30+rooms:
g G small teams let you focus
G geographically-distributed attention-aware J team-oriented g minimal process \ G
\ how do we actually do all this?
\ plan·build·ship
\ show It as soon as possible chat pull requests
wikis, internal apps make it okay to say “no” plan
\ ideas&projects everyone contributes avoid abandonment see status updates plan
\ build simplebranching master branch pull request
\ simplebranching designer friendly (”Non-technical”) build
\ simplebranching simple rollback partial deploysstaff-only specific servers specific processes
build
\ pull requests are discussions that improve code quality build
\ push branch get feedback make improvements merge branch build
\ asynchronous, non-invasive extremely visible for your org one-click merge
button replaces traditional code review build
\ , superfasttests SHIP
\ , 14000 assertions in 200 seconds build (still not
fast enough)
\ , a slow test is a regression build
you don’t need distractions you don’t need to be in
the same country you really don’t need a lot of process
FOR OPTIMIZE HAPPINESS
2008 2009 2010 2011 May 2012
employees 83 employees who have left 0
a happiness-oriented workplace this requires
LEADS TO UNHAPPINESS AND TO LEAVING EMPLOYEE BURNOUT
EXPLORATION x
FREEDOM )
SELF-DIRECTION X
shared side projects hubot internal apps hardware hacking EXPLORATION x
PLAY
spanish tutoring arduino lessons kindles&ebooks KEEP EVERYONE LEARNING EXPLORATION x
ACCEPTED TO SPEAK AT A CONFERENCE? GITHUB PAYS FOR YOU
AND A TRAVEL BUDDY NETWORKING EXPLORATION x MARKETING FOR GITHUB DRINKUPS, YOUR TALK MEET PEOPLE POTENTIAL HIRES, SOCIALIZING IS FUN
BURNOUT HAPPENS WHEN YOU’RE NOT EXPLORATION x PERSONALLY GROWING
NO SET HOURS ) FREEDOM
NO MANAGERS ) FREEDOM
NO MEETINGS ) FREEDOM
NO NEED TO BE IN OFFICE ) FREEDOM
NO VACATION TRACKING ) FREEDOM
SELF-DIRECTION X WORK ON THINGS THAT INTEREST YOU
SELF-DIRECTION X WE HAVE TEAMS, BUT TEAMS SHOULD BE EASY
TO MOVE BEtweEN
KEEP YOUR EMPLOYEES HAPPY REALLY REALLY REALLY
flexible be
build a company you want to work for
happiness push for
thanks.
zachholman @holman zachholman.com/talks