@manhng

Welcome to my blog!

Git Commands That Saved My Life At Least Once

August 13, 2021 14:44

Git Commands That Saved My Life At Least Once (edit)

Usage:

git clean -d -f -f
git checkout dev-feat-01
git pull

git checkout dev
git pull

git merge dev-feat-01 --no-ff

1. Get or set user and email variables

git config user.name
git config user.email
git config --system user.email
git config --global user.email
git config --local user.email

2. How to change the author (email) of one or more commits

git commit --amend --no-edit --author="New Name<new_email@free.com>"
git push --force-with-lease

3. Add new changes to the last commit

git commit --amend

4. Remove a commit from the git log

git reset --hard HEAD^

But let’s say your git log is as below:

* 97c8db67 fix: commit 3 is correct as well
* 69e04606 feat: commit 2 is correct
* 9f130ee1 fix: commit 1 needs to be removed

If you need to remove the 9f130ee1 git-sha (“commit 1 needs to be removed”), you could do the interactive rebase:

git rebase -i HEAD~3

Where 3 is the number of commits that you are going to look for before choosing which you would like to remove. Then a text editor will be open with this content:

pick 9f130ee1 fix: commit 1 needs to be removed
pick 69e04606 fix: commit 2 is correct
pick 97c8db67 fix: commit 3 is correct as well

5. Editing an old commit message

git rebase --interactive HEAD~3

6. How to do a rebase from the default branch

git pull --rebase origin main

This will basically:

  1. undo your local commits
  2. pull commits from the remote
  3. add your local commits back

If there are any git conflicts you will be asked to solve them before you push.

7. Reverting local file back to original version in a different branch

git checkout origin/master FILE_PATH_AND_NAME

8. Reverting/Aborting local commit

git reset HEAD~1 (Windows)

git reset HEAD^ (Unix)

9. Showing file remote history

git diff FILE_COMMIT_HASH FILE_PATH

10. Discarding unnecessary  files

git checkout -- .

11. Reverting local commits

git fetch

git reset --hard origin/REMOTE_BRANCH_NAME
git clean -d -f -f

12. Showing committed files that your will push to the remote

git diff --stat --patch origin REMOTE_BRANCH_NAME
git log --oneline 5a984958..49a7891a

References:

http://tugrulaslan.com/list-of-life-saving-git-commands/

https://betterprogramming.pub/7-git-commands-that-saved-my-life-once-or-forty-two-times-c76cc94244de

Duplicating a repository

July 12, 2021 23:14

Duplicating a repository (edit)

Duplicating a repository - GitHub Docs

git clone --bare "https://github.com/manhng83/AbpFamework.git"

create new repo: AbpFramework

git push --mirror "https://github.com/manhng83/AbpFramework.git"

Git Handbook

March 24, 2021 16:20

Git Handbook (edit)

Advanced Git - @manhng (HAY HAY HAY)

Git Commands - @manhng

Duplicating a repository - @manhng

---- Delete local branch
git branch -d develop-test

---- Delete remote branch
git push origin --delete develop-test

---- Loại bỏ những thay đổi đã được commit của bạn
git reset --hard

git checkout -b develop-new-branch
git add .
git commit -m "Comment"
git push --set-upstream origin develop-new-branch

git checkout -b dev (tạo nhánh mới và chuyển sang nhánh đó)
git checkout -b dev master (tạo nhánh mới từ nhánh gốc master và chuyển sang nhánh vừa tạo đó)
git add . commit -m "Update Login API" (gộp 2 lệnh trên 1 dòng lệnh)
git log --all --oneline (kiểm tra lịch sử commit)

git checkout dev
git merge login (merge fast-forward)

git checkout dev
git merge login --no-ff (merge non fast-forward)

Hotfix

1) Tạo nhánh mới từ nhánh gốc master
git checkout -b fix-xxx master

2) Bạn merge nhánh hotfix vào cả hai branches master và dev, phần sửa lỗi sẽ xuất hiện ở cả hai branches, giúp history không bị rẽ nhánh bất ngờ.

