关于git使用

git原理

Git工作流程图.png
工作目录-缓存目录-本地数据目录.png

对于任何一个文件,在Git内部都只有三种状态:已修改(modified)、已暂存(staged)和已提交(committed)。已修改,表示已经修改了某个文件,但是还没有提交保存;已暂存,表示把已修改的文件放在下次提交时要保存的清单中;已提交,表示该文件已经被完全保存在本地数据库中。

git命令(终端操作命令)

  • 初始化仓库
//初始化仓库(创建新的仓库,不存在远程仓库)
//初始化后,在当前目录下会出现一个名为 .git 的目录,所有git需要的数据和资源都存放在这个目录中
git init 
//初始化仓库(创建新的仓库,已经存在团队创建好的远程仓库,url远程仓库地址)
git clone url
//配置用户名和邮箱
git config --global user.name  xiaoqiang
git config --global user.email  xiaoqiang@gmail.com
//以上两个命令会将用户信息保存在用户目录下的 .gitconfig 文件中
//查看当前所有配置
git config -l
备注信息:
>>项目初始化:
有两种git项目初始化的方法。
一种是团队中还没有远程仓库,在现存的目录下,通过导入所有文件来创建新的git仓库。(git init)
第二种是团队中已经存在远程的仓库,只需要从已有的git仓库中克隆一个新的镜像库来。(git clone url)

>>用户信息配置说明:
配置用户名和电子邮件每次git提交更新时,都会引用用户的配置
信息,说明是提交了代码,如果用了 --global 选项那么更改的配置
文件位于用户主目录下的,所有的用户项目都会使用这里的用户配
置信息。如果要在某个特定的目录中使用其他名字或者邮件,只要
去掉 --global 选项重新配置即可。新的配置保存在,当前项目的 .git/config文件里。

  • 创建文件开始开发
//创建新文件 
touch main.c
open main.c
  • 代码提交
//查看当前代码库状态
git status
//将修改提交到代码库
git add main.c
//将所有修改提交到代码库
git add .
//将修改提交本地仓库并添加备注
git commit -m "添加了main.c"
//将所有修改提交本地仓库并添加备注
git commit -m " 提交所有的修改到本地仓库"
//推送代码到远端
git push
  • 查看所有提交代码版本库日志(在git中,版本号是一个由SHA1生成的哈希值,我们可以根据这个哈希值进行不同版本的切换)
git log
  • 版本号,让我们在任意版本之间穿梭
//回到当前版本,放弃所有没有提交的修改,在没有commit之前的所有内容会被放弃,commit之后的不会改变
git reset --hard HEAD
//回到上一个版本
git reset --hard HEAD^
//回到之前第2个提交版本
git reset --hard HEAD~2
//回到之前第3个提交版本
git reset --hard HEAD~3
//回到指定版本号的版本(版本哈希值)
git reset --hard 11c8eefecd0e40564eafe93cc23675ce37e38ce7
  • 分支管理
//创建分支
git branch branchName
//把分支推送到远程
git push origin branchName
//查看本地分支
git branch
//查看所有分支
git branch  -a
//切换到指定的分支
git branch checkout branchName
//删除本地分支
git branch -d branchName

介绍sourceTree图形化工具使用

通过图形化工具sourceTree介绍开发中对代码的管理,图形化工具对于git版本管理上手是比较快的,当然不同的开发者使用工具的喜好是不同的,有的开发者倾向于使用终端进行代码的版本管理。我也建议,在熟练使用了图形化工具后,对终端命令进行进一步的研究。

  • 建立SSH连接
    SSH(Secure Shell)是一种安全协议,在你的电脑与GitLab服务器进行通信时,我们使用SSH密钥(SSH Keys)认证的方式来保证通信安全。
    SSH连接参考.
  • 初始化本地仓库(已有远程仓库)
初始化本地仓库截图1.0.png
初始化本地仓库截图1.1.png

新添加一个本地仓库(已有远程仓库的情况下,没有远程仓库的情况不再过多讲解,可以通过终端来实现,也可以通过sourcetree)点击从URL克隆后,在新弹框页面,复制粘贴远程仓库的URL地址,在目标路径中选择本地仓库地址,项目名称自动填充完成,最后点击克隆即可完成本地仓库的创建。

  • sourceTree使用介绍
sourceTree主界面截图.png

添加了本地仓库后进入sourceTree日常使用页面,我们日常的开发主要这些仓库基本上可以完成,下面简单介绍一下:

分支管理

