zoukankan      html  css  js  c++  java
  • Git 常用命令整理

    取得Git仓库

    初始化一个版本仓库

    git init

    Clone远程版本库

    git clone git@xbc.me:wordpress.git

    添加远程版本库origin,语法为 git remote add [shortname] [url]

    git remote add origin git@xbc.me:wordpress.git

    查看远程仓库

    git remote -v

    提交你的修改

    添加当前修改的文件到暂存区

    git add .

    如果你自动追踪文件,包括你已经手动删除的,状态为Deleted的文件

    git add -u

    提交你的修改

    git commit –m "你的注释"

    推送你的更新到远程服务器,语法为 git push [远程名] [本地分支]:[远程分支]

    git push origin master

    查看文件状态

    git status

    跟踪新文件

    git add readme.txt

    从当前跟踪列表移除文件,并完全删除

    git rm readme.txt

    仅在暂存区删除,保留文件在当前目录,不再跟踪

    git rm –cached readme.txt

    重命名文件

    git mv reademe.txt readme

    查看提交的历史记录

    git log

    修改最后一次提交注释的,利用–amend参数

    git commit --amend

    忘记提交某些修改,下面的三条命令只会得到一个提交。

    git commit –m "add readme.txt"
    git add readme_forgotten
    git commit –amend

    假设你已经使用git add .,将修改过的文件a、b加到暂存区

    现在你只想提交a文件,不想提交b文件,应该这样

    git reset HEAD b

    取消对文件的修改

    git checkout –- readme.txt

    基本的分支管理

    创建一个分支

    git branch iss53

    切换工作目录到iss53

    git chekcout iss53

    将上面的命令合在一起,创建iss53分支并切换到iss53

    git chekcout –b iss53

    合并iss53分支,当前工作目录为master

    git merge iss53

    合并完成后,没有出现冲突,删除iss53分支

    git branch –d iss53

    拉去远程仓库的数据,语法为 git fetch [remote-name]

    git fetch

    fetch 会拉去最新的远程仓库数据,但不会自动到当前目录下,要自动合并

    git pull

    查看远程仓库的信息

    git remote show origin

    建立本地的dev分支追踪远程仓库的develop分支

    git checkout –b dev origin/develop

    参考资料

    远程仓库的使用

    何谓分支

    基本的分支与合并

    分支的管理

    分支式工作流程

    远程分支

    衍合

    在使用Git Push代码到数据仓库时,提示如下错误:

    [remote rejected] master -> master (branch is currently checked out)
    remote: error: refusing to update checked out branch: refs/heads/master
    remote: error: By default, updating the current branch in a non-bare repository
    remote: error: is denied, because it will make the index and work tree inconsistent
    remote: error: with what you pushed, and will require 'git reset --hard' to match
    remote: error: the work tree to HEAD.
    remote: error:
    remote: error: You can set 'receive.denyCurrentBranch' configuration variable to
    remote: error: 'ignore' or 'warn' in the remote repository to allow pushing into
    remote: error: its current branch; however, this is not recommended unless you
    remote: error: arranged to update its work tree to match what you pushed in some
    remote: error: other way.
    remote: error:
    remote: error: To squelch this message and still keep the default behaviour, set
    remote: error: 'receive.denyCurrentBranch' configuration variable to 'refuse'.
    To git@192.168.1.X:/var/git.server/.../web
     ! [remote rejected] master -> master (branch is currently checked out)
    error: failed to push some refs to 'git@192.168.1.X:/var/git.server/.../web'

    这是由于git默认拒绝了push操作,需要进行设置,修改.git/config添加如下代码:

        [receive]
        denyCurrentBranch = ignore

    注意上面修改的是代码仓库的config,而不是本地分支的config

    在初始化远程仓库时最好使用 git --bare init   而不要使用:git init

       如果使用了git init初始化,则远程仓库的目录下,也包含work tree,当本地仓库向远程仓库push时,   如果远程仓库正在push的分支上(如果当时不在push的分支,就没有问题), 那么push后的结果不会反应在work tree上,  也即在远程仓库的目录下对应的文件还是之前的内容,必须得使用git reset --hard才能看到push后的内容.

  • 相关阅读:
    Centos7:Redis3.0集群搭建
    Centos7:Redis的安装,配置及使用
    nginx 配置反向代理和负载均衡
    Centos7:nginx的安装,配置及使用
    Centos7:dubbo监控中心安装,配置和使用
    Centos7:配置防火墙
    MarkDown常用语法
    关于获取本地系统时间是正确的,但插入数据库是错的,相差8小时
    Uncaught TypeError: Cannot read property 'getters' of undefined
    java mysql连接时出现的问题
  • 原文地址:https://www.cnblogs.com/love-julia/p/3671254.html
Copyright © 2011-2022 走看看