git checkout master
git merge fix-xxx --no-ff

git checkout dev
git merge fix-xxx --no-ff

Cách phân nhánh và chia việc trong nhóm với Git – Ehkoo

Kết luận

Chúng ta có thể tóm tắt bài này lại như sau:

  • Dự án được chia thành nhiều nhánh, bao gồm master, dev và có thể có staging
  • Các nhánh tính năng được chia ra từ dev, phát triển độc lập, được rebase trước khi merge lại vào dev
  • Rebase có thể thay đổi một chút history, hoặc squash lại thành một commit duy nhất
  • Merge có thể là fast-forward hoặc non-fast-forward
  • dev sẽ được merge vào master mỗi khi triển khai. Trường hợp có staging, dev sẽ được merge vào staging, và staging sẽ được merge vào master.
  • Các nhánh hotfix sẽ được chia ra từ master, sau đó merge --no-ff vào master  dev

Dĩ nhiên bài viết này chỉ mang tính tham khảo, vì mỗi team mỗi công ty sẽ có những cách làm riêng.

GIT (Agile)

November 23, 2019 15:23

GIT (edit)

Unable to sync because the current branch does not track a remote branch. Push the branch to sync changes with the remote.

Cannot switch to dev because there are uncommitted changes. Commit or undo your changes before you switch branches. See the Output window for details.

Git

October 5, 2017 17:50

Git Usage (edit)

Add Git Ignore to existing Repository | FreeCode Spot

Trong quá trình làm việc, chúng ta có thể rơi vào trường hợp khi đang thực hiện một công việc dang dở nhưng phải tạm dừng và chuyển qua một nhánh mới để thực hiện tiến trình khác. Nếu chúng ta chỉ muốn lưu lại các thay đổi mà chưa commit thì git stash sẽ giúp bạn.

Bạn đang có vài thay đổi và muốn chuyển qua branch khác, bạn chỉ cần chạy git stash hoặc git stash save.

Lúc này bạn đã có thể chuyển sang branch mới.

Để xem lại cách thay đổi đã được lưu lại, bạn dùng lệnh: git stash list.

Apply thay đổi: git stash apply.

Xoá toàn bộ: git stash clear.

Một số định nghĩa thường gặp khi sử dụng Git. (viblo.asia)

Có 2 lợi ích cơ bản và quan trọng của VCS là:

  • Lưu lại toàn bộ lịch sử thay đổi của phiên bản. Giúp lập trình viên theo dõi và khôi phục dễ dàng sau này.
  • Việc chia sẻ code có thể public cho bất kỳ ai, và cũng có thể để chế độ private cho những người có thẩm quyền được truy cập và tải code về. Giúp việc chia sẻ đơn và dễ dàng với Git.
  • Git hỗ trợ làm việc offline.
  • Hoàn toàn miễn phí.

[Git Là Gì] - Các lệnh cơ bản khi làm việc với Git | Vietnix

Git Cheet Sheets

Bạn không thể nào nhớ được hết các lệnh, lúc này bạn nên sử dụng các Git Cheet Sheets để dễ dàng tìm được lệnh Git bạn cần:

1) Tìm kiếm tên người dùng

git shortlog -s --author="John"

git log --pretty="%an"

2) Hiển thị danh sách tất cả người dùng

git shortlog -sn --all

3) Hiển thị log

git log --pretty=oneline

git log --oneline

git log --oneline --author="John"

git log --author="John"

git log --author="John" --oneline

git log:

  • 1afd158ebdd8c2e3282d8f90fda33775acc8477c
  • 122f3796d1420471aa9f7f30c6db64c5a3f07114
  • fd8c0be685c75b14ebe53e522408c23baa8bbbc4

git show 1afd158ebdd8c2e3282d8f90fda33775acc8477c

git show --name-only 1afd158ebdd8c2e3282d8f90fda33775acc8477c

git log --name-only 1afd158ebdd8c2e3282d8f90fda33775acc8477c

git diff --name-only 1afd158ebdd8c2e3282d8f90fda33775acc8477c..HEAD

4) How do I list all of the files in a commit?

