2015-11-01 05:11:09 +01:00
<!DOCTYPE html>
< html lang = "en" xmlns = "http://www.w3.org/1999/html" >
< head >
< meta charset = "utf-8" >
< meta http-equiv = "X-UA-Compatible" content = "IE=edge,chrome=1" >
< title > Tóm tắt Git-Flow< / title >
< link href = 'http://fonts.googleapis.com/css?family=Sansita+One' rel = 'stylesheet' type = 'text/css' >
< link rel = "stylesheet" href = "css/normalize.css" type = "text/css" media = "screen,print" >
< link rel = "stylesheet" href = "css/style.css" type = "text/css" media = "screen,print" >
< script src = "js/jquery-1.7.2.min.js" > < / script >
< script type = "text/javascript" >
var _gaq = _gaq || [];
_gaq.push(['_setAccount', 'UA-33766650-1']);
_gaq.push(['_trackPageview']);
(function () {
var ga = document.createElement('script');
ga.type = 'text/javascript';
ga.async = true;
ga.src = ('https:' == document.location.protocol ? 'https://ssl' : 'http://www') + '.google-analytics.com/ga.js';
var s = document.getElementsByTagName('script')[0];
s.parentNode.insertBefore(ga, s);
})();
< / script >
< / head >
< body >
< div id = "banner" > < a href = "https://github.com/danielkummer/git-flow-cheatsheet" > Fork me on GitHub< / a > < / div >
< header >
< h1 id = "title" > Tóm tắt về Git-Flow< / h1 >
< p id = "author" >
created by < a href = "http://twitter.com/0r1g4m14dd1c7" > Daniel Kummer< / a >
< a href = "https://twitter.com/share" class = "twitter-share-button" data-via = "0r1g4m14dd1c7" data-size = "large" > Tweet< / a >
< script > ! f u n c t i o n ( d , s , i d ) {
var js, fjs = d.getElementsByTagName(s)[0];
if (!d.getElementById(id)) {
js = d.createElement(s);
js.id = id;
js.src = "//platform.twitter.com/widgets.js";
fjs.parentNode.insertBefore(js, fjs);
}
}(document, "script", "twitter-wjs");< / script >
< / p >
< p id = "desc" > efficient branching using git-flow by < a href = "http://nvie.com/" > Vincent Driessen< / a > < / p >
< p id = "translations" > translations:
< a href = "index.html" title = "english" > English< / a > -
< a href = "index.es_ES.html" title = "spanish" > Castellano< / a > -
< a href = "index.pt_BR.html" title = "Brazilian Portugues" > Brazilian Portugues< / a > -
< a href = "index.zh_TW.html" title = "Traditional Chinese" > 繁體中文(Traditional Chinese)< / a > -
< a href = "index.zh_CN.html" title = "Simplified Chinese" > 简体中文(Simplified Chinese)< / a > -
< a href = "index.ja_JP.html" title = "日本語" > 日本語< / a > -
< a href = "index.tr_TR.html" title = "Turkce" > Türkçe< / a > -
< a href = "index.ko_KR.html" title = "한국어" > 한국어(Korean)< / a > -
< a href = "index.fr_FR.html" title = "Français" > Français< / a > -
< a href = "index.it_IT.html" title = "Italiano" > Italiano< / a > -
< a href = "index.nl_NL.html" title = "Nederlands" > Nederlands< / a > -
< a href = "index.ru_RU.html" title = "Russian" > Русский (Russian)< / a > -
< a href = "index.de_DE.html" title = "German" > Deutsch (German)< / a > -
< a href = "index.ca_CA.html" title = "Català" > Català (Catalan)< / a > -
< a href = "index.ro_RO.html" title = "Romanian" > Română (Romanian)< / a > -
< a href = "index.el_GR.html" title = "Ελληνικά (Greek)" > Ελληνικά (Greek)< / a > -
< a href = "index.uk_UK.html" title = "Ukrainian" > Українська (Ukrainian)< / a > -
< a href = "#" class = "active" title = "Tiếng Việt" > Tiếng Việt (Vietnamese)< / a >
< / p >
< / header >
< div id = "main" >
< div class = "scrollblock" >
< h2 > git-flow là gì?< / h2 >
< p >
git-flow là một tập các thao tác mở rộng của git nhằm cung cấp các thao tác repository (kho mã nguồn) ở mức cao dựa trên mô hình phân nhánh của Vincent Driessen.
< small > < a href = "http://nvie.com/posts/a-successful-git-branching-model/" > xem chi tết ở đây< / a > < / small >
< / p >
< p class = "divider" > ★ ★ ★ < / p >
< p > Bản tóm tắt nãy sẽ cho bạn biết cách sử dụng cơ bản và hiệu quả của git-flow.< / p >
< p class = "divider" > ★ ★ ★ < / p >
< / div >
< div class = "scrollblock" >
< h2 > Một vài lời khuyên< / h2 >
< ul >
< li > Git flow cung cấp giao diện trợ giúp và đầu ra rất tuyệt vời. Hãy đọc chúng cẩn thận để xem điều kì diệu gì sẽ xảy ra ;)< / li >
< li > Git Client - < a href = "http://www.sourcetreeapp.com/" > Sourcetree< / a > là một Git Client có giao diện GUI rất tiện lợi và cũng hỗ trợ luôn git-flow trên giao diện.< / li >
< li > Git-flow là một giải pháp dựa trên merge. Nó không rebase các nhánh tính năng.< / li >
< / ul >
< p class = "divider" > ★ ★ ★ < / p >
< / div >
< div class = "scrollblock" >
< h2 > < a name = "setup" href = "#setup" > Cài đặt< / a > < / h2 >
< ul >
< li > Bạn cần cài đặt git trước khi có thể cài git-flow.< / li >
< li > Git flow có thể hoạt động trên OSX, Linux và Windows.< / li >
< / ul >
< p class = "divider" > ★ ★ ★ < / p >
< div class = "col-1" >
< h3 > OSX< / h3 >
< span > Homebrew< / span >
< blockquote >
$ brew install git-flow
< / blockquote >
< span > Macports< / span >
< blockquote >
$ port install git-flow
< / blockquote >
< h3 > Linux< / h3 >
< blockquote >
$ apt-get install git-flow
< / blockquote >
< h3 > Windows (Cygwin)< / h3 >
< blockquote >
$ wget -q -O - --no-check-certificate
https://github.com/nvie/gitflow/raw/develop/contrib/gitflow-installer.sh | bash
< / blockquote >
< p > Bạn cần wget và util-linux để cài đặt git-flow.< / p >
< / div >
< div class = "col-2" >
< p >
Xem chi tiết về cách cài đặt git flow ở trang sau: < a href = "https://github.com/nvie/gitflow/wiki/Windows" > git flow
wiki< / a > .
< / p >
< img src = "img/download.png" alt = "install git-flow" / >
< / div >
< / div >
< div class = "scrollblock" >
< h2 > < a name = "getting_started" href = "#getting_started" > Bắt đầu nào< / a > < / h2 >
< p > Git flow cần phải khởi tạo để có thể tùy chỉnh các cài đặt của dự án của bạn.< / p >
< p class = "divider" > ★ ★ ★ < / p >
< div class = "col-1" >
< h3 > Khởi tạo< / h3 >
< p > Sau khi di chuyển tới thư mục dự án, chạy lệnh sau để khởi tạo git-flow.< / p >
< blockquote >
git flow init
< / blockquote >
< p >
Bạn sẽ cần trả lời một số câu hỏi cho việc thiết lập git-flow sau câu lệnh khởi tạo.
Chúng tôi khuyên bạn nên sử dụng các giá trị [mặc định].
< / p >
< / div >
< div class = "col-2" >
< div class = "initialize" > < / div >
< div class = "lines-small" > < / div >
< div class = "lines-open" > < / div >
< div class = "lines-big" > < / div >
< / div >
< / div >
< div class = "scrollblock" >
< h2 > < a name = "features" href = "#features" > Các tính năng< / a > < / h2 >
< ul class = "narrow" >
< li > Phát triển các tính năng cho việc release sắp tới.< / li >
< li > Về cơ bản chỉ tổ chức ở repos của các lập trình viên.< / li >
< / ul >
< p class = "divider" > ★ ★ ★ < / p >
< div class = "col-1" >
< h3 > Bắt đầu một tính năng< / h3 >
< p > Phát triển tính năng mới bắt đầu từ nhánh phát triển'develop'. Ví dụ với tính năng MYFEATURE:< / p >
< blockquote >
git flow feature start MYFEATURE
< / blockquote >
< p > Lệnh này sẽ tạo ra một nhánh mới dựa trên nhánh 'develop' và chuyển sang nhánh mới này.< / p >
<!--
- Bump the version number now!
- Start committing last-minute fixes in preparing your release
- When done, run:
git flow release finish 'testrelease'
-->
< / div >
< div class = "col-2" >
< div class = "feature-start" > < / div >
< / div >
< / div >
< div class = "scrollblock" >
< div class = "col-1" >
< h3 > Kết thúc một tính năng< / h3 >
< p >
Sau khi phát triển xong một tính năng, lệnh kết thúc tính năng sẽ thực hiện các thao tác:
< / p >
< ul >
< li > Merge nhánh tính năng - MYFEATURE vào nhánh 'develop'< / li >
< li > Xoá nhánh tính năng< / li >
< li > Chuyển sang nhánh 'develop'< / li >
< / ul >
< blockquote >
git flow feature finish MYFEATURE
< / blockquote >
< / div >
< div class = "col-2" >
< div class = "feature-end" > < / div >
< / div >
< / div >
< div class = "scrollblock" >
< div class = "col-1" >
< h3 > Công bố tính năng< / h3 >
< p >
Khi bạn làm việc với những người khác trên cùng một tính năng,
bạn sẽ cần công bố phần mã nguồn của bạn cho tính năng đó lên remote
để những người khác có thể cập nhập được.
< / p >
< blockquote >
git flow feature publish MYFEATURE
< / blockquote >
< / div >
< div class = "col-2" >
< div class = "feature-publish" > < / div >
< / div >
< / div >
< div class = "scrollblock" >
< div class = "col-1" >
< h3 > Lấy về tính năng< / h3 >
< p >
Pull mã nguồn của tính năng được cập nhập bởi những thành viên khác.
< / p >
< blockquote >
2015-11-01 05:47:37 +01:00
git flow feature pull REMOTE_NAME MYFEATURE
2015-11-01 05:11:09 +01:00
< / blockquote >
< / div >
< div class = "col-2" >
< div class = "feature-pull" > < / div >
< / div >
< / div >
< div class = "scrollblock" >
< h2 > < a name = "release" href = "#release" > Tạo một bản release< / a > < / h2 >
< ul >
2015-11-01 05:47:37 +01:00
< li > Hỗ trợ chuẩn bị cho bản release.< / li >
< li > Cho phép sửa các lỗi nhỏ và chuẩn bị meta-data cho release.< / li >
2015-11-01 05:11:09 +01:00
< / ul >
< p class = "divider" > ★ ★ ★ < / p >
< div class = "col-1" >
2015-11-01 05:47:37 +01:00
< h3 > Bắt đầu release< / h3 >
2015-11-01 05:11:09 +01:00
2015-11-01 05:47:37 +01:00
< p > Để bắt đầu release, sử dụng lệnh release của git flow.< / p >
Lệnh này sẽ tạo ra nhánh 'release' từ nhánh 'develop'.
2015-11-01 05:11:09 +01:00
< / p >
< blockquote >
git flow release start RELEASE [BASE]
< / blockquote >
2015-11-01 05:47:37 +01:00
< p > Tùy chọn < code > [BASE]< / code > cho phép commit được một giá trị hash sha-1. Trường hợp không chỉ định tùy chọn này thì HEAD sẽ được sử dụng.< / p >
2015-11-01 05:11:09 +01:00
< p class = "divider" > ★ ★ ★ < / p >
2015-11-01 05:47:37 +01:00
< p > Để công bố phần code 'release' của mình cho các thành viên khác, ta có thể làm tương tự như với công bố tính năng bằng lệnh sau:< / p >
2015-11-01 05:11:09 +01:00
< blockquote >
git flow release publish RELEASE
< / blockquote >
2015-11-01 05:47:37 +01:00
< p > (Bạn có thể theo dấu remote 'release' bằng lệnh < br / > < code > git flow release track RELEASE< / code > )< / p >
2015-11-01 05:11:09 +01:00
< / div >
< div class = "col-2" >
< div class = "release-start" > < / div >
< / div >
< / div >
< div class = "scrollblock" >
< div class = "col-1" >
2015-11-01 05:47:37 +01:00
< h3 > Kết thúc release< / h3 >
2015-11-01 05:11:09 +01:00
2015-11-01 05:47:37 +01:00
< p > Kết thúc release là một bước lớn trong chiến lược phân nhánh git. Nó thực hiện các việc sau:< / p >
2015-11-01 05:11:09 +01:00
< ul >
2015-11-01 05:47:37 +01:00
< li > Merge nhánh 'release' vào nhánh 'master'< / li >
< li > Gắn tag ở nhánh 'master' dành cho bản release< / li >
< li > Merge lại nhánh 'release' vào nhánh 'develop'< / li >
< li > Xóa bỏ nhánh 'release'< / li >
2015-11-01 05:11:09 +01:00
< / ul >
< blockquote >
git flow release finish RELEASE
< / blockquote >
< / div >
< div class = "col-2" >
< div class = "release-end" > < / div >
< / div >
< / div >
< div class = "scrollblock" >
< h2 > < a name = "hotfixes" href = "#hotfixes" > Sửa lỗi nóng< / a > < / h2 >
< ul >
< li > すぐに適用しなければいけないような、緊急の場合に使用します。< / li >
< li > 'master'ブランチのタグから、緊急対応用のブランチを作成します。< / li >
< / ul >
< p class = "divider" > ★ ★ ★ < / p >
< div class = "col-1" >
< h3 > 緊急対応の開始< / h3 >
< p > 他のgit flowコマンドと似た形で、hotfixを開始します< / p >
< blockquote >
git flow hotfix start VERSION [BASENAME]
< / blockquote >
< p > バージョンの引数は、ホットフィックスリリース名を指定します。 オプションとして開始するベースを指定出来ます。< / p >
< p > < / p >
< / div >
< div class = "col-2" >
< div class = "hotfix-start" > < / div >
< / div >
< / div >
< div class = "scrollblock" >
< div class = "col-1" >
< h3 > 緊急対応の終了< / h3 >
< p > 緊急対応の終了作業は、'develop'と'master'のブランチをマージします。加えて、'master'ブランチは緊急対応のタグが付けられます。< / p >
< blockquote >
git flow hotfix finish VERSION
< / blockquote >
< / div >
< div class = "col-2" >
< div class = "hotfix-end" > < / div >
< / div >
< / div >
< div >
< div class = "col-1" > < / div >
< div class = "col-2" >
< div class = "lines-close" > < / div >
< div class = "lines-small-end" > < / div >
< / div >
< / div >
< div class = "scrollblock" >
< h2 > < a name = "commands" href = "#commands" > Các lệnh< / a > < / h2 >
< img src = "img/git-flow-commands.png" alt = "git-flow commands" / >
< / div >
< div class = "scrollblock" >
< h2 > Lưu ý< / h2 >
< p class = "divider" > ★ ★ ★ < / p >
< ul >
< li > コマンドのすべてをカバーしているわけではなく、重要なものだけカバーしています。< / li >
< li > もちろん、gitのコマンドは通常通りすべて使用することができます。git flowは単にgitのコマンドの集合です。 < / li >
< li > 'support'ブランチの機能はまだベータ版です。それについては言及できません。< / li >
< li > もし翻訳して頂けるなら、統合してもらえると幸いです。< / li >
< / ul >
< p class = "divider" > ★ ★ ★ < / p >
< / div >
< / div >
< footer >
< div class = "scrollblock" >
< h2 > < a name = "comments" href = "#comments" > Bình luận< / a > < / h2 >
< div id = "disqus_thread" > < / div >
< / div >
< / footer >
< script type = "text/javascript" >
/* * * CONFIGURATION VARIABLES: EDIT BEFORE PASTING INTO YOUR WEBPAGE * * */
var disqus_shortname = 'gitflowcheatsheet'; // required: replace example with your forum shortname
/* * * DON'T EDIT BELOW THIS LINE * * */
(function () {
var dsq = document.createElement('script');
dsq.type = 'text/javascript';
dsq.async = true;
dsq.src = 'http://' + disqus_shortname + '.disqus.com/embed.js';
(document.getElementsByTagName('head')[0] || document.getElementsByTagName('body')[0]).appendChild(dsq);
})();
< / script >
< noscript > Please enable JavaScript to view the < a href = "http://disqus.com/?ref_noscript" > comments powered by Disqus.< / a >
< / noscript >
< a href = "http://disqus.com" class = "dsq-brlink" > comments powered by < span class = "logo-disqus" > Disqus< / span > < / a >
< / body >
< / html >