Git Merge 2016

Watch Live

Git Merge

 2016

A conference for the Git community

Presented by

New World Stages

New York City

April 5th 2016

Watch Live Live Feed

*Tune in starting at 10am EST for the Git Merge live stream

About

Git Merge is the pre-eminent Git-focused conference: a full-day offering technical content, user case studies and training workshops for Git users of all levels.

Git Merge is dedicated to amplifying new voices from the Git community and to showcasing the most thought-provoking projects from contributors, maintainers and community managers around the world. By participating in Git Merge, you’ll be contributing to the most forward-thinking community of developers in the world.

All ticket proceeds are donated directly to the Software Freedom Conservancy.

Watch Live

Speakers

Greg Kroah-Hartman

The Linux Foundation

@gregkh

Greg Kroah-Hartman is a Fellow at the Linux Foundation. He is currently responsible for the stable Linux kernel releases, and is a maintainer of the USB, TTY, and driver core subsystems in the kernel as well as other portions of the codebase that he wishes he could forget about. He is the author of two books about Linux kernel development, both free online, and has written many papers and articles about the Linux kernel.

See Session

Read more about this speaker

Ryan Hodson

CloudFlare

Ryan Hodson is a marketer, writer, and web developer at CloudFlare. He's written extensively about Git on both his own website, RyPress.com, and as a consultant for technology companies including Atlassian and Syncfusion. Ryan is also a Mac app developer and author of comprehensive Objective-C, Cocoa development, and MathML tutorials.

See Session

Read more about this speaker

Sytse 'Sid' Sijbrandij

GitLab

Sid saw the first ruby code in 2007 and loved it, so he learned to program and made this his profession. Previously, he engaged in various businesses, from selling programmable infrared receivers to starting a recreational submarine company. He is always looking to publicly document answers and make processes more efficient.

See Session

Read more about this speaker

Emily Xie

Wayfair

@emilyxxie

Emily Xie is a software engineer on the Devtools team at Wayfair. Outside of work, she teaches women how to code and helps organize the Boston branch of Girl Develop It. Emily currently lives in Cambridge, MA, and enjoys photography, cooking, yoga, and razing villages in Age of Empires II.

See Session

Read more about this speaker

Spencer Krum

IBM

@nibalizer

Spencer Krum (spencerkrum.com) has been sysoping Linux since 2010. He works for IBM contributing upstream to OpenStack and Puppet. Spencer is a core contributor to the OpenStack Infrastructure Project. Spencer coordinates the local DevOps user group in Portland and volunteers for an ops-training program at Portland State University called the Braindump. Spencer is a published author and frequent speaker at technical conferences. Spencer is a maintainer for the voxpupuli effort(voxpupuli.org), which attempts to bring together a network of Puppet developers, modules, and infrastructure. Spencer lives and works in Portland, Oregon where he enjoys cheeseburgers and StarCraft II.

See Session

Read more about this speaker

Lars Schneider

Autodesk

@kit3bus

Lars is the technical lead for Git at Autodesk, working out of Berlin, Germany. His current work involves migrating large codebases to Git and establishing Git workflows within teams. He is a Git contributor, the author of the ShowInGitHub Xcode plugin, and is an avid kiteboarder.

See Session

Read more about this speaker

Patrick Reynolds

GitHub

@p_reynolds

Patrick Reynolds leads the team at GitHub that runs Git as a service. He has been building tools to monitor and troubleshoot distributed applications for more than ten years: first as an academic research project, then as a product at BlueStripe Software, and most recently for internal use at GitHub.

See Session

Read more about this speaker

Juan Pablo Buritica

ride.com

@buritica

Juan Pablo Buritica is the VP of Engineering at ride.com where he leads a distributed team throughout the US and Latin America that is working to reinvent how people commute to work and take 1 million cars of the road. Juan Pablo has built effective software engineering organizations by emphasizing Open Source software values, technical excellence, trust and empathy. He has organized five software engineering conferences, spoken at multiple events, and led the growth of Colombia’s JavaScript community, the largest Spanish-speaking JS community in the world with more than 3,000 members.

See Session

