zoukankan      html  css  js  c++  java
  • svn---命令行操作

    一、基本操作

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

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

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

    二、策略

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

       2、锁定--修改

     
    三、xcode设置
    xcode->preferences->locations->Command Line Tools
     
     
    四、笔记
     
    01.    源代码管理工具概述(PPT)
    ================================================================================
    
    * 源代码管理工具的作用:
    # 能追踪一个项目从诞生一直到定案的过程
    # 记录一个项目的所有内容变化
    # 方便地查阅特定版本的修订情况
    
    * 如果是团队开发,使用源代码管理工具是强制性的!
    * 如果是单人开发,也强烈建议现在就开始使用源代码管理工具
    
    * 使用源代码管理工具
    # 由于使用简单,不会增加工作量
    # 不会对现有工作造成任何损害(坏的影响)
    # 是一位合格的软件开发人员必须掌握的技术
    
    02.    SVN介绍(PPT)
    ================================================================================
    
    SVN 是集中式源代码管理工具
    
    概念:
    1> Repository   代码仓库,保存代码的仓库
    2> Server       服务器,保存所有版本的代码仓库
    3> Client       客户端,只保存当前用户的代码仓库
    4> 用户名&密码   访问代码仓库需要使用自己的"用户名和密码",从而可以区分出不同的人对代码做的修改
    
    操作:
    1> checkout     将服务器上最新的代码仓库下载到本地,"只需要做一次"
    2> update       从服务器上将其他人所做的修改下载到本地,"每天上班必须要做的事情"
    3> commit       将工作提交到服务器,"每天下班之前至少做一次"
    
    03.    SVN服务器安装 Visual SVN Server
    ================================================================================
    提示:一般程序员是没有机会安装SVN服务器的,以下内容仅供了解服务器上的安装及配置过程
    
    * Visual SVN Server 是运行在windows操作系统上的,集成了Subversion和Apache
    * 傻瓜式安装一步到位,并提供了图形化界面,安装简单配置方便
    * 下载地址:http://www.visualsvn.com/server/download/
    
    1>  安装
    *   程序目录
    *   代码仓库目录
    
    2>  添加代码仓库"weibo"
    *   暂时不勾选默认结构(trunk, branches, tags)
    
    3>  添加用户
    *   为了方便后续的演练,每个用户的口令不要设置成一样
    #   用户名     口令
    #   manager   jingli
    #   zhangsan  zhang
    #   lisi      li
    
    4>  添加群组,通过群组可以一次性设置多个用户对代码仓库的访问权限,便于管理
    
    5>  设置权限演练
    *   选中项目的代码库,点击右键,选择"Properties"
    
    6>  协议
    *   https   端口 443
    *   http    端口 80
    
    7>  协议的修改
    *   选中"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/
    
    8>  使用浏览器浏览代码仓库
    如果使用了https协议,在不同的浏览器中访问,显示效果会不太一样
    
    04.    SVN演练准备
    ================================================================================
    
    1>  显示隐藏文件夹
    # 显示隐藏文件
    $ defaults write com.apple.finder AppleShowAllFiles Yes && killall Finder
    # 不显示隐藏文件
    $ defaults write com.apple.finder AppleShowAllFiles No && killall Finder
    
    2>  在桌面上新建一个文件夹 "svn演练"
    依次建立以下三个目录
    #   经理
    #   张三
    #   李四
    
    05.    命令行准备
    ================================================================================
    
    熟悉命令行的目的:所有图形工具本质上都是对命令行的封装,理解命令行的操作,更有助于对图形工具的使用
    
    1>  SVN基本命令
    命令行格式:
    svn <subcommand> [options] [args]
    说明
    svn 子命令 [选项] [参数]
    
    提示:
    #   [中括号]中包含的内容是可选的
    #   (子命令缩写)
    
    2>  查看帮助信息
    
    $ svn help
    查看svn所有命令的帮助
    $ svn help 子命令
    
    3>  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

     
     
     
     
     
     
     
  • 相关阅读:
    编程之美 2014资格赛 格格取数
    ios游戏开发--cocos2d学习(1)
    ios开发中常用的也是最基本的mysql语句
    无限树形结构的数据库表设计
    认真的辞职
    几种JavaScript富应用MVC MVVM框架
    javascript创建对象和属性的几种方式
    webresource.axd文件的配置及使用
    ITextSharp用来生成 PDF 的一个组件
    flexpaper 开源轻量级的在浏览器上显示各种文档的组件
  • 原文地址:https://www.cnblogs.com/zhongxuan/p/4821282.html
Copyright © 2011-2022 走看看