git diff-tree --no-commit-id --name-only -r bd61ad98
git show --pretty="" --name-only bd61ad98
git log -p
git show da475798411a3e2769219b4a7655b6821c4d1901

5) How can I list all commits that changed a specific file?

git log --follow -- filename

6) Hiển thị danh sách tệp thay đổi

git log --author="John" --oneline

  • 44669cc
  • 1afd158
  • ...

git show --name-only 44669cc

  • test.cs
  • text.txt

git-tips/tips: Most commonly used git tips and tricks. (github.com) (HAY HAY HAY HAY HAY)

Syncing a Fork of a GitHub Repository with Upstream | Blog (ardalis.com) (HAY HAY HAY HAY HAY)

Basic Syntax | Markdown Guide

Advanced Git - @manhng (git)

Git Common Line Interface - @manhng (git log, git show, gitk --follow)

Git Commands - @manhng (git)

Git - @manhng (git)

7 Git Commands That Saved My Life Atleast Once | by Lucas Tagliani Aguiar | Aug, 2021 | Better Programming

13 Git Commands Every Developer Must Know (zepel.io)

15 Git Hacks to Save your Life as a Developer | by GitShip | Medium

Life-saving git commands - DEV Community (HAY HAY HAY)

4 Useful Git Commands That Save Time | Codica (HAY HAY HAY)

List of life saving git commands – Tugrul ASLAN

Git stash

git stash save

git stash list

git stash apply

Show all developers and comments of the last N commits

git shortlog -sne

git shortlog --summary --numbered --email

git log

git log -1

git log -5

git show --summary

git show --summary -1

git show --summary -5

git log -n 5 --author=ducnn

git log --oneline -n 5 --author=ducnn

Showing all commits

git rev-list --remotes

git rev-list --all --remotes --pretty

git rev-list --all --pretty=oneline

git log --name-status --oneline

git log origin/master..HEAD

git diff --name-only <SHA, tag start> <SHA, tag end>

git diff --name-only HEAD HEAD~3

git diff origin/master..HEAD

Showing committed files that your will push to the remote

git diff --stat --patch origin dev

Chuyển toàn bộ thay đổi sang nhánh mới

git switch -c <new-branch>
git checkout -b <new-branch>
git add <files>
git commit -m "<Brief description of this commit>"

Bỏ thay đổi đang có

git checkout -f

git clean -d -f -f

git reset --hard
git reset --hard HEAD

Bỏ thay đổi

1) Don't remove staged files

git reset --soft HEAD^

2) Remove staged files

git reset HEAD^

If you want to undo commit and lose all the changes, you can use

git reset --hard HEAD^

Xóa nhánh (delete branch)

// delete branch locally
git branch -d localBranchName

// delete branch remotely
git push origin --delete remoteBranchName

Clone chỉ một branch

git clone git@gitlab.company.vn:adc/company-api.git --branch dev --single-branch company-api

Git - @manhng

Advanced Git - @manhng

Cách phân nhánh và chia việc trong nhóm với Git – Ehkoo

Nhàn hơn cùng git stash! (viblo.asia)

Kết luận

Chúng ta có thể tóm tắt bài này lại như sau:

  • Dự án được chia thành nhiều nhánh, bao gồm master, dev và có thể có staging
  • Các nhánh tính năng được chia ra từ dev, phát triển độc lập, được rebase trước khi merge lại vào dev
  • Rebase có thể thay đổi một chút history, hoặc squash lại thành một commit duy nhất
  • Merge có thể là fast-forward hoặc non-fast-forward
  • dev sẽ được merge vào master mỗi khi triển khai. Trường hợp có staging, dev sẽ được merge vào staging, và staging sẽ được merge vào master.
  • Các nhánh hotfix sẽ được chia ra từ master, sau đó merge --no-ff vào master  dev

Dĩ nhiên bài viết này chỉ mang tính tham khảo, vì mỗi team mỗi công ty sẽ có những cách làm riêng.

Khi bạn muốn bỏ tất cả thay đổi

git checkout -f

git clean -d -f -f

