Git stage là gì

Bạn đang quan tâm về Git là gì và một số cách thức hoạt động của Git mà bạn cần nên biết. Vì đây là một công cụ khá hữu ích trong quá trình làm việc của bạn khi phải sử dụng nhiều với giao diện code. Hãy theo dõi bài viết dưới đây của Vietnix nhé!

Git là một hệ thống quản lý mã nguồn phân tán [Distributed Version Control System – DVCS]. Git cung cấp cho mỗi lập trình viên kho lưu trữ [repository] gọi tắt là Repo là nơi chứa cơ sở dữ liệu [database] tất cả những thông tin cần thiết để duy trì và quản lý các sử đổi và lịch sử của dự án. Git trở thành một trong các phần mềm quản lý mã nguồn phổ biến nhất.

Git là gì?

Git là một hệ thống kiểm soát phiên bản [Version Control System] mã nguồn mở miễn phí. Nó theo dõi các project và file khi chúng thay đổi theo thời gian. Cùng với đó là sự trợ giúp của những người đóng góp khác nhau. Sau khi nắm được định nghĩa Git là gì, dưới đây sẽ giúp bạn hiểu rõ hơn về Version Control System. Cùng tìm hiểu nhé.

Version Control System viết tắt là [VCS]hệ thống kiểm soát các phiên bản phân tán mã nguồn mở. VCS sẽ theo dõi và lưu trữ tất cả các file trong toàn bộ dự án và ghi lại lịch sử thay đổi theo thời gian. Mỗi sự thay đổi sẽ được lưu lại thành một version [phiên bản]. 

Đây là hệ thống giúp các lập trình viên lưu trữ nhiều phiên bản khác nhau trong mã nguồn đã được nhân bản từ kho lưu trữ [repository]. Mỗi thay đổi đổi trên mã nguồn được commit đưa lên server nơi chứa kho chứa chính. 

Mỗi phiên bản sẽ bao bồm các thành phần: nội dung thay đổi, ngày và giờ sửa đổi, tác giả thay đổi, tên phiên bản,… hỗ trợ cho các lập trình viên tiện theo dõi và xem lại các danh sách thay đổi của file theo dòng thời gian.

>> Xem thêm: Gitlab là gì?

Git vốn đã là một [Version Control System -VCS] nên Git cũng sẽ ghi nhớ và lưu lại toàn bộ thay đổi trên source code của bạn. Những thành phần Git có thể ghi lại như: thêm code ở đâu, sửa code ở dòng nào, người thay đổi là ai,… tất cả sẽ được Git ghi lại và lưu trữ nó.

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.

Hầu hết các hệ thống đều lưu trữ thông tin dưới dưới dạng danh sách các thay đổi của file. Ví dụ như các hệ thống: CVS, Subversion, Perforce,…

Git coi các thông tin lưu trữ thành một tập hợp snapshot [ảnh chụp toàn bộ nội dung của file tại thời điểm đó]. Mỗi khi commit thì Git sẽ chụp và tạo ra một snapshot cùng một tham chiếu tới snapshop đó.

c

Để bắt đầu Git, chuyển đến terminal và chạy lệnh sau trong thư mục dự án của bạn để khởi tạo một thư mục dự án.

git init

Chạy lệnh sau để thêm file cho Git theo dõi. Thao tác này sẽ thêm các file này vào staging area.

git add

Chạy lệnh sau để commit các thay đổi của bạn đối với các file này.

git commit

Và chúng ta có thể push các thay đổi của mình sau khi hoàn tất.

git push

Cùng với việc thực hiện thêm bất kỳ thay đổi nào trong branch master sẽ yêu cầu các thay đổi này phải được commit lại.

Git là hệ thống quản lý mã nguồn theo hướng phân tán nên Git mang lại những lợi thế lớn trong việc hỗ trợ teamwork, phân chia task và tổng hợp code dễ dàng hơn.

