- Download and install the git tools.
- Open up a terminal (Linux) or Git Bash (Windows) and configure
git
:
$ git config --global user.name "John Doe"
$ git config --global user.email "[email protected]"
$ git config --global --add alias.lol "log --graph --decorate --pretty=oneline --abbrev-commit --all"
- Create a new project and let
git
know we want to version control it:
$ cd ~
$ git init git-busy
Initialized empty Git repository in ~/git-busy/.git/
$ cd git-busy
- Create a markdown-style README file for our project:
$ echo The git-busy README file > README.md
- View the status of the repository:
$ git status
On branch master
Initial commit
Untracked files:
(use "git add <file>..." to include in what will be committed)
README.md
nothing added to commit but untracked files present (use "git add" to track)
- Add the README.md file to the "stage", sometimes called the "index" to make it tracked:
$ git add README.md
- View the status, notice that the file has been "staged" for commit:
$ git status
On branch master
Initial commit
Changes to be committed:
(use "git rm --cached <file>..." to unstage)
new file: README.md
- Commit the change to your repository:
$ git commit -m "Adding README file"
[master (root-commit) e3ede2c] Adding README file
1 file changed, 1 insertion(+)
create mode 100644 README.md
- See the details of your recent commits:
$ git log
commit e3ede2c3777b811feff99eee4a3a456a5030e340
Author: John Doe <[email protected]>
Date: Fri Feb 12 14:42:31 2016 -0600
Adding README file
Notice the hash code, thats the universal commit ID for that change.
- Make a change to your file, restage it and commit in one step:
$ echo More coming soon... >> README.md
$ git commit -am "Updating README"
[master 5642233] Updating README
1 file changed, 1 insertion(+)
- Now view the log again and observe your new commit at the top:
$ git log
commit 564223329b5c6e38024b978c08beeb8907c40477
Author: John Doe <[email protected]>
Date: Fri Feb 12 14:44:37 2016 -0600
Updating README
commit e3ede2c3777b811feff99eee4a3a456a5030e340
Author: John Doe <[email protected]>
Date: Fri Feb 12 14:42:31 2016 -0600
Adding README file
- Compare the latest commit with the previous one:
$ git diff HEAD^
diff --git a/README.md b/README.md
index 2875116..ea66b35 100644
--- a/README.md
+++ b/README.md
@@ -1 +1,2 @@
The git-busy README file
+More coming soon...
- Check out the previous commit:
$ git checkout HEAD^
Note: checking out 'HEAD^'.
You are in 'detached HEAD' state. You can look around, make experimental
changes and commit them, and you can discard any commits you make in this
state without impacting any branches by performing another checkout.
If you want to create a new branch to retain commits you create, you may
do so (now or later) by using -b with the checkout command again. Example:
git checkout -b <new-branch-name>
HEAD is now at e3ede2c... Adding README file
$ cat README.md
The git-busy README file
- Now switch back to the latest commit:
$ git checkout master
Previous HEAD position was e3ede2c... Adding README file
Switched to branch 'master'
$ cat README.md
The git-busy README file
More coming soon...
- Everything up until this point has been local, but now we want to push it to a remote server. Here, we'll just use a different directory called
remoterepo.git
to emulate the remote server. This would normally be assh
orhttps
URL.
$ git init --bare ~/remoterepo.git
Initialized empty Git repository in ~/remoterepo.git/
$ git remote add origin ~/remoterepo.git
- Now let's view the configured remote repository:
$ git remote -v
origin ~/remoterepo.git (fetch)
origin ~/remoterepo.git (push)
- We'll push our changes to the remote repository so other team members can see them:
$ git push -u origin master
Counting objects: 6, done.
Delta compression using up to 8 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (6/6), 517 bytes | 0 bytes/s, done.
Total 6 (delta 0), reused 0 (delta 0)
To ~/remoterepo.git
* [new branch] master -> master
Branch master set up to track remote branch master from origin.
- Let's clone the repository from the remote URL like a team member would:
$ git clone ~/remoterepo.git ~/another-busy
Cloning into '~/another-busy'...
done.
$ cd ~/another-busy
$ git log
commit 564223329b5c6e38024b978c08beeb8907c40477
Author: John Doe <[email protected]>
Date: Fri Feb 12 14:44:37 2016 -0600
Updating README
commit e3ede2c3777b811feff99eee4a3a456a5030e340
Author: John Doe <[email protected]>
Date: Fri Feb 12 14:42:31 2016 -0600
Adding README file
- Finally, we'll clean up the cloned repository:
$ cd ~/git-busy
$ rm -rf ~/another-busy
- Branches are very light in git and extremely powerful, let's create one for a new feature we're adding:
$ git checkout -b feature_x
- Next, let's take a look at our branches:
$ git branch -avv
Notice that feature_x
has an asterisk next to it since it is our current branch. You'll also see the master
branch which has origin/master
next to the commit message. This means that the master
branch is tracking to the master
branch on the remote server that we named origin
. We're not tracking feature_x
on the remote server.
- Let's add our feature, an html version of the README file:
$ cp README.md README.html
$ git add .
$ git commit -m "Adding the README in html format"
- We decided to make some more changes to the html README:
$ echo "<h1>Welcome</h1>" >> README.html
$ git commit -am "Adding welcome message"
$ git lol
- At this point, we're finished with our feature. We want to make sure we're up to date with the latest from the remote repository so let's make sure our local
master
is up to date:
$ git checkout master
$ git fetch origin
$ git merge origin/master
- We'll merge the local master into our
feature_x
branch before we mergefeature_x
intomaster
so that we can fix any conflicts in ourfeature_x
branch, not inmaster
:
$ git checkout feature_x
$ git merge master
-
Our
feature_x
branch is now up to date with the latest frommaster
so we'll merge it and delete it:$ git checkout master $ git merge feature_x $ git branch -d feature_x
-
Let's review the log:
$ git lol
The feature_x branch is gone and the master branch contains the commit message from our feature branch
- Let's push our changes upstream to the remote repository so others can pull them down
$ git push -u origin master