亚洲精品久久久中文字幕-亚洲精品久久片久久-亚洲精品久久青草-亚洲精品久久婷婷爱久久婷婷-亚洲精品久久午夜香蕉

您的位置:首頁(yè)技術(shù)文章
文章詳情頁(yè)

CVS常用命令速查手冊(cè)

瀏覽:12日期:2024-07-20 13:50:41
內(nèi)容: 出處:http://www.chedong.com/tech/cvs_card.htmlCVS是一個(gè)C/S系統(tǒng),多個(gè)開發(fā)人員通過一個(gè)中心版本控制系統(tǒng)來記錄文件版本,從而達(dá)到保證文件同步的目的。工作模式如下: CVS服務(wù)器(文件版本庫(kù)) / | (版 本 同 步) / | 開發(fā)者1 開發(fā)者2 開發(fā)者3開發(fā)人員入門可以主要挑選2,6看就可以了,CVS的管理員則更需要懂的更多一些,最后還簡(jiǎn)單介紹了一些Windows下的cvs客戶端使用,遠(yuǎn)程用戶認(rèn)證的選擇,及與BUG跟蹤系統(tǒng)等開發(fā)環(huán)境的集成問題。CVS環(huán)境初始化:CVS環(huán)境的搭建 管理員 CVS的日常使用:日常開發(fā)中最常用的CVS命令, 開發(fā)人員 管理員 CVS的分支開發(fā):項(xiàng)目按照不同進(jìn)度和目標(biāo)并發(fā)進(jìn)行 管理員 CVS的用戶認(rèn)證:通過SSH的遠(yuǎn)程用戶認(rèn)證,安全,簡(jiǎn)單 管理員 CVSWEB:CVS的WEB訪問界面大大提高代碼版本比較的效率 管理員 CVS TAG:將$Header$加入代碼注釋中,方便開發(fā)過程的跟蹤 開發(fā)人員 CVS vs VSS: CVS和Virsual SourceSafe的比較 開發(fā)人員 管理員 WinCVS: 通過SSH認(rèn)證的WinCVS認(rèn)證設(shè)置 基于CVSTrac的小組開發(fā)環(huán)境搭建:通過CVSTrac實(shí)現(xiàn)web界面的CVS用戶管理及集成的BUG跟蹤和WIKI交流。 一個(gè)系統(tǒng)20%的功能往往能夠滿足80%的需求,CVS也不例外,以下是CVS最常用的功能,可能還不到它全部命令選項(xiàng)的20%,更多的功能在實(shí)際應(yīng)用過程中體會(huì),你想用多少就學(xué)多少,不時(shí)回頭看看經(jīng)常有意外的收獲。CVS環(huán)境初始化============環(huán)境設(shè)置:指定CVS庫(kù)的路徑CVSROOTtcshsetenv CVSROOT /path/to/cvsrootbashCVSROOT=/path/to/cvsroot ; export CVSROOT后面還提到遠(yuǎn)程CVS服務(wù)器的設(shè)置:CVSROOT=:ext:$USER@test.server.address#port:/path/to/cvsroot CVS_RSH=ssh; export CVSROOT CVS_RSH初始化:CVS版本庫(kù)的初始化。cvs init一個(gè)項(xiàng)目的首次導(dǎo)入cvs import -m 'write some comments here' project_name vendor_tag release_tag執(zhí)行后:會(huì)將所有源文件及目錄導(dǎo)入到/path/to/cvsroot/project_name目錄下vender_tag: 開發(fā)商標(biāo)記release_tag: 版本發(fā)布標(biāo)記項(xiàng)目導(dǎo)出:將代碼從CVS庫(kù)里導(dǎo)出cvs checkout project_namecvs 將創(chuàng)建project_name目錄,并將最新版本的源代碼導(dǎo)出到相應(yīng)目錄中。這個(gè)checkout和Virvual SourceSafe中的check out不是一個(gè)概念,相對(duì)于Virvual SourceSafe的check out是cvs update, check in是cvs commit。CVS的日常使用 =============注意:第一次導(dǎo)出以后,就不是通過cvs checkout來同步文件了,而是要進(jìn)入剛才cvs checkout project_name導(dǎo)出的project_name目錄下進(jìn)行具體文件的版本同步(添加,修改,刪除)操作。將文件同步到最新的版本cvs update不制定文件名,cvs將同步所有子目錄下的文件,也可以制定某個(gè)文件名/目錄進(jìn)行同步cvs update file_name最好每天開始工作前或?qū)⒆约旱墓ぷ鲗?dǎo)入到CVS庫(kù)里前都要做一次,并養(yǎng)成“先同步 后修改的習(xí)慣,和Virvual SourceSafe不同,CVS里沒有文件鎖定的概念,所有的沖突是在commit之前解決,如果你修改過程中,有其他人修改并commit到了CVS庫(kù)中,CVS會(huì)通知你文件沖突,并自動(dòng)將沖突部分用>>>>>>content on cvs server標(biāo)記出來,由你確認(rèn)沖突內(nèi)容的取舍。版本沖突一般是在多個(gè)人修改一個(gè)文件造成的,但這種項(xiàng)目管理上的問題不應(yīng)該指望由CVS來解決。確認(rèn)修改寫入到CVS庫(kù)里cvs commit -m 'write some comments here' file_name注意:CVS的很多動(dòng)作都是通過cvs commit進(jìn)行最后確認(rèn)并修改的,最好每次只修改一個(gè)文件。在確認(rèn)的前,還需要用戶填寫修改注釋,以幫助其他開發(fā)人員了解修改的原因。如果不用寫-m 'comments'而直接確認(rèn)`cvs commit file_name` 的話,cvs會(huì)自動(dòng)調(diào)用系統(tǒng)缺省的文字編輯器(一般是vi)要求你寫入注釋。注釋的質(zhì)量很重要:所以不僅必須要寫,而且必須寫一些比較有意義的內(nèi)容:以方便其他開發(fā)人員能夠很好的理解不好的注釋,很難讓其他的開發(fā)人員快速的理解:比如: -m 'bug fixed' 甚至 -m ''好的注釋,甚至可以用中文: -m '在用戶注冊(cè)過程中加入了Email地址校驗(yàn)' 修改某個(gè)版本注釋:每次只確認(rèn)一個(gè)文件到CVS庫(kù)里是一個(gè)很好的習(xí)慣,但難免有時(shí)候忘了指定文件名,把多個(gè)文件以同樣注釋commit到CVS庫(kù)里了,以下命令可以允許你修改某個(gè)文件某個(gè)版本的注釋:cvs admin -m 1.3:'write some comments here' file_name添加文件創(chuàng)建好新文件后,比如:touch new_filecvs add new_file注意:對(duì)于圖片,Word文檔等非純文本的項(xiàng)目,需要使用cvs add -kb選項(xiàng)按2進(jìn)制文件方式導(dǎo)入(k表示擴(kuò)展選項(xiàng),b表示binary),否則有可能出現(xiàn)文件被破壞的情況比如:cvs add -kb new_file.gifcvs add -kb readme.doc然后確認(rèn)修改并注釋 cvs ci -m 'write some comments here'刪除文件將某個(gè)源文件物理刪除后,比如:rm file_namecvs rm file_name然后確認(rèn)修改并注釋cvs ci -m 'write some comments here'以上面前2步合并的方法為:cvs rm -f file_namecvs ci -m 'why delete file'注意:很多cvs命令都有縮寫形式:commit=>ci; update=>up; checkout=>co/get; remove=>rm; 添加目錄cvs add dir_name查看修改歷史cvs log file_namecvs history file_name查看當(dāng)前文件不同版本的區(qū)別cvs diff -r1.3 -r1.5 file_name查看當(dāng)前文件(可能已經(jīng)修改了)和庫(kù)中相應(yīng)文件的區(qū)別cvs diff file_namecvs的web界面提供了更方便的定位文件修改和比較版本區(qū)別的方法,具體安裝設(shè)置請(qǐng)看后面的cvsweb使用正確的通過CVS恢復(fù)舊版本的方法:如果用cvs update -r1.2 file.name這個(gè)命令是給file.name加一個(gè)STICK TAG: '1.2' ,雖然你的本意只是想將它恢復(fù)到1.2版本正確的恢復(fù)版本的方法是:cvs update -p -r1.2 file_name>file_name如果不小心已經(jīng)加成STICK TAG的話:用cvs update -A 解決移動(dòng)文件/文件重命名cvs里沒有cvs move或cvs rename,因?yàn)檫@兩個(gè)操作是可以由先cvs remove old_file_name,然后cvs add new_file_name實(shí)現(xiàn)的。刪除/移動(dòng)目錄最方便的方法是讓管理員直接移動(dòng),刪除CVSROOT里相應(yīng)目錄(因?yàn)镃VS一個(gè)項(xiàng)目下的子目錄都是獨(dú)立的,移動(dòng)到$CVSROOT目錄下都可以作為新的獨(dú)立項(xiàng)目:好比一顆樹,其實(shí)砍下任意一枝都能獨(dú)立存活),對(duì)目錄進(jìn)行了修改后,要求其開發(fā)人員重新導(dǎo)出項(xiàng)目cvs checkout project_name 或者用cvs update -dP同步。項(xiàng)目發(fā)布導(dǎo)出不帶CVS目錄的源文件做開發(fā)的時(shí)候你可能注意到了,每個(gè)開發(fā)目錄下,CVS都創(chuàng)建了一個(gè)CVS/目錄。里面有文件用于記錄當(dāng)前目錄和CVS庫(kù)之間的對(duì)應(yīng)信息。但項(xiàng)目發(fā)布的時(shí)候你一般不希望把文件目錄還帶著含有CVS信息的CVS目錄吧,這個(gè)一次性的導(dǎo)出過程使用cvs export命令,不過export只能針對(duì)一個(gè)TAG或者日期導(dǎo)出,比如:cvs export -r release1 project_name cvs export -D 20021023 project_namecvs export -D now project_nameCVS Branch:項(xiàng)目多分支同步開發(fā)=============================確認(rèn)版本里程碑:多個(gè)文件各自版本號(hào)不一樣,項(xiàng)目到一定階段,可以給所有文件統(tǒng)一指定一個(gè)階段里程碑版本號(hào),方便以后按照這個(gè)階段里程碑版本號(hào)導(dǎo)出項(xiàng)目,同時(shí)也是項(xiàng)目的多個(gè)分支開發(fā)的基礎(chǔ)。cvs tag release_1_0開始一個(gè)新的里程碑:cvs commit -r 2 標(biāo)記所有文件開始進(jìn)入2.x的開發(fā)注意:CVS里的revsion和軟件包的發(fā)布版本可以沒有直接的關(guān)系。但所有文件使用和發(fā)布版本一致的版本號(hào)比較有助于維護(hù)。版本分支的建立在開發(fā)項(xiàng)目的2.x版本的時(shí)候發(fā)現(xiàn)1.x有問題,但2.x又不敢用,則從先前標(biāo)記的里程碑:release_1_0導(dǎo)出一個(gè)分支release_1_0_patchcvs rtag -b -r release_1_0 release_1_0_patch proj_dir一些人先在另外一個(gè)目錄下導(dǎo)出release_1_0_patch這個(gè)分支:解決1.0中的緊急問題,cvs checkout -r release_1_0_patch而其他人員仍舊在項(xiàng)目的主干分支2.x上開發(fā)在release_1_0_patch上修正錯(cuò)誤后,標(biāo)記一個(gè)1.0的錯(cuò)誤修正版本號(hào)cvs tag release_1_0_patch_1如果2.0認(rèn)為這些錯(cuò)誤修改在2.0里也需要,也可以在2.0的開發(fā)目錄下合并release_1_0_patch_1中的修改到當(dāng)前代碼中:cvs update -j release_1_0_patch_1CVS的遠(yuǎn)程認(rèn)證:通過SSH遠(yuǎn)程訪問CVS================================使用cvs本身基于pserver的遠(yuǎn)程認(rèn)證很麻煩,需要定義服務(wù)器和用戶組,用戶名,設(shè)置密碼等,常見的登陸格式如下:cvs -d :pserver:cvs_user_name@cvs.server.address:/path/to/cvsroot login例子:cvs -d :pserver:cvs@samba.org:/cvsroot login不是很安全,因此一般是作為匿名只讀CVS訪問的方式。從安全考慮,通過系統(tǒng)本地帳號(hào)認(rèn)證并通過SSH傳輸是比較好的辦法,通過在客戶機(jī)的/etc/profile里設(shè)置一下內(nèi)容:CVSROOT=:ext:$USER@cvs.server.address#port:/path/to/cvsroot CVS_RSH=ssh; export CVSROOT CVS_RSH所有客戶機(jī)所有本地用戶都可以映射到CVS服務(wù)器相應(yīng)同名帳號(hào)了。比如:CVS服務(wù)器是192.168.0.3,上面CVSROOT路徑是/home/cvsroot,另外一臺(tái)開發(fā)客戶機(jī)是192.168.0.4,如果tom在2臺(tái)機(jī)器上都有同名的帳號(hào),那么從192.168.0.4上設(shè)置了:export CVSROOT=:ext:tom@192.168.0.3:/home/cvsrootexport CVS_RSH=sshtom就可以直接在192.168.0.4上對(duì)192.168.0.3的cvsroot進(jìn)行訪問了(如果有權(quán)限的話)cvs checkout project_namecd project_namecvs update...cvs commit 如果CVS所在服務(wù)器的SSH端口不在缺省的22,或者和客戶端與CVS服務(wù)器端SSH缺省端口不一致,有時(shí)候設(shè)置了::ext:$USER@test.server.address#port:/path/to/cvsroot 仍然不行,比如有以下錯(cuò)誤信息:ssh: test.server.address#port: Name or service not knowncvs [checkout aborted]: end of file from server (consult above messages if any)解決的方法是做一個(gè)腳本指定端口轉(zhuǎn)向(不能使用alias,會(huì)出找不到文件錯(cuò)誤):創(chuàng)建一個(gè)/usr/bin/ssh_cvs文件:#!/usr/bin/sh/path/to/ssh -p 34567 '$@'然后:chmod +x /usr/bin/ssh_cvs并CVS_RSH=ssh_cvs; export CVS_RSH注意:port是指相應(yīng)服務(wù)器SSH的端口,不是cvs pserver的端口CVSWEB:提高文件瀏覽效率=======================CVSWEB就是CVS的WEB界面,可以大大提高程序員定位修改的效率:使用的樣例可以看:http://www.freebsd.org/cgi/cvsweb.cgiCVSWEB的下載:CVSWEB從最初的版本已經(jīng)演化出很多功能界面更豐富的版本,這個(gè)是我個(gè)人感覺安裝設(shè)置比較方便的:http://www.spaghetti-code.de/software/linux/cvsweb/下載解包:tar zxf cvsweb.tgz把配置文件cvsweb.conf放到安全的地方(比如和apache的配置放在同一個(gè)目錄下),修改:cvsweb.cgi讓CGI找到配置文件:$config = $ENV{'CVSWEB_CONFIG'} || '/path/to/apache/conf/cvsweb.conf';轉(zhuǎn)到/path/to/apache/conf下并修改cvsweb.conf:修改CVSROOT路徑設(shè)置:%CVSROOT = ('Development' => '/path/to/cvsroot', # '1',#preference設(shè)置1 在general選單里設(shè)置CVSROOT: username@192.168.0.123:/home/cvsroot設(shè)置Authorization: 選擇SSH server2 Port選單里鉤上:check for alternate rsh name并設(shè)置ssh.exe的路徑,缺省是裝在 C:Program FilesNetworkSimplicitysshssh.exe 然后就可以使用WinCVS進(jìn)行cvs操作了,所有操作都會(huì)跳出命令行窗口要求你輸入服務(wù)器端的認(rèn)證密碼。 當(dāng)然,如果你覺得這樣很煩的話,還有一個(gè)辦法就是生成一個(gè)沒有密碼的公鑰/私鑰對(duì),并設(shè)置CVS使用基于公鑰/私鑰的SSH認(rèn)證(在general選單里)。可以選擇的diff工具:examdiff下載:http://www.prestosoft.com/examdiff/examdiff.htm還是在WinCVS菜單admin==>preference的WinCVS選單里選上:Externel diff program并設(shè)置diff工具的路徑,比如:C:Program Filesed16iExamDiff.exe在對(duì)文件進(jìn)行版本diff時(shí),第一次需要將窗口右下角的use externel diff選上。 基于CVSTrac的小組開發(fā)環(huán)境搭建============================== 作為一個(gè)小組級(jí)的開發(fā)環(huán)境,版本控制系統(tǒng)和BUG跟蹤系統(tǒng)等都涉及到用戶認(rèn)證部分。如何方便的將這些系統(tǒng)集成起來是一個(gè)非常困難的事情,畢竟我們不能指望Linux下有像Source Offsite那樣集成度很高的版本控制/BUG跟蹤集成系統(tǒng)。 我個(gè)人是很反對(duì)使用pserver模式的遠(yuǎn)程用戶認(rèn)證的,但如果大部分組員使用WINDOWS客戶端進(jìn)行開發(fā)的話,總體來說使用CVSROOT/passwd認(rèn)證還是很難避免的,但CVS本身用戶的管理比較麻煩。本來我打算自己用perl寫一個(gè)管理界面的,直到我發(fā)現(xiàn)了CVSTrac:一個(gè)基于WEB界面的BUG跟蹤系統(tǒng),它外掛在CVS系統(tǒng)上的BUG跟蹤系統(tǒng),其中就包括了WEB界面的CVSROOT/passwd文件的管理,甚至還集成了WIKIWIKI討論組功能。這里首先說一下CVS的pserver模式下的用戶認(rèn)證,CVS的用戶認(rèn)證服務(wù)是基于inetd中的:cvspserver stream tcp nowait nobody /usr/bin/cvs cvs --allow-root=/home/cvsroot pserver一般在2401端口CVS用戶數(shù)據(jù)庫(kù)是基于CVSROOT/passwd文件,文件格式:[username]:[crypt_password]:[mapping_system_user]由于密碼都用的是UNIX標(biāo)準(zhǔn)的CRYPT加密,這個(gè)passwd文件的格式基本上是apache的htpasswd格式的擴(kuò)展(比APACHE的PASSWD文件多一個(gè)系統(tǒng)用戶映射字段),所以這個(gè)文件最簡(jiǎn)單的方法可以用apache/bin/htpasswd -b myname mypassword 創(chuàng)建。注意:通過htpasswd創(chuàng)建出來的文件會(huì)沒有映射系統(tǒng)用戶的字段例如:new:geBvosup/zKl2setup:aISQuNAAoY3qwtest:hwEpz/BX.rEDU 映射系統(tǒng)用戶的目的在于:你可以創(chuàng)建一個(gè)專門的CVS服務(wù)帳號(hào),比如叫cvs,并將/home/cvsroot目錄下的所有權(quán)限賦予這個(gè)用戶,然后在passwd文件里創(chuàng)建不同的開發(fā)用戶帳號(hào),但開發(fā)用戶帳號(hào)最后的文件讀寫權(quán)限都映射為cvs用戶,避免了在SSH模式下多個(gè)開發(fā)用戶新建文件后的對(duì)于其他用戶的文件讀寫權(quán)限問題。進(jìn)一步的,你可以將用戶分別映射到2組用戶上,利用2個(gè)用戶的權(quán)限設(shè)置,避免2個(gè)項(xiàng)目組的文件互相訪問。new:geBvosup/zKl2:proj1setup:aISQuNAAoY3qw:proj2test:hwEpz/BX.rEDU:proj1 CVSTrac很好的解決了CVSROOT/passwd的管理問題,而且包含了BUG跟蹤報(bào)告系統(tǒng)和集成WIKIWIKI交流功能等,使用的CGI方式的安裝,并且基于GNU Public License: 安裝過程 下載:可以從http://www.cvstrac.org 下載我用的是已經(jīng)在Linux上編譯好的應(yīng)用程序包:cvstrac-1.1.1.bin.gz,%gzip -d cvstrac-1.1.1.bin.gz%chmod +x cvstrac-1.1.1.bin#mv cvstarc-1.1.1.bin /usr/bin/cvstrac初始化cvstrac數(shù)據(jù)庫(kù):假設(shè)數(shù)據(jù)庫(kù)名是 myproj在已經(jīng)裝好的CVS服務(wù)器上(CVS庫(kù)這時(shí)候應(yīng)該已經(jīng)是初始化好了,比如:cvs init初始化在/home/cvsroot里),運(yùn)行一下%cvstrac init /home/cvsroot myproj運(yùn)行后,/home/cvsroot里會(huì)有一個(gè)的myproj.db庫(kù),使用CVSTRAC服務(wù),/home/cvsroot/myproj.db /home/cvsroot/CVSROOT/readers /home/cvsroot/CVSROOT/writers /home/cvsroot/CVSROOT/passwd這幾個(gè)文件對(duì)于web服務(wù)的運(yùn)行用戶應(yīng)該是可寫的,在RedHat8上,缺省就有一個(gè)叫apache用戶和一個(gè)apache組,所以我在httpd.conf文件中設(shè)置了用apache用戶運(yùn)行web服務(wù):User apacheGroup apache,如果服務(wù)器上apache用的是其他用戶,比如:nobody nogroup運(yùn)行,則后面相應(yīng)的配置中用戶/組都設(shè)置為nobody nogroup然后我設(shè)置了#chown -R apache:apache /home/cvsroot-rw-r--r-- 1 apache apache 55296 Jan 5 19:40 myproj.dbdrwxrwxr-x 3 apache apache 4096 Oct 24 13:04 CVSROOT/drwxrwxr-x 2 apache apache 4096 Aug 30 19:47 some_proj/此外還在/home/cvsroot/CVSROOT中設(shè)置了:chmod 664 readers writers passwd在apche/cgi-bin目錄中創(chuàng)建腳本cvstrac:#!/bin/sh/usr/bin/cvstrac cgi /home/cvsroot設(shè)置腳本可執(zhí)行:chmod +x /home/apache/cgi-bin/cvstrac從 http://cvs.server.address/cgi-bin/cvstrac/myproj 進(jìn)入管理界面缺省登錄名:setup 密碼 setup對(duì)于一般用戶可以從:http://cvs.server.address/cgi-bin/cvstrac/myproj修改登錄密碼,進(jìn)行BUG報(bào)告等,更多使用細(xì)節(jié)可以在使用中慢慢了解。 備注:在inetd里加入cvspserver服務(wù):cvspserver stream tcp nowait apache /usr/bin/cvs cvs --allow-root=/home/cvsroot pserverxietd的配置文件:%cat cvspserver service cvspserver{disable = nosocket_type = streamwait = nouser = apacheserver = /usr/bin/cvsserver_args = -f --allow-root=/home/cvsroot pserverlog_on_failure += USERID}注意:這里的用戶設(shè)置成apache目的是和/home/cvsroot的所有用戶一致,并且必須讓這個(gè)這個(gè)用戶對(duì)/home/cvsroot/下的CVSROOT/passwd和cvstrac初始化生成的myproj.db有讀取權(quán)限。對(duì)于前面提到的WinCVS在perference里設(shè)置:CVSROOT欄輸入:username@ip.address.of.cvs:/home/cvsrootAuthenitication選擇:use passwd file on server side 就可以了從服務(wù)器上導(dǎo)出項(xiàng)目了。總結(jié):利用cvs + (WinCVS/cvsweb/cvstrac),構(gòu)成了一個(gè)相對(duì)完善的跨平臺(tái)工作組開發(fā)版本控制環(huán)境。相關(guān)資源: CVS HOME:http://www.cvshome.orgCVS FAQ:http://www.loria.fr/~molli/cvs-index.html相關(guān)網(wǎng)站:http://directory.google.com/Top/Computers/Software/Configuration_Management/Tools/Concurrent_Versions_System/CVS 免費(fèi)書:http://cvsbook.red-bean.com/CVS 命令的速查卡片:http://www.refcards.com/about/cvs.htmlWinCVS:http://cvsgui.sourceforge.net/CVSTrac: A Web-Based Bug And Patch-Set Tracking System For CVShttp://www.cvstrac.org StatCVS:基于CVS的代碼統(tǒng)計(jì)工具:按代碼量,按開發(fā)者的統(tǒng)計(jì)表等http://sourceforge.net/projects/statcvs Java, java, J2SE, j2se, J2EE, j2ee, J2ME, j2me, ejb, ejb3, JBOSS, jboss, spring, hibernate, jdo, struts, webwork, ajax, AJAX, mysql, MySQL, Oracle, Weblogic, Websphere, scjp, scjd
相關(guān)文章:
主站蜘蛛池模板: 国产成人精品视频一区二区不卡 | 日本不卡在线一区二区三区视频 | 亚洲精品国产精品国自产观看 | 日韩不卡中文字幕 | 最新91视频| 免费观看爱爱视频 | 上海麻豆文化传媒网站入口 | 亚洲精品ai换脸一区二区三区 | 一个看片免费视频www | 韩国毛片视频 | 日韩欧美一中文字幕不卡 | 色天使色婷婷丁香久久综合 | 高清不卡日本v在线二区 | 国产污视频在线观看 | 永久在线免费观看 | 精品国产一区二区三区久久 | 欧美黑人与白人做爰 | 欧美一区二区三区久久综 | 在线a久青草视频在线观看g | 亚洲免费观看在线视频 | 九九99九九视频在线观看 | 韩国xxxx色视频免费 | 丁香五月网久久综合 | 国产精品第1页 | 久久厕所精品国产精品亚洲 | 久色一区 | 亚1洲二区三区四区免费 | 欧美亚洲国产成人高清在线 | 99久久精品免费看国产免费 | 亚洲 欧美 在线观看 | 国产另类视频 | 国产美女a做受大片在线观看 | 全部毛片 | 国产极品嫩模大尺度福利视频 | 中文成人在线 | 国产欧美日韩综合精品二区 | 欧美视频在线观看一区二区 | 艾小青亚洲专区在线播放 | 亚洲综合精品香蕉久久网 | 精品综合一区二区三区 | 久久精品国产精品亚洲20 |