Bạn có thể tập trung xử lý từng task mà không phải bận tâm đến các task liên quan. Mà không phải giẫm chân nhau, làm cho các task không kịp deadline. Khi sử dụng Git thì bạn hoàn toàn có thể kiểm soát và phân chia các task hiệu quả hơn.

Như đã đề cập ở trên, thì khi sử dụng Git nó mang lại cho việc phân chia và sắp xếp các task dễ dàng. Vì vây, bạn cũng có thể dễ dàng thực hiện nhiều task cùng một lúc đơn giản hơn.

Bạn có thể thử nghiệm nhiều tính năng mới và được tách biệt ra khỏi dự án chính. Điều này, giúp bạn có thể thử nghiệm nhiều ý tưởng sáng tạo và cũng là để kiểm tra cho dự án một cách chỉnh chu hơn. Nâng cao được chất lượng code cho dự án chính.

Git được đánh giá rất cao trong nghanh, bạn nên tìm hiểu về Git là gì? Cũng như cách sử dụng nó để đem lại hiệu quả cao trong công việc của mình.

Git ngày càng ưu việt hơn so với hệ thống quản lý phiên bản tập trung [SVN]. Git có thể cho phép bạn làm việc offline trong một khoảng thời gian. Bạn chỉ cần kết nối Internet khi làm việc nhóm, hoặc lưu lịch sử commit code lên remote repos. Còn SVN khi sử dụng bạn cần kết nối đến máy chủ SVN.

Git lưu trữ thông tin mà bạn có thể sử dụng nhiều điều thú vị để viết lại lịch sử commit. Khi tách nhánh, Git sử dụng 41 bytes cho một nhánh mới, giúp tiết kiệm không gian lưu trữ mà vẫn đảm bảo tốt nhu cầu làm việc. Thường SVN sẽ copy toàn bộ source code thành một bản mới khi tách nhóm.

Ngoài những tính năng ở trên, thì Git sử dụng phổ biến cũng vì là Git miễn phí. Tất cả mọi người đều có thể sử dụng những chức năng cơ bản của Git mà không cần bất kì cơ sở hạ tầng server nào.

Khi sử dụng Git bạn nên lưu ý là dùng Git giúp bạn quản lý mã nguồn mà không thể chỉnh code trong Git. Bạn có thể thực hiện các công việc của mình trên môi trường làm việc với các chức năng tiện ích trên IDE của ngôn ngữ lập trình khác. Quy trình xử lý công việc trên Git sẽ như sau:

Quy trình xử lý các công việc của Git

Git là gì? Chắc bạn cũng có thể nắm qua. Thì thường các lập trình viên sẽ làm các dự ấn song song, nên sử Git là cần thiết để đảm bảo việc quản lý và không bị xung đột code giữa các thành viên khác. Và trong các dự án cũng thay đổi thường xuyên, vì vậy nên một hệ thống kiểm soát phiên bản cho phép các nhà phát triển có thể quay lại khôi phục các thay đổi trước đó.

  • Dễ sử dụng, thao tác dễ dàng và đơn giản, đảm bảo an toàn.
  • Dễ phân nhánh các branch, có thể giúp quy trình làm việc đucợ hiệu quả hơn.
  • Bạn có thể clone mã nguồn từ kho lưu trữ hoặc có thể clone một flie thay đổi nào đó, hay các nhánh nào đó.
  • Deloyment sản phẩm của bạn một cách dễ dàng.

Kho lưu trữ [thường được gọi là repo] là một tập hợp các mã nguồn. Repo chứa các commit của dự án hoặc một tập hợp các tham chiếu đến các commit [ví dụ như heads].

Một commit ghi lại một thay đổi hoặc một loạt các thay đổi mà bạn đã thực hiện đối với một file trong repo. Một commit có hash SHA1 duy nhất được sử dụng để theo dõi các file đã thay đổi trong quá khứ. Git History là danh sách một loạt các commit. Sử dụng lệnh commit kết hợp với lệnh git add để cho git biết những thay đổi của bạn và lưu vào kho lưu trữ repositoty.