Read more about this speaker

Tim Pettersen

Atlassian

@kannonboy

Tim has been an Atlassian developer for almost a decade spanning the JIRA, Bitbucket Server and Cloud, FishEye, and Crucible teams. He tweets, speaks and blogs about developer workflows, Java, JavaScript, Atlassian's developer tools and all manner of Git arcana.

See Session

Read more about this speaker

Hamid Shojaee

Axosoft

Hamid Shojaee is addicted to the high of making great software. He is founder of two tech companies, Axosoft and Pure Chat, and has been a leader in the Arizona tech community for over 20 years.

See Session

Read more about this speaker

Saeed Noursalehi

Microsoft

Saeed is on the Visual Studio Team Services team at Microsoft, focused on helping some very large teams within Microsoft migrate to Git. Among other things, this means solving some hard scale problems in Git, which is a great source of fun. He also enjoys rock climbing, road biking, and music.

See Session

Read more about this speaker

Charles Bailey

Bloomberg

@hashpling

Charles Bailey is a programmer and Git advocate. He is at home in C++, Bourne shell, Perl, Sinclair BASIC, Python, C, and various assembly languages. He works for Bloomberg in Developer Experience, helping teams implement optimal practices and workflows.

See Session

Read more about this speaker

Emma Jane Hogbin Westby

UN

@emmajanehw

Emma Jane Hogbin Westby is a member of the field information services development team at United Nations Office for the Coordination of Humanitarian Affairs (UN-OCHA) and the author of the O'Reilly titles Git for Teams and Collaborating with Git.

See Session

Read more about this speaker

John Haley

Axosoft

John Haley has been writing software for over 25 years and is currently Product Owner of Axosoft GitKraken. John loves bridging the two worlds of art and science in order to create software that, like a good piece of art, leaves the user feeling an emotional connection to it.

See Session

Read more about this speaker

Main Stage Schedule

9:00AM - 10:00AM Registration & Breakfast
10:00AM - 10:15AM Intro & Welcome
10:15AM - 10:45AM Linux Kernel Development - Going Faster Than You Think
10:45AM - 11:00AM Break
11:00AM - 11:30AM Scaling at GitHub
11:30AM - 12:00PM Adopt Git at Scale (and Stay Sane)
12:00PM - 1:00PM Lunch
1:00PM - 1:30PM Change Needs Management
1:30PM - 2:00PM From CLI to GUI: Overcoming Challenges to Advance Git
2:00PM - 2:15PM Break
2:15PM - 2:45PM Repo-factoring
2:45PM - 3:15PM Tracking Huge Files with Git LFS
3:15PM - 3:30PM Break
3:30PM - 3:40PM Git for Static Websites
3:45PM - 3:55PM 20 Tricks with Git and Shell
4:00PM - 4:10PM Version Controlled CI and CD: Deploying with Git Instead of Scripts
4:15PM - 4:30PM Break
4:30PM - 5:00PM Dissecting Gits Guts
5:00PM - 5:30PM Git Is Taking Over Microsoft
5:30PM - 6:00PM The Coding Chef: Optimizing Tools and Workflows

Training

9:00AM - 10:00AM Registration & Breakfast
10:00AM - 11:30AM Scripting Git
11:30AM - 12:30PM Lunch
12:30PM - 2:00PM Making the Switch to Git LFS
2:00PM - 2:15PM Break
2:15PM - 3:45PM Get out of (Almost) Anything with Git
3:45PM - 4:00PM Break
4:00PM - 5:00PM Mastering Git Imerge

Registration & Breakfast

April 5th 9:00AM - 10:00AM

Grab your badges and some breakfast

Intro & Welcome

April 5th 10:00AM - 10:15AM

Linux Kernel Development - Going Faster Than You Think

April 5th 10:15AM - 10:45AM
Greg Kroah-Hartman
The Linux Foundation

The Linux kernel is the largest collaborative software development project ever. This talk will discuss exactly how Linux is developed, how fast it is happening, and how we all try to stay sane keeping up with it (hint, git is the reason).

Break

April 5th 10:45AM - 11:00AM

