git 版本管理配置和常用命令


(自己记录的一些git 使用方法,可能有错误,不喜勿喷,有什么问题希望多多指点,适合初学git 者观看)


一、SSH 配置公钥的问题

如果你是跟着廖雪峰的博客学Git的。先在本地创建了个仓库,并且你git  init  , git add . ,git commit 巴拉巴拉的,敲了一大堆。然后当你进行本地仓库跟远程仓库链接之后。执行git push origin master  命令进行push  出现这个问题。

是因为GitHub上创建仓库的时候生成的README.md文件与本地的README.md冲突了。只需要在终端使用命令git pull –r origin master 再push 就好了。

如果错误关联了远程仓库,想要取消关联使用命令git remote remove origin,就移除你跟关联着的远程仓库的联系关系了。


------------===================---------=========---------=========-------

Could not read from remote repository 这个问题是因为 github  上,没有创建SSH key

如何创建 SSH key :

 1.配置本机的user name  和 email

git config --global user.email "12344@163.com"

git config --global user.name "账号"    可以直接设置git仓库的分支账号密码

2)生成密钥:

$ ssh-keygen -t rsa -C “haiyan.xu.vip@gmail.com”(请填你设置的邮箱地址)

按3个回车,密码设置的最少5个字符。

然后系统会自动在.ssh文件夹下生成两个文件,id_rsa和id_rsa.pub

(出现如上图所示就说明操作正确了)

3. cat ~/.ssh/id_rsa.pub : 获取到id_rsa.pub 文件里的内容讲其全部复制下来。(包括ssh-rsa 和结尾处的你的邮箱)

4.在.ssh 文件夹中执行 ssh-add id_rsa 再次输入之前输入的密码

5.设置github 上的SSH (操作三连图)

点  add SSH key  就设置完成了。

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

二、自己在分支上的开发历史保留

通常,合并分支时,如果可能,Git会用Fast forward模式,但这种模式下,删除分支后,会丢掉分支信息。如果要强制禁用Fast forward模式,Git就会在merge时生成一个新的commit,这样,从分支历史上就可以看出分支信息

准备合并dev分支,请注意--no-ff参数,表示禁用Fast forward:

git merge --no-ff -m "merge with no-ff" dev  :合并dev 分支并且不会删除dev分支的历史记录

因为本次合并要创建一个新的commit,所以加上-m参数,把commit描述写进去。

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

三、多人协作模式

现在,你的小伙伴要在dev分支上开发,就必须创建远程origin的dev分支到本地,于是他用这个命令创建本地dev分支:

git checkout -b dev origin/dev :  创建远程origin 分支下的dev 分支

现在你的小伙伴就可以在 dev 分支上修改,时不时的push dev 分支到远程仓库


一般多人协作实战开发时的场景一般是:

首先,可以试图用git push origin 推送自己的修改;

如果推送失败,则因为远程分支比你的本地更新,需要先用git pull试图合并;

如果合并有冲突,则解决冲突,并在本地提交;

没有冲突或者解决掉冲突后,再用git push origin 推送就能成功!

如果git pull提示no tracking information,则说明本地分支和远程分支的链接关系没有创建,用命令git branch --set-upstream-to origin/。

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

(还有一些Bug 分支功能,  Feature 分支功能,感觉目前也用不上,就不写了,但是知道有这么个东西,以后需要的话就去廖雪峰的git 教学官网上查看就可以了。)

git rebase  :  把提交历史整理成一条直线。(额 ,更好看)。详情请看廖大神

git config --global alias.st status :设置 st 就代表命令  status  ,把git 命令简单化,其他的git 命令想修改都是一样的道理。


-----------------------------===============----------------

四、git 使用到的命令记录

                              (本地仓库的一些操作)

mkdir   learngit    :  mkdir  命令是在当前目录下创建一个文件夹

ls -ah : .git 文件默认是隐藏的,ls -ah 命令就可以看见这个文件夹了 

pwd  :  显示当前文件的路径

