Git 常用命令集合

Git 常用命令

1.新建项目
# 在当前目录新建一个Git代码库
$ git init
# 新建一个目录,将其初始化为Git代码库
$ git init [project-name]
# 下载一个项目和它的整个代码历史
$ git clone [url]
2. 配置

Git的设置文件为.gitconfig,它可以在用户主目录下(全局配置),也可以在项目目录下(项目配置)

# 显示当前的Git配置
$ git config --list
# 编辑Git配置文件
$ git config -e [--global]
# 设置提交代码时的用户信息
$ git config [--global] user.name "[name]"
$ git config [--global] user.email "[email address]”

git 修改当前的project的用户名的命令为:
> git config user.name 你的目标用户名;
git修改当前的project提交邮箱的命令为:
> git config user.email 你的目标邮箱名;
如果你要修改当前全局的用户名和邮箱时,需要在上面的两条命令中添加一个参数,–global,代表的是全局。
命令分别为:
> git config  --global user.name 你的目标用户名;
> git config  --global user.email 你的目标邮箱名;

3. 文件操作

# 添加指定文件到暂存区
$ git add [file1] [file2] ...
# 添加指定目录到暂存区,包括子目录
$ git add [dir]
# 添加当前目录的所有文件到暂存区
$ git add .
# 添加每个变化前,都会要求确认
# 对于同一个文件的多处变化,可以实现分次提交
$ git add -p
# 删除工作区文件,并且将这次删除放入暂存区
$ git rm [file1] [file2] ...
# 停止追踪指定文件,但该文件会保留在工作区
$ git rm --cached [file]
# 改名文件,并且将这个改名放入暂存区
$ git mv [file-original] [file-renamed]
4.代码提交
# 
$ git add .
# 提交暂存区到仓库区
$ git commit -m [message]
# 提交暂存区的指定文件到仓库区
$ git commit [file1] [file2] ... -m [message]
# 提交工作区自上次commit之后的变化,直接到仓库区
$ git commit -a
# 提交时显示所有diff信息
$ git commit -v
# 使用一次新的commit,替代上一次提交
# 如果代码没有任何新变化,则用来改写上一次commit的提交信息
$ git commit --amend -m [message]
# 重做上一次commit,并包括指定文件的新变化
$ git commit --amend [file1] [file2] ...
5.tag
查看版本:$ git tag
创建版本:$ git tag [name]
删除版本:$ git tag -d [name]
查看远程版本:$ git tag -r
推送到远程上: $ git push origin --tags 

6. 远程仓库


检出仓库:$ 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]

7.分支(branch)操作相关命令

查看本地分支:$ git branch
查看远程分支:$ git branch -r
创建本地分支:$ git branch [name] ----注意新分支创建后不会自动切换为当前分支
切换分支:$ git checkout [name]
创建新分支并立即切换到新分支:$ git checkout -b [name]
删除分支:$ git branch [name] -d ---- -d选项只能删除已经参与了合并的分支,对于未有合并的分支是无法删除的。如果想强制删除一个分支,可以使用-D选项
合并分支:$ git merge [name] ----将名称为[name]的分支与当前分支合并
本地分支push到远程:$ git push origin [name]
删除远程分支:$ git push origin :heads/[name] 
拉取分支代码:$ git clone -b [name] [url] 
更新远程分支:git remote update origin --prune 
更新远程分支: git fetch origin --prune
修改本地分支: git branch -m [name1] [name2] // name1 要改的本地分支名 name2修改后的分支名
$ git push origin test:master         // 提交本地test分支作为远程的master分支 //好像只写这一句,远程的github就会自动创建一个test分支
$ git push origin test:test              // 提交本地test分支作为远程的test分支
$ git push origin :test              // 刚提交到远程的test将被删除,但是本地还会保存的,不用担心

8 合分支

      git checkout master // 切换到当前分支
      git pull origin rocketed  // 拉取远程分支 rocketed到master
      git push  // 推送到master
     

9. 更新远程分支

1. git fetch origin --prune

合并代码

git status   // 查看当前分支有没有未提交的代码,有就提交一下
git checkout [name]  // 切换分支
git pull  // 更新切换后分支的代码
git pull origin [name]     // name需要合并过来的分支名 
 如果显示自动merge失败就用编辑器再拉一下代码触发编辑器的merge
处理merge,apply
git push // 将合并后的代码推到目标分支

合并已有的远程代码

git checkout -b test origin/rtest   // test 本地分支 rtest 远程分支
git pull origin rtest
本地分支与线上分支建立联系
 git push --set-upstream origin dev (创建新分支)
 git branch --set-upstream-to=origin/[remoteName]  [localBranchName] (已有分支)

git 切换仓库地址

git remote -v   查看远程仓库的地址
git remote rm orgin 删除现有远程仓库
git remote add origin url  添加新的远程仓库

git 代码回滚

切换到要回滚的分支上
git log 打印日志,找到commit的提交码
git reset --hard { commit码 } 回滚到本地某个版本
git cherry-pick 也可以用
git push -f 服务器上回滚

生产发布

切换到dev分支:git checkout dev
拉取最新代码:git pull
切换到master分支:git checkout master
 合并dev分支: git merge --no-ff -m "merge dev" dev
 推送master:git push
新建tag:git tag [tagNmae]
 推送tag:git push origin [tagName]
jenkins上发布tag
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值