SVN
代码版本管理软件
一个人开发也要用版本管理工具?
多人协作开发?
异地开发?
工作流程
安装服务器软件
Setup-Subversion-1.6.5.msi
全部默认即可
创建仓库
运行 cmd
svnadmin create c:\svn_data
说明c:\svn_data是服务器的仓库目录,不是写代码的目录
创建好后打开c:\svn_data\conf
有三个文件:
authz 权限控制
passwd 用户和密码
svnserve.conf 服务器的配置信息
配置用户和密码
用记事本打开passwd文件,格式
[users]
用户名 = 密码
注意:用户名前面不能为空格,等号两边有空格
权限
用记事本打开authz文件,格式
[/] /是代表仓库的根目录
jack = rw
mary = r
用户名 = 权限
启用这些配置, 修改svnserve.conf,让刚才的设置生效
打开svnserve.conf
[general]
把前面的#号去掉:
anon-access = none 不允许匿名用户访问
auth-access = write 认识用户的权限
password-db = passwd 用户和密码信息在哪一文件中
authz-db = authz 权限配置在哪一个文件中
realm = My First Repository 修改这一项内容,会显示在客户端登录时的提示
启动svn服务
运行cmd
svnserve -d -r c:\svn_data
没有任何提示,命令窗口不能关(不适合使用)
添加windows服务
sc create svnserve binPath= "C:\Program Files\Subversion\bin\svnserve.exe --service --root C:\svn_data"
注意: binPath= 之后要有一个空格
成功后,我的电脑右键-》服务=》svnserve 改为自动并启动
停止服务
net stop svnserve
删除服务
sc delete svnserve
windows版本服务端配置完成
安装客户端软件
TortoiseSVN-1.7.12.24070-win32-svn-1.7.9.msi
全部默认,不用选安装目录
安装完成后,在目录上点右键,将多出两个菜单
SVN Checkout
TortoiseSVN
汉化
LanguagePack_1.7.12.24070-win32-zh_CN.msi
选择语言
TortoiseSVN->Settings->General->Language
重启电脑
来到web开发目录
为项目新建一个目录
在这个目录上,点右键->SVN检出(checkout)
版本库URL:
svn://127.0.0.1
确定后提示输入用户名和密码
将SVN服务器 和刚才创建的 项目文件夹 关联起来了
将在这个目录下进行开发
如果将代码提交到SVN服务器
在项目文件夹上,点右键,SVN提交
选择需要提交的文件和文件夹
填写备注信息
图标
蓝色的问号:说明这个文件是新来的,不认识,需要添加到SVN的管理中
蓝加号:说明这个文件已经加入到SVN版本控制,还没有提交到服务器中
如何提交到服务器中
右键SVN Commit
绿色对勾:说明这个文件已经提交到服务器上了
批量提交
到项目根目录上点右键SVN Commit
红色叹号:说明此文件在本地已修改,需要提交到服务器
黄色叹号:说明文件有冲突
灰禁止图标:说明这个文件被忽略,不提交到SVN中
每天上班先更新
下班先更新再提交。
冲突如何产生和解决
7 修改 ->提交 8
7 修改 ->提交 8 已是是8了,服务器将提示你过期了
属于自己负责的文件,在上在签名
不是自己的文件,不能随便改,要通知负责该文件的人
公共文件,先个人修改前,都先加锁,可以避免冲突
清理功能
如果SVN被意外锁定,请使用清理功能
添加到忽略列表