Linux svn 命令
SVN(Subversion)是一个开源的版本控制系统,用于管理文件和目录的变更历史。它可以帮助开发团队协作开发项目,跟踪代码变更,并支持版本回退。
类比理解:可以把 SVN 想象成一个时间机器,它能记录你项目中每个文件的每次修改,就像游戏中的存档点一样,你可以随时回到之前的任何一个版本。
SVN 基本概念
仓库(Repository)
SVN 仓库是存储所有版本数据的地方,相当于一个中央数据库。它保存着项目的完整历史记录。
工作副本(Working Copy)
这是你本地机器上的项目副本,你可以在这里进行修改,然后将变更提交到仓库。
版本号(Revision)
每次提交都会生成一个全局唯一的版本号,用于标识项目的某个特定状态。
SVN 安装与配置
安装 SVN
在大多数 Linux 发行版上,可以通过包管理器安装:
实例
# Ubuntu/Debian
sudo apt-get install subversion
# CentOS/RHEL
sudo yum install subversion
# Fedora
sudo dnf install subversion
sudo apt-get install subversion
# CentOS/RHEL
sudo yum install subversion
# Fedora
sudo dnf install subversion
验证安装
svn --version
常用 SVN 命令详解
检出代码(Checkout)
从 SVN 仓库获取代码到本地:
实例
svn checkout [仓库URL] [本地目录]
# 示例:
svn checkout http://svn.example.com/svn/project/trunk myproject
# 示例:
svn checkout http://svn.example.com/svn/project/trunk myproject
常用选项:
--username
:指定用户名--password
:指定密码--non-interactive
:非交互模式
更新代码(Update)
将本地工作副本与仓库最新版本同步:
实例
svn update
# 更新到特定版本
svn update -r 1234
# 更新到特定版本
svn update -r 1234
提交变更(Commit)
将本地修改提交到仓库:
svn commit -m "提交说明"
查看状态(Status)
查看工作副本的修改状态:
svn status
状态标志说明:
A
:新增文件M
:修改文件D
:删除文件?
:未版本控制的文件!
:丢失的文件
添加文件(Add)
将新文件纳入版本控制:
实例
svn add 文件名
# 添加当前目录下所有新文件
svn add --force .
# 添加当前目录下所有新文件
svn add --force .
删除文件(Delete)
从版本控制中删除文件:
svn delete 文件名
查看日志(Log)
查看提交历史:
实例
svn log
# 查看特定文件的日志
svn log 文件名
# 限制显示条目
svn log -l 10
# 查看特定文件的日志
svn log 文件名
# 限制显示条目
svn log -l 10
比较差异(Diff)
查看修改内容:
实例
# 比较工作副本与基础版本
svn diff
# 比较两个版本
svn diff -r 100:200
svn diff
# 比较两个版本
svn diff -r 100:200
撤销修改(Revert)
放弃本地修改:
实例
svn revert 文件名
# 撤销所有修改
svn revert -R .
# 撤销所有修改
svn revert -R .
解决冲突(Resolve)
当多人修改同一文件时可能出现冲突:
实例
# 查看冲突文件
svn status
# 解决冲突后标记为已解决
svn resolve --accept working 冲突文件
svn status
# 解决冲突后标记为已解决
svn resolve --accept working 冲突文件
高级操作
分支与合并
实例
# 创建分支
svn copy 源URL 目标URL -m "创建分支说明"
# 合并分支
svn merge 源URL[@版本] 工作副本路径
svn copy 源URL 目标URL -m "创建分支说明"
# 合并分支
svn merge 源URL[@版本] 工作副本路径
标签管理
实例
# 创建标签(与创建分支语法相同)
svn copy http://svn.example.com/svn/project/trunk
http://svn.example.com/svn/project/tags/1.0
-m "创建1.0版本标签"
svn copy http://svn.example.com/svn/project/trunk
http://svn.example.com/svn/project/tags/1.0
-m "创建1.0版本标签"
属性管理
实例
# 设置属性
svn propset svn:keywords "Date Rev Author" 文件名
# 查看属性
svn propget svn:keywords 文件名
svn propset svn:keywords "Date Rev Author" 文件名
# 查看属性
svn propget svn:keywords 文件名
实用技巧
-
忽略文件:创建
svn:ignore
属性来排除不需要版本控制的文件svn propset svn:ignore "*.log" .
-
查看文件详细信息:
svn info 文件名
-
导出干净副本(不含.svn目录):
svn export 仓库URL 本地目录
-
清理工作副本:
svn cleanup
常见问题解决
认证失败
实例
# 删除保存的认证信息
rm -rf ~/.subversion/auth/
rm -rf ~/.subversion/auth/
工作副本锁定
svn cleanup
冲突解决流程
- 更新工作副本:
svn update
- 手动解决冲突(编辑文件)
- 标记为已解决:
svn resolve --accept working 文件名
- 提交修改:
svn commit -m "解决冲突"
最佳实践
- 提交前先更新工作副本
- 编写有意义的提交信息
- 频繁提交小变更,而不是一次性提交大量修改
- 使用分支进行功能开发
- 定期备份仓库
SVN 与 Git 比较
特性 | SVN | Git |
---|---|---|
架构 | 集中式 | 分布式 |
速度 | 较慢 | 较快 |
分支/合并 | 较复杂 | 简单高效 |
离线工作 | 有限支持 | 完全支持 |
学习曲线 | 较平缓 | 较陡峭 |
总结
SVN 是一个强大而稳定的版本控制系统,特别适合需要严格权限控制和集中管理的项目。通过掌握这些基本命令和概念,你已经能够高效地使用 SVN 进行日常版本控制工作。记住,版本控制的核心是频繁提交和良好的提交习惯,这将为你的项目开发提供可靠的安全网。
点我分享笔记