Linux svn 命令

Linux 命令大全 Linux 命令大全


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

验证安装

svn --version

常用 SVN 命令详解

检出代码(Checkout)

从 SVN 仓库获取代码到本地:

实例

svn checkout [仓库URL] [本地目录]
# 示例:
svn checkout http://svn.example.com/svn/project/trunk myproject

常用选项:

  • --username:指定用户名
  • --password:指定密码
  • --non-interactive:非交互模式

更新代码(Update)

将本地工作副本与仓库最新版本同步:

实例

svn update
# 更新到特定版本
svn update -r 1234

提交变更(Commit)

将本地修改提交到仓库:

svn commit -m "提交说明"

查看状态(Status)

查看工作副本的修改状态:

svn status

状态标志说明:

  • A:新增文件
  • M:修改文件
  • D:删除文件
  • ?:未版本控制的文件
  • !:丢失的文件

添加文件(Add)

将新文件纳入版本控制:

实例

svn add 文件名
# 添加当前目录下所有新文件
svn add --force .

删除文件(Delete)

从版本控制中删除文件:

svn delete 文件名

查看日志(Log)

查看提交历史:

实例

svn log
# 查看特定文件的日志
svn log 文件名
# 限制显示条目
svn log -l 10

比较差异(Diff)

查看修改内容:

实例

# 比较工作副本与基础版本
svn diff
# 比较两个版本
svn diff -r 100:200

撤销修改(Revert)

放弃本地修改:

实例

svn revert 文件名
# 撤销所有修改
svn revert -R .

解决冲突(Resolve)

当多人修改同一文件时可能出现冲突:

实例

# 查看冲突文件
svn status
# 解决冲突后标记为已解决
svn resolve --accept working 冲突文件

高级操作

分支与合并

实例

# 创建分支
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 propset svn:keywords "Date Rev Author" 文件名

# 查看属性
svn propget svn:keywords 文件名

实用技巧

  1. 忽略文件:创建 svn:ignore 属性来排除不需要版本控制的文件

    svn propset svn:ignore "*.log" .
  2. 查看文件详细信息

    svn info 文件名
  3. 导出干净副本(不含.svn目录):

    svn export 仓库URL 本地目录
  4. 清理工作副本

    svn cleanup

常见问题解决

认证失败

实例

# 删除保存的认证信息
rm -rf ~/.subversion/auth/

工作副本锁定

svn cleanup

冲突解决流程

  1. 更新工作副本:svn update
  2. 手动解决冲突(编辑文件)
  3. 标记为已解决:svn resolve --accept working 文件名
  4. 提交修改:svn commit -m "解决冲突"

最佳实践

  1. 提交前先更新工作副本
  2. 编写有意义的提交信息
  3. 频繁提交小变更,而不是一次性提交大量修改
  4. 使用分支进行功能开发
  5. 定期备份仓库

SVN 与 Git 比较

特性 SVN Git
架构 集中式 分布式
速度 较慢 较快
分支/合并 较复杂 简单高效
离线工作 有限支持 完全支持
学习曲线 较平缓 较陡峭

总结

SVN 是一个强大而稳定的版本控制系统,特别适合需要严格权限控制和集中管理的项目。通过掌握这些基本命令和概念,你已经能够高效地使用 SVN 进行日常版本控制工作。记住,版本控制的核心是频繁提交和良好的提交习惯,这将为你的项目开发提供可靠的安全网。


Linux 命令大全 Linux 命令大全