git reset --hard HEAD

Khi bạn gặp tình huống phải lấy lại toàn bộ source của một branch theo một commit xác định

Lý do: Để kiểm tra những thay đổi bạn đã làm ở thời điểm hiện tại so với thời điểm commit xác định ở trên

git checkout -b <new-branch-name> <commit-id-sha>

git checkout -B <new-branch-name> <commit-id-sha>

bitbucket - how to checkout a specific commit from git - Stack Overflow

git checkout 9ce920d
git checkout -B new_branch
git reset 9ce920d

Git - Học nghiêm túc một lần (Phần 1)

https://viblo.asia/p/git-hoc-nghiem-tuc-mot-lan-phan-1-OeVKBo6JZkW

Git - Học nghiêm túc một lần (Phần 2)

https://giaphiep.com/blog/git-hoc-nghiem-tuc-mot-lan-phan-2-25505

Git - Những câu lệnh hữu dụng

https://viblo.asia/p/tap-hop-nhung-cau-lenh-git-huu-dung-dWrvwWr2vw38

Git - Những câu lệnh cơ bản

https://jusfunny.wordpress.com/2016/11/09/cac-lenh-git-co-ban-ma-toi-hay-dung/

Hủy lệnh merge

git merge --abort

git reset --hard HEAD

Các câu lệnh thường dùng

git checkout master
git pull origin master
git merge test
git push origin master

Getting Started

http://rogerdudler.github.io/git-guide/

Chuyển sang nhánh develop và xóa những thay đổi ở nhánh hiện tại

Giả sử bạn đang ở nhánh my_branch và muốn chuyển sang nhánh develop đồng hời không muốn giữ thay đổi ở nhánh hiện tại

git checkout -f develop

Undo a Git merge | Reverting a Git Merge

git reset --hard HEAD~1
git reset --hard ORIG_HEAD
git revert HEAD

Remove file

Use git rm:

git rm file1.txt
git commit -m "remove file1.txt"

But if you want to remove the file only from the Git repository and not remove it from the filesystem, use:

git rm --cached file1.txt
git commit -m "remove file1.txt"

And to push changes to remote repo

git push origin branch_name

Remove directory from git and local

You could checkout 'master' with both directories;

git rm -r one-of-the-directories
git commit -m "Remove duplicated directory"
git push origin <your-git-branch> (typically 'master', but not always)

Remove directory from git but NOT local

As mentioned in the comments, what you usually want to do is remove this directory from git but not delete it entirely from the filesystem (local)

In that case use:

git rm -r --cached myFolder

Getting Started (continue)

git init

git config --list

git config --global core.editor emacs

git config --global merge.tool vimdiff

git config user.name
git config user.email

git config user.name "John Doe"
git config user.email johndoe@example.com

git config --global user.name "John Doe"
git config --global user.email johndoe@example.com

git clone "https://manhnv@git.company.vn/crm/dev.git"

Determine the URL that a local git repository was originally cloned from

git config --get remote.origin.url
git remote show origin

git add -all
git commit -am "<message>"
git push origin master

git reset --hard

git clean -f

git clean -n
Would remove untracked_file

git clean -f
Removing untracked_file

git clean -dn
Would remove untracked_dir/

git clean -df
Removing untracked_dir/

Tham khảohttp://techkids.vn/blog/cac-cau-lenh-git-khong-khong-biet/ 

git checkout develop

git merge ONGAME-134

comment "ONGAME-134…

press I for INSERT

press ESC for exit INSERT

:qw

ghi và thoát

:q!

lưu lại nội dung như cũ

press ENTER

1/ Một số lệnh git sử dụng với Git Bash

Bạn commit gặp lỗi và muốn xem chuyện gì đang xảy ra?

git log --oneline -10 

git reset --soft c66f836

git status

git log --oneline -10

Bạn muốn xem lệnh commit gần nhất?

git show

Bạn muốn xem có bao nhiêu branch và đang ở branch nào?

git branch

Bạn muốn merge code từ nhánh develop vào nhánh master?

git checkout master

git merge develop

git status