Scaling at GitHub

April 5th 11:00AM - 11:30AM
Patrick Reynolds
GitHub

The GitHub Systems team provides Git as a fast and reliable service, both as the backend for GitHub.com the website, and directly to users. To do that, we first make Git itself fast and reliable. But we also must consider Git as a distributed application, at the scale of billions of operations per day. Hear about the challenges that presents, and learn about the bespoke tools GitHub has built to monitor, shape, cache, and replicate transactions in our Git service.

Adopt Git at Scale (and Stay Sane)

April 5th 11:30AM - 12:00PM
Lars Schneider
Autodesk

Git is hard to grasp. This is especially true if you've worked for decades with centralized version control systems such as Perforce, CVS or SVN. This talk is about our journey to on-board 4000+ engineers with 200+ different code bases to Git at Autodesk. Amongst other things I will cover how we manage the Git client setup at that scale as well as our experiences with large Git repositories.

Lunch

April 5th 12:00PM - 1:00PM

Change Needs Management

April 5th 1:00PM - 1:30PM
Emma Jane Hogbin Westby

For over a decade Emma Jane Hogbin Westby has been teaching people how to use version control systems. Most people she's encountered still find Git hard to learn on their own. In this session you will learn why most approaches to teaching Git fail to appropriately address the adult learner, and what you can do to make the on-boarding experience easier for others. She will touch on adult education best practices, and also share the secrets that make it easier for very large (and corporate) teams to transition to Git.

From CLI to GUI: Overcoming Challenges to Advance Git

April 5th 1:30PM - 2:00PM
John Haley & Hamid Shojaee
Axosoft

Git was designed with the command line in mind, but does that hold the application back? John Haley, Product Owner of Axosoft GitKraken and Hamid Shojaee, Founder of Axosoft, argue that the CLI can be complicated and confusing, with a steep learning curve even for developers. That’s why they’ve created a Git client that is not only beautiful and easy-to-use, but actually translates Git concepts into visually understandable processes.

In this talk, they’ll describe the creative (and oftentimes argumentative) process of development. You'll learn how the process of developing and using a GUI can actually strengthen your knowledge of underlying concepts of Git; and how listening to your team and trusting them to experiment produces software that can advance, and ultimately change, the landscape.

Break

April 5th 2:00PM - 2:15PM

Repo-factoring

April 5th 2:15PM - 2:45PM
Charles Bailey
Bloomberg

Analyzing objects, rewriting history and migrating your team to a healthier repository. Many people have heard that Git does not handle large files or binary files very well and that it needs extensions to do things properly. But how true is this, how large is large, and what is special about "binary" files? In this talk I'll show how to use a new option to 'git cat-file' to analyse what is taking up the space in your repository and how effective Git's delta compression is in your repository.

There are many tools and lots of information available on how to rewrite a repository's history, should you decide that this is necessary. I shall demonstrate one way to rewrite history and talk about the merits of a number of the other options including erasing objects, replacing objects and migrating objects to alternative storage, including migrating to a solution such as Git LFS.

Rewriting history is inherently disruptive for shared team repositories but sometimes the cost is worth the benefit. Learn about techniques and tools for letting all team members - especially those less familiar with advanced uses of Git - easily migrate their work in progress to the new history.

Tracking Huge Files with Git LFS

April 5th 2:45PM - 3:15PM
Tim Pettersen
Atlassian

Developers love Git for its raw speed, powerful history traversal, distributed nature, and the fact that it was built by uber developer Linus Torvalds. What we don't love is the fact that, out of the box, Git has somewhat lacking support for tracking large binary files.

Fortunately, developers from GitHub, Atlassian, and Visual Studio Online have teamed up to work on an open source (MIT licensed) project to solve this problem: Git LFS (Large File Support). This means researchers, web designers, game developers, multimedia producers and all other developers who need to work with large data and rich media can move off legacy centralized systems and start using modern version control.

In this session I'll cover the computer science behind Git LFS' internals & architecture, CLI usage and how to build an effective Git LFS workflow for a development team. Attendees will take away an understanding of how Git LFS works under the hood, and some practical advice on using Git LFS with their software projects and teams.