Một branch về cơ bản là một tập hợp các mã thay đổi duy nhất với một tên duy nhất. Mỗi repo có thể có một hoặc nhiều branch. Branch chính – branch mà tất cả các thay đổi cuối cùng được merge vào – được gọi là branch master. Đây là phiên bản làm việc chính thức cho dự án của bạn và là phiên bản mà bạn sẽ thấy khi truy cập kho dự án tại github.com/yourname/projectname.

Bạn có thể sử dụng lệnh git checkout để chuyển các branch. Bằng cách nhập git checkout sao tên branch mà bạn muốn chuyển đến hoặc nhập git master để trở về branch chính [master branch].

Fork là một bản sao của kho lưu trữ [repository]. Bạn có thể tận dụng các lợi ích của fork để chạy thử nghiệm các thay đổi mà không ảnh hưởng đến kết quả của dự án.

Sử dụng lệnh git fetchđể tìm nạp các bản sao và tải xuống các tệp branch vào máy tính của bạn. Có thể sử dụng nó lưu các thay đổi mới nhất vào repository và có thể tìm nạp branch cùng một lúc.

Head đại diện cho commit mới nhất của repository mà bạn đang làm việc và commit ở đầu của một branch được gọi là head.

Khi sử dụng mà bạn thêm, xóa hoặc thay đổi file thì nó vẫn nằm trong mục index cho đến khi bạn sẵn sàng commit các thay đổi. Bạn dùng lệnh git status để xem nội dung index của bạn.

Lệnh git kết hợp với các yêu cầu kéo [pull request] để thêm các thay đổi từ nhánh này sang nhánh khác.

Là phiên bản mặc định của repository và origin đóng vai trò đặc biệt để liên lạc với nhánh chính. Lệnh git push origin master để đẩy các thay đổi cục bộ đến nhánh chính.

Origin Git

Master là nhánh chính của tất cả các repository, nó bao gồm cả những thay đổi gần đây nhất.

Master

Pull request thể hiện cho banjc ác đề xuất thay đổi trong nhánh chính. Khi bạn làm việc với một nhóm, bạn có thể tạo các pull request để yêu cầu người bảo trì kho lưu trữ xem xét các thay đổi và hợp nhất chúng.

Lệnh git push dùng để cập nhật các nhánh từ xa với những thay đổi mới nhất mà bạn mới commit. 

Remote [kho lưu trữ từ xa] là một bản sao của một chi nhánh. Remote có thể giao tiếp ngược lại với nhánh gốc [origin branch] của chúng và các remote khác trong kho lưu trữ.

git rebase cho phép bạn phân tách, di chuyển và thoát commit. Và cũng có thể sử dụng nó để kết hợp hai nhánh lại với nhau.

Nếu bạn muốn loại bỏ các thay đổi khỏi index của bạn và xáo stashes chúng đi sau thì bạn có thể sử dụng lệnh sau:

git stash

Tiện lợi cho bạn khi bạn muốn tạm dừng công việc hiện tại và làm công việc khác trong một khoảng thời gian. Bạn có thể đặt stash nhiều hơn bộ thay đổi ở cùng một thời điểm.

Đối với tags, thì nó sẽ cung cấp cho bạn một cách để theo dõi commit quan trọng.

Upstream đề cập đến nơi bạn push các thay đổi của mình và thường là các nhánh chính [master branch].

Với mỗi local repo có ba virtual zone khác nhau. Đó là:

  • Working Directory
  • Staging area
  • commit area

Working directory là nơi các file mới được tạo, file cũ bị xóa hoặc nơi thực hiện các thay đổi đối với các file đã có. Sau khi thay đổi được thực hiện, chúng sẽ được thêm vào staging area. Do đó, staging area đôi khi còn được gọi là index.

Sau khi các thay đổi hoàn tất, staging area sẽ chứa một hoặc nhiều file cần được commit. Việc tạo một commit sẽ khiến Git lấy mã mới từ staging area và đưa commit vào repo chính. Sau đó commit này sau đó được chuyển đến commit area.

Local repo

  • Công dụng: Hai cài đặt quan trọng của git là user name và email

Có nhiều cách để để điều chỉnh git config, có thể tùy chỉnh kết quả output màu và thay đổi hành vi git status. Bạn cói thể tìm hiểu git config trong tài liệu Git chính thức.

  • Sử dụng: Khi bạn muốn kiểm tra trên và email trong cấu hình dùng lệnh:
$ git config # Running git config globally $ git config --global user.email "" $ git config --global user.name "Example" # Running git config on the current repository settings $ git config user.email "" $ git config user.name "Example"
  • Công dụng: Dùng để tạo một kho lưu trữ [repository] và 1 dự án [project] mới.
  • Sử dụng: Dùng lệnh git init trong thư mục gốc của dự án.
  • Công dụng: Thêm các file vào stage/index. Một số cách khác có thể sử dụng git add bằng cách thêm toàn bộ thư mục, các file cụ thể.
$ git add # To add all files not staged: $ git add . # To stage a specific file: $ git add index.html # To stage an entire directory: $ git add css
  • Công dụng: Dùng để ghi lại những thay đổi được thực hiện đối với file vào local repository. Để dễ dàng theo dõi commit và mỗi commit sẽ có một mã ID theo dõi duy nhất.
# Adding a commit with message $ git commit -m "Commit message in quotes" $ git commit -m "My first commit message" [SecretTesting 0254c3d] My first commit message 1 file changed, 0 insertions[+], 0 deletions[-] create mode 100644 homepage/index.html
  • Công dụng: Sử dụng lệnh này để trả về trạng thái tại kho lưu trữ [repository]. git status sẽ trả về nhánh làm việc hiện tại của bạn. Nếu một file nằm trong stagging area nhưng không được commit thì nó sẽ hiển thị với git status. Hoặc nếu không có thay đổi nào no sẽ trả về nothing to commit, working directory clean
$ git status # Message when files have not been staged [git add] $ git status On branch SecretTesting Untracked files: [use "git add ..." to include in what will be committed] homepage/index.html # Message when files have been not been committed [git commit] $ git status On branch SecretTesting Your branch is up-to-date with 'origin/SecretTesting'. Changes to be committed: [use "git reset HEAD ..." to unstage] new file: homepage/index.html # Message when all files have been staged and committed $ git status On branch SecretTesting nothing to commit, working directory clean
  • Công dụng: Để xác định nhánh nào trong local repository, thêm hoặc xóa một nhánh mới.
  • Sử dụng:
# Create a new branch $ git branch # List all remote or local branches $ git branch -a # Delete a branch $ git branch -d # Create a new branch $ git branch new_feature # List branches $ git branch -a * SecretTesting new_feature remotes/origin/stable remotes/origin/staging remotes/origin/master -> origin/SecretTesting # Delete a branch $ git branch -d new_feature Deleted branch new_feature [was 0254c3d].
  • Công dụng: Sử dụng git checkoutđể chuyển đổi các chi nhánh.
  • Sử dụng:
# Checkout an existing branch $ git checkout # Checkout and create a new branch with that name $ git checkout -b # Switching to branch 'new_feature' $ git checkout new_feature Switched to branch 'new_feature' # Creating and switching to branch 'staging' $ git checkout -b staging Switched to a new branch 'staging'
  • Công dụng: Hợp nhất các nhánh với nhau, sử dụng git merge để kết hợp các thau đổi từ nhánh này sang nhánh khác.
  • Sử dụng:
# Merge changes into current branch $ git merge # Merge changes into current branch $ git merge new_feature Updating 0254c3d..4c0f37c Fast-forward homepage/index.html | 297 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++ 1 file changed, 297 insertions[+] create mode 100644 homepage/index.html
  • Công dụng: Để kết nối repository với kho lưu trữ từ xa.
  • Sử dụng:
# Add remote repository $ git remote # List named remote repositories $ git remote -v # Adding a remote repository with the name of beanstalk $ git remote add origin :/acccount_name/repository_name.git # List named remote repositories $ git remote -v origin :/acccount_name/repository_name.git [fetch] origin :/acccount_name/repository_name.git [push]
  • Công dụng: Để tạo một bản sao làm việc cục bộ với kho lưu trữ từ xa. Sử dụng git clone để sao chép và tải kho lưu trữ về máy tính. Sao chép giống với Git init khi làm việc với kho lưu trữ từ xa.
  • Sử dụng:
$ git clone $ git clone :/acccount_name/repository_name.git Cloning into 'repository_name'... remote: Counting objects: 5, done. remote: Compressing objects: 100% [3/3], done. remote: Total 5 [delta 0], reused 0 [delta 0] Receiving objects: 100% [5/5], 3.08 KiB | 0 bytes/s, done. Checking connectivity... done.
  • Công dụng: Chạy git pull để tải phiên bản mới nhất của repository. Thao tác với lệnh này kéo các thay đổi từ kho lưu trữ từ xa sang máy tính cục bộ.
  • Sử dụng:
$ git pull # Pull from named remote $ git pull origin staging From account_name.git.beanstalkapp.com:/account_name/repository_name * branch staging -> FETCH_HEAD * [new branch] staging -> origin/staging Already up-to-date. # Pull from URL [not frequently used] $ git pull :/acccount_name/repository_name.git staging From account_name.git.beanstalkapp.com:/account_name/repository_name * branch staging -> FETCH_HEAD * [new branch] staging -> origin/staging Already up-to-date.
  • Công dụng: Dùng để gửi commit đến kho lưu trữ từ xa. git push sử dụng 2 tham số: kho lưu trữ từ xa và nhánh mà push dành cho.
  • Sử dụng:
$ git push # Push all local branches to remote repository $ git push —all # Push a specific branch to a remote with named remote $ git push origin staging Counting objects: 5, done. Delta compression using up to 4 threads. Compressing objects: 100% [3/3], done. Writing objects: 100% [5/5], 734 bytes | 0 bytes/s, done. Total 5 [delta 2], reused 0 [delta 0] To :/acccount_name/repository_name.git ad189cb..0254c3d SecretTesting -> SecretTesting # Push all local branches to remote repository $ git push --all Counting objects: 4, done. Delta compression using up to 4 threads. Compressing objects: 100% [4/4], done. Writing objects: 100% [4/4], 373 bytes | 0 bytes/s, done. Total 4 [delta 2], reused 0 [delta 0] remote: Resolving deltas: 100% [2/2], completed with 2 local objects. To :/acccount_name/repository_name.git 0d56917..948ac97 master -> master ad189cb..0254c3d SecretTesting -> SecretTesting
  • Công dụng: Dùng để lưu các thay đổi được thực hiện nó chưa ở trạng thái commit đến repository.
  • Sử dụng:
# Store current work with untracked files $ git stash -u # Bring stashed work back to the working directory $ git stash pop # Store current work $ git stash -u Saved working directory and index state WIP on SecretTesting: 4c0f37c Adding new file to branch HEAD is now at 4c0f37c Adding new file to branch # Bring stashed work back to the working directory $ git stash pop On branch SecretTesting Your branch and 'origin/SecretTesting' have diverged, and have 1 and 1 different commit each, respectively. [use "git pull" to merge the remote branch into yours] Changes not staged for commit: [use "git add ..." to update what will be committed] [use "git checkout -- ..." to discard changes in working directory] modified: index.html no changes added to commit [use "git add" and/or "git commit -a"] Dropped refs/stash@{0} [3561897724c1f448ae001edf3ef57415778755ec]
  • Công dụng: Để hiển thị lịch sử commit theo thời gian cho một repository.
  • Sử dụng:
