git 常用命令

文档说明 其中[]中的内容为可选命令

git config --global user.name user.name name  #设置公共的提交者的姓名

git config --global user.name user.email email.address #设置公共的交者的邮箱地址

克隆新项目

git clone [-b] branchname  git@git//xxxxx  #git协议的克隆 

git clone [-b]  branchname  https://xxxx.git #克隆https协议的git

-b 为克隆指定分支  branchname 为指定的远程已经存在的分支(默认是master)

git协议和https协议不同点是 https每次需要输入账号密码,二git协议则需要首先配置ssh

ssh协议的配置流程

ssh-keygen -t rsa  -C user_address  然后一路回车,我们假设你这是第一次设置那么在当前目录下就会生成.ssh的目录 里面有一个id_rsa.pub 文件 这是你创建的公钥,把它粘贴到远程的配置里.设置好了,类似这样


这里因为是私人的秘钥,所以就不贴出来了

设置好以后,需要验证下

ssh -T git@gitee.com  这里是你远程的git网址,我自己的是gitee

git status      #查看git 状态

git pull        #拉取别人的提交

git push      #推送提交到远程

git add .      #把文件添加到缓存区  .代表当前目录下的所有文件

git commit -m 'assa'  #把文件提交到工作区  接受git版本控制

分支相关

git branch  查看本地所有分支  绿色代表当前所处 分支 

git branch -r #查看远程分支

git branch -a  查看远程和本地的所有分支 以remotes/origin 开头的是远程分支

    切换分支

我们假设我们现在有dev这个本地分支

git checkout dev  #切换到已有的本地分支

如果想基于当前分支新建一个别的分支,则使用-b选项

git checkout -b wl  #新建并切换到新建的分支

删除本地分支

假设我们现在要把wl这个分支删除了

则执行

git checkout dev  #切换到别的分支,在这个要删除的分支上是无法删除的

git branch -d wl    #删除本地分支wl

基于远程分支创建新的本地分支

git checkout -b test  origin/test

其中  test为新建的本地分支名  origin为默认的远程到本地的映射名称  test为远程分支名

合并提交

我们假设现在你有dev和master两个分支,你现在需要把dev 上的提交合并到master 上

假设一次提交的commitid为 123 是 commit类型的单提交  而456这个提交是merge类型的组合提交

合并有两种方式

1 cherry-pick 

cherry-pick 单次提交 

我们来完成上面的提交

git cherry-pick 123(实际应用中的id是长度为40的字符串)   

这时候如果没有冲突的话,执行pull和push就行

就可以合并成功了

如果有冲突的话,就是需要解决完冲突,然后提交

HEAD

这是原始内容

===========

这是你这次提交的内容

>>>>>>>>>>>commit 注释>>>>>>

合并后,利用 git add .添加到缓存区

然后执行 git cherry-pick --conutinue 填写注释 q 退出

git pull git push 拉取并推送

merge

merge 是合并多次提交产生的

执行 git merge commitid

与cherry-pick不同的是.merge的合并完成后需要commit下

如果有冲突的话,就是需要解决完冲突,然后提交

HEAD

这是原始内容

===========

这是你这次提交的内容

>>>>>>>>>>>commit 注释>>>>>>

合并后,利用 git add .添加到缓存区

然后执行 git cmerge --conutinue 填写注释 q 退出

git pull git push 拉取并推送

强制回退到指定的版本

有时候,我们需要回退到之前的某个版本

这时候执行

git reset --hard  commitid

如果成功的话,就会提示

HEAD is now at commit  id  #id就是你自己的id

然后执行  git push -f  origin branchname    (branchname 为你远程需要推送到的分支名称)

git reset 命令非常危险,它会强制的删除你在这次提交之后的所有操作,并且 一旦强制推送,则那些修改不可找回 ,需要谨慎操作  警告:不要在线上项目上随便测试,以免造成不可挽回的损失

最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 219,427评论 6 508
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 93,551评论 3 395
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 165,747评论 0 356
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,939评论 1 295
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,955评论 6 392
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,737评论 1 305
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,448评论 3 420
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 39,352评论 0 276
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,834评论 1 317
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,992评论 3 338
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 40,133评论 1 351
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,815评论 5 346
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,477评论 3 331
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 32,022评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 33,147评论 1 272
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 48,398评论 3 373
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 45,077评论 2 355

推荐阅读更多精彩内容

  • git branch 查看本地所有分支 git status 查看当前状态 git commit 提交 git b...
    猿万阅读 5,057评论 1 45
  • 一、 Git 常用命令速查 git branch 查看本地所有分支 git status 查看当前状态 git c...
    LOVE_晴天阅读 2,324评论 0 10
  • 配置 首先是配置帐号信息 ssh -T git@github.com#登陆github 修改项目中的个人信息 1 ...
    rochuan阅读 724评论 1 1
  • 配置 首先是配置帐号信息ssh -T git@github.com # 登陆 github 修改项目中的个人信息 ...
    guanguans阅读 738评论 0 3
  • Git简介 Git是Linux之父Linus的第二个伟大的作品,它最早是在Linux上开发的,被用来管理Linux...
    Windy_816阅读 27,163评论 1 37