CVS使用手册(整理)
CVS使用说明
五,CVS中的TAG(标记)
项目快照(snapshot) 用TAG来跟踪项目的状态(事件)
file1 file2 file3 file4 file5 <-*- TAG
1.1 1.1 1.1 1.1 /--1.1* 1.2*- 1.2 1.2 -1.2*1.3 \- 1.3*- 1.3 / 1.3 1.4 \ 1.4 / 1.4 \-1.5*- 1.5 1.6
八,CVS运用实例
两种作业同时进行
分 支 ( Update 作 业 )
(分支顶端)
开发主线(新机种对应作业) TagA(主干稳定点)
八,CVS运用实例
分支的创建及合并的时机
分支达到稳定状态-合并
branchTagA branchTagB (分支稳定点) (分支稳定点)
分 支 ( Update 作 业 )
四,CVS C/S 连接的几种方式
使用pserver方式连接CVS Server
Server Side设置
/etc/services /etc/inetd.conf或/etc/xinetd.d/cvspserver cvsrepository/CVSROOT/passwd
Client Side设置
CVS应用简介
一,CVS的发展简介
CVS(Concurrent Versions System)是现在比较 常用的一种版本控制系统. CVS的产生是为了适应自由软件的发展,和对分布 式协同开发进行有效的版本管理的需要. 90年代初,CVS发展成基于网络平台的应用系统, 并随之被广泛运用. 现在cvs已经能在Windows,Unix,Linux等多种os上 使用,功能也不断完善,因此也成为当前最流行 的版本控制软件之一.
CVS命令使用手册
M:修改A:添加D:删除CVS命令使用一、常用命令1.设置CVSROOT路径在.cshrc文件中:setenv CVSROOT ':pserver:niu-jie@192.168.30.251:/export/home/midcvs/smias3.0' 在.bashrc文件中:export CVSROOT=":pserver:niu-jie@192.168.30.251:/export/home/midcvs/smias3.0"2.Cvs co: 将文件checkout到本地目录Cvs checkout project(project是项目工程名)例如:Cvs checkout smias30简写:Cvs co举例:[niu-jie@t1000 proj]$ cvs co smias30cvs checkout: Updating smias30U smias30/ChangeLogU smias30/MakefileU smias30/READMEU smias30/build.sh下面信息就是从库中下载的代码信息。
3.Cvs add: 往版本库中添加新的文件Cvs add file例如:Cvs add ChangeLog (添加ChangeLog)Cvs add *.c(添加当前目录下所有的c文件)举例:cvs add unismg-misc.conf4.Cvs ci: 将改动的文件提交到版本库Cvs commit -m “LogMessage“ PATH例如:Cvs commit -m “add test file for my test“ test.c简写:Cvs ci举例:Cvs ci -m “comment” file/path【注意】:此处必须添加comment(Comment是:详细的说明修改代码的原因或者功能,也即:能够通过Cvs log获知你提交代码的原因就行);“-m”与“”comment””之间必须有一个空格,否则,CVS默认将当前目录下的文件递归签入库中,可能造成库中代码被“污染”,且CVS版本恢复比较困难,故,在-m与“comment”之间保留一个空格;5.Cvs up: 更新到某个版本Cvs update [-r m ] path例如:Cvs update如果后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本。
CVS操作手册
CVS操作手册CVS操作管理手册1.安装篇所需文件cvsnt-2.5.03.2382.msi、wincvs.exe、Python-2.2.3.exe安装步骤因为CVS中文版需要Python语言支持所以我们需先安装Python-2.2.3.exe 默认安装即可安装CVSNT服务器:双击CVSNT-2.503 点击NEXT->同意协议->NEXT->点击Typical->Install->Finish安装WinCvs客户端:双击wincvs.exe 默认安装即可2. 配置篇2.1 配置CVS服务器开始->所有程序->CVSNT->CVSNT Control Panel2.1.1在About页确认CVSNT、CVSNT Lock服务正常和稳定运行如下图2.1.2选择Repository configuration页面点按Add按钮,选择已经准备好的模块根目录,如:E:\htfz这个目录(没有的话也可以直接在location中写路径),确认,OK,Yes,这时会在E:\htfz下面建立CVSROOT目录,这是CVS默认的管理目录(默认模块)。
详细步骤如下图2.1.3选择ServerSeting页面,Run as 选择第二个,其他默认确认即可。
2.1.4 用户管理采用windows系统用户管理机制即每个开发者用一个系统用户作为CVS的管理用户注:在添加系统用户(仅针对win2003)时应注意用户名和登录名之间的区别以免出现登录失败2.2 CVS客户端配置:开始->所有程序->WinCVS中文版->CVS1.3 打开客户端界面在使用WinCvs工作前,我们需要对它进行一些基本设置。
2.2.1 登录首选项设置(1)首先,我们点击主菜单【管理】选择菜单项【设置】, 见下图:在【设置】对话框中,我们先进行【普通】设置:这里的设置有:【认证方式】。
CVS提供多种认证方式,例如pserver、rhosts、gserver、local等。
CVS中文手册
CVS中文手册CVS—协作版本系统 v1.12.12本手册描述了如何使用和管理 cvs 版本 1.12.12.•Overview: 介绍 CVS•Repository: 源代码储存的地方•Starting a new project: 使用 CVS 开始一个项目•Revisions: 版本的数字或符号名•Branching and merging: 开发中分支的分离或复合•Recursive behavior: CVS 下层目录•Adding and removing: 添加、删除和重命名文件或目录•History browsing: 查看历史记录文件的各种方法CVS 实践 -----------------------•Binary files: CVS 可以处理二进制文件•Multiple developers: CVS 如何帮助开发组•Revision management: 版本管理的策略问题•Keyword substitution: CVS 可以将修订号包含在文件内•Tracking sources: 跟踪第三方代码•Builds: build 系统如何与 CVS 交互操作•Special Files: 设备,链接以及其他非常规文件参考 -----------•CVS commands: CVS 命令中共用部分•Invoking CVS: CVS 命令快速参考•Administrative files: 管理文件参考手册•Environment variables: 影响 CVS 的所有环境变量•Compatibility: 升级 CVS•Troubleshooting: 遇到问题时的一些提示•Credits: 本手册的贡献人员•BUGS: CVS 或本手册中的 bug•_Index: 索引。
CVS完全手册
CVS完全手册CVS完全手册==========================================================================He Wehzhu, kerlion@, created at 2003-11-5updated at 2003-11-12版权声明:可以任意转载,转载时请务必标明原始出处和作者信息==========================================================================内容概述CVS环境设置登录CVS服务器:cvs命令格式CVS的日常使用其他常用命令CVS宏/keywordCVS分支管理CVS服务器的安装和配置WatchersWinCVS的安装和配置CVSWEB的安装概述==================================CVS是一个并行版本控制系统,它采用C/S模式,它的复杂度和功能性属于中等,是当今最流行的版本控制系统。
它有两个基本的特点:*保存修改记录:保存了所有文件的修改历史,并可以建立分支*协作与并行:cvs不推荐使用lock-modify-unlock的串行的工作模式,而采用多人可以并行地修改同一个文件,而在提交时merge conflict;它更适合于大型的工作团体。
使用CVS的好处:*文件集中管理,大家都可以方便的看到所有人员的最新文件,规范化了文件的管理*可以查看以前任何的一个版本或修改历史*可以同时维护多个版本和分支CVS环境设置==================================先不要管CVS服务器的配置,我们先假设已经有一台配置好的服务器,要访问CVS,必需先设置环境变量CVSROOTCVSROOT=:pserver:user@server#port:/path/to/cvsroot*pserver是访问方式,口令认证的意思,这是最常用的方式,其他还有gserver,kserver,ext *user是CVS服务器的用户名,*server是CVS服务器的名称或者IP地址*/path/to/cvsroot是你的CVS服务器的CVSROOT目录,根据你的CVS服务器设置做修改或者询问管理员你可以把设置放到你的shell的profile里(.bash_profile,.profile等)这样就不用每次敲一长串命令了高级功能:现在比较流行是使用ssh来加密口令和数据流CVSROOT=:ext:user@server#port:/path/to/cvsrootCVS_RSH=sshhints:实际上没有CVSROOT也可以,你可以每次用cvs -d :pserver:user@server#port:/path/to/cvsroot来访问,而且它将忽略CVSROOT环境变量,也许你会笑我只有疯子才这么用,不过,cvs可以把每次使用的命令参数放到一个文件中,所以在~/.cvsrc中加入cvs -d :pserver:user@server#port:/path/to/cvsroot即可,它最大的好处是修改了立刻生效,而且它的优先级高于CVSROOT环境变量,到时候不要傻乎乎地来问我,我的环境变量真么不起作用了。
CVS操作手册
CVS操作手册--计费平台部文档编号草稿文档正式文档正式文档修正版CVS操作手册中心:计费平台中心部门:计费平台部作者姓名:马冬梅定稿日期:2005.7.6上海盛大网络有限公司日期版本作者所做修改2005.7.6 1.0 马冬梅初稿2005.7.15 1.0 马冬梅增加分支说明、纠正初稿错误目录CH 1. WINCVS使用简介 (5)1.介绍 (5)2.登录 (5)3.创建新项目 (8)4.取仓库模块 (9)5.将服务器的修改更新到自己工作目录 (11)6.将自己的修改提交到CVS服务器 (12)7.冲突 (13)8.从本地添加文件和目录 (13)9.从本地重命名文件和目录 (14)10.从项目中删除文件 (14)11.恢复己删除文件 (14)12.查看文件修改记录 (15)13..查看文件状态 (15)14..查看谁正在修改 (16)15.不同版本内容比较 (17)CH 2. CVS管理员使用手册 (17)1.常用CVS命令 (17)1.1import 导入源码 (18)1.2checkout 检出模块 (18)1.3update 更新工作列表 (18)1.4commit 提交修改 (19)1.5tag与rtag本地标记与仓库标记 (19)1.6add、remove 添加与移除文件或目录 (20)1.8diff 比较两不同版本之间的区别 (20)1.9log 查看日志信息 (20)1.10release 断开文件/目录与CVS的关联 (20)1.11export 取模块(不含CVS信息) (20)1.12history 查看历史信息 (21)2.CVS常见问题及解决方法 (21)2.1查看目录 (21)2.2添加目录和文件 (21)2.3 cvswrappers文件 (22)2.4忽略文件 (22)2.5重命名文件或目录 (22)2.6 关于分支 (22)2.7关于Sticky Tag (24)3.影响CVS仓库的参数 (24)3.1 .cvsignore (24)3.2SystemAuth (24)3.2.cvspass (25)3.3lockdir (25)4.配置库安装及初始化 (25)4.1添加系统组和系统用户(root) (25)4.2创建目录(root) (25)4.3初始化仓库(cvsroot) (25)4.4添加CVS服务(root) (26)4.5启动CVS服务(root用户) (26)4.6添加CVS用户(cvsroot用户) (26)5.仓库设置 (26)5.1权限设置 (26)DB (27)5.2建立模块 (28)6.备份方法 (28)7.基线及标记方法 (28)tag方法..................................................................................... 错误!未定义书签。
CVS完美操作手册
(c)2019,杨锦方,版权所有。
7
帮助发现极为隐秘的bug
有的bug在被引入之后很长时间之内潜 伏,出现之后极难找出是什么原因引起
的bug。
版本管理记录着所有版次的变动。
经过对不同版本的比较,开发者能较方
便地找出是哪(c)一2019,次杨锦变方,动版权引所有。起bug。
8
具有高价值
(c)2019,杨锦方,版权所有。
28
网络仓库的指定
命令行:
cvs -
d :pserver:cvsuser211.99.38.27:/src/master ...
设置环境变量:
– UNIX csh: setenv
CVSROOT :pserver:cvsuser211.99.38.27:/src/master
– UNIX sh/bash: export
CVSROOT= :pserver:cvsuser211.99.38.27:/src/master
– windows: set
CVSROOT= :pserver:cvsuser211.99.38.27:/src/master
(c)2019,杨锦方,版权所有。
仓库的内容-文件的版本结构树
新仓库对服务器的要求
创建新仓库
(c)2019,杨锦方,版权所有。
18
CVS仓库
仓库的备份
仓库的移动
仓库的指定
共享网络仓库
在windows上使用CVS client
(c)2019,杨锦方,版权所有。
19
什么是CVS仓库
CVS系统用于保存源代码等软件资源的内 部数据库。
24
仓库的备份
如同备份一组目录、文件一样简单易行
cvs使用说明
在控制台输入:cvs passwd,然后控制台会提示将要修改密码,要求输入新的密码:
E:\>cvs passwd
Changing repository password for Able@Able
New password: ***
Verify password: ***
E:\>set cvsroot=:pserver:Administrator@Able:2401/CVS/Home
在控制台输入:cvs login,然后控制台会提示输入密码:
E:\>cvs login
Logging in to :pserver:Administrator@able:2401:/CVS/Home
user1
user2
user3
这些代表user1, user2, user3都是该项目仓库的管理员。将你想指派为管理员的用户的用户名加到文件的末尾,然后提交修改的文件。由于管理员拥有对CVS服务器比较大的使用权限,所以指派管理员的时候要比较小心。
4. 增加能够使用CVSROOT模块的用户
新创建的用户能够使用其账号连接到CVS服务器,但是目前只能够对该项目仓库进行签出操作,不能进行提交。必须让项目的创建者为其指定提交权限之后才能够进行提交。项目创建者是最高权限管理员,由其指定其他用户能够对项目仓库进行的操作,以及指派新的管理员。
3. 项目创建者对参与项目用户的管理
3. 在控制台环境下登录到CVS服务器
以下所讲的在控制台下的操作都是以Windows的控制台作为例子进行讲解,同时必须客户端安装了CVS。<%CVSROOT%>代表前面将账号信息拼装得到的CVSROOT。
CVS基础使用手册
CVS基础使用手册百度在线网络技术(北京)有限公司2006-8-2文档修订记录目录1 Wincvs基础操作 (5)1.1 配置wincvs环境 (5)1.1.1 初始设置 (5)1.1.2 设置本地工作目录 (5)1.2 登录及注销 (6)1.2.1 登录 (6)1.2.2 注销 (6)1.3 基础操作 (6)1.3.1 cvs checkout (6)1.3.2 cvs update (8)1.3.2.1 update到主干最新版本 (8)1.3.2.2 update到某一个特定版本 (8)1.3.3 添加、修改、删除文件 (9)1.3.3.1 cvs add (9)1.3.3.1.1 添加目录 (9)1.3.3.1.2 添加文件 (10)1.3.3.2 modify (11)1.3.3.3 cvs delete (11)1.3.4 cvs tag (11)1.3.4.1 新增tag (11)1.3.4.2 删除tag (12)1.3.5 cvs log (12)1.3.6 cvs status (13)1.3.7 cvs diff (14)1.3.8 cvs graph (15)2 linux命令行基础操作 (16)2.1 配置环境变量 (16)2.2 登录及注销 (16)2.2.1 登录 (16)2.2.2 注销 (16)2.3 基础操作 (16)2.3.1 checkout (17)2.3.2 update (17)2.3.2.1 update到主干最新版本 (17)2.3.2.2 update到某一个特定版本 (17)2.3.2.3 异常情况说明 (17)2.3.3 添加、修改、删除文件 (17)2.3.3.1 cvs add (17)2.3.3.1.1 添加目录 (17)2.3.3.1.2 添加文件 (18)2.3.3.1.3 添加文本文件 (18)2.3.3.1.4 添加二进制文件 (18)2.3.3.2 modify (18)2.3.3.3 cvs delete (18)2.3.3.4 cvs ci (18)2.3.4 cvs tag (19)2.3.4.1 新增tag (19)2.3.4.2 删除tag (19)2.3.4.3 覆盖已经存在的tag (19)2.3.5 cvs log (19)2.3.6 cvs status (20)2.3.7 cvs diff (20)1Wincvs基础操作1.1 配置wincvs环境1.1.1 初始设置在wincvs主窗口,点击“Admin-Preferences……”,如下图所示:选择“Preferences”后,出现如下窗口:在该窗口中,在“Enter the CVSROOT”栏设置用户名以及服务器地址,设置格式如下:username@172.18.23.201:/data/cvsroot其中172.18.23.201:/data/cvsroot 是cvs服务器的ip以及安装路径;1.1.2 设置本地工作目录在如下窗口设置本地工作路径:1.2 登录及注销1.2.1 登录点击“Admin”-“login”,在出现的窗口中输入用户密码,如果输入密码正确,则会出现如下信息:cvs -q login(Logging in to jiangju@172.18.23.201)*****CVS exited normally with code 0*****如果密码输入错误,会出现如下信息:cvs -q login(Logging in to jiangju@172.18.23.201)cvs login: authorization failed: server 172.18.23.201 rejected access to /data/cvsroot for user jiangju*****CVS exited normally with code 1*****注意:1、在wincvs中,凡是操作成功,都会出现“CVS exited normally with code 0”的信息,如果操作失败,会出现“CVS exited normally with code 1”的信息;2、在wincvs中,在login成功后,如果不做logout操作,那么这次登录是永远生效的;故如果在公用机器上login之后,为了保证信息安全,必须执行logout操作;1.2.2 注销点击“Admin”-“logout”,直接登出,会返回如下信息:cvs -q logout(Logging out of jiangju@172.18.23.201)*****CVS exited normally with code 0*****1.3 基础操作1.3.1 c vs checkout第一次操作需从cvs服务器端checkout自己有权限的目录。
CVS操作手册
CVS操作手册一、用户操作部分1.连接CVS服务器启动wincvs后,点击“Admin”-》“Login”后,出现如下对话框:在“CVSROOT”右面的文本框中输入链接串,用户的链接串为::pserver:username@132.35.97.46:2401:/settle/cvsroot标黄色部分需要替换为个人自己的用户名。
点击“确定”后,根据提示选择将要存放cvs目录信息的目录,按照提示输入密码,密码区分大小写。
2.下载源代码到本地登陆完成后,点击“Remote”-》“Checkout Module”,出现对话框Module name填写:JSPROJECTLocal folder to checkout to填写:你将要存放源代码的本地目录,可根据自己的情况填写。
CVSROOT填写:与Login的连接串相同。
点击确定后,wincvs即开始checkout代码,正常checkout后提示如下:3.代码修改提交代码的修改可直接在本地目录中进行,借助个人常用的代码编辑工具进行编辑。
编辑完成后,回到wincvs中,点击下图中标红色的第一个图标”Show All Commitable Files Only”即可列出所有修改过可以进行提交的版本,选择需要提交的文件单击鼠标右键选择“commit”即可。
4.代码提交后在主机上编译测试代码提交到cvs服务器后,通过telnet、ssh登陆到主机后,Cd到需要进行代码编译测试的目录,执行cvsupdate,即可完成代码更新。
此后编译、运行与正常情况下一致。
5.在本地更新获取CVS服务器上的新版本代码在wincvs中,选择指定的目录,右键选择“update”即可。
二、配置管理员操作部分1.管理员账户管理员使用cvsroot账户登录主机进行相关管理操作。
2.添加用户命令:cvsuseradd格式:cvsuseradd user passwd3.删除用户命令:cvsuserdel格式:cvsuserdel user4.修改密码命令:cvspasswd格式:cvspasswd user newpasswd。
实用CVS安装及使用手册
CVS使用手册深圳市金证科技股份有限公司版权所有版权声明本手册版权为深圳市金证科技股份有限公司公司所有,未经本公司书面许可,任何公司、单位和个人不得以任何手段复制本书的全部或部分内容。
目录0前言 (4)0.1 关于本手册 (4)0。
2 名称解释 (4)0。
3 技术支持 (4)1CVS简介......................................................................................................... 错误!未定义书签。
1。
1 CVS的特点.. (5)1。
2 CVS工作思路 (5)2版本管理 (5)2.1 版本树 (5)2.2 总体处理流程 (7)2.3 CVS提交中注释的要求 (10)3CVS服务器的安装与配置 (11)3。
1 CVS服务器的安装 (11)3.2 CVS服务器的配置 (11)4WINDOWS平台下的CVS操作 (12)4.1 W IN CVS安装 (12)4。
2 W IN CVS登录到CVS服务器 (13)4。
3 W IN CVS基本操作 (15)4.4 修改登录名密码 (41)5常用规则 (42)6关于英语单词代表的意思: (43)7小小技巧知识 (43)8需注意的问题 (44)9未解决的问题 (45)0 前言0.1 关于本手册本手册详细说明了如何使用CVS进行版本控制的有关操作方法,本手册只列出了常用的与开发人员有关的操作。
由于时间仓促,加之知识的局限性,尚有不足之处,还请诸位多多赐教。
0.2 名称解释▪配置项:一个信息单元(可以是程序、文档或数据)称为一个配置项(SCI:Software Configuration Item),它是软件配置管理的对象。
▪基线(Baseline):指已经通过正式审核和批准的某规约或产品,是后续开发的基础,并且只能在正式的变化控制流程之下做修改。
▪版本(Revision):是经过修改过的版本。
CVS使用手册
CVS使用手册(UNIX)目录CVS安装和配置 (2)安装: (2)配置: (2)CVS常用命令 (4)常用命令举例: (5)命令列表 (8)CVS常见问题答疑: (14)CVS安装和配置安装:1、从CVS网站()免费获得CVS的安装源码文件,例如下载:cvs-1.11.tar.gz文件。
2、将cvs-1.11.tar.gz文件拷贝到配置管理服务器上,本例以SCO Unix Openserver 服务器为例。
3、用gzip解压缩$gzip –dvf cvs-1.11.tar.gz /*可以用Winzip把cvs-1.11.tar.gz解开成cvs-1.11.tar,注意在WINZIP提问是否要全部解开时,回答NO。
*/4、再用tar命令解开文件:$tar xvf cvs-1.11.tar5、到解压缩后的CVS 目录:$cd cvs-1.116、在cvs-1.11目录下执行以下命令:$./configure /* ./configure --prefix=/usr */$make$make install7、如果没有出现任何错误提示,表示安装成功。
可用以下命令验证CVS可执行文件已经安装成功:$find ./ -name cvs –print (默认在/usr/local/bin下)配置:服务器端配置:1、创建项目用户组和用户帐号以超级用户身份创建项目开发用户组和用户帐号(包括CVS管理员用户),假设以informix作为项目用户组,包含成员:Richard、Paul、marry,CVS系统管理员为:cvsroot 创建项目用户组informix:$groupadd informix创建informix组内用户帐号命令:$useradd –g informix username–p password分别用Richard、Paul、marry、cvsroot代替username为项目组成员及CVS系统管理员创建组内用户帐号和密码。
CVS操作手册
CVS操作手册第1章名词解释Head 主干/主分支Tag(Tag as Version) 标记可以以此标签标记版本序号Branch 分支Merge 合并Branch or version to be merged (end tag) 被合并版本Common base version (start tag) 基线版本第2章遵循规则1.如果把Head 归结为分支的一种则除主分支(Head)外,分支不能独立存在,必须依附于主干(Head)或者某个版本(Version)2.标记版本之前请确保本地代码已经和CVS保持同步3.标记版本之前请确保项目已经稳定4.标记版本上的文件不能直接做修改,删除,新增操作,但是在某些情况下可以新增操作(建议不要在已有版本上做任何操作)。
5.合并版本的时候需要保证本地代码和基线版本保持一致。
第3章CVS操作3.1 标记版本标记版本之前请遵循规则2 操作如下鼠标放置工程点击右键>Team>Tag as Version 然后输入版本名称如(V1)3.2 创建分支鼠标放置工程点击右键>Team>Branch 然后输入分支名称名称如(Br01)3.3 切换版本/分支鼠标放置工程点击右键>Team>Switch to another Branch or Version3.4 合并版本版本信息简单描述:版本version01包含Test01.java,Test02.java在版本version01上创建分支br01_v1本地代码切换至br01_v1,修改Test01.java,删除Test02.java,新增Test03.java提交代码并标记新的版本version02。
现在将版本version02合并到version01中并创建新的版本version03.根据描述可知基线版本为version01,则将本地代码和version01保持完全一致.Merge 合并,将被合并版本/分支新加的内容更新到基线版本中,和平时的update一样的效果Overwrite 覆盖,将被合并版本/分支中的该文件覆盖基线版本中的文件。
CVS客户端使用手册
CVS客户端使用手册中国软件与技术服务股份有限公司文档编号:当前版本号:V1.0最初发布日期:2008-4-23最新修订日期:文档信息文档位置文档存放在文档服务器:文档修改历史分发本文档已被分发到如下人员:相关文档及参考资料目录1 文档说明 (1)2 安装 (2)3 基本操作 (3)3.1 设置 (3)3.2 登录 (5)3.3 设置工作目录 (7)3.4 修改密码 (8)3.5 检出 (9)3.6 更新 (13)3.7 添加文件 (14)3.8 添加文件夹 (18)3.9 修改之后的文件 (26)3.10 删除 (27)3.11 文件过滤使用 (27)3.12 需要注意的问题 (30)1文档说明本文档预期读者为开发人员。
CVS客户端工具有多种,本文档以WinCVS1.3中文版为例,内容为CVS安装和基本操作。
涉及密码、路径、IP 等根据情况修改,或联系CVS管理员。
2安装拷贝CVS安装程序到本地,运行,安装程序正在启动:之后下一步,直到:选择安装路径,下一步,直到安装结束。
3基本操作3.1设置首次使用,要先进行各种设置,打开客户端程序,会自动弹出设置页面,可以在这里设置;也可以取消之后,手动打开设置页面;还可以在登录时设置,下面是打开客户端程序时,自动弹出的设置页面:或打开菜单管理下的设置项进行设置:登录时的设置方法将在下一节中讲到;设置好的普通页:填写说明:1.认证方式选择pserver;2.路径、主机地址、用户名由CVS管理员提供;3.CVSROOT,自动生成,不用填写此项。
之后点开全局设置页,设置好的页面:建议按上图进行设置,为最佳设置。
其它页面不用设置,设置好之后点OK即可,CVS工作界面:左侧为文件夹,右侧为文件夹下的文件及子目录,下面为输出窗口,显示操作结果、记录log等。
3.2登录CVS只需登录一次,检出之后在本地CVS文件夹中会记录登录信息,即使关闭程序再打开,也不用重新登录,并且,可以直接进行更新等操作。
CVS使用手册
CVS使用手册CVS是一个C/S系统,多个开发人员通过一个中心版本控制系统来记录文件版本,从而达到保证文件同步的目的。
工作模式如下:CVS服务器(文件版本库)/ | \(版本同步)/ | \开发者1 开发者2 开发者3作为一般开发人员挑选2,6看就可以了,CVS的管理员则更需要懂的更多一些,最后还简单介绍了一些Windows下的cvs客户端使用,CVS远程用户认证的选择及与BUG跟踪系统等开发环境的集成问题。
一个系统20%的功能往往能够满足80%的需求,CVS也不例外,以下是CVS最常用的功能,可能还不到它全部命令选项的20%,作为一般开发人员平时会用cvs update和cvs commit 就够了,更多的需求在实际应用过程中自然会出现,不时回头看看相关文档经常有意外的收获。
CVS环境初始化环境设置:指定CVS库的路径CVSROOTtcshsetenv CVSROOT /path/to/cvsrootbashCVSROOT=/path/to/cvsroot ; export CVSROOT后面还提到远程CVS服务器的设置:CVSROOT=:ext:$USER@test.server.address#port:/path/to/cvsroot CVS_RSH=ssh; exportCVSROOT CVS_RSH初始化:CVS版本库的初始化。
cvs init一个项目的首次导入cvs import -m "write some comments here" project_name vendor_tag release_tag执行后:会将所有源文件及目录导入到/path/to/cvsroot/project_name目录下vender_tag: 开发商标记release_tag: 版本发布标记项目导出:将代码从CVS库里导出cvs checkout project_namecvs 将创建project_name目录,并将最新版本的源代码导出到相应目录中。
cvs手册
WinCVS操作手册------------------------------------------------------ 第一章:概述CVS是目前比较流行与优秀的版本管理与控制工具,是用来管理其它日常文档(如word 工作文档之类)的一个强有力的工具。
WinCVS是CVS的一个客户端软件,它运行在Windows上,采用图形化方式登陆CVS 服务器和CVS相关的操作与管理,不要学习复杂的cvs命令。
企业内部都采用Linux/Unix 做服务器,用Windows做客户端,所以WinCVS与CVS服务器是目前应用最广泛的版本控制与管理的组合。
本文主要介绍WinCVS的日常操作,CVS服务器的配置将在另外的文章中介绍,本文所有操作是基于CVS服务配置正确、数据仓库已初始化的基础上,第二章:术语1、Repository-------仓库:CVS服务器的根目录。
模块(Module)的集合2、Module------------模块:,CVS服务器根目录下的第一级子目录。
通常用于存放一个项目的所有文件3、Checkout----------检出:通常指将仓库中的一整个模块首次导出到本地。
4、Import------------导入:通常指通过提交整个目录结构并创建一个新的模块。
5、Release-------发行版本:整个产品的版本6、Revision--------修订版:单个文件的版本7、Tag---------------标签:在一个开发的特定期对一个文件集给定的符号名8、Update------------更新:从模块中下载其他人的修改过的文件。
更新本地的拷贝。
9、Commit------------提交:将自己修改过的文件提交到模块中。
第三章:WinCVS初始化配置第一步:安装Wincvs执行setup.exe安装,然后在一步步的确认就ok了.安装完毕后运行wincvs:第二步:配置WinCVS参数➢Preferences -> General :普通参数设置1.Authentication : 验证方式,CVS默认采用pserver。
CVS使用手册
CVS使用手册WinCVS日常使用指南0、前言该文译自WinCvsDailyUseGuide,原文撰写的时间可能比较早,相对于WinCvs的最新版,有些错误,主要是菜单的选择上。
根据我个人的使用经验,增加了如何对文件或目录移动或改名(这主要在UNIX上完成,你也许需要一些UNIX的基本使用知识)。
CVS受到了很多人的宠爱,希望也能受到你的宠爱。
――译者Mirnshi1、介绍本文档介绍了WinCvs 1.0.x客户端的日常使用。
这不是介绍版本控制系统,也不是介绍CVS,更不是介绍WinCvs。
这更适用于当你大概知道你要做什么,但又不十分清楚如何作。
假设你已经安装了WinCvs,并且也已经配置好了与你要使用CVS库通讯。
2、术语CVS文档和WinCvs中的术语也许和其他的源码库系统不同。
为了避免混淆,我们列举了最基本的术语简短列表。
在翻阅文档的其它部分前,请首先熟悉这些术语。
Checkout--检出:一般用于描述从库中将一个整个模块的首次导出。
Commit--提交:将你的修改提交到库中。
Export--输出:指从库中将一个模块全部导出,但没有任何CVS管理文件。
输出的模块没有CVS控制。
Import--输入:通常指通过提交一整个目录结构创建一个新的模块的过程Module--模块:一个目录层。
一个软件工程通常作为一单一模块存放在库中Release--发行版本:整个产品的版本Revision--修订版:单个文件的版本Tag--标签:在一个开发的特定期对一个文件集给定的符号名Update--更新:从库中取出其他人的修改。
只更新本地的拷贝。
关于修订,发行版本,版本和标签的详细说明,参见CVS文档的第四章3、创建新模块将一个工程置于版本控制,在CVS术语中称作输入。
从名字上就可以看出,在考虑版本控制前,你要为此作些准备工作。
对于一个工程的文件层次的重新构建,CVS缺乏良好的支持。
如果你在输入一个新的模块前花费一些时间来制定个计划,将会减少很多的麻烦。
CVS简易操作手册
CVS简易操作手册当第一次使用时,先用分配给你的用户名登录,在本地新建一个文件夹作为工作环境,打开wincvs 程序,在菜单“视图/浏览位置/重新设置”里设置你选择你的wincvs文件为你新建的文件夹。
在工作区选中此文件夹,右键选“检出项目|模块”菜单,在弹出菜单里的“服务器上的模块名和路径”里输入“.”,点确定,就能下载所有你有权限下载的文件了。
常用CVS命令:Cvs ls 列出服务器repository(数据仓库)文件列表。
Cvs chown User 更改文件夹所有人,只有文件夹所有人有权限来更改文件夹的权限和使用该命令。
Cvs lsacl 列出选中的文件夹的所有人,用户权限。
Cvs chacl –R User:rcwn 更改文件夹权限,只有该文件夹的所有人有权限更改,R:读;c:创建;w:写;n:无权限。
常用操作:update和commit文件如果文件内容有改变,应即时的提交到服务器上。
现在我们修改一个demo目录中的readme.txt文件,储存后,文件的图标即变成了红色,表示此文件被修改过,这时,在此文件上点击鼠标右键,再点击"Commit selection…"菜单,出现下面的对话框,输入log message后按确定即可。
如果命令执行失败,可能是另外有人修改了这个文件并提交到了服务器。
即服务器上的版本可能比你现有的文件还新,这时你有三种选择:a. 将服务器上的文件和本地的文件合并后再提交先在文件上点击菜单命令"update…", 在弹出的对话框上什么都不要选,点击确定按钮,合并后的文件前面有一个M标记。
b. 用本地的文件将服务器上的文件覆盖在文件上点击菜单命令"commit…",在出来的对话框上切换到Commit options页,选择Force commit,按确定,其中可以看到文件版本从1.2变到了1.3.c. 用服务器上的文件将本地文件覆盖在文件上点击菜单命令"update…",在出现的对话框中选择Get the clean copy,按确定,更新过的文件为绿色,前面标有U标记。
CVS使用说明书
目录1 CVS简介 (2)2 CVS的术语 (2)3 CVS服务器端的安装 (3)4 CVS服务器端的配置 (6)4.1 创建CVS资源库 (6)4.2 防火墙设置 (8)4.3 添加用户 (8)4.4 用户权限 (8)5 Eclipse连接CVS服务器端 (9)6 Eclipse使用CVS (12)6.1 与VSS的不同 (12)6.2 提交项目 (12)6.3 提交文件 (18)6.4 查看提交历史记录 (19)6.5 检出项目 (19)6.6 冲突问题 (22)6.7 产生版本 (25)6.8 修改旧版本的BUG (27)6.9 团队开发实践建议 (30)CVS使用说明书1CVS简介CVS为“并发版本控制系统(Concurrent Versions System)”CVS服务器端下载:/cvsnt/2CVS的术语资源库(Repository) ——资源文件的集合,版本管理的容器。
在CVS服务器的根目录,在Eclipse中常称为CVS资源库。
模块(Module) ——资源文件的组织形式,CVS服务器根目录的第一级子目录,在版本管理系统中表现形式为目录。
检出(Checkout) ——将CVS资源库中的整个模块导出到本地Eclipse中。
导入(Import) ——将资源库之外的软件模块导入本地,提交整个目录结构并构建一个新的模块。
导出(Export) ——从资源库中取出模块。
使用Export方式取出的模块复本不包含版本管理的相关信息,对该模块复本的修改也不能反映到资源库。
修订版(Revision) ——对文件的每次修改提交后,将产生一个新的修订版本,通常CVS版本管理系统用修订版来管理文件的修改履历,修订版用版本号来表示。
发行版(Release) ——这个发行产品的版本。
更新(Update) ——将资源库中模块文件的最新状态反映到工作空间的复制操作。
标签(Tag) ——在一个开发的特定期对一个文件集给定的符号名。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
CVS使用手册CVS是一个C/S系统,多个开发人员通过一个中心版本控制系统来记录文件版本,从而达到保证文件同步的目的。
工作模式如下:CVS服务器(文件版本库)/ | \(版本同步)/ | \开发者1 开发者2 开发者3作为一般开发人员挑选2,6看就可以了,CVS的管理员则更需要懂的更多一些,最后还简单介绍了一些Windows下的cvs客户端使用,CVS远程用户认证的选择及与BUG跟踪系统等开发环境的集成问题。
一个系统20%的功能往往能够满足80%的需求,CVS也不例外,以下是CVS最常用的功能,可能还不到它全部命令选项的20%,作为一般开发人员平时会用cvs update和cvs commit 就够了,更多的需求在实际应用过程中自然会出现,不时回头看看相关文档经常有意外的收获。
CVS环境初始化环境设置:指定CVS库的路径CVSROOTtcshsetenv CVSROOT /path/to/cvsrootbashCVSROOT=/path/to/cvsroot ; export CVSROOT后面还提到远程CVS服务器的设置:CVSROOT=:ext:$USER@test.server.address#port:/path/to/cvsroot CVS_RSH=ssh; exportCVSROOT CVS_RSH初始化:CVS版本库的初始化。
cvs init一个项目的首次导入cvs import -m "write some comments here" project_name vendor_tag release_tag执行后:会将所有源文件及目录导入到/path/to/cvsroot/project_name目录下vender_tag: 开发商标记release_tag: 版本发布标记项目导出:将代码从CVS库里导出cvs checkout project_namecvs 将创建project_name目录,并将最新版本的源代码导出到相应目录中。
这个checkout 和Virvual SourceSafe中的check out不是一个概念,相对于Virvual SourceSafe的check out是cvs update,check in是cvs commit。
CVS的日常使用注意:第一次导出以后,就不是通过cvs checkout来同步文件了,而是要进入刚才cvs checkout project_name导出的project_name目录下进行具体文件的版本同步(添加,修改,删除)操作。
将文件同步到最新的版本cvs update不制定文件名,cvs将同步所有子目录下的文件,也可以制定某个文件名/目录进行同步cvs update file_name最好每天开始工作前或将自己的工作导入到CVS库里前都要做一次,并养成“先同步后修改”的习惯,和Virvual SourceSafe不同,CVS里没有文件锁定的概念,所有的冲突是在commit之前解决,如果你修改过程中,有其他人修改并commit到了CVS 库中,CVS会通知你文件冲突,并自动将冲突部分用>>>>>>content on cvs server<<<<<<content in your file>>>>>>标记出来,由你确认冲突内容的取舍。
版本冲突一般是在多个人修改一个文件造成的,但这种项目管理上的问题不应该指望由CVS 来解决。
确认修改写入到CVS库里cvs commit -m "write some comments here" file_name注意:CVS的很多动作都是通过cvs commit进行最后确认并修改的,最好每次只修改一个文件。
在确认的前,还需要用户填写修改注释,以帮助其他开发人员了解修改的原因。
如果不用写-m "comments"而直接确认`cvs commit file_name` 的话,cvs会自动调用系统缺省的文字编辑器(一般是vi)要求你写入注释。
注释的质量很重要:所以不仅必须要写,而且必须写一些比较有意义的内容:以方便其他开发人员能够很好的理解不好的注释,很难让其他的开发人员快速的理解:比如:-m "bug fixed" 甚至-m ""好的注释,甚至可以用中文: -m "在用户注册过程中加入了Email地址校验"修改某个版本注释:每次只确认一个文件到CVS库里是一个很好的习惯,但难免有时候忘了指定文件名,把多个文件以同样注释commit到CVS库里了,以下命令可以允许你修改某个文件某个版本的注释:cvs admin -m 1.3:"write some comments here" file_name添加文件创建好新文件后,比如:touch new_filecvs add new_file注意:对于图片,Word文档等非纯文本的项目,需要使用cvs add -kb选项按2进制文件方式导入(k表示扩展选项,b表示binary),否则有可能出现文件被破坏的情况比如:cvs add -kb new_file.gifcvs add -kb readme.doc如果关键词替换属性在首次导入时设置错了怎么办?cvs admin -kkv new_file.css然后确认修改并注释cvs ci -m "write some comments here"删除文件将某个源文件物理删除后,比如:rm file_namecvs rm file_name然后确认修改并注释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查看当前文件不同版本的区别cvs diff -r1.3 -r1.5 file_name查看当前文件(可能已经修改了)和库中相应文件的区别cvs diff file_namecvs的web界面提供了更方便的定位文件修改和比较版本区别的方法,具体安装设置请看后面的cvsweb使用正确的通过CVS恢复旧版本的方法:如果用cvs update -r1.2 这个命令是给加一个STICK TAG:"1.2" ,虽然你的本意只是想将它恢复到1.2版本正确的恢复版本的方法是:cvs update -p -r1.2 file_name >file_name如果不小心已经加成STICK TAG的话:用cvs update -A 解决移动文件/文件重命名cvs里没有cvs move或cvs rename,因为这两个操作是可以由先cvs remove old_file_name,然后cvs add new_file_name实现的。
删除/移动目录最方便的方法是让管理员直接移动,删除CVSROOT里相应目录(因为CVS一个项目下的子目录都是独立的,移动到$CVSROOT目录下都可以作为新的独立项目:好比一颗树,其实砍下任意一枝都能独立存活),对目录进行了修改后,要求其开发人员重新导出项目cvs checkout project_name 或者用cvs update -dP同步。
项目发布导出不带CVS目录的源文件做开发的时候你可能注意到了,每个开发目录下,CVS都创建了一个CVS/目录。
里面有文件用于记录当前目录和CVS库之间的对应信息。
但项目发布的时候你一般不希望把文件目录还带着含有CVS信息的CVS目录吧,这个一次性的导出过程使用cvs export命令,不过export只能针对一个TAG或者日期导出,比如:cvs export -r release1 project_namecvs export -D 20021023 project_namecvs export -D now project_nameCVS Branch:项目多分支同步开发确认版本里程碑:多个文件各自版本号不一样,项目到一定阶段,可以给所有文件统一指定一个阶段里程碑版本号,方便以后按照这个阶段里程碑版本号导出项目,同时也是项目的多个分支开发的基础。
cvs tag release_1_0开始一个新的里程碑:cvs commit -r 2 标记所有文件开始进入2.x的开发注意:CVS里的revsion和软件包的发布版本可以没有直接的关系。
但所有文件使用和发布版本一致的版本号比较有助于维护。
版本分支的建立在开发项目的2.x版本的时候发现1.x有问题,但2.x又不敢用,则从先前标记的里程碑:release_1_0导出一个分支release_1_0_patchcvs rtag -b -r release_1_0 release_1_0_patch proj_dir一些人先在另外一个目录下导出release_1_0_patch这个分支:解决1.0中的紧急问题,cvs checkout -r release_1_0_patch而其他人员仍旧在项目的主干分支2.x上开发在release_1_0_patch上修正错误后,标记一个1.0的错误修正版本号cvs tag release_1_0_patch_1如果2.0认为这些错误修改在2.0里也需要,也可以在2.0的开发目录下合并release_1_0_patch_1中的修改到当前代码中:cvs update -j release_1_0_patch_1CVS的远程认证通过SSH远程访问CVS使用cvs本身基于pserver的远程认证很麻烦,需要定义服务器和用户组,用户名,设置密码等,常见的登陆格式如下:cvs -d :pserver:cvs_user_name@cvs.server.address:/path/to/cvsroot login例子:cvs -d :pserver:cvs@:/cvsroot login不是很安全,因此一般是作为匿名只读CVS访问的方式。
从安全考虑,通过系统本地帐号认证并通过SSH传输是比较好的办法,通过在客户机的/etc/profile里设置一下内容:CVSROOT=:ext:$USER@cvs.server.address#port:/path/to/cvsroot CVS_RSH=ssh; export CVSROOT CVS_RSH所有客户机所有本地用户都可以映射到CVS服务器相应同名帐号了。