zoukankan      html  css  js  c++  java
  • my project 中git使用过程(基本操作流程)

    1.g  it clone git@name:server/BM/APPS.git      

        则BM_APPS.git项目被下载到当前目录下了,这时git@name:server/BM/APPS.git就是自己的origin库。

    2.为自己的仓库定义别名

        为方便以后操作,可给自己的仓库定义一个别名:

        #git remote add fork git@name:dev/zhangsan/BM/APPS.git

    3.checkout 切换到当前的开发分支,作为工作分支

        git checkout origin/dev_sp4 -b dev_sp4 (也可以是

        等价与两条命令:git branch dev_sp4//先创建分支   再 git checkout dev_sp4)

    4.将当前分支push到git Server上的fork库中

        #git push fork dev_sp4

        这时BM_APPS.git项目即为开发者zhangsan自己的仓库,它相当于是从git@name:server/BM/APPS.git中fork出来的。

    5.在本地dev_sp4分支上开发,开发前要先同步代码

        git pull origin dev_sp4

    开发者在本地进行开发(新建/修改文件)并提交(commit)。

        git add .

        git commit -a -m "<san_zhang@audiencetouch.com><BMS-749><dev><2011/05/03>fix BMS-749"

    6.一般开发流程如下:

       开发人员有新的提交后,需要将提交push到自己的fork库中,操作如下:

       A.查看origin上dev_sp4分支的修改记录:

       #git fetch origin dev_sp4

       B.比较看和本地dev_sp4分支有没有改变:

       #git diff origin/dev_sp4

       C.如果有改变就要建立临时分支合并修改:

       #git branch dev_sp4_tmp

       #git checkout dev_sp4_tmp

       #git rebase origin/dev_sp4  这是远端的内容合并到当前分支(当前为tmp分支)

       D.如果有冲突就解决冲突再提交:

     一般过程为:

    git rebase origin/dev_sp5 //同步最新代码出现冲突
    git status //查看冲突文件
    vi conflict_files //修正冲突文件
    git add //重新添加文件到索引中
    git commit //重新提交代码
    git rebase --skip //跳过之前冲突的提交
    git rebase --continue //继续rebase,直到完成

       E.将merge这部分修改合并到本地dev_sp4分支:

       #git checkout dev_sp4

       #git merge dev_sp4_tmp

    可以看出总体是,先下载总库(fetch origin)到本地dev分支(rebase),在这个分支上进行开发后,有了提交(add,commit后)。先不能提交(总库可能有变化,别人提交了),此时再fetch 总库,并合到一个新建tmp分支,处理冲突后,将最新总库内容,合并到真分支(checkout 真分支,然后rebase或者merge tmp都行),最后删除tmp

       F.如果没有冲突就删除临时分支:

       #git branch --d dev_sp4_tmp

       G.推送代码到服务器上的fork库:

       #git push fork dev_sp4

    最后通过邮件或其他方式告知管理员来合并代码。

    aso项目git库:

    查看 cat .git/config后

    [core]
            repositoryformatversion = 0
            filemode = true
            bare = false
            logallrefupdates = true
    [remote "origin"]
            url = git@repo.allfuck.com:aso
            fetch = +refs/heads/*:refs/remotes/origin/*
    [branch "master"]
            remote = origin
            merge = refs/heads/master
    [branch "waterforest"]
            remote = origin
            merge = refs/heads/waterforest

    url是个内部代理名。我的机器是内部网络机,直接用就可以访问到代理名指定的服务器。

    想换成实际ip地址,就要到服务器,去查对应的转换名。

  • 相关阅读:
    网站负载均衡判断
    端口扫描nmap+masscan
    Ant Design Upload 组件之阻止文件默认上传
    Hybrid App技术解析
    react 路由
    webpack进阶(二)
    webpack进阶(一)
    webpack基础
    Promise原理及实现
    TS——类
  • 原文地址:https://www.cnblogs.com/cl1024cl/p/6205575.html
Copyright © 2011-2022 走看看