1. Git 基本原理
1.1哈希
哈希是一个系列的加密算法,各个不同的哈希算法虽然加密强度不同,但是有以下几个共同点:
①不管输入数据的数据量有多大,输入同一个哈希算法,得到的加密结果长度固定。②哈希算法确定,输入数据确定,输出数据能够保证不变③哈希算法确定,输入数据有变化,输出数据一定有变化,而且通常变化很大④哈希算法不可逆
Git 底层采用的是 SHA-1 算法。
哈希算法可以被用来验证文件。原理如下图所示:
1.2Git 保存版本的机制
- 1.2.1 集中式版本控制工具的文件管理机制
以文件变更列表的方式存储信息。这类系统将它们保存的信息看作是一组基本文件和每个文件随时间逐步累积的差异。
- 1.2.2 Git 的文件管理机制
Git 把数据看作是小型文件系统的一组快照。每次提交更新时 Git 都会对当前的全部文件制作一个快照并保存这个快照的索引。为了高效,如果文件没有修改, Git 不再重新存储该文件,而是只保留一个链接指向之前存储的文件。所以 Git 的工作方式可以称之为快照流。
2. GitHub
他是用来干啥的?
gitHub是一个面向开源及私有软件项目的托管平台,因为只支持git 作为唯一的版本库格式进行托管,故名gitHub。
gitHub于2008年4月10日正式上线,除了git代码仓库托管及基本的 Web管理界面以外,还提供了订阅、讨论组、文本渲染、在线文件编辑器、协作图谱(报表)、代码片段分享(Gist)等功能。目前,其注册用户已经超过350万,托管版本数量也是非常之多,其中不乏知名开源项目 Ruby on Rails、jQuery、python 等。
他可以做:
- 1. 最通用的,star喜欢的项目,fork并pull为他人项目打补丁
- 2. Github Pages 可以为项目建立静态主页(即gh-pages分支), 也可以建立命名特殊的repo(http://username.github.io)来建立个人静态网站(使用 GitHub Pages 来做博客并非不道德)
- 3. Vim vundle 用户重度依赖Github来管理插件
- 4. Github可以作为自己的简历 ,比如 GitHub Résumé 和 https://github.com/hit9/GhResume
- 5. 在线编译和测试社区Travis CI依赖Github
- 6. 用Gists管理代码片段,而且可以内嵌到网页
- 7. 托管编程环境。在Github上搜索dotfiles来看看大家都怎么管理自己的vim, git,tmux等配置文件的。一般的,我们可以通过submodule来管理插件等第三方工具
- 8. Read the Docs ,这个东西当然不是Github官方的,但是它会检出你的Github上指定项目的docs目录,并用sphinx来生成在线文档。其实readthedocs也是个’静态服务器’
- 9. 可以为自己的项目建立wiki,github/gollum 是其backend. 而且,我们可以用markdown写wiki,用git来管理wiki
上述是官方的话语,我自己的总结:GitHub是一个远程的仓库,把本地的一些代码文件上传到GitHub中,在本地修改当前的文件,即使修改坏了也无所谓,如果这个文件修改的崩掉了,他是不影响远程GitHub上的文件的,我们可以使用命令向远程仓库拿去一份,继续做修改,直白的来说GitHub就是一个远程的存储仓库,也可以理解成备份的意思.
2.1账号信息
GitHub 首页就是注册页面:https://github.com/
GitHub的账号信息:
2.2 创建远程仓库
第一步:
第二歩:
2.3创建远程库地址别名
git remote -v 查看当前所有远程地址别名
git remote add [别名] [远程地址]
2.4推送
git push [别名] [分支名]
2.5克隆
- 命令
- git origin [远程地址]
- 效果
- 完整的把远程库下载到本地
- 创建 origin 远程地址别名
- 初始化本地库
2.6团队成员邀请
第一步
第二歩:
第三歩:
第四步:
以上的步骤完成之后,就建立好联系了
6.7拉取
将远程指定分支 拉取到 本地指定分支上的四种方法:
- pull=fetch+merge
- git fetch [远程库地址别名] [远程分支名]
- git merge [远程库地址别名/远程分支名]
- git pull [远程库地址别名] [远程分支名]
6.8解决冲突
- 要点
- 如果不是基于 GitHub 远程库的最新版所做的修改,不能推送,必须先拉取。
- 拉取下来后如果进入冲突状态,则按照“分支冲突解决”操作解决就可以。
- 类比
- 债权人:老王
- 债务人:小刘
- 老王说:10 天后归还。小刘接受,双方达成一致。
老王媳妇说:5 天后归还。小刘不能接受。老王媳妇需要找老王确认后再执行。
总结:
上述主要讲了Git的原理,及GitHub怎么注册 登陆账号,
登陆完成之后创建一个远程库,邀请新成员加入你的远程库,
新成员将你的文档拉取下来,修改一下,再传递到远程库中,此时你这边
也修改了文件,并将它上传到远程库中,由于两个文件冲突,怎么解决冲突,解决了冲突
问题才能将新的文件上传到远程库中