git init :  把这个目录变成git 可以管理的仓库

vi  readme.txt : 创建一个TXT 文件

git  add  readme.txt : 用命令 git add 告诉Git ,把文件添加到仓库

git commit -m 'wrote a readme.txt file' : 用命令git commit 告诉Git ,把文件添加到仓库

git config --global user.email "12344@163.com"

git config --global user.name "账号"    可以直接设置git仓库的分支账号密码

git status : 时刻掌握仓库当前的状态 ,告诉你那个文件被改动过了

 git diff file1 :  查看文件file1 具体什么地方被改动了。

git diff  HEAD --learngit.txt  : 查看工作区跟版本儿库里最新版本儿的区别。

git log : 查看历史版本 

 git log --pretty=oneline : 查看历史版本的时候加上 --pretty=oneline  显示的就是你每次            提交版本的时候加的注释,看起来简洁一些。

git reset --hard HEAD^  : 回退到上一个版本儿, 回退到上两个版本儿: HEAD^^  ,回退到上100个版本:HEAD~100

git reset HEAD  readme.txt  :  把文件readme.txt 暂存区的修改撤销掉,放回工作区,这样如果再执行 git checkout -- readme.txt 的话,就可以把修改撤销了。

git reset --hard  1923a  : 这是如果你回退一个版本,只要你知道回退之前的版本号1923a,(这是版本号的前几位,版本号写前几位就行了,没必要写全)就可以回到未来,git 就是这么神奇。

cat file1 : 查看file1 这个文件里的内容。

git reflog  记录你之前用过的命令。如果你回退到了某个版本儿,关机之后,第二天再想回到未来的版本儿,发现找不到commit id  了,你就可以使用这个命令,查看你之前打过哪些命令。所以说在git 里,总有一款后悔药,适合你吃的。

git 版本儿管理系统追踪的是修改,而不是文件。commit 只会提交add  过的文件内的差异,没有add 到缓存区的文件的修改,都不会提交。

git checkout -- file :撤回修改,就是撤回文件最近修改的内容,撤回工作区的修改,只要add 到了缓存区,就checkout  不了了。

rm file  :  删除一个文件 就用 rm 命令

git rm file : 删除版本儿库里的file 文件


                                (远程仓库的一些操作)

$ ssh-keygen -t rsa -C “haiyan.xu.vip@gmail.com”(请填你设置的邮箱地址):生成秘钥

git remote remove origin : 移除关联的远程仓库

git remote add origin git@github.com:michekdh/learngit.git : 关联远程仓库

git push origin master  :  提交本地仓库的代码到远程仓库

git pull -r origin master : 拉取远程仓库上的东西到本地

git clone   git@github.com:michekdh/learngit.git :( 这个远程仓库地址换成自己的)克隆远程仓库到本地。先创建远程仓库,再创建本地仓库。


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

                                 (远程库分支的一些操作)

git remote  : 查看远程仓库信息。 

git remote -v 显示远程仓库更详细的信息。

git checkout -b dev  : 创建 dev 分支,并切换到 dev 分支 。相当于两条命令:git branch dev   ,git  checkout  dev 

git branch : 分支查看,查看一共有多少分支,现在处在哪个分支上。

git merge dev  : 把dev  分支上的成果合并到当前分支上(如果你要想把dev 分支上的东西合并到master 分支,你就应该在master 分支上进行这个命令操作)。分支有冲突的话,就可以直接打开冲突文件进去手动修改。

git branch -d dev : 删除dev 分支,需要你先 git checkout master 切换到主分支上再删除dev分支

git log --graph --pretty=oneline --abbrev-commit : 可以查看分支合并情况

git log --graph : 查看分支合并图。

git merge --no-ff -m "merge with no-ff" dev  :合并dev 分支并且不会删除dev分支的历史记录(准备合并dev分支,请注意--no-ff参数,表示禁用Fast forward:)

git branch --set-upstream branch-name origin/branch-name : 建立本地分支和远程分支的关联。

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

推荐阅读更多精彩内容