久久精品国产精品国产精品污,男人扒开添女人下部免费视频,一级国产69式性姿势免费视频,夜鲁夜鲁很鲁在线视频 视频,欧美丰满少妇一区二区三区,国产偷国产偷亚洲高清人乐享,中文 在线 日韩 亚洲 欧美,熟妇人妻无乱码中文字幕真矢织江,一区二区三区人妻制服国产

歡迎訪問(wèn) 生活随笔!

生活随笔

當(dāng)前位置: 首頁(yè) > 编程资源 > 编程问答 >内容正文

编程问答

git的操作说明超详细

發(fā)布時(shí)間:2025/5/22 编程问答 18 豆豆
生活随笔 收集整理的這篇文章主要介紹了 git的操作说明超详细 小編覺(jué)得挺不錯(cuò)的,現(xiàn)在分享給大家,幫大家做個(gè)參考.

2019獨(dú)角獸企業(yè)重金招聘Python工程師標(biāo)準(zhǔn)>>>

說(shuō)明:

個(gè)人在學(xué)習(xí)Git工作流的過(guò)程中,從原有的 SVN 模式很難完全理解Git的協(xié)作模式,直到有一天我看到了下面的文章,好多遺留在心中的困惑迎刃而解:

  • 我們以使用SVN的工作流來(lái)使用Git有什么不妥?
  • Git方便的branch在哪里,團(tuán)隊(duì)多人如何協(xié)作?沖突了怎么辦?如何進(jìn)行發(fā)布控制?
  • 經(jīng)典的master-發(fā)布、develop-主開發(fā)、hotfix-bug修復(fù)如何避免代碼不經(jīng)過(guò)驗(yàn)證上線?
  • 如何在GitHub上面與他人一起協(xié)作,star-fork-pull request是怎樣的流程?

我個(gè)人很感激這篇文章,所以進(jìn)行了整理,希望能幫到更多的人。整篇文章由?xirong?整理自?oldratlee?的GitHub,方便統(tǒng)一的學(xué)習(xí)回顧,在此感謝下面兩位的貢獻(xiàn)。

原文鏈接:Git Workflows and Tutorials
簡(jiǎn)體中文:由?oldratlee?翻譯在?GitHub?上?Git工作流指南

在第三部分?企業(yè)日常開發(fā)模式探索,xirong 結(jié)合自己所在公司使用git的版本分支開發(fā)過(guò)程,進(jìn)行了總結(jié),歡迎大家提出更好的建議。

在第四部分?開發(fā)工作流的討論?中,引用了幾篇文章,包括 Github 的開發(fā)流程以及 Thoughtworkers 工程師發(fā)表的「Gitflow 有害論」,旨在表名流程并不是唯一的,適合自己當(dāng)前團(tuán)隊(duì)的才是最好的。


?

  • 一、譯序
  • 二、Git工作流指南
    • 2.1 集中式工作流
      • 2.1.1 工作方式
      • 2.1.2 沖突解決
      • 2.1.3 示例
        • 有人先初始化好中央倉(cāng)庫(kù)
        • 所有人克隆中央倉(cāng)庫(kù)
        • 小明開發(fā)功能
        • 小紅開發(fā)功能
        • 小明發(fā)布功能
        • 小紅試著發(fā)布功能
        • 小紅在小明的提交之上rebase
        • 小紅解決合并沖突
        • 小紅成功發(fā)布功能
    • 2.2 功能分支工作流
      • 2.2.1 工作方式
      • 2.2.2 Pull Requests
      • 2.2.3 示例
        • 小紅開始開發(fā)一個(gè)新功能
        • 小紅要去吃個(gè)午飯
        • 小紅完成功能開發(fā)
        • 小黑收到Pull Request
        • 小紅再做修改
        • 小紅發(fā)布她的功能
        • 與此同時(shí),小明在做和小紅一樣的事
    • 2.3 Gitflow工作流
      • 2.3.1 工作方式
      • 2.3.2 歷史分支
      • 2.3.3 功能分支
      • 2.3.4 發(fā)布分支
      • 2.3.5 維護(hù)分支
      • 2.3.6 示例
        • 創(chuàng)建開發(fā)分支
        • 小紅和小明開始開發(fā)新功能
        • 小紅完成功能開發(fā)
        • 小紅開始準(zhǔn)備發(fā)布
        • 小紅完成發(fā)布
        • 最終用戶發(fā)現(xiàn)Bug
    • 2.4 Forking工作流
      • 2.4.1 工作方式
      • 2.4.2 正式倉(cāng)庫(kù)
      • 2.4.3 Forking工作流的分支使用方式
      • 2.4.4 示例
        • 項(xiàng)目維護(hù)者初始化正式倉(cāng)庫(kù)
        • 開發(fā)者fork正式倉(cāng)庫(kù)
        • 開發(fā)者克隆自己fork出來(lái)的倉(cāng)庫(kù)
        • 開發(fā)者開發(fā)自己的功能
        • 開發(fā)者發(fā)布自己的功能
        • 項(xiàng)目維護(hù)者集成開發(fā)者的功能
        • 開發(fā)者和正式倉(cāng)庫(kù)做同步
    • 2.5 Pull Requests
      • 2.5.1 解析Pull Request
      • 2.5.2 工作方式
      • 2.5.3 在功能分支工作流中使用Pull Request
      • 2.5.4 在Gitflow工作流中使用Pull Request
      • 2.5.5 在Forking工作流中使用Pull Request
      • 2.5.6 示例
        • 小紅fork正式項(xiàng)目
        • 小紅克隆她的Bitbucket倉(cāng)庫(kù)
        • 小紅開發(fā)新功能
        • 小紅push功能到她的Bitbucket倉(cāng)庫(kù)中
        • 小紅發(fā)起Pull Request
        • 小明review Pull Request
        • 小紅補(bǔ)加提交
        • 小明接受Pull Request
  • 三、企業(yè)日常開發(fā)模式探索

?

一、譯序

這篇指南以大家在SVN中已經(jīng)廣為熟悉使用的集中式工作流作為起點(diǎn),循序漸進(jìn)地演進(jìn)到其它高效的分布式工作流,還介紹了如何配合使用便利的Pull Request功能,系統(tǒng)地講解了各種工作流的應(yīng)用。 如果你Git用的還不多,可以從前面的講的工作流開始操練。在操作過(guò)程中去感受指南的講解:解決什么問(wèn)題、如何解決問(wèn)題,這樣理解就深了,也方便活用。

行文中實(shí)踐原則和操作示例并重,對(duì)于Git的資深玩家可以梳理思考提升,而新接觸的同學(xué),也可以跟著step-by-step操練學(xué)習(xí)并在實(shí)際工作中上手使用。

工作流其實(shí)不是一個(gè)初級(jí)主題,背后的本質(zhì)問(wèn)題是 有效的項(xiàng)目流程管理 和 高效的開發(fā)協(xié)同約定,而不僅僅是Git或SVN等VCS或SCM工具的使用。

關(guān)于Git工作流主題,網(wǎng)上體系的中文資料不多,主要是零散的操作說(shuō)明,希望這篇文章能讓你更深入理解并在工作中靈活有效地使用起來(lái)。

Gitflow工作流是經(jīng)典模型,處于核心位置,體現(xiàn)了工作流的經(jīng)驗(yàn)和精髓。隨著項(xiàng)目過(guò)程復(fù)雜化,你會(huì)感受到這個(gè)工作流中的深思熟慮和威力!

Forking工作流是分布式協(xié)作的(GitHub風(fēng)格)可以先看看GitHub的Help:Fork A Repo和Using pull requests?。照著操作,給一個(gè)GitHub項(xiàng)目貢獻(xiàn)你的提交,有操作經(jīng)驗(yàn)再看指南容易意會(huì)。指南中給了自己實(shí)現(xiàn)Fork的方法:Fork就是服務(wù)端的克隆。在指南的操練中使用代碼托管服務(wù)(如GitHub、Bitbucket),可以點(diǎn)一下按鈕就讓開發(fā)者完成倉(cāng)庫(kù)的fork操作。

PS

文中Pull Request的介紹用的是Bitbucket代碼托管服務(wù),由于和GitHub基本一樣,如果你用的是GitHub(我自己也主要使用GitHub托管代碼),不影響理解和操作。

PPS

更多Git學(xué)習(xí)資料參見

  • Git的資料整理?by?@xirong
  • 自己整理的分享PPT?Git使用與實(shí)踐?@?個(gè)人整理一些Git

  • ?自己理解粗淺,翻譯中不足和不對(duì)之處,歡迎?
    • 建議,提交Issue
    • 指正,Fork后提通過(guò)Pull Requst貢獻(xiàn)修改
  • 如有文章理解上有疑問(wèn) 或是 使用過(guò)程中碰到些疑惑,請(qǐng)隨時(shí)提交Issue?,一起交流學(xué)習(xí)討論!

二、Git工作流指南

?工作流有各式各樣的用法,但也正因此使得在實(shí)際工作中如何上手使用變得很頭大。這篇指南通過(guò)總覽公司團(tuán)隊(duì)中最常用的幾種Git工作流讓大家可以上手使用。

在閱讀的過(guò)程中請(qǐng)記住,本文中的幾種工作流是作為方案指導(dǎo)而不是條例規(guī)定。在展示了各種工作流可能的用法后,你可以從不同的工作流中挑選或揉合出一個(gè)滿足你自己需求的工作流。

2.1 集中式工作流

如果你的開發(fā)團(tuán)隊(duì)成員已經(jīng)很熟悉Subversion,集中式工作流讓你無(wú)需去適應(yīng)一個(gè)全新流程就可以體驗(yàn)Git帶來(lái)的收益。這個(gè)工作流也可以作為向更Git風(fēng)格工作流遷移的友好過(guò)渡。?

轉(zhuǎn)到分布式版本控制系統(tǒng)看起來(lái)像個(gè)令人生畏的任務(wù),但不改變已用的工作流,你也可以用上Git帶來(lái)的收益。團(tuán)隊(duì)可以用和Subversion完全不變的方式來(lái)開發(fā)項(xiàng)目。

但使用Git加強(qiáng)開發(fā)的工作流,相比SVN,Git有以下兩個(gè)優(yōu)勢(shì): 首先,每個(gè)開發(fā)者可以有屬于自己的整個(gè)工程的本地拷貝。隔離的環(huán)境讓各個(gè)開發(fā)者的工作和項(xiàng)目的其他部分修改獨(dú)立開來(lái) —— 即自由地提交到自己的本地倉(cāng)庫(kù),先完全忽略上游的開發(fā),直到方便的時(shí)候再把修改反饋上去。

其次,Git提供了強(qiáng)壯的分支和合并模型。不像SVN,Git的分支設(shè)計(jì)成可以做為一種用來(lái)在倉(cāng)庫(kù)之間集成代碼和分享修改的『失敗安全』的機(jī)制。

2.1.1 工作方式

像Subversion一樣,集中式工作流以中央倉(cāng)庫(kù)作為項(xiàng)目所有修改的單點(diǎn)實(shí)體。相比SVN缺省的開發(fā)分支trunk,Git叫做master,所有修改提交到這個(gè)分支上。本工作流只用到master這一個(gè)分支。

首先,開發(fā)者克隆中央倉(cāng)庫(kù)。在自己的項(xiàng)目拷貝中,像SVN一樣的編輯文件和提交修改;但修改是存在本地的,和中央倉(cāng)庫(kù)是完全隔離的。開發(fā)者可以把和上游的同步延后到一個(gè)方便時(shí)間點(diǎn)。

然后,開發(fā)者發(fā)布修改到正式項(xiàng)目中,開發(fā)者要把本地master分支的修改『推』到中央倉(cāng)庫(kù)中。這相當(dāng)于svn commit操作,但push操作會(huì)把所有還不在中央倉(cāng)庫(kù)的本地提交都推上去。

2.1.2 沖突解決

中央倉(cāng)庫(kù)代表了正式項(xiàng)目,所以提交歷史應(yīng)該被尊重且是穩(wěn)定不變的。如果開發(fā)者本地的提交歷史和中央倉(cāng)庫(kù)有分歧,Git會(huì)拒絕push提交否則會(huì)覆蓋已經(jīng)在中央庫(kù)的正式提交。

在開發(fā)者提交自己功能修改到中央庫(kù)前,需要先f(wàn)etch在中央庫(kù)的新增提交,rebase自己提交到中央庫(kù)提交歷史之上。 這樣做的意思是在說(shuō),『我要把自己的修改加到別人已經(jīng)完成的修改上。』最終的結(jié)果是一個(gè)完美的線性歷史,就像以前的SVN的工作流中一樣。

如果本地修改和上游提交有沖突,Git會(huì)暫停rebase過(guò)程,給你手動(dòng)解決沖突的機(jī)會(huì)。Git解決合并沖突,用和生成提交一樣的git status和git add命令,很一致方便。還有一點(diǎn),如果解決沖突時(shí)遇到麻煩,Git可以很簡(jiǎn)單中止整個(gè)rebase操作,重來(lái)一次(或者讓別人來(lái)幫助解決)。

2.1.3 示例

讓我們一起逐步分解來(lái)看看一個(gè)常見的小團(tuán)隊(duì)如何用這個(gè)工作流來(lái)協(xié)作的。有兩個(gè)開發(fā)者小明和小紅,看他們是如何開發(fā)自己的功能并提交到中央倉(cāng)庫(kù)上的。

有人先初始化好中央倉(cāng)庫(kù)

第一步,有人在服務(wù)器上創(chuàng)建好中央倉(cāng)庫(kù)。如果是新項(xiàng)目,你可以初始化一個(gè)空倉(cāng)庫(kù);否則你要導(dǎo)入已有的Git或SVN倉(cāng)庫(kù)。

中央倉(cāng)庫(kù)應(yīng)該是個(gè)裸倉(cāng)庫(kù)(bare repository),即沒(méi)有工作目錄(working directory)的倉(cāng)庫(kù)。可以用下面的命令創(chuàng)建:

ssh user@host git init --bare /path/to/repo.git

確保寫上有效的user(SSH的用戶名),host(服務(wù)器的域名或IP地址),/path/to/repo.git(你想存放倉(cāng)庫(kù)的位置)。 注意,為了表示是一個(gè)裸倉(cāng)庫(kù),按照約定加上.git擴(kuò)展名到倉(cāng)庫(kù)名上。

所有人克隆中央倉(cāng)庫(kù)

下一步,各個(gè)開發(fā)者創(chuàng)建整個(gè)項(xiàng)目的本地拷貝。通過(guò)git clone命令完成:

git clone ssh://user@host/path/to/repo.git

基于你后續(xù)會(huì)持續(xù)和克隆的倉(cāng)庫(kù)做交互的假設(shè),克隆倉(cāng)庫(kù)時(shí)Git會(huì)自動(dòng)添加遠(yuǎn)程別名origin指回『父』倉(cāng)庫(kù)。

小明開發(fā)功能

在小明的本地倉(cāng)庫(kù)中,他使用標(biāo)準(zhǔn)的Git過(guò)程開發(fā)功能:編輯、暫存(Stage)和提交。 如果你不熟悉暫存區(qū)(Staging Area),這里說(shuō)明一下:暫存區(qū)用來(lái)準(zhǔn)備一個(gè)提交,但可以不用把工作目錄中所有的修改內(nèi)容都包含進(jìn)來(lái)。 這樣你可以創(chuàng)建一個(gè)高度聚焦的提交,盡管你本地修改很多內(nèi)容。

git status # 查看本地倉(cāng)庫(kù)的修改狀態(tài) git add # 暫存文件 git commit # 提交文件

請(qǐng)記住,因?yàn)檫@些命令生成的是本地提交,小明可以按自己需求反復(fù)操作多次,而不用擔(dān)心中央倉(cāng)庫(kù)上有了什么操作。 對(duì)需要多個(gè)更簡(jiǎn)單更原子分塊的大功能,這個(gè)做法是很有用的。

小紅開發(fā)功能

與此同時(shí),小紅在自己的本地倉(cāng)庫(kù)中用相同的編輯、暫存和提交過(guò)程開發(fā)功能。和小明一樣,她也不關(guān)心中央倉(cāng)庫(kù)有沒(méi)有新提交; 當(dāng)然更不關(guān)心小明在他的本地倉(cāng)庫(kù)中的操作,因?yàn)樗斜镜貍}(cāng)庫(kù)都是私有的。

小明發(fā)布功能

一旦小明完成了他的功能開發(fā),會(huì)發(fā)布他的本地提交到中央倉(cāng)庫(kù)中,這樣其它團(tuán)隊(duì)成員可以看到他的修改。他可以用下面的git push命令:

git push origin master

注意,origin是在小明克隆倉(cāng)庫(kù)時(shí)Git創(chuàng)建的遠(yuǎn)程中央倉(cāng)庫(kù)別名。master參數(shù)告訴Git推送的分支。 由于中央倉(cāng)庫(kù)自從小明克隆以來(lái)還沒(méi)有被更新過(guò),所以push操作不會(huì)有沖突,成功完成。

小紅試著發(fā)布功能

一起來(lái)看看在小明發(fā)布修改后,小紅push修改會(huì)怎么樣?她使用完全一樣的push命令:

git push origin master

但她的本地歷史已經(jīng)和中央倉(cāng)庫(kù)有分岐了,Git拒絕操作并給出下面很長(zhǎng)的出錯(cuò)消息:

error: failed to push some refs to '/path/to/repo.git' hint: Updates were rejected because the tip of your current branch is behind hint: its remote counterpart. Merge the remote changes (e.g. 'git pull') hint: before pushing again. hint: See the 'Note about fast-forwards' in 'git push --help' for details.

這避免了小紅覆寫正式的提交。她要先pull小明的更新到她的本地倉(cāng)庫(kù)合并上她的本地修改后,再重試。

小紅在小明的提交之上rebase

