• gitlab基本的命令


    1) 远程仓库相关命令
    检出仓库:$ git clone git://github.com/jquery/jquery.git
    查看远程仓库:$ git remote -v
    添加远程仓库:$ git remote add [name] [url]
    删除远程仓库:$ git remote rm [name]
    修改远程仓库:$ git remote set-url --push[name][newUrl]
    拉取远程仓库:$ git pull [remoteName] [localBranchName]
    推送远程仓库:$ git push [remoteName] [localBranchName]
     
    2)分支(branch)操作相关命令
    查看本地分支:$ git branch
    查看远程分支:$ git branch -r
    创建本地分支:$ git branch [name] ----注意新分支创建后不会自动切换为当前分支
    切换分支:$ git checkout [name]
    创建新分支并立即切换到新分支:$ git checkout -b [name]
    删除分支:$ git branch -d [name] ---- -d选项只能删除已经参与了合并的分支,对于未有合并的分支是无法删除的。如果想强制删除一个分支,可以使用-D选项
    合并分支:$ git merge [name] ----将名称为[name]的分支与当前分支合并
    创建远程分支(本地分支push到远程):$ git push origin [name]
    删除远程分支:$ git push origin :heads/[name]

    我从master分支创建了一个issue5560分支,做了一些修改后,使用git push origin master提交,但是显示的结果却是'Everything up-to-date',发生问题的原因是git push origin master 在没有track远程分支的本地分支中默认提交的master分支,因为master分支默认指向了origin master 分支,这里要使用git push origin issue5560:master 就可以把issue5560推送到远程的master分支了。

        如果想把本地的某个分支test提交到远程仓库,并作为远程仓库的master分支,或者作为另外一个名叫test的分支,那么可以这么做。

    git push origin test:master         // 提交本地test分支作为远程的master分支 //好像只写这一句,远程的github就会自动创建一个test分支
    git push origin test:test              // 提交本地test分支作为远程的test分支

    如果想删除远程的分支呢?类似于上面,如果:左边的分支为空,那么将删除:右边的远程的分支。

    git push origin :test              // 刚提交到远程的test将被删除,但是本地还会保存的,不用担心
    3)版本(tag)操作相关命令
    查看版本:$ git tag
    创建版本:$ git tag [name]
    删除版本:$ git tag -d [name]
    查看远程版本:$ git tag -r
    创建远程版本(本地版本push到远程):$ git push origin [name]
    删除远程版本:$ git push origin :refs/tags/[name]
     
    4) 子模块(submodule)相关操作命令
    添加子模块:$ git submodule add [url] [path]
    如:$ git submodule add git://github.com/soberh/ui-libs.git src/main/webapp/ui-libs
    初始化子模块:$ git submodule init ----只在首次检出仓库时运行一次就行
    更新子模块:$ git submodule update ----每次更新或切换分支后都需要运行一下
    删除子模块:(分4步走哦)
    1)$ git rm --cached [path]
    2) 编辑“.gitmodules”文件,将子模块的相关配置节点删除掉
    3) 编辑“.git/config”文件,将子模块的相关配置节点删除掉
    4) 手动删除子模块残留的目录
     
    5)忽略一些文件、文件夹不提交
    在仓库根目录下创建名称为“.gitignore”的文件,写入不需要的文件夹名或文件,每个元素占一行即可,如
    target
    bin
    *.db
     
    2. git pull:相当于是从远程获取最新版本并merge到本地

    git pull origin master

     --------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------------

    git远程分支关联的一种方法

    github上已经有master分支 和dev分支

    在本地

    git checkout -b dev 新建并切换到本地dev分支

    git pull origin dev 本地分支与远程分支相关联

    在本地新建分支并推送到远程

    git checkout -b test

    git push origin test   这样远程仓库中也就创建了一个test分支

     ================================================================================================================

    作者:Color
    链接:https://www.zhihu.com/question/21995370/answer/19975870
    来源:知乎
    著作权归作者所有。商业转载请联系作者获得授权,非商业转载请注明出处。

    1. 克隆代码
    git clone https://github.com/master-dev.git  
    # 这个git路径是无效的,示例而已
    2. 查看所有分支
    git branch --all  
    # 默认只有master分支,所以会看到如下两个分支
    # master[本地主分支] origin/master[远程主分支]
    # 新克隆下来的代码默认master和origin/master是关联的,也就是他们的代码保持同步
    3. 创建本地新的dev分支
    git branch dev  # 创建本地分支
    git branch  # 查看分支
    # 这是会看到master和dev,而且master上会有一个星号
    # 这个时候dev是一个本地分支,远程仓库不知道它的存在
    # 本地分支可以不同步到远程仓库,我们可以在dev开发,然后merge到master,使用master同步代码,当然也可以同步
    4. 发布dev分支
    发布dev分支指的是同步dev分支的代码到远程服务器
    git push origin dev:dev  # 这样远程仓库也有一个dev分支了
    5. 在dev分支开发代码
    git checkout dev  # 切换到dev分支进行开发
    # 开发代码之后,我们有两个选择
    # 第一个:如果功能开发完成了,可以合并主分支
    git checkout master  # 切换到主分支
    git merge dev  # 把dev分支的更改和master合并
    git push  # 提交主分支代码远程
    git checkout dev  # 切换到dev远程分支
    git push  # 提交dev分支到远程
    # 第二个:如果功能没有完成,可以直接推送
    git push  # 提交到dev远程分支
    # 注意:在分支切换之前最好先commit全部的改变,除非你真的知道自己在做什么
    6. 删除分支
    git push origin :dev  # 删除远程dev分支,危险命令
    # 下面两条是删除本地分支
    git checkout master  # 切换到master分支
    git branch -d dev  # 删除本地dev分支
     -------------------------------------------------------------------------------------------------------------------------------------------------------
    今天真是崩溃的,由于之前的同事各自作战,一个只在master提交代码,一个只在developer上提交,两人各自做各自的,今天我去合并代码,我的老天爷,一堆冲突,算了,不玩了,我想了半天想到的是我把他们的master和developer down到本地,不合并了,不然没法玩下去了,等找好代码之后再说。
    1.然后先去pull了master到本地,
    2.接着创建了develop本地,然后与remote关联  git branch --set-upstream-to origin/dev dev 
    3.想直接 git pull origin dev:dev 结果发现不行,因为远程的dev和远程的master八百年没有打交道了,一堆冲突。
    4. get pull一下发现报出冲突原因,想清楚了,不合并了。
    5.git reset --hard origin/dev 直接将其隔离

    Git pull error: Your local changes to the following files would be overwritten by merge: git reset --hard origin/dev 直接将其解决 

    这里再说一下可以使用 

    1. git fetch origin develop  
    2. git checkout develop 
    3. git merge origin/develop代替上述的方法,防止冲突发生。
     
  • 相关阅读:
    sabaki and leelazero
    apply current folder view to all folders
    string operation in powershell
    wirte function in powershell
    add environment path to powershell
    Module in powershell
    sql prompt
    vmware中鼠标在部分区域不能使用
    调整多个控件的dock的顺序
    行为型模型 策略模式
  • 原文地址:https://www.cnblogs.com/peizhe123/p/8125698.html
Copyright © 2020-2023  润新知