Break

April 5th 3:15PM - 3:30PM

Git for Static Websites

April 5th 3:30PM - 3:40PM
Ryan Hodson
CloudFlare

Streamlining your static website development workflow is easy with Git. Learn the benefits of “going static” for everything from simple Jekyll blogs hosted on GitHub Pages to prime-time commercial marketing websites. We’ll survey the static website landscape, including Jekyll, Gulp, and automated deployment with Git and Heroku. We’ll also explore practical use cases like automatically purging your CDN’s cache with GitHub hooks and containerizing your static site with a backend API.

20 Tricks with Git and Shell

April 5th 3:45PM - 3:55PM
Spencer Krum
IBM

Learn about a number of neat tricks used on the command line to make git experiences more straightforward. Most of these tricks compose the standard unix utilities. Only one or two require any packages outside of the standard set. At least one of these tricks will wow you so much that you’ll add it to your .bashrc on the spot. Discover the patterns used construct these small utilities and you will start creating and using your own.

Version Controlled CI and CD: Deploying with Git Instead of Scripts

April 5th 4:00PM - 4:10PM
Sytse 'Sid' Sijbrandij
GitLab

Now is the time to bring the collaborative DVCS workflow to your deployments. This talk will walk you through the essential steps of making the collaborative DVCS workflow a reality at your company. Then discuss the strategies GitLab utilizes to make the most of this process.

To make the DVCS workflow a reality, teams must have their infrastructure described in the application git repository. The deployment process and all its stages and environments are a critical part of this. Your revision control software should have a container registry and your docker images created per each commit. Finally, updating configuration management cookbooks, manifests, playbook, and modules should not require a script but should be handled directly by the configuration management software.

Break

April 5th 4:15PM - 4:30PM

Dissecting Gits Guts

April 5th 4:30PM - 5:00PM
Emily Xie
Wayfair

In this talk, we’ll explore and use Git’s plumbing commands to dissect what is going on behind the scenes at a low level when you use Git.

We’ll walk through the underlying structures that constitute Git as we go spelunking in the .git folder, and explore its various parts: the objects directory (where we’ll inspect blobs, tree objects, and commit objects and how they relate to one another), the HEAD file, and finally, the refs folder, where we’ll look at heads and remotes. As we examine the general layout, we’ll discuss how Git is essentially structured as a Merkle Tree. Finally, we’ll look at Git’s garbage collection and how it ties into the system’s general structure.

Along the way, we’ll solidify our conceptual understanding of Git, exploring questions such as: How does Git store our information? What is at the heart of a branch? What is actually happening when you do a Git checkout? Or a reset?

Git Is Taking Over Microsoft

April 5th 5:00PM - 5:30PM
Saeed Noursalehi
Microsoft

Microsoft is in the middle of moving the majority of its own product development onto Git. Yes, that Microsoft. From small codebase to large. Over 15k developers are already using Git today, with 10’s of thousands yet to come. The journey to get there has been an interesting one, full of ups and downs. We'll discuss our journey and the challenges along the way, both social and technical.

The Coding Chef: Optimizing Tools and Workflows

April 5th 5:30PM - 6:00PM
Juan Pablo Buritica
ride.com

Public recipes are the original open source, and for hundreds of years cooks have not only shared their source but also built incredible schools in their kitchens. Cooks of all levels face the constant pressure of staying relevant, and just like the best engineers, they do this by doggedly practicing the basics while experimenting on the bleeding edge. In this talk, we’ll learn to stay relevant by looking at the surprising parallels between modern kitchens and effective engineering teams.

Registration & Breakfast

April 5th 9:00AM - 10:00AM

Grab your badges and some breakfast

Scripting Git

April 5th 10:00AM - 11:30AM

This workshop will cover several ways to write Git scripts. We will start by using the command-line client and Git's plumbing commands in shell scripts. Following that, we will demonstrate how to write Git scripts in scripting languages, by using libgit2 and the various bindings to it (the workshop examples will focus on Ruby and Rugged). Attendees should understand the basics of Git internals.

Lunch

