Git in real product
Git???
• Git là 1 hệ thống Distributed revision control (Distributed version control or decentralized version control), tạm dịch là hệ thống quản lý source phân tán.
• By Linus Torvalds• Chỉ mất 3s để đồng bộ metadata !!!
History• Bắt đầu được phát triển tháng 03/04/2005• Public 06/04/2005• Self-hosting vào 07/04/2005• Lần merge đầu tiên giữa nhiều branch diễn ra
vào 18/04/2005• Torvals đã đạt được mục tiêu của ông vào
29/04/2005 khi ông thử kiểm với Linux Kernel trong 6.7s
• Release cùng kernel 2.6.12 vào 16/06/2005• Release phiên bản 1.0 vào 21/12/2005
Spec• Strong support for non-linear development: hỗ trợ mạnh mẽ
phát triển không tuyến tính (phát triển song song các chức năng)• Distributed development: Hỗ trợ phát triển và lưu source 1 cách
phân tán giống như Darcs, BitKeeper, Mercurial, SVK, Bazaar and Monotone. Người dùng sẽ có 1 bản copy trên local và sẽ sử dụng nó để phát triển, merger branch,...
• Compatibility with existing systems/protocols: thích ứng được với những hệ thống và giao thức hiện có (HTTP,FTP,rsync,ssh, plain socket,...)
• Efficient handling of large projects: có khả năng quản lý được những project lớn, git hoạt động nhanh, mạnh mẽ, hiệu suất cao.
• Cryptographic authentication of history: xác thực history bằng mật mã.
• Toolkit-based design: git được viết bằng C để nâng cao tốc độ thực thi.
• Pluggable merge strategies: git có 1 model để meger không toàn vẹn và cũng hỗ trợ rất nhiều thuật toán để hoàn thiện quá trình merge, chỉ với trường hợp ko thể meger được thì mới cần người dùng phải tiến hành merge bằng tay.
Mô hình Git
Decentralized but centralized
Git sv SVN
Git sv SVN
• GIT is distributed, SVN is not•GIT stores content as metadata, SVN stores just files
•GIT branches are not the same as SVN branches
•GIT’s content integrity is better than SVN’s: SHA-1
• Using Git in real product
Branch
• Main branches:– master– develop
• Supporting branches– Feature branches– Release branches– Hotfix branches
Main branch
• branch sẽ tồn tại mãi mãi và song song– master: ứng với phiên bản thực
tế của product– develop: ứng với phiên bản
cuối cùng sẵn sàng để release lên phiên bản thực tế
Supporting branches
• Feature branches– branch off từ : develop– merge vào: develop– Quy luật đặt tên: bất kể j trừ master, develop,
release-, hay hotfix-• Release branches
– Được branch off từ:develop– Được merge vào develop và master.– Quy tắc đặt tên: release-*
Supporting branches
• Hotfix branches– Branch off from: master– được merge vào:develop and master– Quy tắc đặt tên:hotfix-*
Supporting branches
Gitlab
• Open source• Git repository management, code reviews,
issue tracking, activity feeds, wikis and continuous integration
• 25,000 users on one server or a highly available active/active cluster
https://about.gitlab.com/downloads/
Ref• Git flow
– https://www.atlassian.com/git/tutorials/comparing-workflows/gitflow-workflow– http://nvie.com/posts/a-successful-git-branching-model/
• Tut– Online Training
• https://try.github.io/levels/1/challenges/1• http://pcottle.github.io/learnGitBranching/
– Other• http://git-scm.com/docs/gittutorial• https://www.atlassian.com/git/tutorials/setting-up-a-repository/git-init