git push origin master

2/ Một số lỗi thường gặp với Git

Gặp lỗi git không commit được vì có nhiều tài khoản git trên cùng 1 máy

Cmd > control userpasswords2

Advanced > Manage Passwords > Web Credentials > Remove all credentials related with git, github...

Git

June 7, 2017 15:29

Tham khảo

https://www.visualstudio.com/en-us/docs/git/gitquickstart

Một số chú ý:

1) Checkout new branch

Đôi khi muốn Visual Studio nhìn thấy new branch thì bạn phải vào một branch khác và thực hiện lênh fetch cái branch khác đó thì mới có thể nhìn thấy new branch

2) Stash Save

Trước khi định merge code từ trên origin về với code của bạn, bạn nên lưu lại những thay đổi của bạn bằng Stash Save như hình dưới

3) Merge code

 

4) Commit & Push

GIT

Những câu lệnh thường dùng

git add -all
git commit -am "<message>"
git push origin master

 

git init

 

Nếu bạn sử dụng GitHub và bạn đẩy code lên một repo GitHub được lưu trữ online, thì khi đó bạn sử dụng remote repo (repo từ xa). Tên mặc định cho cái remote repo đó là origin. Nếu bạn clone một project từ GitHub thì tự thân nó đã có origin rồi. Bạn có thể xem URL của remote repo đó bằng câu lệnh git remote -v.

 

git remote -v

 

Nếu bạn muốn tự khởi tạo Git của riêng mình và muốn nó liên kết với GitHub, thì bạn phải tự tạo trên GitHub trước, copy URL của repo, sử dụng lệnh git remote add origin <URL>, thay URL của repo vào “<URL>”. Từ đó, bạn có thể thêm, commit và push đến remote repo của bạn.

git remote -v
git remote add origin <url>
git remote set-url origin <url>

 

Câu lệnh cuối được sử dụng khi bạn cần đổi remote repo. Giả dụ bạn copy một cái repo của người khác và bạn muốn chuyển owner thành tài khoản GitHub của bạn. Thì bạn sử dụng câu lệnh đó.

 

git clone <url>

 

Câu lệnh git branch liệt kê tất cả các branch (nhánh) trong local của bạn.

Nếu bạn muốn tạo một branch mới, bạn có thể sử dụng câu lệnh git branch <tên branch>.

Câu lệnh git checkout <tên branch> sẽ chuyển sang một nhánh đã tồn tại khác.

Bạn cũng có thể sử dụng lệnh git checkout -b <tên branch> để tạo một nhánh và ngay lập tức chuyển sang nhánh đó.

Hầu hết mọi người sử dụng câu lệnh này thay vì dùng tự tạo một branch riêng rồi nhảy sang branch đó.

 

git branch

git branch <name>

git checkout <name>

git checkout -b <name>

 

Nếu bạn đã thực hiện một loạt các thay đổi cho một branch, giả dụ tên branch là “develop”, và bạn muốn hợp nhất branch đó vào branch chính – master của bạn, bạn sử dụng câu lệnh git merge <tên branch>. Bạn sẽ checkout nhánh master, rồi chạy lệnh git merge develop để hợp nhất nhánh develop vào nhánh master.

 

git merge <branch>

 

Nếu bạn làm việc với nhiều người, bạn sẽ gặp trường hợp trên GitHub đã được cập nhật rồi nhưng máy bạn lại không có những thay đổi đó. Khi đó, bạn có thể sử dụng lệnh git pull origin <tên branch> để kéo những thay đổi mới nhất về.

 

git pull origin <branch>

 

Nếu bạn muốn biết những file nào đã bị thay đổi và những file nào được theo dõi, bạn có thể sử dụng lệnh git status. Nếu bạn muốn biết những file đã được thay đổi bao nhiêu, bạn có thể sử dụng lệnh git diff để biết được mỗi file đã thay đổi bao nhiêu dòng code.

 

git status

git diff --stat

 

Tham khảo

http://techkids.vn/blog/cac-cau-lenh-git-khong-khong-biet/

 

 

Categories

Recent posts