svn(subversion)代码版本管理在linux下的一些常见使用命令
2016-10-12 11:09
531 查看
以下的操作都是默认你的服务器安装有svn的大前提下进行的。一、创建版本库我的版本库存放路径为: /var/svn ; 下面我们来创建一个名为 svntet 的版本库
注释: svnadmin create svntet 就是svn的创建版本库命令;执行之后我们会发现 /var/svn 下会出现 svntet 的文件夹
二、修改新建的版本库的配置文件进入 /var/svn/svntet ;我们会发现有3个配置文件
我们先修改下 passwd ,添加 svntet 版本库的用户名和密码
修改 authz ,添加 svntet 版本库的用户的权限
注释:现在给 svntet 版本库的用户名为admin的用户添加他对该版本的读写权限
修改 svnserve.conf
三、导入代码文件到 svntet 版本库我的代码文件存放在 /var/www/html/qinkaizhu/svntest ; svn代码版本库的路径 /var/svn/svntet (也就是刚刚我们创建的版本库的位置);执行导入命令: svn import /var/www/html/qinkaizhu/svntest file:///var/svn/svntet -m "i"
四、从版本库导出代码导出代码到当前目录下; 执行导出命令: svn checkout svn://192.168.1.5/svntet
这时候,已经从 svntet 版本库取了最新版本的代码
五、从工作的代码拷贝提交到版本库如何我们没有修改如何代码,那么提交是没有意义的。下面我们先来修改下1.php;cd svntet vim 1.php
保存修改后,在 svntet 目录下执行提交命令:svn commit -m "cxcxcxc"
注释:-m “msg” 其中msg:为本次提交版本的一些描述(例如修改了什么之类的)
六、从版本库更新工作的代码拷贝假如有n个人在进行同一项工作,大家都是公用同一版本库,那么可能你现在的版本库就不是最新的了。所以,我们需要从版本库里更新下工作的代码拷贝。执行代码:cd svntet svn update
七、在工作的代码拷贝新建文件或者文件夹,然后提交到版本库1、先新建 3.php 4.php 2、执行加入版本控制命令:svn add 3.php 4.php
小插曲 【start】在这里注意了,经常我们在开发的时候,可能会加人很多的新文件,难道我们要一个一个地加吗?当然,你也可以实现的。。但是,如果我们加的文件特别多,而且目录结构也特别复杂。怎么办?svn status — 打印工作拷贝文件和目录的状态。我们可以借助svn status 或者 svn st快速找到新添加并没有纳入版本控制的文件。
第一列代表状态改变的文件的状态:'?' 项目不在版本控制之下;'M' 项目已经修改了;'!' 项目已经丢失;'~' 项目作为一种对象(文件、目录或链接)纳入版本控制,但是已经被另一种对象替代。更多的状态信息,可以在这里看见:传送门我们利用grep筛选出不在版本控制之下的文件或者文件夹svn st | grep ?
svn st | grep ? | awk '{print $2}'我们可以利用awk逐一获取到他们的信息,现在我们就只需要他们的路径就好了,然后有svn将他们加入版本控制
前面是和大家一起慢慢来,顺便回顾下shell的一些命令使用。其实就工作备份的最外层执行下面的代码就可以将没有加入版本控制的文件或者文件名加入版本控制svn status | grep ? | awk '{print $2}' | xargs svn add
然后,下次执行提交的时候,就会将新加文件提交加入到版本库了。。。小插曲 【end】
3、再执行提交到版本库的命令:svn commit -m "addnewfile"
注释:执行加入版本控制命令:svn add 3.php 4.php 后,版本库的并没有更新版本。直到下一次执行 commit 才会提交更新
八、删除工作拷贝和版本库的文件情况一:先在工作的拷贝删除,在下次执行commit命令时候,自动从版本库里删除1、先执行删除命令:svn del 1.php 2.php2、再执行提交命令:svn commit -m "delfile"
情况二:直接从版本库里删除,然后在工作拷贝下更新(update)执行删除命令:svn del -m "del 4.php" file:///var/svn/svntet/4.php
以上是我经常用到的一下svn在linux的命令操作。大家在操作的时候应该注意命令操作时候所在的当前目录。例如 svn update ;svn commite,不然会导致一些错误。
在工作拷贝中在每个目录下都会存在.svn文件;在项目完成要上线的时候,我们怎么样快速都将所有的.svn文件都删除呢。。我们可以写个shell脚本来进行删除。find -type d -name ".svn" | xargs rm -rf
其他常用的命令:更新到某个版本 svn update -r m path 例如: svn update如果后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本。 svn update -r 200 test.php(将版本库中的文件test.php还原到版本200) svn update test.php(更新,于版本库同步。如果在提交的时候提示过期的话,是因为冲突,需要先update,修改文件,然后清除svn resolved,最后再提交commit) 简写:svn up
加锁/解锁 svn lock -m “LockMessage“ [--force] PATH 例如:svn lock -m “lock test file“ test.php svn unlock PATH
查看日志 svn log path 例如:svn log test.php 显示这个文件的所有修改记录,及其版本号的变化
比较差异 svn diff path(将修改的文件与基础版本比较) 例如:svn diff test.php svn diff -r m:n path(对版本m和版本n比较差异) 例如:svn diff -r 200:201 test.php 简写:svn di
将两个版本之间的差异合并到当前文件 svn merge -r m:n path 例如:svn merge -r 200:205 test.php(将版本200与205之间的差异合并到当前文件,但是一般都会产生冲突,需要处理一下)
版本库下的文件和目录列表 svn list path 显示path目录下的所有属于版本库的文件和目录 简写:svn ls
创建纳入版本控制下的新目录 svn mkdir: 创建纳入版本控制下的新目录。 用法: 1、mkdir PATH… 2、mkdir URL… 创建版本控制的目录。 1、每一个以工作副本 PATH 指定的目录,都会创建在本地端,并且加入新增 调度,以待下一次的提交。 2、每个以URL指定的目录,都会透过立即提交于仓库中创建。 在这两个情况下,所有的中间目录都必须事先存在。
注释: svnadmin create svntet 就是svn的创建版本库命令;执行之后我们会发现 /var/svn 下会出现 svntet 的文件夹
二、修改新建的版本库的配置文件进入 /var/svn/svntet ;我们会发现有3个配置文件
我们先修改下 passwd ,添加 svntet 版本库的用户名和密码
修改 authz ,添加 svntet 版本库的用户的权限
注释:现在给 svntet 版本库的用户名为admin的用户添加他对该版本的读写权限
修改 svnserve.conf
三、导入代码文件到 svntet 版本库我的代码文件存放在 /var/www/html/qinkaizhu/svntest ; svn代码版本库的路径 /var/svn/svntet (也就是刚刚我们创建的版本库的位置);执行导入命令: svn import /var/www/html/qinkaizhu/svntest file:///var/svn/svntet -m "i"
四、从版本库导出代码导出代码到当前目录下; 执行导出命令: svn checkout svn://192.168.1.5/svntet
这时候,已经从 svntet 版本库取了最新版本的代码
五、从工作的代码拷贝提交到版本库如何我们没有修改如何代码,那么提交是没有意义的。下面我们先来修改下1.php;cd svntet vim 1.php
保存修改后,在 svntet 目录下执行提交命令:svn commit -m "cxcxcxc"
注释:-m “msg” 其中msg:为本次提交版本的一些描述(例如修改了什么之类的)
六、从版本库更新工作的代码拷贝假如有n个人在进行同一项工作,大家都是公用同一版本库,那么可能你现在的版本库就不是最新的了。所以,我们需要从版本库里更新下工作的代码拷贝。执行代码:cd svntet svn update
七、在工作的代码拷贝新建文件或者文件夹,然后提交到版本库1、先新建 3.php 4.php 2、执行加入版本控制命令:svn add 3.php 4.php
小插曲 【start】在这里注意了,经常我们在开发的时候,可能会加人很多的新文件,难道我们要一个一个地加吗?当然,你也可以实现的。。但是,如果我们加的文件特别多,而且目录结构也特别复杂。怎么办?svn status — 打印工作拷贝文件和目录的状态。我们可以借助svn status 或者 svn st快速找到新添加并没有纳入版本控制的文件。
第一列代表状态改变的文件的状态:'?' 项目不在版本控制之下;'M' 项目已经修改了;'!' 项目已经丢失;'~' 项目作为一种对象(文件、目录或链接)纳入版本控制,但是已经被另一种对象替代。更多的状态信息,可以在这里看见:传送门我们利用grep筛选出不在版本控制之下的文件或者文件夹svn st | grep ?
svn st | grep ? | awk '{print $2}'我们可以利用awk逐一获取到他们的信息,现在我们就只需要他们的路径就好了,然后有svn将他们加入版本控制
前面是和大家一起慢慢来,顺便回顾下shell的一些命令使用。其实就工作备份的最外层执行下面的代码就可以将没有加入版本控制的文件或者文件名加入版本控制svn status | grep ? | awk '{print $2}' | xargs svn add
然后,下次执行提交的时候,就会将新加文件提交加入到版本库了。。。小插曲 【end】
3、再执行提交到版本库的命令:svn commit -m "addnewfile"
注释:执行加入版本控制命令:svn add 3.php 4.php 后,版本库的并没有更新版本。直到下一次执行 commit 才会提交更新
八、删除工作拷贝和版本库的文件情况一:先在工作的拷贝删除,在下次执行commit命令时候,自动从版本库里删除1、先执行删除命令:svn del 1.php 2.php2、再执行提交命令:svn commit -m "delfile"
情况二:直接从版本库里删除,然后在工作拷贝下更新(update)执行删除命令:svn del -m "del 4.php" file:///var/svn/svntet/4.php
以上是我经常用到的一下svn在linux的命令操作。大家在操作的时候应该注意命令操作时候所在的当前目录。例如 svn update ;svn commite,不然会导致一些错误。
在工作拷贝中在每个目录下都会存在.svn文件;在项目完成要上线的时候,我们怎么样快速都将所有的.svn文件都删除呢。。我们可以写个shell脚本来进行删除。find -type d -name ".svn" | xargs rm -rf
其他常用的命令:更新到某个版本 svn update -r m path 例如: svn update如果后面没有目录,默认将当前目录以及子目录下的所有文件都更新到最新版本。 svn update -r 200 test.php(将版本库中的文件test.php还原到版本200) svn update test.php(更新,于版本库同步。如果在提交的时候提示过期的话,是因为冲突,需要先update,修改文件,然后清除svn resolved,最后再提交commit) 简写:svn up
加锁/解锁 svn lock -m “LockMessage“ [--force] PATH 例如:svn lock -m “lock test file“ test.php svn unlock PATH
查看日志 svn log path 例如:svn log test.php 显示这个文件的所有修改记录,及其版本号的变化
比较差异 svn diff path(将修改的文件与基础版本比较) 例如:svn diff test.php svn diff -r m:n path(对版本m和版本n比较差异) 例如:svn diff -r 200:201 test.php 简写:svn di
将两个版本之间的差异合并到当前文件 svn merge -r m:n path 例如:svn merge -r 200:205 test.php(将版本200与205之间的差异合并到当前文件,但是一般都会产生冲突,需要处理一下)
版本库下的文件和目录列表 svn list path 显示path目录下的所有属于版本库的文件和目录 简写:svn ls
创建纳入版本控制下的新目录 svn mkdir: 创建纳入版本控制下的新目录。 用法: 1、mkdir PATH… 2、mkdir URL… 创建版本控制的目录。 1、每一个以工作副本 PATH 指定的目录,都会创建在本地端,并且加入新增 调度,以待下一次的提交。 2、每个以URL指定的目录,都会透过立即提交于仓库中创建。 在这两个情况下,所有的中间目录都必须事先存在。
相关文章推荐
- svn(subversion)代码版本管理在linux下的一些常见使用命令
- svn(subversion)代码版本管理在linux下的一些常见使用命令
- SVN版本管理工具使用中常见的代码提交冲突问题的解决方法
- linux使用svn版本管理之创建仓储权和限管理
- ubuntu14.04下svn版本管理系统的安装及常用命令的使用整理
- 今天在Mac机器上使用了Flex Builder编辑了一个源代码文件,保存后使用vim命令去打开时发现系统自动在每一行的结尾添加了^M符号,其实^M在Linux/Unix中是非常常见的,也就是我们在Win中见过的/r回车符号。由于编辑软件的编码问题,某些IDE的编辑器在编辑完文件之后会自动加上这个^M符号。看起来对我们的源代码没有任何影响,其实并不然,当我们把源代码文件Check In到svn之类
- linux 进程管理的一些命令使用
- linux上安装svn版本管理系统(subversion+apache+jsvnadmin)
- [linux] svn merge 命令(命令使用,解决产生冲突,代码回滚)
- SVN版本号管理工具使用中常见的代码提交冲突问题的解决方法
- Linux下使用代码版本库:svn和git
- Linux下使用一些常用的svn命令
- 使用SVN的版本管理时,一些小技巧避免不必要的冲突(C)
- linux学习:持续集成篇--svn版本管理系统的安装与使用-02
- 持续集成篇_03_svn版本管理系统的使用(centos+subversion+apache+jsvnadmin+tortoisesvn)
- SVN版本管理系统的使用(CentOS+Subversion+Apache+Jsvnadmin+TortoiseSVN)
- [CodeVersion--SVN]代码版本管理的一些问题
- ubuntu14.04下svn版本管理系统的安装及常用命令的使用整理
- 使用subversion实现虚拟机中linux和windows宿主机代码共享管理
- SVN版本管理平台(Subversion+Apache+Jsvnadmin)安装配置和使用