April 5th 11:30AM - 12:30PM

Making the Switch to Git LFS

April 5th 12:30PM - 2:00PM

If you're starting a new project, using Git LFS is easy. For existing projects, however, converting a project can present a few challenges. In this workshop, we'll adapt an existing sample project to use Git LFS with Git's filter-branch command as well as the BFG Repo Cleaner. We'll also talk about the implications of these approaches on your project and your collaborators. Attendees should have a general understanding of Git internals and be comfortable working on the command line.

Break

April 5th 2:00PM - 2:15PM

Get out of (Almost) Anything with Git

April 5th 2:15PM - 3:45PM

One of the big advantages of version control is knowing you have a safety net in case anything goes awry. In this workshop, we'll explore common predicaments and discuss how to use the best tool for the job to get out of different those tight spots. While the material we'll cover can help the beginner and the seasoned professional alike, attendees should have a basic working knowledge of Git and be comfortable on the command line.

Break

April 5th 3:45PM - 4:00PM

Mastering Git Imerge

April 5th 4:00PM - 5:00PM

git-imerge reduces the pain of merge conflicts to its unavoidable minimum, by finding and presenting the smallest possible conflicts: those between the changes introduced by one commit from each branch. It lets you interrupt, save, and publish in-progress merges — allowing you to test partially-merged code, or even collaboratively fix conflicts. In addition, it offers a straightforward method for preserving history while rebasing. This workshop will teach you how to use git-imerge to do all of this. It is intended for reasonably experienced users, though it requires no expertise in Git.

Workshops

Git users of all levels are invited to deep-dive into a variety of topics from some of the best Git trainers in the world.

Get out of (almost) Anything with Git

April 5, 2:15PM - 3:45PM

One of the big advantages of version control is knowing you have a safety net in case anything goes awry. In this workshop, we'll explore common predicaments and discuss how to use the best tool for the job to get out of different

Read More

Making the Switch to Git LFS

April 5, 12:30PM - 2:00PM

If you're starting a new project, using Git LFS is easy. For existing projects, however, converting a project can present a few challenges. In this workshop, we'll adapt an existing sample project to use Git LFS with Git's filter-branch command

Read More

Mastering Git Imerge

April 5, 4:00PM - 5:00PM

git-imerge reduces the pain of merge conflicts to its unavoidable minimum, by finding and presenting the smallest possible conflicts: those between the changes introduced by one commit from each branch. It lets you interrupt, save, and publish in-progress merges

Read More

Scripting Git

April 5, 10:00AM - 11:30AM

This workshop will cover several ways to write Git scripts. We will start by using the command-line client and Git's plumbing commands in shell scripts. Following that, we will demonstrate how to write Git scripts in scripting languages, by using

Read More

Getting There

No matter where you're coming from, it's easy to get to Git Merge.

Flag icon

Venue

350 West 50th Street, New York City, NY 10019

Git Merge will be held at New World Stages in New York City. This modern space is in the heart of the theatre district, and has served as the home of Tony Award-winning, Guinness World Record-setting and Pulitzer Prize-earning shows.

New World Stages is just off of Times Square between 8th and 9th Avenues, easily accessed by four major subway lines. Parking is conveniently located on 49th St., 50th St.

Plane icon

Travel & Accommodations

New York City is accessible from several airports: JFK, LGA and EWR. From these airports, you may travel into town via Uber, taxi, shuttle, bus or subway.

Subway Routes
Hotel icon

Hotels

These hotels are within easy walking distance of New World Stages.

Ink48
653 11th Ave
New York, NY 10036

Learn More

CitizenM
218 West 50th Street
New York, NY 10019
Get a 15% discount code

Learn More
Party icon

After Party

SpinNYC - April 5, 2016 - 8:00pm-11:00pm
Sponsored by Gitlab

The Git Merge 2016 Afterparty will be held at SpinNYC, an ping pong club that offers an unusual mix of sport, design and entertainment. With 17 ping pong courts, a special appearance by a world champion player and a light selection of late-night snacks, you won’t want to miss this celebration.

Location

Presented by

Sponsors

A little help from our friends: