What is Git?

28/12/2020
Git

What is Git?

Today most software development projects are collaborative efforts. These projects can have hundreds or thousands of people working on them. So keeping track of changes is a necessity for smoother collaboration. Git is an open-source distributed version control system that keeps track of software assets and helps run more efficient development processes.

What is a Version Control System?

When developers are working on a software, they need to keep track of their changes. A version control system (VCS) remembers the versions of the software as it moves through the various stages of development. Working with a version control system has the following benefits:

  • Long-Term History: Version control systems maintain the history of who, what and when of any modifications to the software code. This history is a valuable resource to find any fault with the software. If there are any problems with the new code, you can always go back to the older versions.
  • Branching and Merging: Most version controls have branching and merging capabilities. So development teams can divide the work into multiple streams and work concurrently on various aspects of the project.
  • Traceability: Version control gives developers a way to easily and reliably trace bugs and problems in a software. It diminishes confusion. It creates an effective and transparent collaboration environment.

Git – The Distributed Version Control

Initially, most version control systems were centralized. In the centralized model, the version control information like authorship, date, time, and modification information would be maintained in a centralized server or database. The problem with this model was that the development teams would be restricted by the power or traffic of the central server. When the central server went down, the whole system would be at a standstill.

In a distributed version control system (DVCS), the version information is maintained with every copy of the code. It allows peer-to-peer sharing. There is no need for a centralized repository (even though it’s possible to set one up).


Short History of Git

Git started in a bit of controversy as an act of revenge. In 2002, Linux community started to use the proprietary distributed version control system BitKeeper for free. But in 2005, the relationship between the Linux community and BitKeeper broke down when the free-use status was revoked. So Linus Torvalds, the creator of Linux, started to develop Git as an open-source product. That year, the first version of Git was released. Today Git is the most popular version control system.

Pros and Cons of Git

Git is a simple and powerful distributed version control system with the following pros and cons:

Pros

Performance: Most development teams move to Git for the performance benefits. Commits, branching and merging is faster in Git than centralized version control systems like CVS, SVN or Perforce. Also, the distributed nature of the software makes it easier for developers to share work peer-to-peer. This process is faster than getting the code from a central server.

Security: The integrity of the code is easier to verify on Git. It uses SHA1 cryptographically secure hashing. The hashes are unique to each modification. If anyone changes a modification, the hashes will not match. This property of Git makes it harder for anyone to sneak in code changes surreptitiously.

Flexibility: Git was designed to adapt to any workflow. Older version control systems are more restrictive. But Git gives your team more leeway. You can even create a centralized workflow or integrate with other version control systems to make your legacy systems work.

Cons

Harder to Learn: Git concepts are not always intuitive. Other version control systems take a more user interface based approach. Git community tends to prefer the command-line. So it’s more challenging for non-technical users to learn.

Nostalgia for Centralized Version Control: Businesses are sometimes hesitant about using Git because there is no centralized control. But if you need a centralized repository, you can always design a workflow to implement it.


Conclusion

Git has risen in popularity due to the value it adds to any development team. Even if you are working alone on a project, having a reliable history can save you a lot of time. Git is a free and helpful tool for any software development project.

Further Study:

Git Website
Git Basics
GitHub – Git Hosting Site
BitBucket – Git Hosting Site

References:

ONET IDC thành lập vào năm 2012, là công ty chuyên nghiệp tại Việt Nam trong lĩnh vực cung cấp dịch vụ Hosting, VPS, máy chủ vật lý, dịch vụ Firewall Anti DDoS, SSL… Với 10 năm xây dựng và phát triển, ứng dụng nhiều công nghệ hiện đại, ONET IDC đã giúp hàng ngàn khách hàng tin tưởng lựa chọn, mang lại sự ổn định tuyệt đối cho website của khách hàng để thúc đẩy việc kinh doanh đạt được hiệu quả và thành công.
Bài viết liên quan

How to Cherry Pick in Git

git cherry pick is a merge feature of Git. But there is a slight difference in git cherry pick and git merge. Also, the...
Git
29/12/2020

SSH Key Setup for GitHub

To understand Github you first need to make sure you are aware of a Git . Git is a open source version control system that...
Git
29/12/2020

Git – Push Changes to Remote Git Branch

In this article, I am going to show you how to push (upload) your local Git repository to a remote Git repository hosted...
Git
29/12/2020