目录
一、前置准备
二、git简介
三、gitee.com的基本使用
1.创建仓库(私库和公库)
?2.创建文件及文件夹
?新建文件夹两种方式
①?
?②
?3.删除
删除文件
?删除仓库
四、组长组员的git使用?
git clone
?查看文件
?git status
??git add?
?git commit
??git push
? ?## 命令行配置
多个添加
?git reset HEAD
?git pull
?git init
?上传到码云(gitee.com)
五、git冲突
一、前置准备
1.申请并[激活]一个Gitee帐号 ? 2.在window中安装Git ? ? ?版本要求:Git-2.22.0-64-bit.exe或以上版本, ? ? ?安装路径:请不要安装在C盘(win10会有权限问题),建议选择“D:\tools\Git”
data:image/s3,"s3://crabby-images/6102d/6102d70bfc8b1cf1b1108c9cddc986517063d678" alt=""
data:image/s3,"s3://crabby-images/94a95/94a956f152af7de85f5b9ea6a5fbd4f5a0703539" alt=""
二、git简介
Git是什么? ? ?Git是一个开源的[分布式][版本控制系统],用于敏捷高效地处理任何或小或大的项目
版本控制器 ? ?CVS/SVN/Git
Git与SVN区别 ? 2.1 去中心化 ? ? ? GIT是分布式的,SVN不是:这是GIT和其它非分布式的版本控制系统,例如SVN,CVS等,最核心的区别。 ? ?? ? 2.2 git仓库的任何一个拷贝都可以独立作为一个服务器来使用 ? 2.3 在Git中文件有四种状态: ? ? ? 未跟踪(untrack):表示文件为新增加的 ? ? ? 已修改(modified):表示修改了文件,但还没保存到git仓库中。 ? ? ? 已暂存(staged):表示对一个已修改文件的当前版本做了标记,使之包含在下次提交的快照中 ? ? ? 已提交(committed):表示文件已保存在git仓库中。 ? 2.4 其它 ? ? ? GIT没有一个全局的版本号,而SVN有:目前为止这是跟SVN相比GIT缺少的最大的一个特征。 ? ? ? GIT的内容完整性要优于SVN:GIT的内容存储使用的是SHA-1哈希算法。这能确保代码内容的完整性,确保在遇到磁盘故障和网络问题时降低对版本库的破坏 ? 2.5 直接记录快照,而非差异 ? ? ? GIT把内容按元数据方式存储,而SVN是按文件:所有的资源控制系统都是把文件的元信息隐藏在一个类似.svn,.cvs等的文件夹里。 ? ? ? 直接记录快照,而非差异 ? 2.6 直接记录快照,而非差异 ? ? ? GIT分支和SVN的分支不同,分支在SVN中一点不特别,就是版本库中的另外的一个目录。 ? 2.7 git存在分支
data:image/s3,"s3://crabby-images/1631f/1631f7eca7d56f056b3df5f334e106d3420c9396" alt=""
三、gitee.com的基本使用
1.创建仓库(私库和公库)
data:image/s3,"s3://crabby-images/de6bc/de6bc7fbba332f634dc4d4dfccd36956930ed65b" alt=""
?data:image/s3,"s3://crabby-images/76af4/76af49e6007244afd808169c3bdf17f6674b88e8" alt=""
data:image/s3,"s3://crabby-images/e349f/e349f7993e1812809a1150268b6e5eff094e6adb" alt=""
?
?创建成功 此时是私库data:image/s3,"s3://crabby-images/88884/88884d0fa3e3b5689cbd0ed951974660e0e3819f" alt=""
?改成开源即是公库 滑到管理的地方
data:image/s3,"s3://crabby-images/88fa0/88fa023b2da38fa0927a74eb70db857c0da8d565" alt=""
?选择开源data:image/s3,"s3://crabby-images/330a2/330a2465203af3fd1f55078f889304f1d2323e4c" alt=""
?2.创建文件及文件夹
data:image/s3,"s3://crabby-images/f9525/f95258c0eaaab0094c9cf1fbab897818e7460c6e" alt=""
data:image/s3,"s3://crabby-images/42307/42307a6130eaae6350702e34fec71561b14f42db" alt=""
?data:image/s3,"s3://crabby-images/84943/849436abe4dc5d50f6d7c693794485451dde105e" alt=""
?新建文件夹两种方式
①data:image/s3,"s3://crabby-images/3f24b/3f24b1bc321e69bd5b9829ad5f786059ecdf90ab" alt=""
?data:image/s3,"s3://crabby-images/1c232/1c2323b7f3dcde253d7e4f2357562d5cd693cc71" alt=""
?②
data:image/s3,"s3://crabby-images/86f25/86f250be9fb9af8e76432b4e6094370a02263228" alt=""
?3.删除
删除文件
data:image/s3,"s3://crabby-images/245f2/245f2f1976b1110ca5eec31686dfbe7e6240818f" alt=""
?删除仓库
点击仓库名-->管理-->删除仓库-->输入要删除的仓库名-->输入密码确认删除
data:image/s3,"s3://crabby-images/db8e3/db8e33b3681947ce5a27eaf6d650e707a50ae363" alt=""
data:image/s3,"s3://crabby-images/4d868/4d868cd5b1d66aa540a4eb6fd6daa4e12ecb29e2" alt=""
?data:image/s3,"s3://crabby-images/9ea99/9ea9979bd708f3f6e19363117d111a453cb5915c" alt=""
?data:image/s3,"s3://crabby-images/66a24/66a24327b9181190241087fb70c6311f7db0604c" alt=""
?data:image/s3,"s3://crabby-images/5ef71/5ef71852de9ad1059ebd8a04493746187d00973b" alt=""
四、组长组员的git使用?
准备工作:
新建一个仓库cdl-a
改成公有的
创建一个文件Goods
常用命令(重点) ? ?git clone :将远程仓库clone到本地计算机。 ? ?git status :展示工作区及暂存区域中不同状态的文件。 ? ?git add :将内容从工作目录添加到暂存区。 ? ?git commit :所有通过 git add 暂存的文件提交到本地仓库。 ? ?git push :将本地仓库的记录提交到远程仓库。 ? ?git reset HEAD <file> :从暂存区移除指定文件。 ? ?git pull :拉取远程仓库的数据。
git clone
在本地新建一个文件夹
data:image/s3,"s3://crabby-images/aafa7/aafa725718052a83161918da325ad1cadd460925" alt=""
?右键
data:image/s3,"s3://crabby-images/0cc90/0cc90185cc0d1b5de44b94c601057977d5c93dbd" alt=""
?出现黑窗口
data:image/s3,"s3://crabby-images/ec9e0/ec9e04bfe1ec2fea0400e434f39ff70e26faa6e2" alt=""
?data:image/s3,"s3://crabby-images/ad402/ad4020aa143147fa6289912bf01ccd3bdd705050" alt=""
完整命令
data:image/s3,"s3://crabby-images/40a40/40a4019b3a6ff4ccba939787f0fc2305c9405ed4" alt=""
?回车 成功加载到本地
data:image/s3,"s3://crabby-images/e5eee/e5eeec89e3e96cf65081691552feb3e165dbeea7" alt=""
?查看文件
data:image/s3,"s3://crabby-images/02bb4/02bb40bdd494922e56b688284113192c6d0b2ee5" alt=""
?data:image/s3,"s3://crabby-images/4adda/4addae420bdf31630af9f062d902950f24902a50" alt=""
?git status
展示工作区及暂存区域中不同状态的文件
表示该文件为新添加的
data:image/s3,"s3://crabby-images/5d709/5d7098c625574738664b35ee22078f2f1f0fb22d" alt=""
??git add?
将内容从工作目录添加到暂存区。
data:image/s3,"s3://crabby-images/6d3ee/6d3ee5dca16ef77713163dd1a396480368103090" alt=""
?git commit
所有通过 git add 暂存的文件提交到本地仓库
data:image/s3,"s3://crabby-images/e3064/e3064637dd8eb5074cb7c5a5ea7749c757a5f86c" alt=""
?data:image/s3,"s3://crabby-images/69f78/69f78df3d40cc4d547370f42746a8879680d262b" alt=""
??git push
将本地仓库的记录提交到远程仓库
data:image/s3,"s3://crabby-images/85582/8558217bb8d2391aa5a16ed0d46270d693f3033e" alt=""
?data:image/s3,"s3://crabby-images/38e18/38e185d0e653669fdbd146c5ae1d14387d4a4ed8" alt=""
?data:image/s3,"s3://crabby-images/d4519/d4519d8c67eb9cfbbd19b0f987c7c03eb4ecf364" alt=""
?本地电脑:
? ?代码区:工作区间,放代码的地方
? ?暂存区:git所管理的暂存区域
? ?本地仓库:git在本地所管理的硬盘区
远程电脑:
? ?远程仓库:github,gitee
? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ? ?git add? ? ? ?git commit? ? git push
? ?代码提交过程:代码区-->暂存区-->本地仓库-->远程仓库
? ?代码区-->暂存区-->本地仓库 不需要联网
????本地仓库-->远程仓库 需要联网??
? ?## 命令行配置
? ?0.“Git bash here”打开命令窗口 ? ?1.查看git的配置列表 ? ? ?git config --list ? ? ?注1:如果没有配置东西,应该是空的。照着下面步骤配置完成后,你可以再试一下该命令,就会出现一系列配置信息 ? ?2.设置用户名/邮箱/密码 ? ? ?git config --global user.name "username" ? ? ?git config --global user.email "email" ? ? ?git config --global user.password "password"
多个添加
本地添加几个文件
data:image/s3,"s3://crabby-images/d44ab/d44ab2bed1c1f6fd492cd52bda5a6305aff69fdf" alt=""
?data:image/s3,"s3://crabby-images/d0523/d05234812406eefc3223bcd173e6f68b0dffe947" alt=""
?data:image/s3,"s3://crabby-images/2b2c5/2b2c54162682f15c303bb0fdefdcd0fd4182310e" alt=""
data:image/s3,"s3://crabby-images/c366a/c366ac67da82ccd6128c06d09f7102c7213e3d17" alt=""
安全性降低
?git reset HEAD <file>
从暂存区移除指定文件
data:image/s3,"s3://crabby-images/031c3/031c3973914a1694177c2eb45d29f919da8390df" alt=""
?git pull
拉取远程仓库的数据。
此时假设组长对上传的文件进行改变
data:image/s3,"s3://crabby-images/a495f/a495fcb4526e144f8cbf4104dd5b87b1794c4098" alt=""
?data:image/s3,"s3://crabby-images/090de/090dee7c07e61316c369f5fea310efed18524b0b" alt=""
?data:image/s3,"s3://crabby-images/8fede/8fedeb8aaa39eac8fec2b953421780602ab07834" alt=""
?没有所删除的文件data:image/s3,"s3://crabby-images/db7d5/db7d5329e53037db0100a0211c65d492b95a5c33" alt=""
?data:image/s3,"s3://crabby-images/d5062/d5062a6d83bbe710d7ba09359afc44121dd797ec" alt=""
?git init
新建一个项目(文件夹)
data:image/s3,"s3://crabby-images/fb7a7/fb7a70014273978d741fce0ce0d6cd21061c83c3" alt=""
?上传到码云(gitee.com)
新建一个空的仓库,并且设置开源
将本地仓库和远程仓库进行关联
?初始化前有画黄线的命令
data:image/s3,"s3://crabby-images/63cd5/63cd5640efe28e24f1b451efb433f7706360a5b1" alt=""
data:image/s3,"s3://crabby-images/8162c/8162c1e2e4f1ecff171860d042c2ac6f7a037d98" alt=""
?失败的原因:github本身进行的改变
要在执行改命令前进行本地仓库与远程仓库的同步,实现远程与本地代码的合并git pull --rebase origin master
data:image/s3,"s3://crabby-images/8f73f/8f73f2fa5b6c8e1a4fd24d0bb2c9a99870d778ae" alt=""
data:image/s3,"s3://crabby-images/1f38d/1f38d4d3edd831bb881cd1fce658193a5dd21e54" alt=""
注意:空的文件夹上传不了
组长:
? 1.在某一个工作区间搭建环境,ssm能跑起来
? 2.在该工作区间中执行git init 命令,标记该工作区间由git所管理
? 3.在gitee/github中新建仓库
? 4.通过git remote add origin url 将本地仓库与远程仓库关联
? 5.将本地仓库与远程仓库进行文件同步
? 6.执行git三部曲 add commit push 将搭建好的环境推送到远程仓库
组员:
?1:通过git clone将组长搭建好的环境克隆到本地,并且保证项目能运行
?2.测试组员修改/新增代码是能够推送到远程仓库的
? ? 测试git add/commit/push是否有用
五、git冲突
Git冲突与解决方法 ? ? ?1.git冲突的场景(课程中主要演示情景三) ? ? ?情景一:多个分支代码合并到一个分支时; ? ? ?情景二:多个分支向同一个远端分支推送代码时; ? ? ?情景三:同一分支,同一文件修改后的提交(即为多个程序员修改了同一个文件) ? ? ?实际上,push操作和pull操作其实就分别是用本地分支合并到远程分支 和 将远程分支合并到本地分支,所以这两个过程中也可能存在冲突。 ?? ? ?分别在同一项目的两个不同本地仓库修改a.txt并提交,则会报出以下错误: ? ?! [rejected] master -> master (fetch first) error: failed to push some refs to ' 。。。'
? ?拒绝 ? ?错误:无法推送某些引用?
? ?解决方案: ? ?1.将代码copy出来 ? ?2.先从远程仓库pull代码至本地,再修改冲突代码, ? ? ?? ? ? ?注1:git status查看仓库状态,会显示红色的错误提示消息“ both modified: ? a.txt” ? ?3.打开a.txt,手动修改冲突部分的代码 ? ? ?<<<<<<< HEAD ? ? ?ww add 18:42 from e:\temp\test1 ? ? ?=======
? ? ?ls add 123 at 18:17 from d:\temp\test1 ? ? ?>>>>>>> 63c73e5933bb7d3d2bed04b06c37a74602d65b2e ? ? ?注1:<<<<<<< HEAD ?>>>>>>>之间的即为冲突的代码,手动修改即可 ? ? ?? ? ?3.依次add/commit/push代码至远程仓库 ? ? ?commit执行完生,重新查看仓库状态git status,红色的错误提示消息“ both modified: ? a.txt” ? ? ?已经没有,表示冲突已解决 ?
?
|