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
Git and Github
Search
Sponsored
·
Ship Features Fearlessly
Turn features on and off without deploys. Used by thousands of Ruby developers.
→
高見龍
May 08, 2013
Technology
5
630
Git and Github
高見龍
May 08, 2013
Tweet
Share
More Decks by 高見龍
See All by 高見龍
宅宅自以為的浪漫:跟 AI 一起為自己辦的研討會寫一個售票系統
eddie
0
540
自己的售票系統自己做!
eddie
0
540
AI Agent 時代的開發者生存指南
eddie
4
2.6k
print("Hello, World")
eddie
2
620
為你自己學 Python - 冷知識篇
eddie
1
430
為你自己學 Python
eddie
0
720
Generative AI 年會小聚 - AI 教我寫程式
eddie
0
190
讓數據說話:用 Python、Prometheus 和 Grafana 講故事
eddie
0
710
AI 時代的程式語言學習法
eddie
0
230
Other Decks in Technology
See All in Technology
Context Engineeringの取り組み
nutslove
0
310
Tebiki Engineering Team Deck
tebiki
0
24k
Claude_CodeでSEOを最適化する_AI_Ops_Community_Vol.2__マーケティングx_AIはここまで進化した.pdf
riku_423
2
520
Frontier Agents (Kiro autonomous agent / AWS Security Agent / AWS DevOps Agent) の紹介
msysh
3
150
SREじゃなかった僕らがenablingを通じて「SRE実践者」になるまでのリアル / SRE Kaigi 2026
aeonpeople
6
2.2k
AzureでのIaC - Bicep? Terraform? それ早く言ってよ会議
torumakabe
1
460
入社1ヶ月でデータパイプライン講座を作った話
waiwai2111
1
260
10Xにおける品質保証活動の全体像と改善 #no_more_wait_for_test
nihonbuson
PRO
2
220
仕様書駆動AI開発の実践: Issue→Skill→PRテンプレで 再現性を作る
knishioka
2
610
なぜ今、コスト最適化(倹約)が必要なのか? ~AWSでのコスト最適化の進め方「目的編」~
htan
1
110
生成AIを活用した音声文字起こしシステムの2つの構築パターンについて
miu_crescent
PRO
1
150
SREのプラクティスを用いた3領域同時 マネジメントへの挑戦 〜SRE・情シス・セキュリティを統合した チーム運営術〜
coconala_engineer
2
620
Featured
See All Featured
Navigating Team Friction
lara
192
16k
Measuring & Analyzing Core Web Vitals
bluesmoon
9
750
Producing Creativity
orderedlist
PRO
348
40k
The Cost Of JavaScript in 2023
addyosmani
55
9.5k
How Software Deployment tools have changed in the past 20 years
geshan
0
32k
Intergalactic Javascript Robots from Outer Space
tanoku
273
27k
Build your cross-platform service in a week with App Engine
jlugia
234
18k
Deep Space Network (abreviated)
tonyrice
0
47
Introduction to Domain-Driven Design and Collaborative software design
baasie
1
580
Marketing Yourself as an Engineer | Alaka | Gurzu
gurzu
0
130
Fight the Zombie Pattern Library - RWD Summit 2016
marcelosomers
234
17k
BBQ
matthewcrist
89
10k
Transcript
Git and Github eddiekao@NCKU
None
Current Status 80% iOS app, 20% Ruby/Rails
Before we start..
You may create lots of files day by day..
edit them, save, edit them, and save.. x N
Backup?
Ctrl-C + Ctrl-V
"ProjectA" -> "ProjectA20130506" -> "ProjectA20130508-1" -> "ProjectA20130508-2" -> "ProjectA-bak" ->
"ProjectA-forEddie"
backup and sync on LAN
Version Control
Subversion (SVN)
but the problem is..
when network or svn server is down..
Is there any better way..?
Git
What's Git?
Version Control System (VCS)
created by Linus Torvalds for managing Linux kernel source code
in 2005
distributed
remote, and also local
Git
Git != Github
Why version control?
backup just like you can load saving data while playing
RPG game
history and evidence you know whom to blame when something
is going wrong :)
Why Git?
free
fast & smaller footprint
http://git-scm.com/book/en/Getting-Started-Git-Basics some other version control system..
http://git-scm.com/book/en/Getting-Started-Git-Basics git
just snapshots, not differences
local commit and remote push
most of the operations are local
easy to co-work with others
But..
git is easy to use, but hard to master
Install Git
on Mac: > brew install git on Ubuntu or some
linux OS: > sudo apt-get install git-core or > sudo apt-get install git
Exercise: please install git in your machine.
How to Git
configurations
.gitconfig it should locate in your home directory
set your username and email > git config --global user.name
"eddie" > git config --global user.email "
[email protected]
" list all settings > git config --list
make some useful aliases
[alias] co = checkout br = branch aa = add
--all l = "!source ~/.dotfiles/.githelper && pretty_git_log" https://github.com/kaochenlong/eddie-dotfiles
Exercise: 1. set your username and email for git. 2.
edit the ".gitconfig" and add some aliases.
.gitignore https://github.com/github/gitignore
don't be afraid of command line tools
git init
Exercise: please create a new directory and initialize for git
version control.
git clone
git clone git://github.com/kaochenlong/eddie-vim.git
Exercise: please try to copy a project from Github or
somewhere to your local machine.
working, staging, and repository
http://git-scm.com/about/staging-area
git add can add a single file or all modified
files, even a single line.
Exercise: add a new file named "hello.rb" and add to
staging area.
Exercise: after adding "hello.rb" to staging area, then try to
modify it and see what happen?
git status
Exercise: try to check if "hello.rb" is in staging area,
and then remove it from staging area.
git mv
Exercise: add "hello.rb" to staging area, and then rename it
to "world.rb".
git commit
Exercise: just commit it :)
When to make a Commit?!
commit message matters!
amend committed message
git commit --amend
Exercise: you just committed with a rubbish message, pleases amend
it to make sense for your project.
Exercise: in last commit, you forgot to add another file,
but you don't want to commit again just for this single file, please try to commit it with -- amend.
Notice: empty folder won't be committed!
if you still want to commit an empty folder, you
can put an empty “.gitkeep” file in it by convention.
git log
git log --pretty=oneline
git log --pretty=format:"%h %s"
git help log
Exercise: check your commit log
Exercise: read the help manual of “git log”, and make
your prefer log format.
Exercise: modify something in the "world.rb" then commit again.
git rm
Exercise: remove a file and then checkout it back.
git tag
tag is a milestone
Exercise: create a tag for your project
git branch
branching is very cheap
When to make a Branch?!
git checkout
Exercise: 1. create a new branch name "fruit" 2. checkout
to "fruit" branch 3. add a "banana.rb" and commit it
Exercise: please try to list all branches, including local and
remote branches.
Exercise: you accidentally delete the "world.rb" file, please try to
recover it with git commands.
Exercise: you just create a tag name “ncku”, try to
checkout to this tag after several commits.
git merge
conflict?
Exercise: 1. checkout back to "master" branch 2. merge "fruit"
to "master" 3. remove "fruit" branch if you like
git reset soft v.s. hard
Exercise: reset a file to untracked status which you just
added to staging.
Exercise: you just merged a branch, please try reset it
to back to un-merged branch.
git pull
git pull = git fetch + git merge
git push
git push origin ncku-branch
git clean remove untracked files
git stash apply, pop, list, clear
git remote
Reading References
1. Pro Git 2. ihower's blog http://ihower.tw/git/
Git Flow
http://git-scm.com/book/en/Git-Branching-Branching-Workflows
http://nvie.com/posts/a-successful-git-branching-model/
on Mac: > brew install git-flow on Ubuntu or some
linux OS: > sudo apt-get install git-flow https://github.com/nvie/gitflow/wiki/Installation
Exercise: please install git flow in your machine, and initialize
a git flow project.
init a project with git flow > git flow init
Branches Master, Develop, Feature, Release, Hotfix
add a new feature: > git flow feature start my_new_feature
when done with the new feature: > git flow feature finish my_new_feature
Exercise: your boss ask you to add a new feature
which can let user upload their photos, please try to finish this assignment in git flow.
Exercise: your boss find a bug and ask you to
fix it ASAP, please try to do this assignment in git flow.
Github
What's Github?
a git repository server
coders' facebook :)
None
make friends with other awesome coders :)
resume for coders!
Free? Price?
SSH/HTTPS/GIT
How to Github?
Exercise: register a new account on Github
without password?
SSH Key
Exercise: generate a SSH key pair in your local machine
and add the public key to Github
Exercise: create a new repository on Github
git push
Exercise: upload your project to Github
Exercise: 1. clone a project from Github 2. do some
changes 3. commit and push back to Github
Exercise: 1. create a new local branch 2. add some
change and then push this branch to Github
tag won't be pushed to repo by default
push a tag: > git push origin v2.0 push several
tags: > git push origin --tags
Exercise: create some tags for your project and upload them
to Github
git pull
Fork
Pull Request
Exercise: 1. fork a project from your classmate who is
sitting just next to you. 2. add some change and commit. 3. fire a pull request.
Github Pages
host static files for FREE
upload files via git commands
User pages kaochenlong.github.io
Project Pages gh-pages branch
custom domain name
Exercise: 1. create a github page for your account. 2.
set your domain name in CNAME if you have one.
something else?
bitbucket free private repo
git + dropbox
What's inside the .git folder?