查看本地分支:本地仓库会显示在分支6这个地方,进入主页面后新的项目会自动创建一个本地的master仓库,也是目前唯一的本地仓库。
从远端拉取新分支到本地:使用操作4抓取可以抓取远程的代码和远程的分支,抓取之后展开7所在的远端,就可以看到所有的远程分支,双击对应的远程分支会创建一个与之对应的本地分支并且切换到该本地分支上
切换本地分支:在6所在的本地分支列表上,双击分支即可实现本地分支的自由切换
创建新的本地分支:点击操作5,即可在当前本地分支的基础上创建一个新的本地分支,新的本地分支创建完成后,别忘了使用操作3推送,把新创建的本地分支推送到远端。新的分支最要按照一定的规则,每一个团队创建分支都是有一定的规范,这样可以操作规范化也可以规避不必要的问题。

代码提交

一般开发我们会在相应的开发分支完成整个项目的开发工作。下面简单介绍在功能开发过程中的一些代码提交操作。

暂存文件:如下文件暂存示例图所示,在未暂存文件区域,选择文件即可暂存文件

文件暂存示例图.png

放弃文件修改:如果在代码提交过程中不需要某些文件的更改,想要放弃,可以放弃文件。如文件暂存示例图所示,右击文件,选择丢弃文件即可。
提交代码:点击文件状态8在右侧区域可以看到当前分支所有文件改动,右侧区域分为暂存区域和非暂存区域,将需要提交的文件提交到暂存区域,点击操作提交1,填写提交文件备注即可。
推送远端:将代码提交本地后,首先要操作2拉取,拉取其他开发者代码改动,有冲突要解决冲突编译成功后暂存文件重新操作1提交文件到本地仓库后,最后点击操作3推送,将本地仓库的改动提交到远端的仓库。
分支合并
分支合并操作示例图.png

冲突解决:在提交代码和分支合并过程中往往会产生代码冲突,解决冲突也是日常开发中的必修课程。某些复杂的逻辑需要修改文件的双方一起修改,一般这类问题修改双方会一起讨论如何修改,代码中如何删除保留。还有在解决冲突过程中,如果文件冲突解决后编译不成功,那就是冲突没有解决成功的问题了,这时候我们可以,重新合并冲突的文件,重新解决文件冲突指导解决成功为止。
重新合并冲突文件.png

Git-Flow

Git Flow是构建在Git之上的一个组织软件开发活动的模型,是在Git之上构建的一项软件开发最佳实践。Git Flow是一套使用Git进行源代码管理时的一套行为规范和简化部分Git操作的工具。
http://www.ituring.com.cn/article/56870

  • git-flow 基于git本身的分支管理机制
git-workflow-release-feature.png

git-flow就是通过在一个项目里划分不同的分支,来实现功能开发、bug修复、版本发布,以及开发过程中的冲突处理等。

Master:

就是平时我们看到的master,项目的主要分支,你可以把它理解成稳定无bug发布版 ,Master上的代码就是我们线上最新的发布版本。可以说Master稳定性和重要性最高的,所以git-flow要求我们不能在master下做开发。

Develop:

处于功能开发最前线的版本,查看develop分支就能知道下一个发布版有哪些功能了。develop一开始是从master里分出来的,并且定期会合并到master里,每一次合并到master,表示我们完成了一个阶段的开发,产生一个稳定版。同样的,develop下也不建议直接开发代码,develop代表的是已经开发好的功能
的回归版本(为什么说回归?)

Feature:

带着develop处的疑问,我们在feature里为你解答。(有点长,别不看)feature的作用是为每一个新功能从develop里创建出来的一个分支。例如小明和小白分别做两个不相干的功能,就应该分别创建两个分支,各自开发完以后,先后合并到develop里,这就叫做回归。在这个过程里,小明小白不需要任何的沟通,分别并行地开发,git-flow能很好的处理好分支间并行开发的关系。而develop,则会在适当的时候,由合适的人,合并到master,作为下一个稳定版本

Hotfix:

以上3种以外,还有一个很重要的类型,hotfix。它是用来修复紧急bug的,而bug通常是来自线上的,所以hotfix分支是从master里创建出来的,并且,在bug修改好以后,要同时合并到master和develop,这一点需要特别注意。

Release :

release更多倾向与版本发布,项目上线前的一些全面测试以及上线准备。同样也肩负着版本归档,回滚支持等。

其他

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

推荐阅读更多精彩内容

  • 小巷,悠长寂寥又落寞衰败! 这里却有一道绚烂至极的风景。 巷子中间距离上有户人家的围墙上种了一棵叶子花。花...
    静女默默阅读 325评论 1 2