一、基本操作

1、checkout是将服务器上的代码下载到本地(下载所有文件)。Checkout只需要做一次

2、commit是将本地修改之后的文件提交到服务器(只提交修改之后的)。每天下班前:commit“可运行版本”

3、update是将服务器上的代码更新到本地(只会更新被修改的文件)。每天上班前:update前一天所有代码

二、策略

1、拷贝--修改--合并

2、锁定--修改

 
三、xcode设置
xcode->preferences->locations->Command Line Tools
 
 
四、笔记
 
  1. . 源代码管理工具概述(PPT)
  2. ================================================================================
  3.  
  4. * 源代码管理工具的作用:
  5. # 能追踪一个项目从诞生一直到定案的过程
  6. # 记录一个项目的所有内容变化
  7. # 方便地查阅特定版本的修订情况
  8.  
  9. * 如果是团队开发,使用源代码管理工具是强制性的!
  10. * 如果是单人开发,也强烈建议现在就开始使用源代码管理工具
  11.  
  12. * 使用源代码管理工具
  13. # 由于使用简单,不会增加工作量
  14. # 不会对现有工作造成任何损害(坏的影响)
  15. # 是一位合格的软件开发人员必须掌握的技术
  16.  
  17. . SVN介绍(PPT)
  18. ================================================================================
  19.  
  20. SVN 是集中式源代码管理工具
  21.  
  22. 概念:
  23. > Repository 代码仓库,保存代码的仓库
  24. > Server 服务器,保存所有版本的代码仓库
  25. > Client 客户端,只保存当前用户的代码仓库
  26. > 用户名&密码 访问代码仓库需要使用自己的"用户名和密码",从而可以区分出不同的人对代码做的修改
  27.  
  28. 操作:
  29. > checkout 将服务器上最新的代码仓库下载到本地,"只需要做一次"
  30. > update 从服务器上将其他人所做的修改下载到本地,"每天上班必须要做的事情"
  31. > commit 将工作提交到服务器,"每天下班之前至少做一次"
  32.  
  33. . SVN服务器安装 Visual SVN Server
  34. ================================================================================
  35. 提示:一般程序员是没有机会安装SVN服务器的,以下内容仅供了解服务器上的安装及配置过程
  36.  
  37. * Visual SVN Server 是运行在windows操作系统上的,集成了SubversionApache
  38. * 傻瓜式安装一步到位,并提供了图形化界面,安装简单配置方便
  39. * 下载地址:http://www.visualsvn.com/server/download/
  40.  
  41. > 安装
  42. * 程序目录
  43. * 代码仓库目录
  44.  
  45. > 添加代码仓库"weibo"
  46. * 暂时不勾选默认结构(trunk, branches, tags)
  47.  
  48. > 添加用户
  49. * 为了方便后续的演练,每个用户的口令不要设置成一样
  50. # 用户名 口令
  51. # manager jingli
  52. # zhangsan zhang
  53. # lisi li
  54.  
  55. > 添加群组,通过群组可以一次性设置多个用户对代码仓库的访问权限,便于管理
  56.  
  57. > 设置权限演练
  58. * 选中项目的代码库,点击右键,选择"Properties"
  59.  
  60. > 协议
  61. * https 端口
  62. * http 端口
  63.  
  64. > 协议的修改
  65. * 选中"VisualSVN Server",点击鼠标右键,选择"Properties"
  66. * 选择"Network",勾选"Use secure connection"会使用https协议访问服务器的代码仓库
  67.  
  68. 补充:HTTPS = HTTP + SSL
  69. 注意:有关https的概念暂时不要纠结,有一个印象就可以!后面课程安全部分会讲到!
  70. --------------------------------------------------------------------------------
  71. HTTPS(Hyper Text Transfer Protocol over Secure Socket Layer)是以安全为目标的HTTP通道,
  72. 简单讲是HTTP的安全版
  73.  
  74. HTTPS提供了身份验证与加密通讯方法,现在被广泛用于互联网上安全敏感的通讯,例如交易支付方面
  75.  
  76. HTTPS的证书需要申请认证,这一认证是付费的,认证网站 http://cn.globalsign.com/
  77.  
  78. > 使用浏览器浏览代码仓库
  79. 如果使用了https协议,在不同的浏览器中访问,显示效果会不太一样
  80.  
  81. . SVN演练准备
  82. ================================================================================
  83.  
  84. > 显示隐藏文件夹
  85. # 显示隐藏文件
  86. $ defaults write com.apple.finder AppleShowAllFiles Yes && killall Finder
  87. # 不显示隐藏文件
  88. $ defaults write com.apple.finder AppleShowAllFiles No && killall Finder
  89.  
  90. > 在桌面上新建一个文件夹 "svn演练"
  91. 依次建立以下三个目录
  92. # 经理
  93. # 张三
  94. # 李四
  95.  
  96. . 命令行准备
  97. ================================================================================
  98.  
  99. 熟悉命令行的目的:所有图形工具本质上都是对命令行的封装,理解命令行的操作,更有助于对图形工具的使用
  100.  
  101. > SVN基本命令
  102. 命令行格式:
  103. svn <subcommand> [options] [args]
  104. 说明
  105. svn 子命令 [选项] [参数]
  106.  
  107. 提示:
  108. # [中括号]中包含的内容是可选的
  109. # (子命令缩写)
  110.  
  111. > 查看帮助信息
  112.  
  113. $ svn help
  114. 查看svn所有命令的帮助
  115. $ svn help 子命令
  116.  
  117. > 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。常见问题总结

去到公司的第一天,下载公司的代码到电脑上
svn checkout
 
修改了某个早已存在的旧文件,然后提交到服务器
svn commit
 
