美文网首页
git 常用操作命令

git 常用操作命令

作者: 华华00526 | 来源:发表于2019-03-07 14:48 被阅读0次

    查看当前项目ip等信息:cat .git/config

    编辑外网ip:vim .git/config

    修改外网ip:点击 'I’修改, ‘esc’ 退出编辑,  ‘:wq’ 保存并退出

    npm install -g cnpm --registry=https://registry.npm.taobao.org 安装淘宝镜像

    一 、本地项目推送到空远程仓库

    master分支:

    Git init

    Git add .

    Git commit -m ‘第一次提交’

    Git remote add origin https://github.com/xxx.git(仓库地址)

    Git push -u origin master (首次推送)(下次git push origin master)

    方法二:

    1、切换远程仓库地址:

    方式一:修改远程仓库地址

    【git remote set-url origin URL】 更换远程仓库地址,URL为新地址。

    方式二:先删除远程仓库地址,然后再添加

    【git remote rm origin】 删除现有远程仓库

    【git remote add origin url】添加新远程仓库

    2、【git remote -v 】查看远程仓库的地址

    错误提示:

    更改仓库地址时报错  fatal: remote origin already exists. 

    执行:

        1、先输入$ git remote rm origin

        2、再输入$ git remote add origin http://仓库地址   就不会报错了!

        3、如果输入$ git remote rm origin 还是报错的话,error: Could not remove config section 'remote.origin'. 我们需要修改gitconfig文件的内容

        4、找到你的github的安装路径,我的是C:\Users\ASUS\AppData\Local\GitHub\PortableGit_ca477551eeb4aea0e4ae9fcd3358bd96720bb5c8\etc

        5、找到一个名为gitconfig的文件,打开它把里面的[remote "origin"]那一行删掉就好了!

    git branch --set-upstream 本地关联远程分支

    最近使用git pull的时候多次碰见下面的情况:

    There is no tracking information for the current branch.

    Please specify which branch you want to merge with.

    See git-pull(1) for details.

    git pull <remote> <branch>

    If you wish to set tracking information for this branch you can do so with:

    git branch --set-upstream-to=origin/<branch> release

    其实,输出的提示信息说的还是比较明白的。

    使用git在本地新建一个分支后,需要做远程分支关联。如果没有关联,git会在下面的操作中提示你显示的添加关联。

    关联目的是在执行git pull, git push操作时就不需要指定对应的远程分支,你只要没有显示指定,git pull的时候,就会提示你。

    解决方法就是按照提示添加一下呗:

    git branch --set-upstream-to=origin/remote_branch  your_branch

    其中,origin/remote_branch是你本地分支对应的远程分支;your_branch是你当前的本地分支。

    1、failed to push some refs to https://github.com/guyibang/TEST2.git(在创建仓库的时候自动创建了readme,而本地没有)

    执行:git pull --rebase origin master  后再推送

    2、还有就是你上线有文件需要进行运程本地连接

    git branch --set-upstream-to=origin/<branch>  master

    3、报错本地分支与远程分支强制合并:

    git pull origin master --allow-unrelated-histories  (强制合并)

    二 、 本地分支提交到远程已有分支步骤:https://blog.csdn.net/huangjw_806/article/details/78297851

    git branch 分支名

    例如:git branch dev,这条命令是基于当前分支创建的本地分支,假设当前分支是master(远程分支),则是基于master分支创建的本地分支dev。

    切换到本地分支

    git checkout 分支名

    例如:git checkout dev,这条命令表示从当前master分支切换到dev分支。

    创建本地分支并切换

    git checkout -b 分支名

    例如:git checkout -b dev,这条命令把创建本地分支和切换到该分支的功能结合起来了,即基于当前分支master创建本地分支dev并切换到该分支下。

    提交本地分支到远程仓库

    git push origin 本地分支名

    例如:git push origin dev,这条命令表示把本地dev分支提交到远程仓库,即创建了远程分支dev。

    注:要想和其他人分享某个本地分支,你需要把它推送到一个你拥有写权限的远程仓库。你创建的本地分支不会因为你的写入操作而被自动同步到你引入的远程服务器上,你需要明确地执行推送分支的操作。换句话说,对于无意分享的分支,你尽管保留为私人分支好了,而只推送那些协同工作要用到的特性分支。

    新建本地分支与远程分支关联

    git branch –set-upstream 本地新建分支名 origin/远程分支名(有时会提示如下两个操作:git fetch   git push -u )

    例如:git branch –set-upstream dev origin/dev,把本地dev分支和远程dev分支相关联。

    注:本地新建分支, push到远程服务器上之后,使用git pull或者git pull 拉取或提交数据时会报错,必须使用命令:git pull origin dev(指定远程分支);如果想直接使用git pull或git push拉去提交数据就必须创建本地分支与远程分支的关联。

    三、 其他命令

    查看状态 :git status       

    查看分支/主枝状态路径: gitk --all &                                           

    查看所在分支:git branch    

     查看远程与本地所以分支:git branch -a   

    拉取代码到本地仓库:git pull          

    提交代码到远程仓库:git push        

    克隆指定分支名代码:git clone -b (指定分支名)(git地址)  

    删除本地分支:git branch -D dev   

    删除远程分支:git push (项目名project) --delete dev

    git回滚到任意版本:https://blog.csdn.net/QH_JAVA/article/details/77979622

    git如何回滚远程仓库https://www.cnblogs.com/iloveyou-sky/p/6534409.html

    先显示提交的log:git log -3(最近3条)

    回滚到指定的版本: git reset --hard e377f60e28c8b84158

    会滚到之前一个版本:git reset --hard HEAD

    撤销前一次commit: git revert HEAD

    强推:git push origin (分支名字) -f (因为本地比远程低一个版本,所以使用强推覆盖远程)

    四、将本地新项目提交到git上:https://www.cnblogs.com/sdcs/p/8270029.html

    1、第一个方法:

    1)现在git clone https://XXX

    2)将项目拷贝到下载的项目中,在提交。

    2、第二个方法:

    1)git init   通过命令git init把这个文件夹变成Git可管理的仓库

    2)git add .

    3)git commit -m ’test’

    4)git remote add origin https://XXX    git和本地仓库进行关联

    5)git push -u origin master 把本地库的所有内容推送到远程仓库,如果仓库

        git push origin master  由于新建的远程仓库是空的,所以要加上-u这个参数,等远程仓库里面有了内容之后,去掉-u

    6)可能存在报错现象:在创建远程仓库的时候,如果你勾选了Initialize this repository with a README(就是创建仓库的时候自动给你创建一个README文件),那么你将本地仓库内容推送到远程仓库的时候就会报一个to   https://XXX的错,这是由于你新创建的那个仓库里面的README文件不在本地仓库目录中,这时我们可以通过以下命令先将内容合并以下:git pull --rebase origin master,这时你再push就能成功了。

    五,git 命令放弃本地修改操作

    一,

    未使用 git add 缓存代码时。

    可以使用 git checkout -- filepathname (比如: git checkout -- readme.md,不要忘记中间的 “--” ,不写就成了检出分支了!!)。放弃所有的文件修改可以使用 git checkout .  命令。

    此命令用来放弃掉所有还没有加入到缓存区(就是 git add 命令)的修改:内容修改与整个文件删除。但是此命令不会删除掉刚新建的文件。因为刚新建的文件还没已有加入到 git 的管理系统中。所以对于git是未知的。自己手动删除就好了。

    二,

    已经使用了  git add 缓存了代码。

    可以使用 git reset HEAD filepathname (比如: git reset HEAD readme.md)来放弃指定文件的缓存,放弃所以的缓存可以使用 git reset HEAD . 命令。

    此命令用来清除 git  对于文件修改的缓存。相当于撤销 git add 命令所在的工作。在使用本命令后,本地的修改并不会消失,而是回到了如(一)所示的状态。继续用(一)中的操作,就可以放弃本地的修改。

    三,

    已经用 git commit  提交了代码。

    可以使用 git reset --hard HEAD^ 来回退到上一次commit的状态。此命令可以用来回退到任意版本:git reset --hard  commitid 

    你可以使用 git log 命令来查看git的提交历史。git log 的输出如下,之一这里可以看到第一行就是 commitid:

    commit cf0d692e982d8e372a07aaa6901c395eec73e356 (HEAD -> master)

    Author: toyflivver <2440659688@qq.com>

    Date: Thu Sep 28 14:07:14 2017 +0800

    多余的空行

    commit 14aa4d7ad4ac6fba59b4b8261d32e478e8cc99ff

    Author: toyflivver <2440659688@qq.com>

    Date: Thu Sep 28 14:06:44 2017 +0800

    正常的代码

    commit da3a95c84b6a92934ee30b6728e258bcda75f276

    Author: toyflivver <2440659688@qq.com>

    Date: Thu Sep 28 13:58:12 2017 +0800

    qbf

    commit 267466352079296520320991a75321485224d6c6

    Author: toyflivver <2440659688@qq.com>

    Date: Thu Sep 28 13:40:09 2017 +0800

    qbf

    可以看出现在的状态在 commitid 为 cf0d692e982d8e372a07aaa6901c395eec73e356 的提交上(有 HEAD -> master 标记)。

    git重置远程分支到指定版本

    分支操作者:

    git checkout test-release

    这个test-release就是需要被配置的分支,它对应的远程就是origin/test-release

    git reset --hard xxx

    这是将当前branch重置到xxx的commit点, --hard是重置是丢弃xxx之前的所有代码变化

    git push --force

    其他分支使用者:

    git checkout test-release

    git reset --hard origin/test-release

    这步就是其他同事把自己本地test-release重置到与origin/test-release一致,注意--hard参数会丢弃超过origin的所有commit,如果不想丢弃可以用 --mixed 或 --soft 具体用哪个自行研究吧

    相关文章

      网友评论

          本文标题:git 常用操作命令

          本文链接:https://www.haomeiwen.com/subject/giuouqtx.html