【转】Linux下svn的常用工作流程
原文网址:http://www.cnblogs.com/cobbliu/archive/2011/07/08/2389011.html
上篇文章在ubuntu和redhat5.5上搭建好了svnserve环境,下面总结一下svn的具体使用流程。
服务器的搭建
1)建立代码库。
#svnadmin create /srv/svn/repos/myproject
2)修改配置文件svnserve.conf
anon_access = none
auth_access = write
password_db = passwd 其中passwd是一个文件,默认是当前文件夹下的passwd,如果要用其他的passwd需要制定路径名
3)配置passwd文件
添加用户名和密码: cobing = 123
4)启动svnserve服务
#svnserve -d -T -r /srv/svn/repos
-d 表示把进程svnserve作为守护进程在后台运行
-T 表示用多线程的方式处理数据
-r
可以有效地改变文件系统的根位置,客户端可以使用去掉前半部分的路径,留下的要短一些的
要想让svnserve在系统启动时自动启动,需要把它添加到/etc/rc.local文件中
客户端
1)将本地代码导入到svn代码库中
#svn import test svn://192.168.146.128/myproject
注意:当初建立代码库的路径时/srv/svn/repos/myproject,我们启动svn服务器指定的根目录是/srv/svn/repos,而现在客户导入代码的目录是/myproject。因为svnserve指定了根目录,所以用户在访问192.168.146.128是就相当于在访问服务器的/srv/svn/repos目录,所以这个时候我们只需要指出myproject目录即可。这个地方很容易出错,多家防范,我掉进去摸索了好久才出来。
2)代码导入SVN代码库中以后,其他用户就可以从代码库下载代码进行修改了,这个操作由svn checkout 完成
# svn checkout svn://192.168.146.128/myproject
checkout之后,svn会在你的当前目录下生成一个myproject的文件夹,这个文件夹就是你将来进行各种操作、与svn服务器交互的地方
3)之后就可以coding了,但是要注意:每次对myproject下文件的添加、删除、移动、复制操作都要告诉svn:
a, 增加文件、目录 #svn add 文件或目录名
b,删除文件、目录 #svn delete 文件或目录名
c, 拷贝文件、目录 #svn copy 条目名1 条目名2
d, 拷贝条目并删除原条目 #svn move 条目名1 条目名2
svn项目本身已经存在的文件只需要对其修改即可,svn会自动检测到修改。
4)修改完文件后不能马上提交,还有很多工作要做:
a, 检验修改
当你完成修改,你需要提交他们到版本库,但是在此之前,检查一下做过什么修改是个好主意,通过提交前的检查,你可以整理一份精确的日志信息,你也可以发现你不小心修改的文件,给了你一次恢复修改的机会。此外,这是一个审查和仔细察看修改的好机会,你可通过命令svn status浏览所做的修改,通过svn diff检查修改的详细信息。
# svn status 会检测你做的所有文件和目录的修改
A item
-
预定加入到版本库的文件、目录或符号链的
item
。 C item
-
文件
item
发生冲突,在从服务器更新时与本地版本发生交迭,在你提交到版本库前,必须手工的解决冲突。 D item
-
文件、目录或是符号链
item
预定从版本库中删除。 M item
-
文件
item
的内容被修改了。
-
#svn diff 会精确地检测到你做的修改
b, 取消本地修改
假定我们在看svn diff的输出,你发现对某个文件的所有修改都是错误的,或许你根本不应该修改这个文件,或者是从开头重新修改会更加容易。
#svn revert 文件名
c,手动解决冲突,把由冲突的文件手动改过来
d, 接着用svn update查看本地版本与服务器版本由什么区别:
#svn update
这时有三个标示:
U : 表示本地没有修改
G: 表示本地已经修改,但是与版本库没有重叠的地方,可以合并
C: 服务器上的改动同本地的改动冲突了,需要手动解决冲突或者用svn revert 放弃本地修改
4)At Last,您的修改结束了,并且与服务器上的版本没有冲突,那就提交吧!
#svn commit -m "LOGMSG"
不知道你们看到这里有没有疑惑?是不是在想svn update 和 svn status 到底什么区别,不都是检验修改么?仔细翻翻svn用户手册就会发现,svn revert , svn status 和svn diff这三个命令在没有连接svn服务器的时候也可以进行,为什么呢?细心的用户或者在windows上用过svn的用户就会发现,当前工作的svn文件夹里有一个./svn的文件,官方文档是这样说的“Subversion通过在.svn
管理区域使用原始的版本缓存来做到这一点,这使得报告和恢复本地修改而不必访问网络,这个缓存(叫做“text-base”)也允许Subversion可以根据原始版本生成一个压缩的增量(“区别”) 提交—即使你有个非常快的网络,有这样一个缓存有极大的好处,只向服务器提交修改的部分而不是整个文件”。也许你已经明白了,是的,svn status是本地修改与.svn中的数据对比,而svn update是本地修改与服务器数据对比。两者的冲突是不一样的,svn status下的冲突是你跟之前checkout时服务器数据冲突,svn update下的冲突是当前时刻与服务器数据冲突。
以上操作均在redhat5.5上测试通过。
svn创建分支
有时候,我们在开发主分支trunk外创建另外的分支,这样可以保证主分支和另外的分支同时工作,当分支的任务完成之后就可以将分支合并到主分支上,继续前进。svn中的分支要创建在branches目录中。
1,创建分支时首先要复制主分支的一个版本到新分支中:
svn cp http://svn.ss.com/YStatTST/trunk http://svn.ss.com/YStatTST/branches/uvList2uvTree -m "we modified ..."
2,然后下载分支uvList2uvTree到你的目录下
svn co http://svn.ss.com/YStatTST/branches/uvList2uvTree
3,修改你的代码
4, 提交你的代码到分支uvList2uvTree上
svn commit -m "xxx"
svn删除分支
如果不小心创建错了一个分支,或者某个分支你不想用了,就可以删除分支
1, svn delete http://svn.ss.com/YStatTST/branches/uvList2uvTree -m "this comment must be pretty pretty long"
注意,日志必须足够长,如果这个日志信息不够20个字符的话,不能删掉分支呃~
svn分支对比
如果你想看看你的新分支跟其他分支(包括主分支)的区别,那就用svn diff吧
svn diff http://svn.ss.com/YStatTST/branches/uvList2uvTree http://svn.ss.com/YStatTST/trunk > filename.diff
【转】Linux下svn的常用工作流程的更多相关文章
- linux下svn的常用代码【转】
转自:http://www.2cto.com/os/201205/130192.html 1.将文件checkout到本地目录 svn checkout path(path是服务器上的目录) 例 ...
- linux下svn命令常用操作
1.将文件checkout到本地目录 svn checkout path(path是服务器上的目录) 例如:svn checkout svn://192.168.1.1/pro/domain 简写:s ...
- linux下svn常用指令
windows下的TortoiseSVN是资源管理器的一个插件,以覆盖图标表示文件状态,几乎所以命令都有图形界面支持,比较好用,这里就不多说.主要说说linux下svn的使用,因为linux下大部分的 ...
- [转载]linux下svn常用指令
一下内容转载于:http://blog.chinaunix.net/space.php?uid=22976768&do=blog&id=1640924.这个总结的很好~ windows ...
- Linux下svn常用指令【转】
转自:http://blog.csdn.net/myarrow/article/details/8110858 Windows下的TortoiseSVN是资源管理器的一个插件,以覆盖图标表示文件状态, ...
- Linux下SVN命令
一下内容转载于:http://blog.chinaunix.net/space.php?uid=22976768&do=blog&id=1640924.这个总结的很好~ windows ...
- linux下svn版本控制的常用命令大全
1.将文件checkout到本地目录 svn checkout path(path是服务器上的目录) 例如:svn checkout svn://192.168.1.1/pro/domain 简写:s ...
- 转载-Linux下svn搭建配置流程
Linux下svn搭建配置流程 一. 源文件编译安装.源文件共两个,为: 1. 下载subversion源文件 subversion-1.6.1.tar.gz http://d136 ...
- linux下svn命令使用大全
最近经常使用svn进行代码管理,这些命令老是记不住,得经常上网查,终于找了一个linux下svn命令使用大全:1.将文件checkout到本地目录 svn checkout path(path是服务器 ...
随机推荐
- js常用笔记
此文仅为笔记,代码来源自网络 网络技术文档:https://developer.mozilla.org/zh-CN/docs/Web/JavaScript 1.使用||和&&简化语句, ...
- 29、Jquery Ajax
Ajax Asynchronsous Javascript and XML(异步Javascript和XML). Ajax 是一种无需重新加载整个页面的情况下,更新局部页面的技术. 不是指一种单一的技 ...
- 26、Jquery 基础
什么是Jquery? Jquery是一套Javascript脚本库. 使用时需要先下载下来,并引用到项目中. 下载地址:http://jquery.com/download/ 目前jquery分为 1 ...
- 求职,找工作,平台大PK
国内 猎聘网:www.lietou.com 拉钩网:Lagou.com 智联招聘:www.zhaopin.com 前程无忧:http://www.51job.com/ 中华英才网:chinahr.co ...
- Java设计模式--单列设计模式
设计模式:解决某一类问题行知最有效的方法.java有23种设计模式 单列设计模式: 解决一个类在内存中只存在一个对象 思路:(要保证对象的唯一性) 1.为了避免其它程序建立该对象,先禁止替他类创建改对 ...
- 尽量不要用select into 复制表
select into 复制表会带来灾难后果,因为只是复制了一个外壳,就像克隆人,有躯体没意识,像原表的主键 外键 约束 触发器 索引都不会被复制过来, 创建一个表:CREATE TABLE [dbo ...
- oracle学习笔记3:基本的SQL语句
oracle基本的SQL语句和SQLSERVER基本一样,在这里只简单列出与SQLSERVER不一样的地方 1.select * from orderinfo where address = 'abc ...
- iOS相关,过年回来电脑上的证书都失效了,解决方法。
今天发了个问题,就是关于电脑上的证书都失效的问题,就这个问题的解决方法如下:https://segmentfault.com/q/1010000004433963 1,按照链接下载,https://d ...
- POJ 1185 炮兵阵地(动态规划+状态压缩)
炮兵阵地 Description 司令部的将军们打算在N*M的网格地图上部署他们的炮兵部队.一个N*M的地图由N行M列组成,地图的每一格可能是山地(用"H" 表示),也可能是平原( ...
- C++语言体系设计哲学的一些随想(未完待续)
对于静态类型语言,其本质目标在于恰当地操作数据,得到期望的值.具体而言,需要: (1)定义数据类型 你定义的数据是什么,是整形还是浮点还是字符.该类型的数据可以包含的值的范围是什么. (2)定义操作的 ...