提交一个自己新建的文件到服务器
svn add à svn commit
 
删除一个早已存在的旧文件,然后同步到服务器上
svn delete à svn commit
 
将其他同事提交的新代码更新到自己电脑上
svn update
 
不小心写错了很多东西,想撤销所写的东西(还未把修改提交到服务器)
svn revert
 
不小心删错了文件,想把文件恢复回来(还未把删除提交到服务器)
svn revert
 
不小心写错了很多东西,想撤销所写的东西(已经把修改提交到服务器)
svn update -r 版本号
 
不小心删错了文件,想把文件恢复回来(已经把删除提交到服务器)
svn update -r 版本号

六、文件反悔

如果修改文件之后,并且文件没有“提交”(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---命令行操作的更多相关文章

  1. 转:svn命令行操作

    原文:http://zhumeng8337797.blog.163.com/blog/static/10076891420115218821912/SVN命令行 -- ::| 分类: CVS |字号 ...

  2. SVN命令行操作

    参考 https://wenku.baidu.com/view/511a7d29ed630b1c59eeb5f3.html 1, 将文件checkout到本地目录 svn check out http ...

  3. 命令行操作svn和git和git

    前几天在写代码的时候电脑突然坏掉,老大交代的任务没完成,非常痛恨自己用svn或者git保存代码,相信很多程序员遇到过,硬盘坏掉,存在硬盘中的代码丢失,无法找回的问题,svn和git可谓程序员界的福音, ...

  4. SVN的命令行操作

    最近在进行svn二次开发,使用的是svnkit.看了很多svnkit的api,渐渐发现都是和SVN的命令行操作对应的.顺便研究一下svn的命名行操作. 1.将文件checkout到本地目录: 基本命令 ...

  5. windows下使用TortoiseGit代替Git命令行操作

    windows下使用TortoiseGit代替Git命令行操作 大家在使用svn的时候,都非常喜欢使用小乌龟,也就是TortoiseSVN:那么git也有小乌龟版本,即TortoiseGit. 1.安 ...

  6. svn命令行修改已提交的版本备注

    svn命令行修改已提交的版本备注 参考文章: stackoverflow.com/questions/304383/how-do-i-edit-a-log-message-that-i-already ...

  7. Linux环境SVN命令行使用经验总结(转)

    在windows机器上开发得差不多了之后,打包传送到开发机编译,在开发机上解决编译错误. [缺点] 浪费时间在打包解包,机器间传输代码. 在windows机器上开发之后,check in代码进分支,在 ...

  8. svn命令行批量删除和批量添加

    svn命令行批量删除和批量添加 如果使用svn的命令行,例如在linux下的终端中使用,svn的添加命令是svn add,删除命令是svn del,但是缺乏批量的操作,如果我在资源管理器中,手动添加了 ...

  9. mysql 命令行操作入门(详细讲解版)

    之前分享过多次Mysql主题,今天继续分享mysql命令行入门   1. 那么多mysql客户端工具,为何要分享命令行操作? -快捷.简单.方便 -在没有客户端的情况下怎么办 -如果是mysql未开启 ...

  10. Mac SVN 命令行

    Mac自带了SVN命令行,如我的升级到10.10(OSX yosemite)后命令行版本为1.7.10 以下是一些常用命令 1.将文件checkout到本地目录 svn checkout path(p ...

随机推荐

  1. [iOS基础控件 - 4.2] APP列表 字典转模型Model

    A.使用字典加载数据的缺点 1.用户自行指定key,容易出错 2.存入.取出都需要key,容易混乱   B.模型 (MVC中的model) 1.字典与模型对比: (1)字典:存储数据,通过字符串类型的 ...

  2. FreeModbus for stm32(Keil工程)——精简Modbus slave协议【worlsing笔记】

    FreeModbus For stm32:点击下载源码 1.测试环境Keil MDK 4.7a  stm32f103c8, PB12为输出线圈,    可以通过Modbus Poll来控制线圈的输出状 ...

  3. hdu 1520 (树形DP)

    dp[i][0]表示i不参加 dp[i][1]表示i参加 简单的树形dp #include<stdio.h> #include<string.h> #define N 6100 ...

  4. 转(HP大中华区总裁孙振耀退休感言)

    开篇转发一篇好文,苦闷,消沉,寂寞,堕落的时候看看. 发现这篇文章是09年之前就有人转发到自己博客了.放到自己的地盘,容易记起有这么个心灵鸡汤.   一.关于工作与生活 我有个有趣的观察,外企公司多的 ...

  5. ECSHOP在线手册布局参考图--商品分类页 category.dwt

        A.购物车 1,设置方法 程序自动读取购物车的商品数量 2,代码相关 cart.lbi 中 {insert_scripts files='transport.js'} <div clas ...

  6. class ResultServletContextListener implements ServletContextListener

    package com.management.spring; import java.io.BufferedReader; import java.io.IOException; import jav ...

  7. 安装Windows SDK7.1时发生的一个错误(附解决办法)

    A problem occurred while installing selected Windows SDK components. Installation of the "Micro ...

  8. java_TreeSet 定制排序实例

    package ming; import java.util.Comparator; import java.util.TreeSet; class M { int age; public M(int ...

  9. Spring(AbstractRoutingDataSource)实现动态数据源切换--转载

    原始出处:http://linhongyu.blog.51cto.com/6373370/1615895 一.前言 近期一项目A需实现数据同步到另一项目B数据库中,在不改变B项目的情况下,只好选择项目 ...

  10. Porsche Piwis Tester II “No VCI has been detected”,how to do?

    Hi,Joy, I am sorry that my Porsche Piwis Tester II from your shop said “No VCI has been detected” wh ...