- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章Linux下CVS的安装配置与操作命令全解析由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
在介绍CVS命令之前,先说点别的 如以前说,仓库内除乐源文件外,还包括一系列的管理文件.位于$CVSROOT/CVSROOT 修改管理文件的方法等同于源代码文件,利用CVS命令提取和修改. 下面描述每个文件的用途
checkoutlist 支持CVSROOT目录的其它管理文件,允许为各种CVS命令定置信息 commitinfo 在cvs commit命令执行时,这个文件指定乐文件提交时执行的命令 cvswrappers 定义乐一个包装程序当文件登记或检取时就会执行. editinfo 允许你在commit命令启动前在日志信息被记录后执行的脚本 history 跟踪所有影响仓库的命令 loginfo 类似coimmitinfo, 只是在文件提交后执行 modules 允许为一组文件定义一个符号,否则必须为每一个要引用的文件 指定部分路径名(相对于$CVSROOT) nitify 控制从/"watch/"来的通知./"watch/"由/"cvs watch add/"和/"cvs edit/" 设置 rcsinfo 为commit log回话指定一个模板. taginfo 定义乐在任意/"tag/"操作后执行的程序. 。
CVS服务器的安装 默认情况下,CVS在Redhat Linux中已经安装,这一点可以通过在Linux命令行的情况下运行: 。
如果出现CVS的版本信息就证明已经安装成功了。 CVS服务器安装包可以从网上的很多地方下载,也可以到CVS的官方网站进行下载。根据你所使用的系统,下载相应的版本,然后进行安装。因为我们的项目是在Redhat Linux下使用CVS服务器进行版本管理,所以本文将主要基于Redhat Linux进行介绍。首先下载CVS服务器的rpm包,当然也可以下载其它方式的包如源程序包,然后采用以下命令进行安装: 。
。
CVS服务器的配置 安装完之后的第一件事就是要配置CVS服务器的配置文件,使其能正常的工作。首先在/etc/services文件中添加cvspserver,使其成为Linux的一种服务也就是cvs服务器例程的入口,配置如下: cvspserver 2401/tcp # cvs client/server operations cvspserver 2401/udp # cvs client/server operations 如果文件中已经存在上面的两行文字,就不用添加了.
配置xinetd,用xinetd来启动CVS验证服务器: 进入到/etc/xinetd.d/目录,然后编辑一个文本文件,名字一定要与/etc/services中的入口名字cvspserver一致,所以这里用cvspserver作为文件名,文件的内容如下所示: 。
编辑文件之后测试cvspserver服务是否配置成功。 执行 。
重新启动服务,启动成功之后,执行下面的语句,验证服务是否启动正常:
如果出现如下字样: Trying 127.0.0.1... Connected to localhost. Escape character is '^]'. 输入hi,会继续输出如下字样 cvs [pserver aborted]: bad auth protocol start: hi Connection closed by foreign host. 出现以上的现象表示CVS用户验证服务器已经配置成功。 如果出现如下字样,表示配置不成功,请重新检查以上的配置: Trying 127.0.0.1... telnet: connect to address 127.0.0.1: Connection refused 。
。
CVS的环境变量 。
CVS使用乐几个环境变量 。
CVSROOT 仓库根目录的完整路径名 CVSREAD 如果设置,表明在checkout操作时所有的文件都置成只读 CVSBIN CVS利用乐很多RCS的命令,指定乐RCS工具的路径 CVSEDITOR 指定用户书写日志信息所使用的编辑器 CVS_RSH 启动一个远程CVS服务器时,所使用的shell的名称 CVS_SERVER 决定/"cvs server/"的名字,缺省是CVS CVSWRAPPERS cvswrapper脚本, 用来指定包装文件名. 。
关键字 管理源文件的一种技术叫/"关键字替换/".在每次执行/"cvs commit/"操作后 源文件的某些关键字会被替换为可用的词 。
$AUTHOR$ 用户名 $Data$ 登记时的时间 $Header$ 标准的首部,包含RCS的完整路径名,日期,作者 $Id$ 除RCS文件名不完整外与$Header$同. $Log$ 包含RCS的完整路径名,版本号,日期,作者和在提交时提供的日志信息. $RCSfile$ 包含RCS的文件名,不包括路径名 $Revision$ 分配的版本号 $Source$ RCS文件的完整名 $State$ 分配的版本的状态,由 cvs admin -s 分配. 。
例: 在cvs commit之前,main.c里有 static char *rcsid=/"$Id$/"; 执行cvs commit后 main.c的改行变为: static char *rcsid=/"$Id: main.c,v 1.2 1999/04/29 15:10:14 trimblef Exp$/",
下面开始说说CVS的命令 我们已下面仓库的数据为例 $CVSROOT --CVSROOT --project --src --main --main.c --main.h --print --print.c --print.h --term --term.c --term.h 。
CVS checkout 命令 。
从仓库提取指定的文件到当前目录,并建立同样的结构,并创建CVS目录 例 。
为使用便利,我们可以对一个目录建一个缩写,方法是修改$CVSROOT/CVSROOT/下的 modules文件.(当然是用cvs 命令完成) 。
我们在文件尾加上 。
cvs commit 以后我们就可以用cvs checkout print来代替 cvs checkout project/src/print 。
。
cvs checkout命令缺省是得到最新版本.我们也可以得到某一个老版本 。
将print的1.1版的代码取出. cvs checkout的详细用法见cvs -H checkout的输出. 。
。
CVS commit 命令 在对文件的修改完成后,用cvs commit提交到仓库. 。
提交完成后,当前的版本号会更新,如原来为1.1,现为1.2. 这两个版本都在 仓库的主干(maintrunk)上. -m选项可以记录有关提交的注释.如果没有指定-m选项,在环境变量CVSEDITOR 中指定的编辑器被调用(vi是缺省的),提示键入文本,修改记录注释. 。
。
CVS update 。
CVS允许多人同时对一个文件进行修改. 假设泥正在修改文件的一部分,现想合并更新自己的本地拷贝(checkout)和 另一个人所做的修改(已经放在仓库里),可用cvs update 。
。
CVS tag , CVS rtag 。
创建分支可以使用户对一些文件进行修改而不会影响主干(当commit时). 创建分支首先为拟修改的某些文件创建一个标签(tag),标签是赋于一个文件或一组文件的符号.在源代码的生命周期里,组成一组模块的文件被赋于相同的标签. 。
创建标签:在工作目录里执行cvs tag 例: 为src创建标签: 。
标签创建后, 就可以为其创建一个分支: 。
-b :创建分支 -r release-1-0 :指定存在的标签 releas-1-0-patch:分支 print: 模块名 。
。
合并 使用cvs update -j 选项可以将分支上的改变与本地文件拷贝合并. 。
。
cvs release 对源文件作必要修改后, 可以用cvs release 删除本地工作拷贝 并通知其他开发者这个模块不再使用. 。
-d : 删除 print: 目录 。
。
冲突 由于CVS允许多人同时修改同一文件,冲突是不可避免的.例如当两人 同时修改同一文件的同一行时. 这时,如用cvs update 更新,CVS检测到冲突的存在,它会将冲突的代码 用/"<<<<<<<<<<<<<<</", /">>>>>>>>>>>>>>>/"标识.这时需手工处理这段代码.与引起 冲突的开发者协商,并对文件修改后即可用cvs commit提交. 。
最后此篇关于Linux下CVS的安装配置与操作命令全解析的文章就讲到这里了,如果你想了解更多关于Linux下CVS的安装配置与操作命令全解析的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
关闭。这个问题是off-topic .它目前不接受答案。 想改进这个问题吗? Update the question所以它是on-topic用于堆栈溢出。 关闭 9 年前。 Improve this
我有一系列 SQL 命令,我想在大约 40 个不同的表上运行。必须有一种方法可以在不编写 40 条不同命令的情况下执行此操作... 我在 SQL Server 中运行它。所有表都有不同的名称,我要操作
我习惯在 PHP 中使用命令“mysql_insert_id()”来返回插入到我的数据库中的最后一行的 id。 在 C# 中的 SQLite 中是否有等效的命令? 谢谢! -阿德娜 最佳答案 选择 l
试图找出一种方法来回填 ds 分区 Hive 表的分区。 我知道如何从 CLI 运行 Hive 命令,例如 $HIVE_HOME/bin/hive -e 'select a.col from tab1
我有 .bat 文件。看起来像下一个 ....many commands1 ftp -i -s:copy.txt ...many commands2 copy.txt 包含下一个命令 open ...
基本上我想输入 show 并检查是否有 show 命令或别名已定义并触发它,如果未定义则触发 git show 。 例如 rm 应该执行 rm 但 checkout 应该执行 git checkout
我公司的主数据库是 iSeries 机器,我已经非常习惯使用 DB2 命令和结构。我现在正在尝试做一个小项目,更新一个包含超过 300 万条记录的表。我想出一种比较和“清理”数据的更快方法是使用 My
我想在带有 Node 的终端中制作一个简单的按钮板,并“blessed”用于连接或运行不同的命令。 ----------------------------------------------- _
我们有一个 selenium IDE 脚本,正在转换为 python webdriver。以下命令未转换: [openWindow | http://mywebsite.com/index.php |
我正在学习这个关于从 GIT HUB 下载和安装 Web 文件的在线教程。我进入主题:启动我们的静态网站,系统提示我输入命令以下载和安装 Web 文件。但是,当我输入命令 yarn install 时
我在 shell 脚本中使用 elif 命令时遇到问题,就像在 fortran 中一样。 我有 100 家公司的员工名单。我想屏蔽那些员工少于 500 人的公司。我的脚本是 rm -f categor
我有一些 Linux 命令可以生成 token 。我在 Linux 机器上使用操作系统库形式的 Python 自动化了这些命令。它工作正常。 但是,当我在 Windows 中尝试相同的代码时,它没有返
本文分享自华为云社区《Git你有可能不知道交互式暂存》,作者:龙哥手记。 本节中的几个交互式 Git 命令可以帮助你将文件的特定部分组合成提交。 当你在修改了大量文件后,希望这些改动能拆分为若干提交而
我想知道如何使用 IN 比较语法来做到这一点。 当前的 SQL 查询是: select * from employee where (employeeName = 'AJAY' and month(e
我在这个位置安装了 Hadoop /usr/local/hadoop$ 现在我想列出 dfs 中的文件。我使用的命令是: hduser@ubuntu:/usr/local/hadoop$ bin/ha
是否有一个单一的 docker 命令可用于清除所有内容?如果正在运行,请停止所有容器、删除所有图像、删除所有卷...等。 最佳答案 我认为没有一个命令可以做到这一点。您首先需要停止所有容器使用 $ d
我基本上是在 clojure/nrepl 模式中寻找与 C-u C-x C-e 或 C-c C-p 等效的 Scheme。 我想要一个 C-x C-e 将输出打印到缓冲区,而不是仅仅在 repl 中。
我可以在 vim 中使用 pudb(一个 ncurses Python 调试器),因为,例如,:!python %在实际的终端窗口中运行。我更喜欢使用 gvim,但 gvim 运行 :!python
我正在尝试编写一个 FFMPEG 命令: 取为 输入 一个视频 input.mp4 和一个图像 pic.jpg 作为 输出 将 input.mp4 拆分为 20 秒的视频,按顺序重命名;对于每个分割视
我想转储视频每帧的比特率。我正在尝试使用 -vstats 获取此信息命令。当我运行此命令时 - ffmpeg -i input.mp4 -vstats 它显示至少应该定义一个文件。 如果有人能建议我任
我是一名优秀的程序员,十分优秀!