小紅用git pull合并上游的修改到自己的倉(cāng)庫(kù)中。 這條命令類似svn update——拉取所有上游提交命令到小紅的本地倉(cāng)庫(kù),并嘗試和她的本地修改合并:

git pull --rebase origin master

--rebase選項(xiàng)告訴Git把小紅的提交移到同步了中央倉(cāng)庫(kù)修改后的master分支的頂部,如下圖所示:

如果你忘加了這個(gè)選項(xiàng),pull操作仍然可以完成,但每次pull操作要同步中央倉(cāng)庫(kù)中別人修改時(shí),提交歷史會(huì)以一個(gè)多余的『合并提交』結(jié)尾。 對(duì)于集中式工作流,最好是使用rebase而不是生成一個(gè)合并提交。

小紅解決合并沖突

rebase操作過(guò)程是把本地提交一次一個(gè)地遷移到更新了的中央倉(cāng)庫(kù)master分支之上。 這意味著可能要解決在遷移某個(gè)提交時(shí)出現(xiàn)的合并沖突,而不是解決包含了所有提交的大型合并時(shí)所出現(xiàn)的沖突。 這樣的方式讓你盡可能保持每個(gè)提交的聚焦和項(xiàng)目歷史的整潔。反過(guò)來(lái),簡(jiǎn)化了哪里引入Bug的分析,如果有必要,回滾修改也可以做到對(duì)項(xiàng)目影響最小。

如果小紅和小明的功能是不相關(guān)的,不大可能在rebase過(guò)程中有沖突。如果有,Git在合并有沖突的提交處暫停rebase過(guò)程,輸出下面的信息并帶上相關(guān)的指令:

CONFLICT (content): Merge conflict in <some-file>

Git很贊的一點(diǎn)是,任何人可以解決他自己的沖突。在這個(gè)例子中,小紅可以簡(jiǎn)單的運(yùn)行g(shù)it status命令來(lái)查看哪里有問(wèn)題。 沖突文件列在Unmerged paths(未合并路徑)一節(jié)中:

# Unmerged paths: # (use "git reset HEAD <some-file>..." to unstage) # (use "git add/rm <some-file>..." as appropriate to mark resolution) # # both modified: <some-file>

接著小紅編輯這些文件。修改完成后,用老套路暫存這些文件,并讓git rebase完成剩下的事:

git add <some-file> git rebase --continue

要做的就這些了。Git會(huì)繼續(xù)一個(gè)一個(gè)地合并后面的提交,如其它的提交有沖突就重復(fù)這個(gè)過(guò)程。

如果你碰到了沖突,但發(fā)現(xiàn)搞不定,不要驚慌。只要執(zhí)行下面這條命令,就可以回到你執(zhí)行g(shù)it pull --rebase命令前的樣子:

git rebase --abort

小紅成功發(fā)布功能

小紅完成和中央倉(cāng)庫(kù)的同步后,就能成功發(fā)布她的修改了:

git push origin master

如你所見,僅使用幾個(gè)Git命令我們就可以模擬出傳統(tǒng)Subversion開發(fā)環(huán)境。對(duì)于要從SVN遷移過(guò)來(lái)的團(tuán)隊(duì)來(lái)說(shuō)這太好了,但沒(méi)有發(fā)揮出Git分布式本質(zhì)的優(yōu)勢(shì)。

如果你的團(tuán)隊(duì)適應(yīng)了集中式工作流,但想要更流暢的協(xié)作效果,絕對(duì)值得探索一下?功能分支工作流?的收益。 通過(guò)為一個(gè)功能分配一個(gè)專門的分支,能夠做到一個(gè)新增功能集成到正式項(xiàng)目之前對(duì)新功能進(jìn)行深入討論。


2.2 功能分支工作流

功能分支工作流以集中式工作流為基礎(chǔ),不同的是為各個(gè)新功能分配一個(gè)專門的分支來(lái)開發(fā)。這樣可以在把新功能集成到正式項(xiàng)目前,用Pull Requests的方式討論變更。

一旦你玩轉(zhuǎn)了集中式工作流,在開發(fā)過(guò)程中可以很簡(jiǎn)單地加上功能分支,用來(lái)鼓勵(lì)開發(fā)者之間協(xié)作和簡(jiǎn)化交流。

功能分支工作流背后的核心思路是所有的功能開發(fā)應(yīng)該在一個(gè)專門的分支,而不是在master分支上。 這個(gè)隔離可以方便多個(gè)開發(fā)者在各自的功能上開發(fā)而不會(huì)弄亂主干代碼。 另外,也保證了master分支的代碼一定不會(huì)是有問(wèn)題的,極大有利于集成環(huán)境。

功能開發(fā)隔離也讓pull requests工作流成功可能,?pull requests工作流能為每個(gè)分支發(fā)起一個(gè)討論,在分支合入正式項(xiàng)目之前,給其它開發(fā)者有表示贊同的機(jī)會(huì)。 另外,如果你在功能開發(fā)中有問(wèn)題卡住了,可以開一個(gè)pull requests來(lái)向同學(xué)們征求建議。 這些做法的重點(diǎn)就是,pull requests讓團(tuán)隊(duì)成員之間互相評(píng)論工作變成非常方便!

2.2.1 工作方式

功能分支工作流仍然用中央倉(cāng)庫(kù),并且master分支還是代表了正式項(xiàng)目的歷史。 但不是直接提交本地歷史到各自的本地master分支,開發(fā)者每次在開始新功能前先創(chuàng)建一個(gè)新分支。 功能分支應(yīng)該有個(gè)有描述性的名字,比如animated-menu-items或issue-#1061,這樣可以讓分支有個(gè)清楚且高聚焦的用途。

對(duì)于master分支和功能分支,Git是沒(méi)有技術(shù)上的區(qū)別,所以開發(fā)者可以用和集中式工作流中完全一樣的方式編輯、暫存和提交修改到功能分支上。

另外,功能分支也可以(且應(yīng)該)push到中央倉(cāng)庫(kù)中。這樣不修改正式代碼就可以和其它開發(fā)者分享提交的功能。 由于master是僅有的一個(gè)『特殊』分支,在中央倉(cāng)庫(kù)上存多個(gè)功能分支不會(huì)有任何問(wèn)題。當(dāng)然,這樣做也可以很方便地備份各自的本地提交。

2.2.2?Pull Requests

功能分支除了可以隔離功能的開發(fā),也使得通過(guò)Pull Requests討論變更成為可能。 一旦某個(gè)開發(fā)者完成一個(gè)功能,不是立即合并到master,而是push到中央倉(cāng)庫(kù)的功能分支上并發(fā)起一個(gè)Pull Request請(qǐng)求,將修改合并到master。 在修改成為主干代碼前,這讓其它的開發(fā)者有機(jī)會(huì)先去Review變更。

Code Review是Pull Requests的一個(gè)重要的收益,而Pull Requests則是討論代碼的一個(gè)通用方式。 你可以把Pull Requests作為專門給某個(gè)分支的討論。這意味著可以在更早的開發(fā)過(guò)程中就可以進(jìn)行Code Review。 比如,一個(gè)開發(fā)者開發(fā)功能需要幫助時(shí),要做的就是發(fā)起一個(gè)Pull Request,相關(guān)的人就會(huì)自動(dòng)收到通知,在相關(guān)的提交旁邊能看到需要幫助解決的問(wèn)題。

一旦Pull Request被接受了,發(fā)布功能要做的就和集中式工作流就很像了。 首先,確定本地的master分支和上游的master分支是同步的。然后合并功能分支到本地master分支并push已經(jīng)更新的本地master分支到中央倉(cāng)庫(kù)。

倉(cāng)庫(kù)管理的產(chǎn)品解決方案像Bitbucket或Stash,可以良好地支持Pull Requests。可以看看Stash的Pull Requests文檔。

2.2.3 示例

下面的示例演示了如何把Pull Requests作為Code Review的方式,但注意Pull Requests可以用于很多其它的目的。

小紅開始開發(fā)一個(gè)新功能

在開始開發(fā)功能前,小紅需要一個(gè)獨(dú)立的分支。使用下面的命令新建一個(gè)分支:

git checkout -b marys-feature master

這個(gè)命令檢出一個(gè)基于master名為marys-feature的分支,Git的-b選項(xiàng)表示如果分支還不存在則新建分支。 這個(gè)新分支上,小紅按老套路編輯、暫存和提交修改,按需要提交以實(shí)現(xiàn)功能:

git status git add <some-file> git commit

小紅要去吃個(gè)午飯

早上小紅為新功能添加一些提交。 去吃午飯前,push功能分支到中央倉(cāng)庫(kù)是很好的做法,這樣可以方便地備份,如果和其它開發(fā)協(xié)作,也讓他們可以看到小紅的提交。

git push -u origin marys-feature

這條命令push?marys-feature分支到中央倉(cāng)庫(kù)(origin),-u選項(xiàng)設(shè)置本地分支去跟蹤遠(yuǎn)程對(duì)應(yīng)的分支。 設(shè)置好跟蹤的分支后,小紅就可以使用git push命令省去指定推送分支的參數(shù)。

小紅完成功能開發(fā)

小紅吃完午飯回來(lái),完成整個(gè)功能的開發(fā)。在合并到master之前, 她發(fā)起一個(gè)Pull Request讓團(tuán)隊(duì)的其它人知道功能已經(jīng)完成。但首先,她要確認(rèn)中央倉(cāng)庫(kù)中已經(jīng)有她最近的提交:

git push

然后,在她的Git?GUI客戶端中發(fā)起Pull Request,請(qǐng)求合并marys-feature到master,團(tuán)隊(duì)成員會(huì)自動(dòng)收到通知。?Pull Request很酷的是可以在相關(guān)的提交旁邊顯示評(píng)注,所以你可以對(duì)某個(gè)變更集提問(wèn)。

小黑收到Pull Request

小黑收到了Pull Request后會(huì)查看marys-feature的修改。決定在合并到正式項(xiàng)目前是否要做些修改,且通過(guò)Pull Request和小紅來(lái)回地討論。

小紅再做修改

要再做修改,小紅用和功能第一個(gè)迭代完全一樣的過(guò)程。編輯、暫存、提交并push更新到中央倉(cāng)庫(kù)。小紅這些活動(dòng)都會(huì)顯示在Pull Request上,小黑可以斷續(xù)做評(píng)注。

如果小黑有需要,也可以把marys-feature分支拉到本地,自己來(lái)修改,他加的提交也會(huì)一樣顯示在Pull Request上。

小紅發(fā)布她的功能

一旦小黑可以的接受Pull Request,就可以合并功能到穩(wěn)定項(xiàng)目代碼中(可以由小黑或是小紅來(lái)做這個(gè)操作):

git checkout master git pull git pull origin marys-feature git push

無(wú)論誰(shuí)來(lái)做合并,首先要檢出master分支并確認(rèn)是它是最新的。然后執(zhí)行g(shù)it pull origin marys-feature合并marys-feature分支到和已經(jīng)和遠(yuǎn)程一致的本地master分支。 你可以使用簡(jiǎn)單git merge marys-feature命令,但前面的命令可以保證總是最新的新功能分支。 最后更新的master分支要重新push回到origin。

這個(gè)過(guò)程常常會(huì)生成一個(gè)合并提交。有些開發(fā)者喜歡有合并提交,因?yàn)樗褚粋€(gè)新功能和原來(lái)代碼基線的連通符。 但如果你偏愛線性的提交歷史,可以在執(zhí)行合并時(shí)rebase新功能到master分支的頂部,這樣生成一個(gè)快進(jìn)(fast-forward)的合并。

一些GUI客戶端可以只要點(diǎn)一下『接受』按鈕執(zhí)行好上面的命令來(lái)自動(dòng)化Pull Request接受過(guò)程。 如果你的不能這樣,至少在功能合并到master分支后能自動(dòng)關(guān)閉Pull Request。

與此同時(shí),小明在做和小紅一樣的事

當(dāng)小紅和小黑在marys-feature上工作并討論她的Pull Request的時(shí)候,小明在自己的功能分支上做完全一樣的事。

通過(guò)隔離功能到獨(dú)立的分支上,每個(gè)人都可以自主的工作,當(dāng)然必要的時(shí)候在開發(fā)者之間分享變更還是比較繁瑣的。

到了這里,但愿你發(fā)現(xiàn)了功能分支可以很直接地在?集中式工作流?的僅有的master分支上完成多功能的開發(fā)。 另外,功能分支還使用了Pull Request,使得可以在你的版本控制GUI客戶端中討論某個(gè)提交。

功能分支工作流是開發(fā)項(xiàng)目異常靈活的方式。問(wèn)題是,有時(shí)候太靈活了。對(duì)于大型團(tuán)隊(duì),常常需要給不同分支分配一個(gè)更具體的角色。?Gitflow工作流是管理功能開發(fā)、發(fā)布準(zhǔn)備和維護(hù)的常用模式。


2.3?Gitflow工作流

Gitflow工作流通過(guò)為功能開發(fā)、發(fā)布準(zhǔn)備和維護(hù)分配獨(dú)立的分支,讓發(fā)布迭代過(guò)程更流暢。嚴(yán)格的分支模型也為大型項(xiàng)目提供了一些非常必要的結(jié)構(gòu)。

這節(jié)介紹的Gitflow工作流借鑒自在nvie的Vincent Driessen。

Gitflow工作流定義了一個(gè)圍繞項(xiàng)目發(fā)布的嚴(yán)格分支模型。雖然比功能分支工作流復(fù)雜幾分,但提供了用于一個(gè)健壯的用于管理大型項(xiàng)目的框架。

Gitflow工作流沒(méi)有用超出功能分支工作流的概念和命令,而是為不同的分支分配一個(gè)明確的角色,并定義分支之間如何和什么時(shí)候進(jìn)行交互。 除了使用功能分支,在做準(zhǔn)備、維護(hù)和記錄發(fā)布時(shí),也定義了各自的分支。 當(dāng)然你可以用上功能分支工作流所有的好處:Pull Requests、隔離實(shí)驗(yàn)性開發(fā)和更高效的協(xié)作。

2.3.1 工作方式

Gitflow工作流仍然用中央倉(cāng)庫(kù)作為所有開發(fā)者的交互中心。和其它的工作流一樣,開發(fā)者在本地工作并push分支到要中央倉(cāng)庫(kù)中。

2.3.2 歷史分支

相對(duì)于使用僅有的一個(gè)master分支,Gitflow工作流使用兩個(gè)分支來(lái)記錄項(xiàng)目的歷史。master分支存儲(chǔ)了正式發(fā)布的歷史,而develop分支作為功能的集成分支。 這樣也方便master分支上的所有提交分配一個(gè)版本號(hào)。

剩下要說(shuō)明的問(wèn)題圍繞著這2個(gè)分支的區(qū)別展開。

2.3.3 功能分支

每個(gè)新功能位于一個(gè)自己的分支,這樣可以push到中央倉(cāng)庫(kù)以備份和協(xié)作。 但功能分支不是從master分支上拉出新分支,而是使用develop分支作為父分支。當(dāng)新功能完成時(shí),合并回develop分支。 新功能提交應(yīng)該從不直接與master分支交互。

注意,從各種含義和目的上來(lái)看,功能分支加上develop分支就是功能分支工作流的用法。但Gitflow工作流沒(méi)有在這里止步。

2.3.4 發(fā)布分支

一旦develop分支上有了做一次發(fā)布(或者說(shuō)快到了既定的發(fā)布日)的足夠功能,就從develop分支上checkout一個(gè)發(fā)布分支。 新建的分支用于開始發(fā)布循環(huán),所以從這個(gè)時(shí)間點(diǎn)開始之后新的功能不能再加到這個(gè)分支上—— 這個(gè)分支只應(yīng)該做Bug修復(fù)、文檔生成和其它面向發(fā)布任務(wù)。 一旦對(duì)外發(fā)布的工作都完成了,發(fā)布分支合并到master分支并分配一個(gè)版本號(hào)打好Tag。 另外,這些從新建發(fā)布分支以來(lái)的做的修改要合并回develop分支。

使用一個(gè)用于發(fā)布準(zhǔn)備的專門分支,使得一個(gè)團(tuán)隊(duì)可以在完善當(dāng)前的發(fā)布版本的同時(shí),另一個(gè)團(tuán)隊(duì)可以繼續(xù)開發(fā)下個(gè)版本的功能。 這也打造定義良好的開發(fā)階段(比如,可以很輕松地說(shuō),『這周我們要做準(zhǔn)備發(fā)布版本4.0』,并且在倉(cāng)庫(kù)的目錄結(jié)構(gòu)中可以實(shí)際看到)。

常用的分支約定:

