svn---命令行操作
一、基本操作
1、checkout是将服务器上的代码下载到本地(下载所有文件)。Checkout只需要做一次
2、commit是将本地修改之后的文件提交到服务器(只提交修改之后的)。每天下班前:commit“可运行版本”
3、update是将服务器上的代码更新到本地(只会更新被修改的文件)。每天上班前:update前一天所有代码
二、策略
1、拷贝--修改--合并
2、锁定--修改
. 源代码管理工具概述(PPT)
================================================================================ * 源代码管理工具的作用:
# 能追踪一个项目从诞生一直到定案的过程
# 记录一个项目的所有内容变化
# 方便地查阅特定版本的修订情况 * 如果是团队开发,使用源代码管理工具是强制性的!
* 如果是单人开发,也强烈建议现在就开始使用源代码管理工具 * 使用源代码管理工具
# 由于使用简单,不会增加工作量
# 不会对现有工作造成任何损害(坏的影响)
# 是一位合格的软件开发人员必须掌握的技术 . SVN介绍(PPT)
================================================================================ SVN 是集中式源代码管理工具 概念:
> Repository 代码仓库,保存代码的仓库
> Server 服务器,保存所有版本的代码仓库
> Client 客户端,只保存当前用户的代码仓库
> 用户名&密码 访问代码仓库需要使用自己的"用户名和密码",从而可以区分出不同的人对代码做的修改 操作:
> checkout 将服务器上最新的代码仓库下载到本地,"只需要做一次"
> update 从服务器上将其他人所做的修改下载到本地,"每天上班必须要做的事情"
> commit 将工作提交到服务器,"每天下班之前至少做一次" . SVN服务器安装 Visual SVN Server
================================================================================
提示:一般程序员是没有机会安装SVN服务器的,以下内容仅供了解服务器上的安装及配置过程 * Visual SVN Server 是运行在windows操作系统上的,集成了Subversion和Apache
* 傻瓜式安装一步到位,并提供了图形化界面,安装简单配置方便
* 下载地址:http://www.visualsvn.com/server/download/ > 安装
* 程序目录
* 代码仓库目录 > 添加代码仓库"weibo"
* 暂时不勾选默认结构(trunk, branches, tags) > 添加用户
* 为了方便后续的演练,每个用户的口令不要设置成一样
# 用户名 口令
# manager jingli
# zhangsan zhang
# lisi li > 添加群组,通过群组可以一次性设置多个用户对代码仓库的访问权限,便于管理 > 设置权限演练
* 选中项目的代码库,点击右键,选择"Properties" > 协议
* https 端口
* http 端口 > 协议的修改
* 选中"VisualSVN Server",点击鼠标右键,选择"Properties"
* 选择"Network",勾选"Use secure connection"会使用https协议访问服务器的代码仓库 补充:HTTPS = HTTP + SSL
注意:有关https的概念暂时不要纠结,有一个印象就可以!后面课程安全部分会讲到!
--------------------------------------------------------------------------------
HTTPS(Hyper Text Transfer Protocol over Secure Socket Layer)是以安全为目标的HTTP通道,
简单讲是HTTP的安全版 HTTPS提供了身份验证与加密通讯方法,现在被广泛用于互联网上安全敏感的通讯,例如交易支付方面 HTTPS的证书需要申请认证,这一认证是付费的,认证网站 http://cn.globalsign.com/ > 使用浏览器浏览代码仓库
如果使用了https协议,在不同的浏览器中访问,显示效果会不太一样 . SVN演练准备
================================================================================ > 显示隐藏文件夹
# 显示隐藏文件
$ defaults write com.apple.finder AppleShowAllFiles Yes && killall Finder
# 不显示隐藏文件
$ defaults write com.apple.finder AppleShowAllFiles No && killall Finder > 在桌面上新建一个文件夹 "svn演练"
依次建立以下三个目录
# 经理
# 张三
# 李四 . 命令行准备
================================================================================ 熟悉命令行的目的:所有图形工具本质上都是对命令行的封装,理解命令行的操作,更有助于对图形工具的使用 > SVN基本命令
命令行格式:
svn <subcommand> [options] [args]
说明
svn 子命令 [选项] [参数] 提示:
# [中括号]中包含的内容是可选的
# (子命令缩写) > 查看帮助信息 $ svn help
查看svn所有命令的帮助
$ svn help 子命令 > UNIX常用命令介绍(UNIX常用命令.m)
五、命令行操作
1、进入经历文件夹
2、输入svn checkout指令
3、输入电脑密码
4、输入用户名
5、输入密码
6、检出成功
7、检出(将项目下载到本地)
通过指定的账号密码检出
svn checkout http://192.168.15.155/svn/weibo/ --username=ls --password=ls
svn checkout URL [PATH]([]省略的时候代表下载到当前所在路径)
svn的本质是通过一个文件夹来管理源代码默认情况下,用于管理源代码的文件夹是隐藏的,这个隐藏文件夹的名称叫做.svn
8、添加
①、添加新建的文件到本地的版本控制库中:svn add 文件path
②、提交刚才的添加操作到服务器:svn commit
注意:新建文件或者文件夹之后如果直接提交(直接commit)会报错:is not under version control(提示我提交的文件没有纳入版本控制)
svn add只会将文件添加到本地,不会添加到服务器
9、查看入会的文件的情况(只输出改变的)
svn status (svn st)
10、提交
将改动过的文件提交至服务器
svn commit -m “注释” [PATH]
注意:在提交代码时必须写上注释(认真写),否则报错:Could not use external editor to fetch log message.
11、更新
将服务器的最新代码更新到本地
svn update [PATH](svn up)
将文件恢复至某个版本
svn update -r 版本号 [PATH]
12、删除
①、将文件从本地的版本控制库中移除:svn delete PATH、svn remove PATH
②、提交刚才的删除操作的服务器:svn commit
13。常见问题总结
六、文件反悔
如果修改文件之后,并且文件没有“提交”(commit)想反悔,可以使用svn的revert指令让文件回到上一次提交之前的状态
svn revert main.c
update除了可以更新服务器最新的代码以外还可以更新到指定版本。
每次提交代码之后,svn的版本号都会自动加1,正是因为版本每次会自动加1,也就是版本号是唯一的,
所以我们可以通过版本号更新到指定的版本的代码。
svn update -r 版本号
svn log main.c (查看注释)
版本控制器中最常见的两个问题:
1.超时
SVN 使用svn有一个原则:先更新再提交
只要本地的版本号大于等于服务器的版本号时才能提交,否则会报一个out of date错误。
2.冲突
当多个人修改了同一个文件的同一行代码就会导致冲突Conflict discovered in
(mc)mine-conflict,代表用我们的代码替代服务器的代码
本地代码只保留我们自己写的代码
(tc)theirs-conflict,代表用服务器代码替换我们的代码
本地代码只保留服务器代码,删除我们的代码
(p)postpone,自己手动解决
本地文件中会同时保留服务器代码和本地代码
会在本地创建3个备份
main.c.mine备份自己最新的代码
main.c.r17本地修改之前的版本
main.c.r18服务器最新的版本
main.c 合并两个版本的代码:
<<<<<< 到 =======中间存放的是我们自己修改的代码
===== 到 >>>>>>> 中间存放的是服务器最新的代码
注意:手动解决完冲突之后,需要告诉svn服务器我们已经解决冲突,这样才能保证数据的安全性和svn的可靠性 svn resolved main.c
svn---命令行操作的更多相关文章
- 转:svn命令行操作
原文:http://zhumeng8337797.blog.163.com/blog/static/10076891420115218821912/SVN命令行 -- ::| 分类: CVS |字号 ...
- SVN命令行操作
参考 https://wenku.baidu.com/view/511a7d29ed630b1c59eeb5f3.html 1, 将文件checkout到本地目录 svn check out http ...
- 命令行操作svn和git和git
前几天在写代码的时候电脑突然坏掉,老大交代的任务没完成,非常痛恨自己用svn或者git保存代码,相信很多程序员遇到过,硬盘坏掉,存在硬盘中的代码丢失,无法找回的问题,svn和git可谓程序员界的福音, ...
- SVN的命令行操作
最近在进行svn二次开发,使用的是svnkit.看了很多svnkit的api,渐渐发现都是和SVN的命令行操作对应的.顺便研究一下svn的命名行操作. 1.将文件checkout到本地目录: 基本命令 ...
- windows下使用TortoiseGit代替Git命令行操作
windows下使用TortoiseGit代替Git命令行操作 大家在使用svn的时候,都非常喜欢使用小乌龟,也就是TortoiseSVN:那么git也有小乌龟版本,即TortoiseGit. 1.安 ...
- svn命令行修改已提交的版本备注
svn命令行修改已提交的版本备注 参考文章: stackoverflow.com/questions/304383/how-do-i-edit-a-log-message-that-i-already ...
- Linux环境SVN命令行使用经验总结(转)
在windows机器上开发得差不多了之后,打包传送到开发机编译,在开发机上解决编译错误. [缺点] 浪费时间在打包解包,机器间传输代码. 在windows机器上开发之后,check in代码进分支,在 ...
- svn命令行批量删除和批量添加
svn命令行批量删除和批量添加 如果使用svn的命令行,例如在linux下的终端中使用,svn的添加命令是svn add,删除命令是svn del,但是缺乏批量的操作,如果我在资源管理器中,手动添加了 ...
- mysql 命令行操作入门(详细讲解版)
之前分享过多次Mysql主题,今天继续分享mysql命令行入门 1. 那么多mysql客户端工具,为何要分享命令行操作? -快捷.简单.方便 -在没有客户端的情况下怎么办 -如果是mysql未开启 ...
- Mac SVN 命令行
Mac自带了SVN命令行,如我的升级到10.10(OSX yosemite)后命令行版本为1.7.10 以下是一些常用命令 1.将文件checkout到本地目录 svn checkout path(p ...
随机推荐
- java对身份证验证及正则表达式解析
原文地址:http://www.cnblogs.com/zhongshengzhen/ java对身份证验证及正则表达式解析 package service; import java.text.Par ...
- 利用openssl进行BASE64编码解码、md5/sha1摘要、AES/DES3加密解密
国内私募机构九鼎控股打造APP,来就送 20元现金领取地址:http://jdb.jiudingcapital.com/phone.html内部邀请码:C8E245J (不写邀请码,没有现金送)国内私 ...
- Oracle12c功能增强 新特性之管理功能的增强
1. 数据文件在线重命名和迁移 不想先前的版本号.在Oracle12cR1中,数据文件的迁移或重命名不再要求一系列的步骤,比如:将表空间至于仅仅读模式,然后数据文件逻辑等操作.在12cR1中.数 ...
- hadoop学习;block数据块;mapreduce实现样例;UnsupportedClassVersionError异常;关联项目源代码
对于开源的东东,尤其是刚出来不久,我认为最好的学习方式就是能够看源代码和doc,測试它的样例 为了方便查看源代码,关联导入源代码的项目 先前的项目导入源代码是关联了源代码文件 block数据块,在配置 ...
- WCF之初体验
什么是WCF? WCF的全称是:Windows通信基础(WindowsCommunication Foundation).本质来讲,他是一套软件开发包. WCF和WebService的差别 Webse ...
- mysqldump原理2
本文主要探讨 mysqldump 的几种主要工作方式,并且比较一下和 mk-parralel-dump的一些差异,为备份方式的选择提供更多的帮助. 首先来看下 mysqldump 的几个主要参数的实际 ...
- 介绍一些实用的IOS手势识别库 (COCOS2D)
http://www.supersuraccoon-cocos2d.com/zh/2012/11/14/introduction-to-some-great-ios-gesture-recogniti ...
- php读取图片成二进制流输出
header( "Content-type: image/jpeg");$PSize = filesize('1.jpg');$picturedata = fread(fopen( ...
- 多台Linux服务器SSH相互访问无需密码--转
一.环境配置 1.系统:CentOS release 5.6 IP:192.168.4.200 主机名:JW01 2.系统:CentOS release 5.9 IP:192.168.4. ...
- axel源码学习(0)——程序逻辑
axel简介 axel是一个命令行下的轻量级http/ftp 下载加速工具,支持多线程下载和断点续传,支持从多个镜像下载同一文件. axel的用法如下: 图 0.1 axel usage axel 粗 ...