# Show entire git log $ git log # Show git log with date pameters $ git log --= # Show git log based on commit author $ git log --="Author Name" # Show entire git log $ git log commit 4c0f37c711623d20fc60b9cbcf393d515945952f Author: Brian Kerr Date: Tue Oct 25 17:46:11 2016 -0500 Updating the wording of the homepage footer commit 0254c3da3add4ebe9d7e1f2e76f015a209e1ef67 Author: Ashley Harpp Date: Wed Oct 19 16:27:27 2016 -0500 My first commit message # Show git log with date pameters $ git log --before="Oct 20" commit 0254c3da3add4ebe9d7e1f2e76f015a209e1ef67 Author: Ashley Harpp Date: Wed Oct 19 16:27:27 2016 -0500 My first commit message # Show git log based on commit author $ git log --author="Brian Kerr" commit 4c0f37c711623d20fc60b9cbcf393d515945952f Author: Brian Kerr Date: Tue Oct 25 17:46:11 2016 -0500 Updating the wording of the homepage footer
  • Công dụng: Xóa file hoặc folder khỏi index [staging area]. Với git rm có hai tùy chọn cần lưu ý: buộc và lưu vào bộ nhớ cache. Lệnh được lưu trong bộ nhớ cache sẽ xóa file và folder khỏi index.
  • Sử dụng:
# To remove a file from the working index [cached]: $ git rm --cached # To delete a file [force]: $ git rm -f # To remove an entire directory from the working index [cached]: $ git rm -r --cached # To delete an entire directory [force]: $ git rm -r -f # To remove a file from the working index: $ git rm --cached css/style.css rm 'css/style.css' # To delete a file [force]: $ git rm -f css/style.css rm 'css/style.css' # To remove an entire directory from the working index [cached]: $ git rm -r --cached css/ rm 'css/style.css' rm 'css/style.min.css' # To delete an entire directory [force]: $ git rm -r -f css/ rm 'css/style.css' rm 'css/style.min.css'

Khi làm việc bạn cũng không thể nào nhớ toàn bộ các lệnh, thì bạn nên sử dụng công cụ hỗ trợ là Git Cheet Sheet để tìm kiếm được lệnh git cần thiết khi làm việc:

Nên tách nhỏ commit và thực hiện commit thường xuyên nhất. Nó có ích cho các thành viên trong nhóm dễ dàng tích hợp công việc với nhau mà không gặp phải xung đột hợp nhất.

Lưu ý không được commit nếu chưa hoàn tất quá trình. Ngoài ra trước khi chia sẻ những thay đổi của bạn với người khác phải được test kĩ càng.

Viết ghi chú khi commit để các thành viên trong nhóm nhận biết được loại thay đổi bạn đã thực hiện.

  • Hãy lưu ý không nên commit nếu chưa hoàn tất process. Bạn nên test các thay đổi của bạn trước khi public.
  • Nên commit thường xuyên bằng cách tách nhỏ từng commit của bạn và commit thường xuyên. Điều này sẽ hỗ trợ cho các thành viên trong nhóm dễ dàng tích hợp các công việc của họ hơn.
  • Viết các ghi chú commit để cho các thành viên khác trong nhóm biết các thay đổi của bạn đã thực hiện. Nếu thực hiện càng cụ thể và chi tiết thì càng tốt.
  • Bạn cần tận dụng các lợi ích của branch để giúp bạn dễ dàng theo dõi các dòng phát triển khác nhau.
  • Bạn cũng nên theo một Git Workflow để đảm bảo sự đồng nhất giữa các thành viên trong nhóm.

>> Xem thêm các bài viết liên quan đến Git:

  • Git Bash là gì.
  • GitHub là gì.
  • GitLab là gì.

Trên đây là bài viết khá đầy đủ và chi tiết để giúp bạn hiểu hơn về Git là gì, cùng một số lệnh mà bạn có thể tham khảo để sử dụng trong quá trình làm việc của mình đạt được hiệu suất cao hơn. Hy vọng bài viết trên của Vietnix sẽ hỗ trợ kiến thức và thông tin hữu ích cho bạn. Chúc các bạn thành công.

Video liên quan

Chủ Đề