用于新建發(fā)布分支的分支: develop 用于合并的分支: master 分支命名: release-* 或 release/*

2.3.5 維護(hù)分支

維護(hù)分支或說(shuō)是熱修復(fù)(hotfix)分支用于給產(chǎn)品發(fā)布版本(production releases)快速生成補(bǔ)丁,這是唯一可以直接從master分支fork出來(lái)的分支。 修復(fù)完成,修改應(yīng)該馬上合并回master分支和develop分支(當(dāng)前的發(fā)布分支),master分支應(yīng)該用新的版本號(hào)打好Tag。

為Bug修復(fù)使用專門分支,讓團(tuán)隊(duì)可以處理掉問(wèn)題而不用打斷其它工作或是等待下一個(gè)發(fā)布循環(huán)。 你可以把維護(hù)分支想成是一個(gè)直接在master分支上處理的臨時(shí)發(fā)布。

2.3.6 示例

下面的示例演示本工作流如何用于管理單個(gè)發(fā)布循環(huán)。假設(shè)你已經(jīng)創(chuàng)建了一個(gè)中央倉(cāng)庫(kù)。

創(chuàng)建開發(fā)分支

第一步為master分支配套一個(gè)develop分支。簡(jiǎn)單來(lái)做可以本地創(chuàng)建一個(gè)空的develop分支,push到服務(wù)器上:

git branch develop git push -u origin develop

以后這個(gè)分支將會(huì)包含了項(xiàng)目的全部歷史,而master分支將只包含了部分歷史。其它開發(fā)者這時(shí)應(yīng)該克隆中央倉(cāng)庫(kù),建好develop分支的跟蹤分支:

git clone ssh://user@host/path/to/repo.git git checkout -b develop origin/develop

現(xiàn)在每個(gè)開發(fā)都有了這些歷史分支的本地拷貝。

小紅和小明開始開發(fā)新功能

這個(gè)示例中,小紅和小明開始各自的功能開發(fā)。他們需要為各自的功能創(chuàng)建相應(yīng)的分支。新分支不是基于master分支,而是應(yīng)該基于develop分支:

git checkout -b some-feature develop

他們用老套路添加提交到各自功能分支上:編輯、暫存、提交:

git status git add <some-file> git commit

小紅完成功能開發(fā)

添加了提交后,小紅覺(jué)得她的功能OK了。如果團(tuán)隊(duì)使用Pull Requests,這時(shí)候可以發(fā)起一個(gè)用于合并到develop分支。 否則她可以直接合并到她本地的develop分支后push到中央倉(cāng)庫(kù):

git pull origin develop git checkout develop git merge some-feature git push git branch -d some-feature

第一條命令在合并功能前確保develop分支是最新的。注意,功能決不應(yīng)該直接合并到master分支。 沖突解決方法和集中式工作流一樣。

小紅開始準(zhǔn)備發(fā)布

這個(gè)時(shí)候小明正在實(shí)現(xiàn)他的功能,小紅開始準(zhǔn)備她的第一個(gè)項(xiàng)目正式發(fā)布。 像功能開發(fā)一樣,她用一個(gè)新的分支來(lái)做發(fā)布準(zhǔn)備。這一步也確定了發(fā)布的版本號(hào):

git checkout -b release-0.1 develop

這個(gè)分支是清理發(fā)布、執(zhí)行所有測(cè)試、更新文檔和其它為下個(gè)發(fā)布做準(zhǔn)備操作的地方,像是一個(gè)專門用于改善發(fā)布的功能分支。

只要小紅創(chuàng)建這個(gè)分支并push到中央倉(cāng)庫(kù),這個(gè)發(fā)布就是功能凍結(jié)的。任何不在develop分支中的新功能都推到下個(gè)發(fā)布循環(huán)中。

小紅完成發(fā)布

一旦準(zhǔn)備好了對(duì)外發(fā)布,小紅合并修改到master分支和develop分支上,刪除發(fā)布分支。合并回develop分支很重要,因?yàn)樵诎l(fā)布分支中已經(jīng)提交的更新需要在后面的新功能中也要是可用的。 另外,如果小紅的團(tuán)隊(duì)要求Code Review,這是一個(gè)發(fā)起Pull Request的理想時(shí)機(jī)。

git checkout master git merge release-0.1 git push git checkout develop git merge release-0.1 git push git branch -d release-0.1

發(fā)布分支是作為功能開發(fā)(develop分支)和對(duì)外發(fā)布(master分支)間的緩沖。只要有合并到master分支,就應(yīng)該打好Tag以方便跟蹤。

git tag -a 0.1 -m "Initial public release" master git push --tags

Git有提供各種勾子(hook),即倉(cāng)庫(kù)有事件發(fā)生時(shí)觸發(fā)執(zhí)行的腳本。 可以配置一個(gè)勾子,在你push中央倉(cāng)庫(kù)的master分支時(shí),自動(dòng)構(gòu)建好版本,并對(duì)外發(fā)布。

最終用戶發(fā)現(xiàn)Bug

對(duì)外版本發(fā)布后,小紅小明一起開發(fā)下一版本的新功能,直到有最終用戶開了一個(gè)Ticket抱怨當(dāng)前版本的一個(gè)Bug。 為了處理Bug,小紅(或小明)從master分支上拉出了一個(gè)維護(hù)分支,提交修改以解決問(wèn)題,然后直接合并回master分支:

git checkout -b issue-#001 master # Fix the bug git checkout master git merge issue-#001 git push

就像發(fā)布分支,維護(hù)分支中新加這些重要修改需要包含到develop分支中,所以小紅要執(zhí)行一個(gè)合并操作。然后就可以安全地刪除這個(gè)分支了:

git checkout develop git merge issue-#001 git push git branch -d issue-#001

到了這里,但愿你對(duì)集中式工作流、功能分支工作流和Gitflow工作流已經(jīng)感覺(jué)很舒適了。 你應(yīng)該也牢固的掌握了本地倉(cāng)庫(kù)的潛能,push/pull模式和Git健壯的分支和合并模型。

記住,這里演示的工作流只是可能用法的例子,而不是在實(shí)際工作中使用Git不可違逆的條例。 所以不要畏懼按自己需要對(duì)工作流的用法做取舍。不變的目標(biāo)就是讓Git為你所用。


2.4?Forking工作流

Forking工作流是分布式工作流,充分利用了Git在分支和克隆上的優(yōu)勢(shì)。可以安全可靠地管理大團(tuán)隊(duì)的開發(fā)者(developer),并能接受不信任貢獻(xiàn)者(contributor)的提交。

Forking工作流和前面討論的幾種工作流有根本的不同,這種工作流不是使用單個(gè)服務(wù)端倉(cāng)庫(kù)作為『中央』代碼基線,而讓各個(gè)開發(fā)者都有一個(gè)服務(wù)端倉(cāng)庫(kù)。這意味著各個(gè)代碼貢獻(xiàn)者有2個(gè)Git倉(cāng)庫(kù)而不是1個(gè):一個(gè)本地私有的,另一個(gè)服務(wù)端公開的。

Forking工作流的一個(gè)主要優(yōu)勢(shì)是,貢獻(xiàn)的代碼可以被集成,而不需要所有人都能push代碼到僅有的中央倉(cāng)庫(kù)中。 開發(fā)者push到自己的服務(wù)端倉(cāng)庫(kù),而只有項(xiàng)目維護(hù)者才能push到正式倉(cāng)庫(kù)。 這樣項(xiàng)目維護(hù)者可以接受任何開發(fā)者的提交,但無(wú)需給他正式代碼庫(kù)的寫權(quán)限。

效果就是一個(gè)分布式的工作流,能為大型、自發(fā)性的團(tuán)隊(duì)(包括了不受信的第三方)提供靈活的方式來(lái)安全的協(xié)作。 也讓這個(gè)工作流成為開源項(xiàng)目的理想工作流。

2.4.1 工作方式

和其它的Git工作流一樣,Forking工作流要先有一個(gè)公開的正式倉(cāng)庫(kù)存儲(chǔ)在服務(wù)器上。 但一個(gè)新的開發(fā)者想要在項(xiàng)目上工作時(shí),不是直接從正式倉(cāng)庫(kù)克隆,而是fork正式項(xiàng)目在服務(wù)器上創(chuàng)建一個(gè)拷貝。

這個(gè)倉(cāng)庫(kù)拷貝作為他個(gè)人公開倉(cāng)庫(kù) —— 其它開發(fā)者不允許push到這個(gè)倉(cāng)庫(kù),但可以pull到修改(后面我們很快就會(huì)看這點(diǎn)很重要)。 在創(chuàng)建了自己服務(wù)端拷貝之后,和之前的工作流一樣,開發(fā)者執(zhí)行g(shù)it clone命令克隆倉(cāng)庫(kù)到本地機(jī)器上,作為私有的開發(fā)環(huán)境。

要提交本地修改時(shí),push提交到自己公開倉(cāng)庫(kù)中 —— 而不是正式倉(cāng)庫(kù)中。 然后,給正式倉(cāng)庫(kù)發(fā)起一個(gè)pull request,讓項(xiàng)目維護(hù)者知道有更新已經(jīng)準(zhǔn)備好可以集成了。 對(duì)于貢獻(xiàn)的代碼,pull request也可以很方便地作為一個(gè)討論的地方。

為了集成功能到正式代碼庫(kù),維護(hù)者pull貢獻(xiàn)者的變更到自己的本地倉(cāng)庫(kù)中,檢查變更以確保不會(huì)讓項(xiàng)目出錯(cuò),?合并變更到自己本地的master分支, 然后pushmaster分支到服務(wù)器的正式倉(cāng)庫(kù)中。 到此,貢獻(xiàn)的提交成為了項(xiàng)目的一部分,其它的開發(fā)者應(yīng)該執(zhí)行pull操作與正式倉(cāng)庫(kù)同步自己本地倉(cāng)庫(kù)。

2.4.2 正式倉(cāng)庫(kù)

在Forking工作流中,『官方』倉(cāng)庫(kù)的叫法只是一個(gè)約定,理解這點(diǎn)很重要。 從技術(shù)上來(lái)看,各個(gè)開發(fā)者倉(cāng)庫(kù)和正式倉(cāng)庫(kù)在Git看來(lái)沒(méi)有任何區(qū)別。 事實(shí)上,讓正式倉(cāng)庫(kù)之所以正式的唯一原因是它是項(xiàng)目維護(hù)者的公開倉(cāng)庫(kù)。

2.4.3?Forking工作流的分支使用方式

所有的個(gè)人公開倉(cāng)庫(kù)實(shí)際上只是為了方便和其它的開發(fā)者共享分支。 各個(gè)開發(fā)者應(yīng)該用分支隔離各個(gè)功能,就像在功能分支工作流和Gitflow工作流一樣。 唯一的區(qū)別是這些分支被共享了。在Forking工作流中這些分支會(huì)被pull到另一個(gè)開發(fā)者的本地倉(cāng)庫(kù)中,而在功能分支工作流和Gitflow工作流中是直接被push到正式倉(cāng)庫(kù)中。

2.4.4 示例

項(xiàng)目維護(hù)者初始化正式倉(cāng)庫(kù)

和任何使用Git項(xiàng)目一樣,第一步是創(chuàng)建在服務(wù)器上一個(gè)正式倉(cāng)庫(kù),讓所有團(tuán)隊(duì)成員都可以訪問(wèn)到。 通常這個(gè)倉(cāng)庫(kù)也會(huì)作為項(xiàng)目維護(hù)者的公開倉(cāng)庫(kù)。

公開倉(cāng)庫(kù)應(yīng)該是裸倉(cāng)庫(kù),不管是不是正式代碼庫(kù)。 所以項(xiàng)目維護(hù)者會(huì)運(yùn)行像下面的命令來(lái)搭建正式倉(cāng)庫(kù):

ssh user@host git init --bare /path/to/repo.git

Bitbucket和Stash提供了一個(gè)方便的GUI客戶端以完成上面命令行做的事。 這個(gè)搭建中央倉(cāng)庫(kù)的過(guò)程和前面提到的工作流完全一樣。 如果有現(xiàn)存的代碼庫(kù),維護(hù)者也要push到這個(gè)倉(cāng)庫(kù)中。

開發(fā)者fork正式倉(cāng)庫(kù)

其它所有的開發(fā)需要fork正式倉(cāng)庫(kù)。 可以用git clone命令用SSH協(xié)議連通到服務(wù)器, 拷貝倉(cāng)庫(kù)到服務(wù)器另一個(gè)位置 —— 是的,fork操作基本上就只是一個(gè)服務(wù)端的克隆。?Bitbucket和Stash上可以點(diǎn)一下按鈕就讓開發(fā)者完成倉(cāng)庫(kù)的fork操作。

這一步完成后,每個(gè)開發(fā)都在服務(wù)端有一個(gè)自己的倉(cāng)庫(kù)。和正式倉(cāng)庫(kù)一樣,這些倉(cāng)庫(kù)應(yīng)該是裸倉(cāng)庫(kù)。

開發(fā)者克隆自己fork出來(lái)的倉(cāng)庫(kù)

下一步,各個(gè)開發(fā)者要克隆自己的公開倉(cāng)庫(kù),用熟悉的git clone命令。

在這個(gè)示例中,假定用Bitbucket托管了倉(cāng)庫(kù)。記住,如果這樣的話各個(gè)開發(fā)者需要有各自的Bitbucket賬號(hào), 使用下面命令克隆服務(wù)端自己的倉(cāng)庫(kù):

git clone https://user@bitbucket.org/user/repo.git

相比前面介紹的工作流只用了一個(gè)origin遠(yuǎn)程別名指向中央倉(cāng)庫(kù),Forking工作流需要2個(gè)遠(yuǎn)程別名 —— 一個(gè)指向正式倉(cāng)庫(kù),另一個(gè)指向開發(fā)者自己的服務(wù)端倉(cāng)庫(kù)。別名的名字可以任意命名,常見的約定是使用origin作為遠(yuǎn)程克隆的倉(cāng)庫(kù)的別名 (這個(gè)別名會(huì)在運(yùn)行g(shù)it clone自動(dòng)創(chuàng)建),upstream(上游)作為正式倉(cāng)庫(kù)的別名。

git remote add upstream https://bitbucket.org/maintainer/repo

需要自己用上面的命令創(chuàng)建upstream別名。這樣可以簡(jiǎn)單地保持本地倉(cāng)庫(kù)和正式倉(cāng)庫(kù)的同步更新。 注意,如果上游倉(cāng)庫(kù)需要認(rèn)證(比如不是開源的),你需要提供用戶:

git remote add upstream https://user@bitbucket.org/maintainer/repo.git

這時(shí)在克隆和pull正式倉(cāng)庫(kù)時(shí),需要提供用戶的密碼。

開發(fā)者開發(fā)自己的功能

在剛克隆的本地倉(cāng)庫(kù)中,開發(fā)者可以像其它工作流一樣的編輯代碼、提交修改和新建分支:

git checkout -b some-feature # Edit some code git commit -a -m "Add first draft of some feature"

所有的修改都是私有的直到push到自己公開倉(cāng)庫(kù)中。如果正式項(xiàng)目已經(jīng)往前走了,可以用git pull命令獲得新的提交:

git pull upstream master

由于開發(fā)者應(yīng)該都在專門的功能分支上工作,pull操作結(jié)果會(huì)都是快進(jìn)合并。

開發(fā)者發(fā)布自己的功能

一旦開發(fā)者準(zhǔn)備好了分享新功能,需要做二件事。 首先,通過(guò)push他的貢獻(xiàn)代碼到自己的公開倉(cāng)庫(kù)中,讓其它的開發(fā)者都可以訪問(wèn)到。 他的origin遠(yuǎn)程別名應(yīng)該已經(jīng)有了,所以要做的就是:

git push origin feature-branch

這里和之前的工作流的差異是,origin遠(yuǎn)程別名指向開發(fā)者自己的服務(wù)端倉(cāng)庫(kù),而不是正式倉(cāng)庫(kù)。

第二件事,開發(fā)者要通知項(xiàng)目維護(hù)者,想要合并他的新功能到正式庫(kù)中。?Bitbucket和Stash提供了Pull Request按鈕,彈出表單讓你指定哪個(gè)分支要合并到正式倉(cāng)庫(kù)。 一般你會(huì)想集成你的功能分支到上游遠(yuǎn)程倉(cāng)庫(kù)的master分支中。

項(xiàng)目維護(hù)者集成開發(fā)者的功能

當(dāng)項(xiàng)目維護(hù)者收到pull request,他要做的是決定是否集成它到正式代碼庫(kù)中。有二種方式來(lái)做:

  • 直接在pull request中查看代碼
  • pull代碼到他自己的本地倉(cāng)庫(kù),再手動(dòng)合并
  • 第一種做法更簡(jiǎn)單,維護(hù)者可以在GUI中查看變更的差異,做評(píng)注和執(zhí)行合并。 但如果出現(xiàn)了合并沖突,需要第二種做法來(lái)解決。這種情況下,維護(hù)者需要從開發(fā)者的服務(wù)端倉(cāng)庫(kù)中fetch功能分支, 合并到他本地的master分支,解決沖突:

    git fetch https://bitbucket.org/user/repo feature-branch # 查看變更 git checkout master git merge FETCH_HEAD

    變更集成到本地的master分支后,維護(hù)者要push變更到服務(wù)器上的正式倉(cāng)庫(kù),這樣其它的開發(fā)者都能訪問(wèn)到:

    git push origin master

    注意,維護(hù)者的origin是指向他自己公開倉(cāng)庫(kù)的,即是項(xiàng)目的正式代碼庫(kù)。到此,開發(fā)者的貢獻(xiàn)完全集成到了項(xiàng)目中。

    開發(fā)者和正式倉(cāng)庫(kù)做同步

    由于正式代碼庫(kù)往前走了,其它的開發(fā)需要和正式倉(cāng)庫(kù)做同步:

    git pull upstream master

    如果你之前是使用SVN,Forking工作流可能看起來(lái)像是一個(gè)激進(jìn)的范式切換(paradigm shift)。 但不要害怕,這個(gè)工作流實(shí)際上就是在功能分支工作流之上引入另一個(gè)抽象層。 不是直接通過(guò)單個(gè)中央倉(cāng)庫(kù)來(lái)分享分支,而是把貢獻(xiàn)代碼發(fā)布到開發(fā)者自己的服務(wù)端倉(cāng)庫(kù)中。

    示例中解釋了,一個(gè)貢獻(xiàn)如何從一個(gè)開發(fā)者流到正式的master分支中,但同樣的方法可以把貢獻(xiàn)集成到任一個(gè)倉(cāng)庫(kù)中。 比如,如果團(tuán)隊(duì)的幾個(gè)人協(xié)作實(shí)現(xiàn)一個(gè)功能,可以在開發(fā)之間用相同的方法分享變更,完全不涉及正式倉(cāng)庫(kù)。

    這使得Forking工作流對(duì)于松散組織的團(tuán)隊(duì)來(lái)說(shuō)是個(gè)非常強(qiáng)大的工具。任一開發(fā)者可以方便地和另一開發(fā)者分享變更,任何分支都能有效地合并到正式代碼庫(kù)中。


    2.5?Pull Requests

    Pull requests是Bitbucket提供的讓開發(fā)者更方便地進(jìn)行協(xié)作的功能,提供了友好的Web界面可以在提議的修改合并到正式項(xiàng)目之前對(duì)修改進(jìn)行討論。

    開發(fā)者向團(tuán)隊(duì)成員通知功能開發(fā)已經(jīng)完成,Pull Requests是最簡(jiǎn)單的用法。 開發(fā)者完成功能開發(fā)后,通過(guò)Bitbucket賬號(hào)發(fā)起一個(gè)Pull Request。 這樣讓涉及這個(gè)功能的所有人知道要去做Code Review和合并到master分支。

    但是,Pull Request遠(yuǎn)不止一個(gè)簡(jiǎn)單的通知,而是為討論提交的功能的一個(gè)專門論壇。 如果變更有任何問(wèn)題,團(tuán)隊(duì)成員反饋在Pull Request中,甚至push新的提交微調(diào)功能。 所有的這些活動(dòng)都直接跟蹤在Pull Request中。

    相比其它的協(xié)作模型,這種分享提交的形式有助于打造一個(gè)更流暢的工作流。?SVN和Git都能通過(guò)一個(gè)簡(jiǎn)單的腳本收到通知郵件;但是,討論變更時(shí),開發(fā)者通常只能去回復(fù)郵件。 這樣做會(huì)變得雜亂,尤其還要涉及后面的幾個(gè)提交時(shí)。?Pull Requests把所有相關(guān)功能整合到一個(gè)和Bitbucket倉(cāng)庫(kù)界面集成的用戶友好Web界面中。

    2.5.1 解析Pull Request

    當(dāng)要發(fā)起一個(gè)Pull Request,你所要做的就是請(qǐng)求(Request)另一個(gè)開發(fā)者(比如項(xiàng)目的維護(hù)者) 來(lái)pull你倉(cāng)庫(kù)中一個(gè)分支到他的倉(cāng)庫(kù)中。這意味著你要提供4個(gè)信息以發(fā)起Pull Request: 源倉(cāng)庫(kù)、源分支、目的倉(cāng)庫(kù)、目的分支。

    這幾值多數(shù)Bitbucket都會(huì)設(shè)置上合適的缺省值。但取決你用的協(xié)作工作流,你的團(tuán)隊(duì)可能會(huì)要指定不同的值。 上圖顯示了一個(gè)Pull Request請(qǐng)求合并一個(gè)功能分支到正式的master分支上,但可以有多種不同的Pull Request用法。

    2.5.2 工作方式

    Pull Request可以和功能分支工作流、Gitflow工作流或Forking工作流一起使用。 但一個(gè)Pull Request要求要么分支不同要么倉(cāng)庫(kù)不同,所以不能用于集中式工作流。 在不同的工作流中使用Pull Request會(huì)有一些不同,但基本的過(guò)程是這樣的:

  • 開發(fā)者在本地倉(cāng)庫(kù)中新建一個(gè)專門的分支開發(fā)功能。
  • 開發(fā)者push分支修改到公開的Bitbucket倉(cāng)庫(kù)中。
  • 開發(fā)者通過(guò)Bitbucket發(fā)起一個(gè)Pull Request。
  • 團(tuán)隊(duì)的其它成員review?code,討論并修改。
  • 項(xiàng)目維護(hù)者合并功能到官方倉(cāng)庫(kù)中并關(guān)閉Pull Request。
  • 本文后面內(nèi)容說(shuō)明,Pull Request在不同協(xié)作工作流中如何應(yīng)用。

    2.5.3 在功能分支工作流中使用Pull Request

    功能分支工作流用一個(gè)共享的Bitbucket倉(cāng)庫(kù)來(lái)管理協(xié)作,開發(fā)者在專門的分支上開發(fā)功能。 但不是立即合并到master分支上,而是在合并到主代碼庫(kù)之前開發(fā)者應(yīng)該開一個(gè)Pull Request發(fā)起功能的討論。

    功能分支工作流只有一個(gè)公開的倉(cāng)庫(kù),所以Pull Request的目的倉(cāng)庫(kù)和源倉(cāng)庫(kù)總是同一個(gè)。 通常開發(fā)者會(huì)指定他的功能分支作為源分支,master分支作為目的分支。

    收到Pull Request后,項(xiàng)目維護(hù)者要決定如何做。如果功能沒(méi)問(wèn)題,就簡(jiǎn)單地合并到master分支,關(guān)閉Pull Request。 但如果提交的變更有問(wèn)題,他可以在Pull Request中反饋。之后新加的提交也會(huì)評(píng)論之后接著顯示出來(lái)。

    在功能還沒(méi)有完全開發(fā)完的時(shí)候,也可能發(fā)起一個(gè)Pull Request。 比如開發(fā)者在實(shí)現(xiàn)某個(gè)需求時(shí)碰到了麻煩,他可以發(fā)一個(gè)包含正在進(jìn)行中工作的Pull Request。 其它的開發(fā)者可以在Pull Request提供建議,或者甚至直接添加提交來(lái)解決問(wèn)題。

    2.5.4 在Gitflow工作流中使用Pull Request

    Gitflow工作流和功能分支工作流類似,但圍繞項(xiàng)目發(fā)布定義一個(gè)嚴(yán)格的分支模型。 在Gitflow工作流中使用Pull Request讓開發(fā)者在發(fā)布分支或是維護(hù)分支上工作時(shí), 可以有個(gè)方便的地方對(duì)關(guān)于發(fā)布分支或是維護(hù)分支的問(wèn)題進(jìn)行交流。

    Gitflow工作流中Pull Request的使用過(guò)程和上一節(jié)中完全一致: 當(dāng)一個(gè)功能、發(fā)布或是熱修復(fù)分支需要Review時(shí),開發(fā)者簡(jiǎn)單發(fā)起一個(gè)Pull Request, 團(tuán)隊(duì)的其它成員會(huì)通過(guò)Bitbucket收到通知。

    新功能一般合并到develop分支,而發(fā)布和熱修復(fù)則要同時(shí)合并到develop分支和master分支上。?Pull Request可能用做所有合并的正式管理。

    2.5.5 在Forking工作流中使用Pull Request

    在Forking工作流中,開發(fā)者push完成的功能到他自己的倉(cāng)庫(kù)中,而不是共享倉(cāng)庫(kù)。 然后,他發(fā)起一個(gè)Pull Request,讓項(xiàng)目維護(hù)者知道他的功能已經(jīng)可以Review了。

    在這個(gè)工作流,Pull Request的通知功能非常有用, 因?yàn)轫?xiàng)目維護(hù)者不可能知道其它開發(fā)者在他們自己的倉(cāng)庫(kù)添加了提交。

    由于各個(gè)開發(fā)有自己的公開倉(cāng)庫(kù),Pull Request的源倉(cāng)庫(kù)和目標(biāo)倉(cāng)庫(kù)不是同一個(gè)。 源倉(cāng)庫(kù)是開發(fā)者的公開倉(cāng)庫(kù),源分支是包含了修改的分支。 如果開發(fā)者要合并修改到正式代碼庫(kù)中,那么目標(biāo)倉(cāng)庫(kù)是正式倉(cāng)庫(kù),目標(biāo)分支是master分支。

    Pull Request也可以用于正式項(xiàng)目之外的其它開發(fā)者之間的協(xié)作。 比如,如果一個(gè)開發(fā)者和一個(gè)團(tuán)隊(duì)成員一起開發(fā)一個(gè)功能,他們可以發(fā)起一個(gè)Pull Request, 用團(tuán)隊(duì)成員的Bitbucket倉(cāng)庫(kù)作為目標(biāo),而不是正式項(xiàng)目的倉(cāng)庫(kù)。 然后使用相同的功能分支作為源和目標(biāo)分支。

    2個(gè)開發(fā)者之間可以在Pull Request中討論和開發(fā)功能。 完成開發(fā)后,他們可以發(fā)起另一個(gè)Pull Request,請(qǐng)求合并功能到正式的master分支。 在Forking工作流中,這樣的靈活性讓Pull Request成為一個(gè)強(qiáng)有力的協(xié)作工具。

    2.5.6 示例

    下面的示例演示了Pull Request如何在在Forking工作流中使用。 也同樣適用于小團(tuán)隊(duì)的開發(fā)協(xié)作和第三方開發(fā)者向開源項(xiàng)目的貢獻(xiàn)。

    在示例中,小紅是個(gè)開發(fā),小明是項(xiàng)目維護(hù)者。他們各自有一個(gè)公開的Bitbucket倉(cāng)庫(kù),而小明的倉(cāng)庫(kù)包含了正式工程。

    小紅fork正式項(xiàng)目

    小紅先要fork小明的Bitbucket倉(cāng)庫(kù),開始項(xiàng)目的開發(fā)。她登陸B(tài)itbucket,瀏覽到小明的倉(cāng)庫(kù)頁(yè)面, 點(diǎn)Fork按鈕。

    然后為fork出來(lái)的倉(cāng)庫(kù)填寫名字和描述,這樣小紅就有了服務(wù)端的項(xiàng)目拷貝了。

    小紅克隆她的Bitbucket倉(cāng)庫(kù)

    下一步,小紅克隆自己剛才fork出來(lái)的Bitbucket倉(cāng)庫(kù),以在本機(jī)上準(zhǔn)備出工作拷貝。命令如下:

    git clone https://user@bitbucket.org/user/repo.git

    請(qǐng)記住,git clone會(huì)自動(dòng)創(chuàng)建origin遠(yuǎn)程別名,是指向小紅fork出來(lái)的倉(cāng)庫(kù)。

    小紅開發(fā)新功能

    在開始改代碼前,小紅要為新功能先新建一個(gè)新分支。她會(huì)用這個(gè)分支作為Pull Request的源分支。

    git checkout -b some-feature # 編輯代碼 git commit -a -m "Add first draft of some feature"

    在新功能分支上,小紅按需要添加提交。甚至如果小紅覺(jué)得功能分支上的提交歷史太亂了,她可以用交互式rebase來(lái)刪除或壓制提交。 對(duì)于大型項(xiàng)目,整理功能分支的歷史可以讓項(xiàng)目維護(hù)者更容易看出在Pull Request中做了什么內(nèi)容。

    小紅push功能到她的Bitbucket倉(cāng)庫(kù)中

    小紅完成了功能后,push功能到她自己的Bitbucket倉(cāng)庫(kù)中(不是正式倉(cāng)庫(kù)),用下面簡(jiǎn)單的命令:

    git push origin some-branch

    這時(shí)她的變更可以讓項(xiàng)目維護(hù)者看到了(或者任何想要看的協(xié)作者)。

    小紅發(fā)起Pull Request

    Bitbucket上有了她的功能分支后,小紅可以用她的Bitbucket賬號(hào)瀏覽到她的fork出來(lái)的倉(cāng)庫(kù)頁(yè)面, 點(diǎn)右上角的【Pull Request】按鈕,發(fā)起一個(gè)Pull Request。 彈出的表單自動(dòng)設(shè)置小紅的倉(cāng)庫(kù)為源倉(cāng)庫(kù),詢問(wèn)小紅以指定源分支、目標(biāo)倉(cāng)庫(kù)和目標(biāo)分支。

    小紅想要合并功能到正式倉(cāng)庫(kù),所以源分支是她的功能分支,目標(biāo)倉(cāng)庫(kù)是小明的公開倉(cāng)庫(kù), 而目標(biāo)分支是master分支。另外,小紅需要提供Pull Request的標(biāo)題和描述信息。 如果需要小明以外的人審核批準(zhǔn)代碼,她可以把這些人填在【Reviewers】文本框中。

    創(chuàng)建好了Pull Request,通知會(huì)通過(guò)Bitbucket系統(tǒng)消息或郵件(可選)發(fā)給小明。

    小明review?Pull Request

    在小明的Bitbucket倉(cāng)庫(kù)頁(yè)面的【Pull Request】Tab可以看到所有人發(fā)起的Pull Request。 點(diǎn)擊小紅的Pull Request會(huì)顯示出Pull Request的描述、功能的提交歷史和每個(gè)變更的差異(diff)。

    如果小明想要合并到項(xiàng)目中,只要點(diǎn)一下【Merge】按鈕,就可以同意Pull Request并合并到master分支。

    但如果像這個(gè)示例中一樣小明發(fā)現(xiàn)了在小紅的代碼中的一個(gè)小Bug,要小紅在合并前修復(fù)。 小明可以在整個(gè)Pull Request上加上評(píng)注,或是選擇歷史中的某個(gè)提交加上評(píng)注。

    小紅補(bǔ)加提交

    如果小紅對(duì)反饋有任何疑問(wèn),可以在Pull Request中響應(yīng),把Pull Request當(dāng)作是她功能討論的論壇。

    小紅在她的功能分支新加提交以解決代碼問(wèn)題,并push到她的Bitbucket倉(cāng)庫(kù)中,就像前一輪中的做法一樣。 這些提交會(huì)進(jìn)入的Pull Request,小明在原來(lái)的評(píng)注旁邊可以再次review變更。

    小明接受Pull Request

    最終,小明接受變更,合并功能分支到Master分支,并關(guān)閉Pull Request。 至此,功能集成到項(xiàng)目中,其它的項(xiàng)目開發(fā)者可以用標(biāo)準(zhǔn)的git pull命令pull這些變更到自己的本地倉(cāng)庫(kù)中。

    到了這里,你應(yīng)該有了所有需要的工具來(lái)集成Pull Request到你自己的工作流。 請(qǐng)記住,Pull Request并不是為了替代任何?基于Git的協(xié)作工作流, 而是它們的一個(gè)便利的補(bǔ)充,讓團(tuán)隊(duì)成員間的協(xié)作更輕松方便。


    三、企業(yè)日常開發(fā)模式探索

    在看這部分前,請(qǐng)先回顧閱讀業(yè)界認(rèn)可的成功的 Git Branch Work Flow 模型?A Successful Git Branching Model?,了解日常開發(fā)中的場(chǎng)景,有助于熟悉下面的使用過(guò)程。

    在企業(yè)開發(fā)中,使用 Git 作為版本控制軟件最看重的還是結(jié)合公司自己搭建的?Gitlab,將 Code Review 加入打包部署持續(xù)集成的流程中,這樣,代碼開發(fā)完成,提交測(cè)試前,便可以對(duì)開發(fā)人員提交的代碼進(jìn)行 Review,發(fā)現(xiàn)潛在的問(wèn)題,及時(shí)指導(dǎo),對(duì)于新人來(lái)講,也能更快更好的學(xué)習(xí)。

    解決的需求場(chǎng)景如下:

    • 能支持日常迭代開發(fā)、緊急線上bug修復(fù)、多功能并行開發(fā)
    • 大概50人左右的團(tuán)隊(duì),平日迭代項(xiàng)目較多,且周期短(1~2周一個(gè)迭代)
    • 能夠通過(guò)tag重建整個(gè)系統(tǒng)
    • 支持code review
    • 所有上線的代碼必須都是經(jīng)過(guò)測(cè)試保證,且能自動(dòng)同步到下一次的迭代中
    • 能和公司的項(xiàng)目管理/持續(xù)集成系統(tǒng)整合

    上圖就是 xirong 團(tuán)隊(duì)在日常開發(fā)中總結(jié)出來(lái)的適合企業(yè)開發(fā)的模式,下面進(jìn)行簡(jiǎn)單的介紹,方便大家學(xué)習(xí)了解,歡迎提交 Issue 進(jìn)行討論。(本模式適合敏捷開發(fā)流程,小迭代上線,傳統(tǒng)的瀑布開發(fā)模型并沒(méi)有進(jìn)行測(cè)試)

  • 迭代需求會(huì)、沖刺會(huì)后確定本次迭代的目標(biāo)后,將迭代內(nèi)容視為一個(gè)項(xiàng)目,在 Gitlab 上創(chuàng)建一個(gè) Repository,初始化工程代碼結(jié)構(gòu),根據(jù)上線日期,比如20150730上線,開出分支 release20150730、dev20150730 兩個(gè)分支,dev 分支作為日常開發(fā)主干分支,release 分支作為提測(cè)打包、Code Review 的分支。
  • 迭代開始,日常開發(fā)進(jìn)行中,開發(fā)人員在 dev 分支上進(jìn)行 Commit、Push 代碼,并且解決掉日常協(xié)同開發(fā)中的沖突等問(wèn)題,等到達(dá)到提測(cè)條件的時(shí)候,提測(cè)者,首先 Merge Master 分支上的最新代碼?git merge --no-ff origin/master?,使得 Master 分支上的變更更新到迭代開發(fā)分支dev上面,之后,在 Gitlab 上面發(fā)起?pull request?請(qǐng)求,并指定 Code Review 人,請(qǐng)求的分支選擇本次上線的 release 分支,即 release20150730。
  • 被指定 Code Review 的人,對(duì)發(fā)起者的代碼 Review 后,決定是否可以提交測(cè)試,若有問(wèn)題,評(píng)論注釋代碼后,提交者對(duì)代碼進(jìn)行進(jìn)行修改,重復(fù)步驟2,直到代碼 Review 者認(rèn)為 Ok。之后便可以借助自己公司的打包部署,對(duì)這些代碼發(fā)布到測(cè)試環(huán)境驗(yàn)證。
  • 步驟2-3重復(fù)多次后,就會(huì)達(dá)到一個(gè)穩(wěn)定可發(fā)布的版本,即上線版本,上線后,將 release 版本上面最后的提交(圖中0.2.4上線對(duì)應(yīng)處)合并到 Master 分支上面,并打 Tag0.3。至此,一次完整的迭代開發(fā)完成。
  • 若此次上線后,不久發(fā)現(xiàn)生產(chǎn)環(huán)境有 Bug 需要修復(fù),則從 Tag 處新開分支 release_bugfix_20150731、dev_bugfix_20150731 ,開發(fā)人員從 dev_bugfix_20150731分支上進(jìn)行開發(fā),提測(cè)code review在 release_bugfix_20150731 分支上,具體步驟參考2-3,測(cè)試環(huán)境驗(yàn)證通過(guò)后,發(fā)布到線上,驗(yàn)證OK,合并到 Master 分支,并打 Tag0.2.3,此次 Bug 修復(fù)完畢,專為解 Bug 而生的這兩個(gè)分支可以退伍了,刪除release_bugfix_20150731、dev_bugfix_20150731兩分支即可。(所有的歷史 Commit 信息均已經(jīng)提交到了 Master 分支上,不用擔(dān)心丟失)
  • 這樣經(jīng)過(guò)上面的1-5步驟,企業(yè)日常迭代開發(fā)中的代碼版本控制基本上就 Ok 了,有問(wèn)題歡迎 Issue 討論。

    2016-11月 更新?Git 分支開發(fā)部署模型?的一些使用原則如下:

    • master:master永遠(yuǎn)是線上代碼,最穩(wěn)定的分支,存放的是隨時(shí)可供在生產(chǎn)環(huán)境中部署的代碼,當(dāng)開發(fā)活動(dòng)告一段落,產(chǎn)生了一份新的可供部署的代碼時(shí),發(fā)布成功之后,代碼才會(huì)由 aone2 提交到 master,master 分支上的代碼會(huì)被更新。應(yīng)用上 aone2 后禁掉所有人的 master的寫權(quán)限
    • develop:保存當(dāng)前最新開發(fā)成果的分支。通常這個(gè)分支上的代碼也是可進(jìn)行每日夜間發(fā)布的代碼,只對(duì)開發(fā)負(fù)責(zé)人開放develop權(quán)限。
    • feature: 功能特性分支,每個(gè)功能特性一個(gè) feature/ 分支,開發(fā)完成自測(cè)通過(guò)后合并入 develop 分支。可以從 master 或者develop 中拉出來(lái)。
    • hotfix: 緊急bug分支修復(fù)分支。修復(fù)上線后,可以直接合并入master。

    Git-Develop 分支模式是基于 Git 代碼庫(kù)設(shè)計(jì)的一種需要嚴(yán)格控制發(fā)布質(zhì)量和發(fā)布節(jié)奏的開發(fā)模式。develop 作為固定的持續(xù)集成和發(fā)布分支,并且分支上的代碼必須經(jīng)過(guò) CodeReview 后才可以提交到 Develop 分支。它的基本流程如下:

    • 每一個(gè)需求/變更都單獨(dú)從Master上創(chuàng)建一條Branch分支;
    • 用戶在這個(gè)Branch分支上進(jìn)行Codeing活動(dòng);
    • 代碼達(dá)到發(fā)布準(zhǔn)入條件后aone上提交Codereview,Codereview通過(guò)后代碼自動(dòng)合并到Develop分支;
    • 待所有計(jì)劃發(fā)布的變更分支代碼都合并到Develop后,系統(tǒng)再 rebase master 代碼到Develop 分支,然后自行構(gòu)建,打包,部署等動(dòng)作。
    • 應(yīng)用發(fā)布成功后Aone會(huì)基于Develop分支的發(fā)布版本打一個(gè)“當(dāng)前線上版本Tag”基線;
    • 應(yīng)用發(fā)布成功后Aone會(huì)自動(dòng)把Develop分支的發(fā)布版本合并回master;

    轉(zhuǎn)載于:https://my.oschina.net/u/3371661/blog/3044490

    《新程序員》:云原生和全面數(shù)字化實(shí)踐50位技術(shù)專家共同創(chuàng)作,文字、視頻、音頻交互閱讀

    總結(jié)

    以上是生活随笔為你收集整理的git的操作说明超详细的全部?jī)?nèi)容,希望文章能夠幫你解決所遇到的問(wèn)題。

    如果覺(jué)得生活随笔網(wǎng)站內(nèi)容還不錯(cuò),歡迎將生活随笔推薦給好友。

    内射欧美老妇wbb | 国产深夜福利视频在线 | 成在人线av无码免观看麻豆 | 日本欧美一区二区三区乱码 | 水蜜桃色314在线观看 | 国产精品爱久久久久久久 | 亚洲中文字幕乱码av波多ji | 99久久精品无码一区二区毛片 | 国产香蕉尹人视频在线 | 色婷婷久久一区二区三区麻豆 | 四十如虎的丰满熟妇啪啪 | 成人女人看片免费视频放人 | 亚洲精品久久久久久久久久久 | 久久国产36精品色熟妇 | 国产色xx群视频射精 | 国产办公室秘书无码精品99 | 亚洲国产成人a精品不卡在线 | 中文字幕无码av波多野吉衣 | 日韩av无码中文无码电影 | 强辱丰满人妻hd中文字幕 | 国内揄拍国内精品少妇国语 | 国产香蕉97碰碰久久人人 | 亚洲欧洲日本无在线码 | 欧美怡红院免费全部视频 | 日本护士xxxxhd少妇 | 7777奇米四色成人眼影 | 欧美日韩人成综合在线播放 | 亚洲中文字幕av在天堂 | 久久99精品国产.久久久久 | 狠狠cao日日穞夜夜穞av | 一二三四社区在线中文视频 | 欧美熟妇另类久久久久久多毛 | 精品欧洲av无码一区二区三区 | 亚洲爆乳无码专区 | 久久精品国产99精品亚洲 | 女人被爽到呻吟gif动态图视看 | 亚洲另类伦春色综合小说 | 精品亚洲成av人在线观看 | 丰满少妇女裸体bbw | 日韩少妇白浆无码系列 | 亚洲熟妇色xxxxx亚洲 | 国产成人精品视频ⅴa片软件竹菊 | 精品无人国产偷自产在线 | 亚洲国产精华液网站w | 日韩人妻少妇一区二区三区 | 国产偷国产偷精品高清尤物 | 久久99精品国产麻豆蜜芽 | 99国产欧美久久久精品 | 丝袜人妻一区二区三区 | 红桃av一区二区三区在线无码av | 九九热爱视频精品 | 国产无套粉嫩白浆在线 | 欧美日韩久久久精品a片 | 亚洲日本在线电影 | 色情久久久av熟女人妻网站 | 国产一区二区三区精品视频 | 国产卡一卡二卡三 | 久激情内射婷内射蜜桃人妖 | 久久五月精品中文字幕 | 国产av一区二区精品久久凹凸 | 国产精品久久久久久久9999 | 国产后入清纯学生妹 | 亚洲色偷偷偷综合网 | 亚洲国产午夜精品理论片 | 国产三级久久久精品麻豆三级 | 日本丰满护士爆乳xxxx | 牛和人交xxxx欧美 | 久久久国产精品无码免费专区 | 成熟人妻av无码专区 | 女人高潮内射99精品 | 国产精品欧美成人 | 色窝窝无码一区二区三区色欲 | 无码人妻精品一区二区三区下载 | 亚洲国产成人a精品不卡在线 | 波多野结衣乳巨码无在线观看 | 无码av岛国片在线播放 | 国产亚洲精品久久久久久国模美 | 激情爆乳一区二区三区 | 7777奇米四色成人眼影 | 中文字幕无码热在线视频 | 久久国产自偷自偷免费一区调 | 国产又粗又硬又大爽黄老大爷视 | 内射爽无广熟女亚洲 | 强开小婷嫩苞又嫩又紧视频 | 一本一道久久综合久久 | 激情爆乳一区二区三区 | 97色伦图片97综合影院 | 日韩亚洲欧美中文高清在线 | 一本久久a久久精品vr综合 | 国产精品多人p群无码 | 欧美人与牲动交xxxx | 亚洲の无码国产の无码步美 | 男女超爽视频免费播放 | 乱中年女人伦av三区 | 国产真人无遮挡作爱免费视频 | 日本熟妇大屁股人妻 | 欧美亚洲日韩国产人成在线播放 | 成 人影片 免费观看 | 亚洲国精产品一二二线 | 国产精品国产自线拍免费软件 | 在线a亚洲视频播放在线观看 | 久精品国产欧美亚洲色aⅴ大片 | 亚洲精品综合一区二区三区在线 | 精品偷拍一区二区三区在线看 | 色妞www精品免费视频 | 国产 精品 自在自线 | 任你躁在线精品免费 | 国产九九九九九九九a片 | 色欲av亚洲一区无码少妇 | 亚洲国产精品美女久久久久 | 国产无套内射久久久国产 | 国产午夜福利亚洲第一 | 日韩人妻无码中文字幕视频 | 国产在线一区二区三区四区五区 | 亚洲 日韩 欧美 成人 在线观看 | 亚洲精品国偷拍自产在线观看蜜桃 | 日韩少妇内射免费播放 | 久久久亚洲欧洲日产国码αv | 亚洲国产成人a精品不卡在线 | 久久久久免费看成人影片 | 亚洲日本在线电影 | 国产真实夫妇视频 | 国产精品18久久久久久麻辣 | 男人的天堂av网站 | 亚洲自偷自拍另类第1页 | 日韩人妻无码一区二区三区久久99 | 欧美午夜特黄aaaaaa片 | 丰腴饱满的极品熟妇 | 奇米影视7777久久精品人人爽 | 激情国产av做激情国产爱 | 精品亚洲成av人在线观看 | 国产精品永久免费视频 | 久久久中文久久久无码 | 久久久精品456亚洲影院 | 日韩视频 中文字幕 视频一区 | 中文字幕无码视频专区 | 久久久久久久人妻无码中文字幕爆 | 久久久久亚洲精品男人的天堂 | 蜜桃视频插满18在线观看 | 国精品人妻无码一区二区三区蜜柚 | 真人与拘做受免费视频 | 欧美日韩视频无码一区二区三 | 99久久精品午夜一区二区 | 丰满人妻被黑人猛烈进入 | 色婷婷久久一区二区三区麻豆 | 国内精品九九久久久精品 | 亚洲国产av精品一区二区蜜芽 | 成人无码视频在线观看网站 | 国产精品va在线观看无码 | 国产极品美女高潮无套在线观看 | 国产精品福利视频导航 | 亚洲人成网站免费播放 | 无码午夜成人1000部免费视频 | 18禁黄网站男男禁片免费观看 | 亚洲一区二区三区 | 欧美老妇交乱视频在线观看 | 精品欧美一区二区三区久久久 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 最近免费中文字幕中文高清百度 | 国产两女互慰高潮视频在线观看 | 欧美人与牲动交xxxx | 日本爽爽爽爽爽爽在线观看免 | 76少妇精品导航 | 人妻互换免费中文字幕 | 国内综合精品午夜久久资源 | 亚洲一区二区三区国产精华液 | 亚洲精品久久久久avwww潮水 | 最新国产麻豆aⅴ精品无码 | 88国产精品欧美一区二区三区 | 1000部夫妻午夜免费 | 中文字幕无码免费久久99 | 人妻插b视频一区二区三区 | 国产精品-区区久久久狼 | 国产在线一区二区三区四区五区 | 亚洲综合无码久久精品综合 | 日韩少妇内射免费播放 | 婷婷丁香五月天综合东京热 | 国产精品亚洲专区无码不卡 | 亚洲国产精品无码久久久久高潮 | 中文字幕av无码一区二区三区电影 | 无码人妻丰满熟妇区毛片18 | 99视频精品全部免费免费观看 | 日日夜夜撸啊撸 | 亚洲日本va中文字幕 | 野狼第一精品社区 | 欧美freesex黑人又粗又大 | 成熟妇人a片免费看网站 | 亚洲一区二区三区含羞草 | 亚洲高清偷拍一区二区三区 | 国产精品igao视频网 | 精品国产一区二区三区av 性色 | 无码av岛国片在线播放 | 牲欲强的熟妇农村老妇女视频 | 国产舌乚八伦偷品w中 | 国产精品手机免费 | 夜先锋av资源网站 | 噜噜噜亚洲色成人网站 | 亚洲精品久久久久久久久久久 | 国产成人精品视频ⅴa片软件竹菊 | 久久久中文久久久无码 | 国产成人无码av一区二区 | 精品国产国产综合精品 | 久久精品一区二区三区四区 | 亚洲熟悉妇女xxx妇女av | 红桃av一区二区三区在线无码av | 乱码午夜-极国产极内射 | 久久亚洲精品成人无码 | 日本欧美一区二区三区乱码 | 丰满少妇熟乱xxxxx视频 | 300部国产真实乱 | 综合激情五月综合激情五月激情1 | 人人超人人超碰超国产 | 99久久人妻精品免费一区 | 无码成人精品区在线观看 | 日日橹狠狠爱欧美视频 | 欧美日韩亚洲国产精品 | 99久久亚洲精品无码毛片 | 色五月丁香五月综合五月 | 日韩精品成人一区二区三区 | 奇米影视7777久久精品人人爽 | 清纯唯美经典一区二区 | 亚洲精品一区三区三区在线观看 | 亚洲精品国产品国语在线观看 | 日本精品人妻无码免费大全 | 亚洲国产欧美日韩精品一区二区三区 | 日本大乳高潮视频在线观看 | 最近的中文字幕在线看视频 | 久久无码专区国产精品s | 精品国产aⅴ无码一区二区 | 三上悠亚人妻中文字幕在线 | 国内综合精品午夜久久资源 | 色五月丁香五月综合五月 | 国产内射爽爽大片视频社区在线 | 暴力强奷在线播放无码 | 久久精品一区二区三区四区 | 少妇人妻av毛片在线看 | 日本一卡2卡3卡4卡无卡免费网站 国产一区二区三区影院 | 成年美女黄网站色大免费全看 | 国产成人精品一区二区在线小狼 | 亚洲欧美日韩成人高清在线一区 | 亚洲爆乳无码专区 | 一本久道久久综合婷婷五月 | 国产精品久久久 | 熟女俱乐部五十路六十路av | 樱花草在线播放免费中文 | 国产 精品 自在自线 | 国产真实伦对白全集 | 性做久久久久久久免费看 | 国产在线无码精品电影网 | 欧美xxxxx精品 | 亚洲国产欧美国产综合一区 | 亚洲精品国产精品乱码视色 | 熟妇人妻激情偷爽文 | 久久人人爽人人人人片 | 亚洲欧美国产精品专区久久 | 天堂无码人妻精品一区二区三区 | 人妻尝试又大又粗久久 | 天天燥日日燥 | 欧美丰满熟妇xxxx | 中文字幕无线码 | 人人妻人人澡人人爽欧美一区九九 | 人人爽人人澡人人人妻 | 国产精品毛多多水多 | yw尤物av无码国产在线观看 | 成人精品一区二区三区中文字幕 | 色欲人妻aaaaaaa无码 | 在线观看欧美一区二区三区 | 午夜福利试看120秒体验区 | 亚洲精品午夜国产va久久成人 | 久久精品女人的天堂av | 亚洲综合无码久久精品综合 | 亚洲色偷偷男人的天堂 | 少妇邻居内射在线 | 免费观看激色视频网站 | 国产艳妇av在线观看果冻传媒 | 99久久久无码国产精品免费 | 一本久久伊人热热精品中文字幕 | 国产卡一卡二卡三 | 日本丰满护士爆乳xxxx | 亚洲精品一区国产 | 黑人巨大精品欧美一区二区 | 少妇一晚三次一区二区三区 | 亚洲自偷自拍另类第1页 | 亚洲区欧美区综合区自拍区 | 亚洲日韩一区二区三区 | 久久综合给合久久狠狠狠97色 | 好屌草这里只有精品 | 亚洲中文字幕在线观看 | 乱人伦人妻中文字幕无码 | 精品国产成人一区二区三区 | 色婷婷久久一区二区三区麻豆 | 亚洲精品国产精品乱码不卡 | 99视频精品全部免费免费观看 | 丰满少妇弄高潮了www | 成年美女黄网站色大免费视频 | 欧美真人作爱免费视频 | 内射老妇bbwx0c0ck | 2020久久香蕉国产线看观看 | 亚洲色欲久久久综合网东京热 | 中文字幕乱码人妻二区三区 | 国产免费观看黄av片 | 国产在线精品一区二区三区直播 | 丰满人妻翻云覆雨呻吟视频 | 在线a亚洲视频播放在线观看 | 久久精品国产一区二区三区 | 综合人妻久久一区二区精品 | 真人与拘做受免费视频一 | 一本久久a久久精品亚洲 | 国产疯狂伦交大片 | 在线 国产 欧美 亚洲 天堂 | 在线a亚洲视频播放在线观看 | 蜜桃视频韩日免费播放 | 亚洲一区二区观看播放 | 中文字幕人妻无码一区二区三区 | 久久精品国产亚洲精品 | 国产精品亚洲专区无码不卡 | 久久99久久99精品中文字幕 | 欧洲熟妇色 欧美 | 在线а√天堂中文官网 | 国产一精品一av一免费 | 四十如虎的丰满熟妇啪啪 | 大肉大捧一进一出视频出来呀 | 国产亚洲视频中文字幕97精品 | 人人澡人人透人人爽 | 中文字幕无码视频专区 | 内射老妇bbwx0c0ck | 午夜时刻免费入口 | 免费人成在线观看网站 | 亚洲爆乳精品无码一区二区三区 | 无码人妻久久一区二区三区不卡 | 欧美成人免费全部网站 | 乱人伦中文视频在线观看 | 国产在线aaa片一区二区99 | 疯狂三人交性欧美 | 少妇人妻偷人精品无码视频 | 少妇无码av无码专区在线观看 | 性欧美牲交在线视频 | 人人澡人人妻人人爽人人蜜桃 | 东京无码熟妇人妻av在线网址 | aa片在线观看视频在线播放 | 成 人影片 免费观看 | 亚洲va欧美va天堂v国产综合 | 熟妇人妻激情偷爽文 | 精品无码国产自产拍在线观看蜜 | 人妻互换免费中文字幕 | 永久免费精品精品永久-夜色 | 日韩av无码一区二区三区 | 国产超级va在线观看视频 | 国产sm调教视频在线观看 | 狠狠色色综合网站 | 免费男性肉肉影院 | 300部国产真实乱 | 亚洲无人区午夜福利码高清完整版 | 免费观看激色视频网站 | 国精品人妻无码一区二区三区蜜柚 | 国产成人精品优优av | 国产成人精品三级麻豆 | 久久久久免费看成人影片 | 夜先锋av资源网站 | 国产精品免费大片 | av无码久久久久不卡免费网站 | 真人与拘做受免费视频 | 日本熟妇大屁股人妻 | 精品国产一区二区三区av 性色 | 国产人妻精品午夜福利免费 | 欧美人与动性行为视频 | 久久99精品久久久久久 | 中文字幕无线码 | 中文字幕色婷婷在线视频 | 日本在线高清不卡免费播放 | 亚洲日本一区二区三区在线 | 日本免费一区二区三区最新 | 欧洲精品码一区二区三区免费看 | 少妇人妻偷人精品无码视频 | 亚洲中文字幕久久无码 | 日韩精品乱码av一区二区 | 国产精品igao视频网 | 亚洲成av人综合在线观看 | 亚洲性无码av中文字幕 | 国产麻豆精品精东影业av网站 | 国产日产欧产精品精品app | 国内老熟妇对白xxxxhd | 亚洲无人区午夜福利码高清完整版 | 国内少妇偷人精品视频 | 国产成人精品优优av | 图片小说视频一区二区 | 人人澡人摸人人添 | 国产超碰人人爽人人做人人添 | 欧美三级不卡在线观看 | 久久久久久亚洲精品a片成人 | 久久久国产一区二区三区 | 又湿又紧又大又爽a视频国产 | 亚洲成熟女人毛毛耸耸多 | 成人性做爰aaa片免费看不忠 | 大地资源网第二页免费观看 | 成人无码视频免费播放 | 亚洲精品久久久久久久久久久 | 无码福利日韩神码福利片 | 欧美色就是色 | 日韩人妻无码一区二区三区久久99 | 成年美女黄网站色大免费全看 | 亚洲日韩一区二区 | 少妇无套内谢久久久久 | 丰满人妻被黑人猛烈进入 | 少妇无码一区二区二三区 | 黑人大群体交免费视频 | 国产无遮挡吃胸膜奶免费看 | 97夜夜澡人人爽人人喊中国片 | 狂野欧美性猛xxxx乱大交 | 精品偷自拍另类在线观看 | 国产亚av手机在线观看 | 无码av最新清无码专区吞精 | 欧美国产亚洲日韩在线二区 | 六十路熟妇乱子伦 | 美女张开腿让人桶 | 国产成人精品优优av | 亚洲成av人综合在线观看 | 人人超人人超碰超国产 | 亚洲国产欧美国产综合一区 | 在线观看国产一区二区三区 | √8天堂资源地址中文在线 | 在线精品国产一区二区三区 | 中文字幕乱妇无码av在线 | 久久综合九色综合欧美狠狠 | 十八禁真人啪啪免费网站 | 国产成人精品一区二区在线小狼 | 男女猛烈xx00免费视频试看 | 久久久久久亚洲精品a片成人 | 性欧美videos高清精品 | 一本加勒比波多野结衣 | 成熟女人特级毛片www免费 | 亚洲经典千人经典日产 | 在线天堂新版最新版在线8 | 天天拍夜夜添久久精品大 | 爽爽影院免费观看 | 亚洲国产欧美国产综合一区 | 亚洲中文字幕无码中文字在线 | 国产成人一区二区三区别 | 搡女人真爽免费视频大全 | 久久精品人人做人人综合试看 | 在线亚洲高清揄拍自拍一品区 | 国内精品人妻无码久久久影院 | 日日摸夜夜摸狠狠摸婷婷 | 任你躁国产自任一区二区三区 | 色欲久久久天天天综合网精品 | 日韩欧美中文字幕在线三区 | 精品夜夜澡人妻无码av蜜桃 | 日本xxxx色视频在线观看免费 | 久久精品人人做人人综合 | √8天堂资源地址中文在线 | 国产精品.xx视频.xxtv | 桃花色综合影院 | 成人免费无码大片a毛片 | 久久无码人妻影院 | 永久免费观看美女裸体的网站 | 美女极度色诱视频国产 | www国产亚洲精品久久久日本 | 亚洲精品一区二区三区大桥未久 | 嫩b人妻精品一区二区三区 | 99久久精品午夜一区二区 | 国产亚洲精品久久久久久大师 | 无码中文字幕色专区 | 欧美真人作爱免费视频 | 精品国产精品久久一区免费式 | 日本一区二区更新不卡 | 亚洲日韩av一区二区三区中文 | 老司机亚洲精品影院无码 | 亚洲精品一区二区三区在线观看 | 久久久久99精品成人片 | 精品一区二区三区波多野结衣 | 天天拍夜夜添久久精品 | 亚洲aⅴ无码成人网站国产app | 亚洲一区二区三区香蕉 | 狠狠色噜噜狠狠狠狠7777米奇 | 美女极度色诱视频国产 | 久久精品国产大片免费观看 | 亚洲春色在线视频 | 亚洲精品成a人在线观看 | 中文字幕人妻无码一夲道 | 成在人线av无码免费 | 国产一区二区三区四区五区加勒比 | 欧美一区二区三区 | 久久aⅴ免费观看 | 波多野结衣av一区二区全免费观看 | 狠狠综合久久久久综合网 | a片免费视频在线观看 | 5858s亚洲色大成网站www | 高清不卡一区二区三区 | 欧美日韩精品 | 无码av免费一区二区三区试看 | 在线播放无码字幕亚洲 | 特黄特色大片免费播放器图片 | 亚洲小说春色综合另类 | 九九在线中文字幕无码 | 亚洲欧美日韩国产精品一区二区 | 在线观看国产一区二区三区 | 久久无码人妻影院 | 天天做天天爱天天爽综合网 | 小鲜肉自慰网站xnxx | 性色欲情网站iwww九文堂 | 久久精品国产99久久6动漫 | 清纯唯美经典一区二区 | 亚洲中文字幕乱码av波多ji | 亚洲一区二区三区香蕉 | 无码人妻精品一区二区三区下载 | 日韩 欧美 动漫 国产 制服 | 内射巨臀欧美在线视频 | 亚洲日韩一区二区 | 无码帝国www无码专区色综合 | 日本一本二本三区免费 | 精品久久8x国产免费观看 | 亚洲日韩一区二区 | 国产乱码精品一品二品 | 99久久亚洲精品无码毛片 | 天堂а√在线中文在线 | 婷婷丁香六月激情综合啪 | 又黄又爽又色的视频 | 老熟妇仑乱视频一区二区 | 欧美成人高清在线播放 | 亚洲日韩中文字幕在线播放 | 丰满人妻一区二区三区免费视频 | 天下第一社区视频www日本 | 久久久久久久久蜜桃 | 国产在线精品一区二区三区直播 | 一区二区传媒有限公司 | 久久国产精品二国产精品 | 性生交大片免费看女人按摩摩 | 任你躁在线精品免费 | 精品厕所偷拍各类美女tp嘘嘘 | 少妇性l交大片 | 精品国产乱码久久久久乱码 | 国产精品亚洲五月天高清 | 亚洲成av人影院在线观看 | 波多野结衣aⅴ在线 | 蜜臀aⅴ国产精品久久久国产老师 | 久久久无码中文字幕久... | 亚洲毛片av日韩av无码 | 精品少妇爆乳无码av无码专区 | 男人和女人高潮免费网站 | 久久五月精品中文字幕 | 高清国产亚洲精品自在久久 | 欧美成人家庭影院 | 在线观看欧美一区二区三区 | 18无码粉嫩小泬无套在线观看 | 国产激情无码一区二区 | 久久久久久久人妻无码中文字幕爆 | 亚洲精品国产第一综合99久久 | 狠狠色丁香久久婷婷综合五月 | 伊人久久大香线蕉av一区二区 | 欧美人与动性行为视频 | 给我免费的视频在线观看 | 无遮无挡爽爽免费视频 | 亚洲日韩av一区二区三区四区 | 亚洲午夜福利在线观看 | 扒开双腿吃奶呻吟做受视频 | a在线观看免费网站大全 | 大胆欧美熟妇xx | 亚洲一区二区三区含羞草 | 成人综合网亚洲伊人 | 日产精品高潮呻吟av久久 | 中文字幕+乱码+中文字幕一区 | 国产深夜福利视频在线 | 99久久无码一区人妻 | 免费国产黄网站在线观看 | 亚洲国产高清在线观看视频 | 日日碰狠狠躁久久躁蜜桃 | 精品无码一区二区三区爱欲 | 国产日产欧产精品精品app | 精品成人av一区二区三区 | 亚洲爆乳精品无码一区二区三区 | 少妇无码av无码专区在线观看 | 精品aⅴ一区二区三区 | 欧美色就是色 | 麻豆av传媒蜜桃天美传媒 | 激情五月综合色婷婷一区二区 | 日日躁夜夜躁狠狠躁 | 日韩无套无码精品 | 高潮毛片无遮挡高清免费视频 | 中文字幕人成乱码熟女app | 国产午夜手机精彩视频 | 蜜桃视频韩日免费播放 | 久久精品人人做人人综合 | 99国产精品白浆在线观看免费 | 精品乱子伦一区二区三区 | 人妻少妇精品视频专区 | 精品无码一区二区三区爱欲 | 国产手机在线αⅴ片无码观看 | 无码国产激情在线观看 | 日本一区二区更新不卡 | 久久精品国产大片免费观看 | 色一情一乱一伦 | 国产av无码专区亚洲a∨毛片 | 久久亚洲中文字幕无码 | 午夜免费福利小电影 | 中文字幕日产无线码一区 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 人人爽人人爽人人片av亚洲 | 丝袜人妻一区二区三区 | 人妻与老人中文字幕 | 亚洲色偷偷偷综合网 | 日韩少妇内射免费播放 | 国产亚洲视频中文字幕97精品 | 精品亚洲韩国一区二区三区 | 日日鲁鲁鲁夜夜爽爽狠狠 | 综合人妻久久一区二区精品 | 一本精品99久久精品77 | 久久久国产精品无码免费专区 | 天堂亚洲2017在线观看 | 精品偷自拍另类在线观看 | 成人精品视频一区二区 | 人人妻人人澡人人爽精品欧美 | 精品亚洲成av人在线观看 | 日韩精品无码一本二本三本色 | 狠狠噜狠狠狠狠丁香五月 | 东京热无码av男人的天堂 | 人妻有码中文字幕在线 | 亚洲一区二区三区无码久久 | 国产精品无码成人午夜电影 | 黑人巨大精品欧美一区二区 | 亚洲无人区午夜福利码高清完整版 | 日本肉体xxxx裸交 | www国产亚洲精品久久网站 | 在线亚洲高清揄拍自拍一品区 | 久久久久99精品成人片 | 给我免费的视频在线观看 | 亚洲精品www久久久 | 欧美成人免费全部网站 | 熟女俱乐部五十路六十路av | 日本丰满护士爆乳xxxx | 色综合视频一区二区三区 | 亚洲国产精华液网站w | 久久久久免费看成人影片 | 国产午夜福利亚洲第一 | 久久国产精品萌白酱免费 | 中文无码成人免费视频在线观看 | 国产精品-区区久久久狼 | 国产成人无码av在线影院 | 51国偷自产一区二区三区 | 国产97色在线 | 免 | 亚洲日韩乱码中文无码蜜桃臀网站 | 亚洲成熟女人毛毛耸耸多 | 欧美一区二区三区 | 精品偷拍一区二区三区在线看 | 久久无码中文字幕免费影院蜜桃 | 欧美色就是色 | 亚洲综合无码久久精品综合 | 久久人人97超碰a片精品 | 色综合久久久久综合一本到桃花网 | 国产欧美熟妇另类久久久 | 亚洲精品久久久久久一区二区 | 亚洲日韩av片在线观看 | 日本在线高清不卡免费播放 | 久青草影院在线观看国产 | 精品成人av一区二区三区 | 欧美精品无码一区二区三区 | a国产一区二区免费入口 | 丰满护士巨好爽好大乳 | 全球成人中文在线 | 中文字幕乱码中文乱码51精品 | 国产 精品 自在自线 | 成人无码影片精品久久久 | 久久亚洲中文字幕精品一区 | 久久久婷婷五月亚洲97号色 | 亚洲国产精品久久人人爱 | 大地资源网第二页免费观看 | 国产成人综合色在线观看网站 | 精品久久久久久亚洲精品 | 樱花草在线社区www | 久久久久久国产精品无码下载 | 理论片87福利理论电影 | 欧美人与牲动交xxxx | 亚洲熟妇色xxxxx欧美老妇 | 欧美精品在线观看 | 精品成在人线av无码免费看 | 无码人妻黑人中文字幕 | 奇米综合四色77777久久 东京无码熟妇人妻av在线网址 | 草草网站影院白丝内射 | 久久精品女人的天堂av | 少妇厨房愉情理9仑片视频 | 大地资源网第二页免费观看 | 国产人妻久久精品二区三区老狼 | 欧美日本免费一区二区三区 | 在线观看免费人成视频 | 人人妻在人人 | 沈阳熟女露脸对白视频 | 夜夜夜高潮夜夜爽夜夜爰爰 | 久久人人97超碰a片精品 | 六月丁香婷婷色狠狠久久 | 日本精品人妻无码免费大全 | 青青青手机频在线观看 | 亚洲成色www久久网站 | 国产午夜福利100集发布 | www一区二区www免费 | 四虎影视成人永久免费观看视频 | 性做久久久久久久免费看 | 亚洲 激情 小说 另类 欧美 | 久久久久免费看成人影片 | 国产sm调教视频在线观看 | 精品国产av色一区二区深夜久久 | 台湾无码一区二区 | 久久精品国产亚洲精品 | 国产疯狂伦交大片 | 久久久久se色偷偷亚洲精品av | 亚洲国产欧美日韩精品一区二区三区 | 国产suv精品一区二区五 | 乱人伦人妻中文字幕无码久久网 | 午夜成人1000部免费视频 | 纯爱无遮挡h肉动漫在线播放 | 色婷婷综合中文久久一本 | 国产精品手机免费 | 理论片87福利理论电影 | 亚洲va欧美va天堂v国产综合 | www国产精品内射老师 | www国产精品内射老师 | 狠狠色欧美亚洲狠狠色www | 老熟女重囗味hdxx69 | 亚洲精品成a人在线观看 | 国产又爽又猛又粗的视频a片 | 国产精品无码永久免费888 | 亚洲の无码国产の无码步美 | 人人妻人人澡人人爽欧美一区九九 | 国内精品人妻无码久久久影院蜜桃 | 黑森林福利视频导航 | 西西人体www44rt大胆高清 | 亚洲中文字幕成人无码 | 精品水蜜桃久久久久久久 | 亚洲精品无码国产 | 无码人妻精品一区二区三区下载 | 久久天天躁狠狠躁夜夜免费观看 | 无套内射视频囯产 | 少妇久久久久久人妻无码 | 一本一道久久综合久久 | 影音先锋中文字幕无码 | 天天拍夜夜添久久精品 | 久久国产劲爆∧v内射 | 国产精品久久国产精品99 | 亚洲色欲色欲天天天www | 人人妻人人澡人人爽欧美精品 | 内射爽无广熟女亚洲 | 国产精品va在线观看无码 | 国产精品爱久久久久久久 | 麻豆国产丝袜白领秘书在线观看 | 亚洲欧美精品伊人久久 | 色一情一乱一伦 | 日本爽爽爽爽爽爽在线观看免 | 午夜性刺激在线视频免费 | 亚洲日本va午夜在线电影 | 日本精品久久久久中文字幕 | 亚洲国产成人a精品不卡在线 | 思思久久99热只有频精品66 | 人妻aⅴ无码一区二区三区 | 最新国产麻豆aⅴ精品无码 | 兔费看少妇性l交大片免费 | 亚洲毛片av日韩av无码 | 欧美性猛交内射兽交老熟妇 | 蜜桃av蜜臀av色欲av麻 999久久久国产精品消防器材 | 精品国产一区av天美传媒 | 日日鲁鲁鲁夜夜爽爽狠狠 | 亚洲日韩中文字幕在线播放 | 鲁鲁鲁爽爽爽在线视频观看 | 精品国产乱码久久久久乱码 | 欧洲欧美人成视频在线 | 偷窥日本少妇撒尿chinese | www国产亚洲精品久久久日本 | 亚洲aⅴ无码成人网站国产app | 久久久久久亚洲精品a片成人 | 亚洲男人av香蕉爽爽爽爽 | 西西人体www44rt大胆高清 | 中文字幕乱妇无码av在线 | 乱码av麻豆丝袜熟女系列 | 欧美变态另类xxxx | 四十如虎的丰满熟妇啪啪 | 国产无套内射久久久国产 | 强伦人妻一区二区三区视频18 | 无人区乱码一区二区三区 | 亚洲成a人一区二区三区 | 日本大香伊一区二区三区 | 色 综合 欧美 亚洲 国产 | 中文字幕人妻丝袜二区 | 亚洲の无码国产の无码步美 | 日韩欧美中文字幕在线三区 | 色一情一乱一伦一区二区三欧美 | 精品国产青草久久久久福利 | 亚洲精品久久久久avwww潮水 | 亚洲日韩中文字幕在线播放 | 亚洲第一无码av无码专区 | 国产精品久久久av久久久 | 国产成人无码午夜视频在线观看 | 色一情一乱一伦一视频免费看 | 精品成在人线av无码免费看 | 成 人 免费观看网站 | 久久久精品国产sm最大网站 | 奇米影视7777久久精品人人爽 | 美女黄网站人色视频免费国产 | 人人爽人人爽人人片av亚洲 | 婷婷五月综合激情中文字幕 | 日韩少妇白浆无码系列 | 欧美熟妇另类久久久久久不卡 | 77777熟女视频在线观看 а天堂中文在线官网 | 欧美猛少妇色xxxxx | 在线成人www免费观看视频 | 亚洲日韩一区二区三区 | 亚洲爆乳无码专区 | 亚洲gv猛男gv无码男同 | 欧美日韩色另类综合 | 性做久久久久久久免费看 | 亚洲va中文字幕无码久久不卡 | 国内老熟妇对白xxxxhd | 久久天天躁狠狠躁夜夜免费观看 | 在教室伦流澡到高潮hnp视频 | 99久久人妻精品免费一区 | 99久久人妻精品免费一区 | 在教室伦流澡到高潮hnp视频 | 国产亚洲欧美日韩亚洲中文色 | 国产精品无码一区二区桃花视频 | 色噜噜亚洲男人的天堂 | 黑人巨大精品欧美一区二区 | 少妇高潮一区二区三区99 | 少妇激情av一区二区 | 国产凸凹视频一区二区 | 西西人体www44rt大胆高清 | 天天av天天av天天透 | 亚洲成a人片在线观看日本 | 久久久久se色偷偷亚洲精品av | 午夜理论片yy44880影院 | 亚洲中文无码av永久不收费 | 无码中文字幕色专区 | 国产精品高潮呻吟av久久4虎 | 亚洲国产欧美在线成人 | 在线欧美精品一区二区三区 | 少妇高潮一区二区三区99 | 亚洲国产av精品一区二区蜜芽 | 狠狠噜狠狠狠狠丁香五月 | 99riav国产精品视频 | 久久www免费人成人片 | 欧美大屁股xxxxhd黑色 | 国产成人人人97超碰超爽8 | 欧美丰满熟妇xxxx性ppx人交 | 中文字幕人成乱码熟女app | 成熟女人特级毛片www免费 | 正在播放东北夫妻内射 | 精品水蜜桃久久久久久久 | 国产无套内射久久久国产 | 久久午夜无码鲁丝片 | 久久99精品国产.久久久久 | 亚洲中文无码av永久不收费 | 高清不卡一区二区三区 | 国产亚洲人成a在线v网站 | 老头边吃奶边弄进去呻吟 | 国产精品无码一区二区桃花视频 | 丰满人妻翻云覆雨呻吟视频 | 日韩少妇内射免费播放 | 国产成人精品三级麻豆 | 亚洲最大成人网站 | 国产麻豆精品精东影业av网站 | 国产va免费精品观看 | 日本丰满熟妇videos | 亚洲精品国偷拍自产在线观看蜜桃 | 欧美日本精品一区二区三区 | 精品无码国产一区二区三区av | 99久久精品国产一区二区蜜芽 | 免费视频欧美无人区码 | 狠狠色欧美亚洲狠狠色www | 欧美喷潮久久久xxxxx | 久久久婷婷五月亚洲97号色 | 九九综合va免费看 | 久久婷婷五月综合色国产香蕉 | 中文字幕av无码一区二区三区电影 | 国产99久久精品一区二区 | 欧美丰满老熟妇xxxxx性 | 久激情内射婷内射蜜桃人妖 | 我要看www免费看插插视频 | 东北女人啪啪对白 | aa片在线观看视频在线播放 | 真人与拘做受免费视频一 | 精品欧洲av无码一区二区三区 | 久久综合激激的五月天 | 国产亚洲精品久久久久久大师 | 日日鲁鲁鲁夜夜爽爽狠狠 | 亚洲 日韩 欧美 成人 在线观看 | www国产亚洲精品久久网站 | 日韩精品无码一本二本三本色 | 精品国产福利一区二区 | 久久久成人毛片无码 | 久久综合给合久久狠狠狠97色 | 中文字幕 亚洲精品 第1页 | 欧美人与动性行为视频 | 精品午夜福利在线观看 | 精品国产一区av天美传媒 | 女高中生第一次破苞av | 日韩av无码中文无码电影 | 国产精品亚洲а∨无码播放麻豆 | 亚洲精品国产品国语在线观看 | 欧美亚洲日韩国产人成在线播放 | 久久久精品456亚洲影院 | 国产精品美女久久久久av爽李琼 | 人人爽人人澡人人人妻 | 天天做天天爱天天爽综合网 | 国精品人妻无码一区二区三区蜜柚 | 国产熟妇高潮叫床视频播放 | 精品无人国产偷自产在线 | 久久精品国产大片免费观看 | 51国偷自产一区二区三区 | 色综合视频一区二区三区 | 国产农村妇女aaaaa视频 撕开奶罩揉吮奶头视频 | 无套内谢的新婚少妇国语播放 | 中文字幕av伊人av无码av | 天天av天天av天天透 | 东京热一精品无码av | 久久国产精品萌白酱免费 | 亚洲成a人片在线观看日本 | 亚洲综合在线一区二区三区 | 国内精品人妻无码久久久影院 | 永久免费观看美女裸体的网站 | 中文字幕无码乱人伦 | 无码福利日韩神码福利片 | 午夜熟女插插xx免费视频 | 亚洲色www成人永久网址 | 国产福利视频一区二区 | 亚洲欧洲中文日韩av乱码 | 波多野结衣av一区二区全免费观看 | 噜噜噜亚洲色成人网站 | 麻花豆传媒剧国产免费mv在线 | 亚洲日韩乱码中文无码蜜桃臀网站 | 色综合久久网 | 无码av免费一区二区三区试看 | 野外少妇愉情中文字幕 | 国产无遮挡又黄又爽免费视频 | 秋霞特色aa大片 | 久久天天躁狠狠躁夜夜免费观看 | 中文字幕 亚洲精品 第1页 | 欧美猛少妇色xxxxx | 少妇性荡欲午夜性开放视频剧场 | 欧美日本精品一区二区三区 | 伊人久久大香线蕉av一区二区 | 无套内谢的新婚少妇国语播放 | 九一九色国产 | 亚洲欧洲日本无在线码 | 国产九九九九九九九a片 | 九九在线中文字幕无码 | 中文字幕久久久久人妻 | 亚洲国产精品久久久久久 | 午夜精品久久久内射近拍高清 | 一区二区三区高清视频一 | 免费男性肉肉影院 | 大色综合色综合网站 | 国产无遮挡又黄又爽免费视频 | 曰韩无码二三区中文字幕 | 福利一区二区三区视频在线观看 | 玩弄人妻少妇500系列视频 | 一本加勒比波多野结衣 | 成人性做爰aaa片免费看 | 99精品视频在线观看免费 | 久久精品成人欧美大片 | 国产成人亚洲综合无码 | 大乳丰满人妻中文字幕日本 | 欧美熟妇另类久久久久久不卡 | 少妇性l交大片 | 国产午夜手机精彩视频 | 亚洲色大成网站www | 亚洲欧美精品伊人久久 | 樱花草在线社区www | 波多野结衣aⅴ在线 | 久精品国产欧美亚洲色aⅴ大片 | 久久久无码中文字幕久... | 亚洲一区二区三区四区 | 国语自产偷拍精品视频偷 | 小鲜肉自慰网站xnxx | 成人免费视频视频在线观看 免费 | 中文字幕无码乱人伦 | 97精品国产97久久久久久免费 | 99精品无人区乱码1区2区3区 | 午夜精品久久久久久久久 | 亚洲色无码一区二区三区 | 99麻豆久久久国产精品免费 | 国产精品va在线播放 | 日韩欧美群交p片內射中文 | 男人的天堂av网站 | 亚洲国产精品一区二区美利坚 | 波多野结衣av一区二区全免费观看 | 国产超碰人人爽人人做人人添 | 日韩欧美中文字幕在线三区 | 少妇性荡欲午夜性开放视频剧场 | 久久久久人妻一区精品色欧美 | 婷婷综合久久中文字幕蜜桃三电影 | 久久精品国产精品国产精品污 | 亚洲欧洲中文日韩av乱码 | 国产无套内射久久久国产 | 欧洲精品码一区二区三区免费看 | 18精品久久久无码午夜福利 | 亚洲精品一区二区三区在线观看 | 午夜精品久久久内射近拍高清 | 十八禁真人啪啪免费网站 | 丰满人妻一区二区三区免费视频 | 亚洲成色在线综合网站 | 无码乱肉视频免费大全合集 | 国产精品毛多多水多 | 国产熟妇另类久久久久 | 久久久中文字幕日本无吗 | www一区二区www免费 | 亚洲中文字幕久久无码 | 超碰97人人做人人爱少妇 | 国产午夜无码精品免费看 | 狠狠色噜噜狠狠狠7777奇米 | 在线播放亚洲第一字幕 | 狠狠亚洲超碰狼人久久 | 国产真实夫妇视频 | 国产人成高清在线视频99最全资源 | 日韩av激情在线观看 | 呦交小u女精品视频 | 六十路熟妇乱子伦 | 国产成人精品久久亚洲高清不卡 | 99久久久无码国产aaa精品 | 亚洲精品成人av在线 | 一个人看的www免费视频在线观看 | 无码人妻丰满熟妇区毛片18 | 高潮喷水的毛片 | 国产亚洲精品久久久久久大师 | 国产极品美女高潮无套在线观看 | 欧美三级a做爰在线观看 | 成 人 网 站国产免费观看 | 欧美放荡的少妇 | 国产真实伦对白全集 | 精品水蜜桃久久久久久久 | 成人无码视频免费播放 | 亚洲欧洲无卡二区视頻 | 国产黄在线观看免费观看不卡 | 少妇无码一区二区二三区 | 中文字幕无线码免费人妻 | 精品无码av一区二区三区 | 丝袜人妻一区二区三区 | 天下第一社区视频www日本 | 亚洲日韩av片在线观看 | 日韩欧美中文字幕公布 | 自拍偷自拍亚洲精品被多人伦好爽 | 日韩在线不卡免费视频一区 | 131美女爱做视频 | 人妻互换免费中文字幕 | 国内精品九九久久久精品 | 国产亚洲精品久久久久久 | 亚洲一区二区三区无码久久 | 青春草在线视频免费观看 | 男人和女人高潮免费网站 | 九九久久精品国产免费看小说 | 人人澡人人妻人人爽人人蜜桃 | 成人欧美一区二区三区黑人免费 | 天堂无码人妻精品一区二区三区 | 国产熟妇另类久久久久 | 中文字幕乱码人妻二区三区 | 亚洲欧美综合区丁香五月小说 | 国内丰满熟女出轨videos | 亚洲理论电影在线观看 | 日本丰满护士爆乳xxxx | 亚洲色偷偷男人的天堂 | a在线亚洲男人的天堂 | 黄网在线观看免费网站 | 波多野结衣 黑人 | 99久久无码一区人妻 | 国产莉萝无码av在线播放 | 久久人人爽人人爽人人片av高清 | 粗大的内捧猛烈进出视频 | 黄网在线观看免费网站 | 国产精品毛多多水多 | 久久99精品久久久久久动态图 | 夜夜高潮次次欢爽av女 | 国产精品久久国产三级国 | 啦啦啦www在线观看免费视频 | 成熟女人特级毛片www免费 | 97精品人妻一区二区三区香蕉 | 久久人人爽人人爽人人片av高清 | 国产内射爽爽大片视频社区在线 | 亚洲精品久久久久中文第一幕 | 色 综合 欧美 亚洲 国产 | 人妻插b视频一区二区三区 | 无码精品人妻一区二区三区av | 精品国产一区二区三区四区 | 人人超人人超碰超国产 | 欧美日本日韩 | 永久免费观看国产裸体美女 | 精品久久久久久亚洲精品 | 人妻少妇精品无码专区二区 | 亚洲一区二区三区含羞草 | 人妻少妇被猛烈进入中文字幕 | 精品无码成人片一区二区98 | 无码乱肉视频免费大全合集 | 久久精品国产99精品亚洲 | 久久久久久亚洲精品a片成人 | 久久99久久99精品中文字幕 | 亚洲精品欧美二区三区中文字幕 | 青青草原综合久久大伊人精品 | 国产亲子乱弄免费视频 | 无遮挡国产高潮视频免费观看 | 欧美日韩人成综合在线播放 | 国产午夜亚洲精品不卡 | 国产成人精品三级麻豆 | 久9re热视频这里只有精品 | 无码国产乱人伦偷精品视频 | 人人妻人人澡人人爽人人精品 | 成人一区二区免费视频 | 国产精品美女久久久网av | 狂野欧美性猛xxxx乱大交 | 色婷婷欧美在线播放内射 | 亚洲成a人片在线观看无码3d | 色婷婷久久一区二区三区麻豆 | 国产三级久久久精品麻豆三级 | 无码人中文字幕 | 欧美日韩亚洲国产精品 | 国产激情精品一区二区三区 | 99精品视频在线观看免费 | 亚洲自偷自偷在线制服 | 国产无遮挡又黄又爽又色 | 精品久久久中文字幕人妻 | 亚洲七七久久桃花影院 | 国产综合色产在线精品 | 久久精品人人做人人综合试看 | 色婷婷av一区二区三区之红樱桃 | √天堂中文官网8在线 | 免费乱码人妻系列无码专区 | 鲁大师影院在线观看 | 国产成人久久精品流白浆 | 久久综合久久自在自线精品自 | 国产av剧情md精品麻豆 | 欧美丰满熟妇xxxx性ppx人交 | 亚洲gv猛男gv无码男同 | 成人免费视频视频在线观看 免费 | 97精品国产97久久久久久免费 | 国产卡一卡二卡三 | 久久国产自偷自偷免费一区调 | а天堂中文在线官网 | 久久久中文久久久无码 | 无码国产乱人伦偷精品视频 | 久久 国产 尿 小便 嘘嘘 | 亚洲熟妇色xxxxx欧美老妇y | 在线 国产 欧美 亚洲 天堂 | 成在人线av无码免费 | 精品久久久中文字幕人妻 | 久久久成人毛片无码 | 国产无遮挡又黄又爽又色 | 波多野结衣av在线观看 | 亚洲中文字幕成人无码 | 人人妻人人澡人人爽欧美精品 | 久久97精品久久久久久久不卡 | 无码国内精品人妻少妇 | 亚洲中文字幕久久无码 | 欧美老熟妇乱xxxxx | av无码电影一区二区三区 | 国产黄在线观看免费观看不卡 | 青青草原综合久久大伊人精品 | 大地资源中文第3页 | 欧美三级a做爰在线观看 | 欧美乱妇无乱码大黄a片 | 亚洲精品一区三区三区在线观看 | 天天躁夜夜躁狠狠是什么心态 | 性欧美疯狂xxxxbbbb | √天堂资源地址中文在线 | 精品厕所偷拍各类美女tp嘘嘘 | 人人爽人人爽人人片av亚洲 | 国产成人精品必看 | 国产农村妇女高潮大叫 | 久久这里只有精品视频9 | 国产97在线 | 亚洲 | 欧美国产日韩久久mv | 最近免费中文字幕中文高清百度 | 精品国产一区二区三区av 性色 | 午夜无码人妻av大片色欲 | 国产av无码专区亚洲awww | 亚洲日韩精品欧美一区二区 | 日产精品99久久久久久 | 国产香蕉97碰碰久久人人 | 人妻少妇精品无码专区动漫 | 国产成人综合色在线观看网站 | 久久精品视频在线看15 | 午夜福利一区二区三区在线观看 | 扒开双腿疯狂进出爽爽爽视频 | 亚洲欧洲日本综合aⅴ在线 | 亚洲精品中文字幕久久久久 | 国产高清不卡无码视频 | 久久久久久九九精品久 | 国产午夜无码精品免费看 | 沈阳熟女露脸对白视频 | 98国产精品综合一区二区三区 | 欧美午夜特黄aaaaaa片 | 欧美成人午夜精品久久久 | 国产熟女一区二区三区四区五区 | 亚洲一区二区三区偷拍女厕 | 国产成人综合美国十次 | 丰满岳乱妇在线观看中字无码 | 国产欧美亚洲精品a | 免费看男女做好爽好硬视频 | 欧美zoozzooz性欧美 | 日韩欧美群交p片內射中文 | 精品国产青草久久久久福利 | 亚洲精品久久久久avwww潮水 | 国产人妻精品一区二区三区 | 欧美阿v高清资源不卡在线播放 | 精品无码成人片一区二区98 | 国产黄在线观看免费观看不卡 | 99久久久国产精品无码免费 | 中文字幕日韩精品一区二区三区 | 97久久精品无码一区二区 | 一本无码人妻在中文字幕免费 | 对白脏话肉麻粗话av | 西西人体www44rt大胆高清 | 久久久久人妻一区精品色欧美 | 国产网红无码精品视频 | 99精品久久毛片a片 | 一本久道久久综合狠狠爱 | 未满成年国产在线观看 | 国产免费无码一区二区视频 | 亚洲欧美精品伊人久久 | 国产片av国语在线观看 | 久久99精品国产麻豆蜜芽 | 鲁鲁鲁爽爽爽在线视频观看 | 亚洲综合无码一区二区三区 | 精品人妻人人做人人爽夜夜爽 | 国产午夜精品一区二区三区嫩草 | 国产一区二区三区日韩精品 | 中文字幕无码乱人伦 | 亚洲狠狠色丁香婷婷综合 | 国内精品一区二区三区不卡 | 日本护士毛茸茸高潮 | 久热国产vs视频在线观看 | 成 人 免费观看网站 | 精品欧美一区二区三区久久久 | 国产激情无码一区二区 | 成熟妇人a片免费看网站 | 麻豆精产国品 | 亚洲国产av精品一区二区蜜芽 | 亚洲一区二区三区国产精华液 | 国产福利视频一区二区 | v一区无码内射国产 | 日韩精品乱码av一区二区 | 思思久久99热只有频精品66 | 动漫av一区二区在线观看 | 妺妺窝人体色www在线小说 | 亚洲国产精品一区二区美利坚 | 亚洲无人区午夜福利码高清完整版 | 国产成人无码区免费内射一片色欲 | 少妇太爽了在线观看 | 大色综合色综合网站 | 久激情内射婷内射蜜桃人妖 | 欧洲欧美人成视频在线 | 日本xxxx色视频在线观看免费 | 欧美亚洲日韩国产人成在线播放 | 欧美人与动性行为视频 | 欧美性生交xxxxx久久久 | 欧洲熟妇色 欧美 | 内射白嫩少妇超碰 | 国产精品久久久久久亚洲影视内衣 | 超碰97人人做人人爱少妇 | 久久午夜夜伦鲁鲁片无码免费 | 国产精品多人p群无码 | 成人免费视频视频在线观看 免费 | 久久久久av无码免费网 | 婷婷丁香五月天综合东京热 | a在线亚洲男人的天堂 | 97久久国产亚洲精品超碰热 | 国产精品对白交换视频 | 国产精品二区一区二区aⅴ污介绍 | 国内精品人妻无码久久久影院蜜桃 | 波多野结衣高清一区二区三区 | 日韩精品一区二区av在线 | 人人超人人超碰超国产 | 大乳丰满人妻中文字幕日本 | 久久午夜无码鲁丝片午夜精品 | 黑人粗大猛烈进出高潮视频 | 黑人玩弄人妻中文在线 | 国产精品免费大片 | 久久人人爽人人爽人人片av高清 | 国产麻豆精品精东影业av网站 | 夜夜影院未满十八勿进 | 中文无码精品a∨在线观看不卡 | 日韩少妇内射免费播放 | 婷婷综合久久中文字幕蜜桃三电影 | 大肉大捧一进一出视频出来呀 | 久久国内精品自在自线 | 日韩av无码一区二区三区 | 国产真人无遮挡作爱免费视频 | 免费无码的av片在线观看 | 天天拍夜夜添久久精品 | 爽爽影院免费观看 | 久久婷婷五月综合色国产香蕉 | 夜夜高潮次次欢爽av女 | 日韩av无码一区二区三区 | 亚洲精品国产精品乱码视色 | 人人妻人人澡人人爽精品欧美 | 色五月五月丁香亚洲综合网 | 国产人妻大战黑人第1集 | 久久精品99久久香蕉国产色戒 | 99久久久无码国产aaa精品 | 一本大道久久东京热无码av | 亚洲国精产品一二二线 | 亚洲の无码国产の无码步美 | 国产xxx69麻豆国语对白 | 亚洲国产精品无码久久久久高潮 | 亚洲色成人中文字幕网站 | 欧美人与物videos另类 | 日产精品高潮呻吟av久久 | 香港三级日本三级妇三级 | 无码乱肉视频免费大全合集 | 国产激情一区二区三区 | 久久国语露脸国产精品电影 | 久久zyz资源站无码中文动漫 | 亚洲国产av精品一区二区蜜芽 | 久久人人97超碰a片精品 | 精品一区二区三区无码免费视频 | 97精品国产97久久久久久免费 | 人人妻人人藻人人爽欧美一区 | 搡女人真爽免费视频大全 | 一个人免费观看的www视频 | 中文字幕日韩精品一区二区三区 | 国产av剧情md精品麻豆 | 国产成人精品久久亚洲高清不卡 | 国产艳妇av在线观看果冻传媒 | 国产精品成人av在线观看 | 狠狠综合久久久久综合网 | 亚洲中文无码av永久不收费 | www国产精品内射老师 | 1000部啪啪未满十八勿入下载 | 欧美激情综合亚洲一二区 | 99久久久国产精品无码免费 | 无码国产色欲xxxxx视频 | 亚洲欧美精品伊人久久 | 久久精品女人的天堂av | 亚洲精品一区二区三区在线观看 | 波多野42部无码喷潮在线 | 天天拍夜夜添久久精品 | 青草青草久热国产精品 | 亚洲成a人片在线观看日本 | 全黄性性激高免费视频 | 午夜不卡av免费 一本久久a久久精品vr综合 | 天天做天天爱天天爽综合网 | 色五月丁香五月综合五月 | 大肉大捧一进一出好爽视频 | 久久精品人妻少妇一区二区三区 | a在线亚洲男人的天堂 | 色婷婷av一区二区三区之红樱桃 | 国产亚洲精品久久久久久久 | 水蜜桃亚洲一二三四在线 | 天海翼激烈高潮到腰振不止 | 欧洲美熟女乱又伦 | 精品人人妻人人澡人人爽人人 | 精品无码国产一区二区三区av | 精品日本一区二区三区在线观看 | 成人aaa片一区国产精品 | 99麻豆久久久国产精品免费 | 亚洲精品一区二区三区在线 | 玩弄人妻少妇500系列视频 | 性生交片免费无码看人 | 久久精品国产亚洲精品 | 性欧美牲交xxxxx视频 | 搡女人真爽免费视频大全 | 波多野结衣一区二区三区av免费 | 伊人久久婷婷五月综合97色 | 国产亚av手机在线观看 | 人人澡人摸人人添 | 亚洲日韩一区二区 | 亚洲中文字幕无码一久久区 | 狠狠综合久久久久综合网 | 久久综合给合久久狠狠狠97色 | 人人妻人人澡人人爽人人精品 | 在教室伦流澡到高潮hnp视频 | 中文字幕乱码人妻二区三区 | a片免费视频在线观看 | 亚洲欧洲中文日韩av乱码 | 国产精品国产自线拍免费软件 | 精品乱子伦一区二区三区 | 男女爱爱好爽视频免费看 | 国产一区二区三区精品视频 | 欧美亚洲日韩国产人成在线播放 | 免费中文字幕日韩欧美 | 精品一区二区不卡无码av | 人人妻人人澡人人爽人人精品浪潮 | yw尤物av无码国产在线观看 | 暴力强奷在线播放无码 | 欧美变态另类xxxx | 好男人社区资源 | 露脸叫床粗话东北少妇 | aⅴ在线视频男人的天堂 | 国模大胆一区二区三区 | 亚洲综合精品香蕉久久网 | 未满成年国产在线观看 | 国产麻豆精品一区二区三区v视界 | 国产精品18久久久久久麻辣 | 国精品人妻无码一区二区三区蜜柚 | 欧美日韩一区二区三区自拍 | 99精品久久毛片a片 | 亚洲国产日韩a在线播放 | 国产精品久久久av久久久 | 麻豆精品国产精华精华液好用吗 | 无码国产激情在线观看 | 99久久人妻精品免费二区 | 中文字幕人妻无码一区二区三区 | 亚洲国产精品久久久天堂 | 亚洲高清偷拍一区二区三区 | 精品少妇爆乳无码av无码专区 | 国产精品久久久久久无码 | 色婷婷综合中文久久一本 | 最近的中文字幕在线看视频 | 377p欧洲日本亚洲大胆 | 扒开双腿吃奶呻吟做受视频 | 国产亚洲精品久久久久久大师 | 在线天堂新版最新版在线8 | 中文无码精品a∨在线观看不卡 | 精品国产乱码久久久久乱码 | 正在播放东北夫妻内射 | 欧美性猛交内射兽交老熟妇 | 国产三级精品三级男人的天堂 | 国产午夜福利100集发布 | 久久无码专区国产精品s | 99久久人妻精品免费二区 | 草草网站影院白丝内射 | 国产无套粉嫩白浆在线 | 国产乱人伦偷精品视频 | 精品午夜福利在线观看 | 最新国产乱人伦偷精品免费网站 | 免费视频欧美无人区码 | 国产人妻精品一区二区三区不卡 | 我要看www免费看插插视频 | 波多野42部无码喷潮在线 | 日本免费一区二区三区最新 | 久久精品丝袜高跟鞋 | 牛和人交xxxx欧美 | 奇米影视888欧美在线观看 | 亚洲午夜无码久久 | aⅴ亚洲 日韩 色 图网站 播放 | 国产综合色产在线精品 | 在线欧美精品一区二区三区 | 亚洲国产欧美国产综合一区 | 亚洲色欲色欲天天天www | 成在人线av无码免费 | 精品国精品国产自在久国产87 | 国产无遮挡又黄又爽免费视频 | 久久亚洲精品成人无码 | 国产精品igao视频网 | 大胆欧美熟妇xx | 久久综合九色综合欧美狠狠 | 99久久亚洲精品无码毛片 | 99久久亚洲精品无码毛片 | 国产在线无码精品电影网 | 大肉大捧一进一出视频出来呀 | 99国产精品白浆在线观看免费 | 成人影院yy111111在线观看 | 亚洲 高清 成人 动漫 | 国产成人无码a区在线观看视频app | 久久人人97超碰a片精品 | 97久久国产亚洲精品超碰热 | 极品嫩模高潮叫床 | 丰满少妇熟乱xxxxx视频 | 亚洲成av人片在线观看无码不卡 | 高清国产亚洲精品自在久久 | 激情亚洲一区国产精品 | 国产成人久久精品流白浆 | 亚洲国产欧美国产综合一区 | 美女极度色诱视频国产 | 欧美大屁股xxxxhd黑色 | 国产人妻久久精品二区三区老狼 | 少妇无码一区二区二三区 | 精品成人av一区二区三区 | 国产无套内射久久久国产 | 久久国产精品二国产精品 | 色一情一乱一伦 | 国产精品人人妻人人爽 | 99久久精品日本一区二区免费 | 久久久久国色av免费观看性色 | 亚洲成av人在线观看网址 | 久久综合给久久狠狠97色 | 精品一区二区三区波多野结衣 | 亚洲日韩精品欧美一区二区 | 亲嘴扒胸摸屁股激烈网站 | 日韩精品无码一区二区中文字幕 | 图片小说视频一区二区 | 乱人伦人妻中文字幕无码久久网 | 无码人妻丰满熟妇区五十路百度 | 国产精品久久国产三级国 | 亚洲乱码中文字幕在线 | 国产女主播喷水视频在线观看 | 日本肉体xxxx裸交 | 国产疯狂伦交大片 | 欧美freesex黑人又粗又大 | 亚洲国产高清在线观看视频 | 国产乱人伦app精品久久 国产在线无码精品电影网 国产国产精品人在线视 | 成年美女黄网站色大免费全看 | 国产做国产爱免费视频 | 性啪啪chinese东北女人 | 精品久久久无码中文字幕 | 亚洲国产成人av在线观看 | 无码av中文字幕免费放 | 久久精品国产大片免费观看 | 日本高清一区免费中文视频 | 高清不卡一区二区三区 | 国产在线无码精品电影网 | 亚洲精品一区二区三区在线 | 天天av天天av天天透 | 久久精品中文字幕一区 | 成人精品视频一区二区 | 亚洲一区二区三区播放 | 亚洲乱码日产精品bd | 亚洲一区二区三区四区 | 少妇厨房愉情理9仑片视频 | 国产亚洲日韩欧美另类第八页 | 久久熟妇人妻午夜寂寞影院 | 精品一区二区三区波多野结衣 | 亚洲爆乳精品无码一区二区三区 | 亚洲精品无码人妻无码 | 国产一区二区不卡老阿姨 | 无码国内精品人妻少妇 | 久热国产vs视频在线观看 | 欧美激情一区二区三区成人 | 亚洲中文字幕无码一久久区 | 夫妻免费无码v看片 | 男女爱爱好爽视频免费看 | √8天堂资源地址中文在线 | 天堂а√在线地址中文在线 | 人妻天天爽夜夜爽一区二区 | 人妻插b视频一区二区三区 | 精品一二三区久久aaa片 | 97人妻精品一区二区三区 | 精品久久久无码中文字幕 | 成人试看120秒体验区 | 国产成人人人97超碰超爽8 | 99久久久无码国产精品免费 | 国精产品一品二品国精品69xx | 天堂а√在线地址中文在线 | 中文字幕乱码人妻二区三区 | 丰满护士巨好爽好大乳 | 免费人成在线观看网站 | 国产精品永久免费视频 | 欧洲熟妇精品视频 | aa片在线观看视频在线播放 | 男女性色大片免费网站 | 性史性农村dvd毛片 | 一本久久伊人热热精品中文字幕 | 暴力强奷在线播放无码 | 亚洲狠狠色丁香婷婷综合 | 国产成人精品三级麻豆 | 亚洲午夜久久久影院 | 国产av无码专区亚洲a∨毛片 | yw尤物av无码国产在线观看 | 国产精品福利视频导航 | 国产绳艺sm调教室论坛 | 国产真实伦对白全集 | 永久免费精品精品永久-夜色 | 欧美日韩视频无码一区二区三 | 四虎永久在线精品免费网址 | 国产精品.xx视频.xxtv | 国产精品无码久久av | 天天爽夜夜爽夜夜爽 | 妺妺窝人体色www在线小说 | 无码一区二区三区在线 | 18无码粉嫩小泬无套在线观看 | 天天躁日日躁狠狠躁免费麻豆 | 久久综合色之久久综合 | 少妇被黑人到高潮喷出白浆 | 日韩精品一区二区av在线 | 亚洲另类伦春色综合小说 | 99国产精品白浆在线观看免费 | 99久久精品无码一区二区毛片 | 国产69精品久久久久app下载 | 成人性做爰aaa片免费看不忠 | 帮老师解开蕾丝奶罩吸乳网站 | 欧美精品一区二区精品久久 | 亚洲色无码一区二区三区 | 亚洲国产精品久久久天堂 | 波多野结衣av一区二区全免费观看 | 国产精品视频免费播放 | 又色又爽又黄的美女裸体网站 | 日本丰满护士爆乳xxxx | 熟妇女人妻丰满少妇中文字幕 | 欧美成人午夜精品久久久 | 曰本女人与公拘交酡免费视频 | 色综合久久久无码网中文 | 国产精华av午夜在线观看 | 久久人人爽人人爽人人片ⅴ | 国产人成高清在线视频99最全资源 | 国产精华av午夜在线观看 | 久久久国产一区二区三区 | 精品久久久久久亚洲精品 | 小泽玛莉亚一区二区视频在线 | 成人试看120秒体验区 | 久久午夜无码鲁丝片秋霞 | 黑人粗大猛烈进出高潮视频 | 麻豆蜜桃av蜜臀av色欲av | 国产无套粉嫩白浆在线 | 国产亚洲欧美在线专区 | 色五月丁香五月综合五月 | 欧美日本精品一区二区三区 | 白嫩日本少妇做爰 | 欧美黑人巨大xxxxx | 大肉大捧一进一出好爽视频 | 精品一区二区三区波多野结衣 | 国产精品无码mv在线观看 | 国产精品无码一区二区三区不卡 | av小次郎收藏 | 欧美熟妇另类久久久久久多毛 | 麻豆成人精品国产免费 | 综合激情五月综合激情五月激情1 | 熟女少妇人妻中文字幕 | 欧美人妻一区二区三区 | 撕开奶罩揉吮奶头视频 | 精品国偷自产在线视频 | 国产深夜福利视频在线 | 国产av剧情md精品麻豆 | 清纯唯美经典一区二区 | 又粗又大又硬又长又爽 | 妺妺窝人体色www在线小说 | 无码中文字幕色专区 | 中文字幕av伊人av无码av | 精品一区二区三区波多野结衣 | 一本久久伊人热热精品中文字幕 | v一区无码内射国产 | 在线亚洲高清揄拍自拍一品区 | 装睡被陌生人摸出水好爽 | 天天拍夜夜添久久精品大 | 亚洲毛片av日韩av无码 | 最近中文2019字幕第二页 | 欧美午夜特黄aaaaaa片 | 成人欧美一区二区三区 | 丰满少妇熟乱xxxxx视频 | 国语自产偷拍精品视频偷 | 最近中文2019字幕第二页 | 国产国产精品人在线视 | 婷婷丁香六月激情综合啪 | 国产精品久久久av久久久 | 狠狠色丁香久久婷婷综合五月 | 久久久国产精品无码免费专区 | 国产极品美女高潮无套在线观看 | 俺去俺来也www色官网 | 丁香花在线影院观看在线播放 | 国产精品无码mv在线观看 | 日本在线高清不卡免费播放 | 荫蒂添的好舒服视频囗交 | 青春草在线视频免费观看 | 丰满岳乱妇在线观看中字无码 | 欧美日韩色另类综合 | 亚洲无人区午夜福利码高清完整版 | 乱人伦人妻中文字幕无码 | 色婷婷av一区二区三区之红樱桃 | 亚洲综合无码一区二区三区 | 日日碰狠狠躁久久躁蜜桃 | 对白脏话肉麻粗话av | 日本大香伊一区二区三区 | 色窝窝无码一区二区三区色欲 | 天天av天天av天天透 | 大肉大捧一进一出好爽视频 | 亚洲国产欧美国产综合一区 | 内射爽无广熟女亚洲 | 亚洲高清偷拍一区二区三区 | 日日摸日日碰夜夜爽av | 少女韩国电视剧在线观看完整 | 精品夜夜澡人妻无码av蜜桃 | 一个人看的www免费视频在线观看 | 久久久亚洲欧洲日产国码αv | 久久国产精品精品国产色婷婷 | 日本精品少妇一区二区三区 | 无码任你躁久久久久久久 | 久久人人97超碰a片精品 | 人妻无码久久精品人妻 | 亚洲 高清 成人 动漫 | 一本久久伊人热热精品中文字幕 | 无遮挡啪啪摇乳动态图 | 中文字幕无码日韩专区 | 少女韩国电视剧在线观看完整 | 免费播放一区二区三区 | 全黄性性激高免费视频 | 88国产精品欧美一区二区三区 | 日本护士xxxxhd少妇 | 特大黑人娇小亚洲女 | 色窝窝无码一区二区三区色欲 | 国产精品理论片在线观看 | 国产精品久免费的黄网站 | 色五月丁香五月综合五月 | 欧洲欧美人成视频在线 | 午夜性刺激在线视频免费 | 丝袜美腿亚洲一区二区 | 精品久久久久久亚洲精品 |