导图社区 git版本控制
git版本控制,摘自https://www.cnblogs.com/auguse/ 蝉声且送阳西 老师
编辑于2022-07-29 21:18:28git版本控制工具
初识
Git Bash:Unix与Linux风格的命令行,目前使用最多,推荐使用
Git CMD:Windows风格的命令行
Git GUI:图形界面的Git,不建议初学者使用
常用命令
查看配置 git config -l
#查看系统config git config --system --list
#查看当前用户(global)配置 git config --global --list
Git相关的配置文件:
1)D:\test_tools\Git\etc\gitconfig :Git 安装目录下的 gitconfig --system 系统级
2)C:\Users\Administrator\ .gitconfig 只适用于当前登录用户的配置 --global 全局
初始化配置信息
配置用户名: git config --global user.name "输入你的用户名"
配置邮箱信息: git config --global user.email "输入你的邮箱信息"
创建本地仓库的方法有两种
# 在当前目录新建一个Git代码库
$ git init
.克隆远程仓库
# 克隆一个项目和它的整个代码历史(版本信息) $ git clone url # https://gitee.com/Discuz/DiscuzX.git
文件的四种状态
Unmodify: 文件已经入库, 未修改, 即版本库中的文件快照内容与文件夹中完全一致. 这种类型的文件有两种去处, 如果它被修改, 而变为Modified. 如果使用git rm移出版本库, 则成为Untracked文件
Modified: 文件已修改, 仅仅是修改, 并没有进行其他的操作. 这个文件也有两个去处, 通过git add可进入暂存staged状态, 使用git checkout 则丢弃修改过, 返回到unmodify状态, 这个git checkout即从库中取出文件, 覆盖当前修改 !
Staged: 暂存状态. 执行git commit则将修改同步到库中, 这时库中的文件和本地文件又变为一致, 文件为Unmodify状态. 执行git reset HEAD filename取消暂存, 文件状态为Modified
Untracked: 未跟踪, 此文件在文件夹中, 但并没有加入到git库, 不参与版本控制. 通过git add 状态变为Staged.
通过如下命令可以查看到文件的状态
#查看指定文件状态 git status [filename]
#查看所有文件状态 git status
#添加所有文件到暂存区 git add .
#提交暂存区中的内容到本地仓库 -m 提交信息 git commit -m "消息内容"
忽略文件
有些时候我们不想把某些文件纳入版本控制中,比如数据库文件,临时文件,设计文件等
在主目录下建立".gitignore"文件,此文件有如下规则:
忽略文件中的空行或以井号(#)开始的行将会被忽略。
可以使用Linux通配符。例如:星号(*)代表任意多个字符,问号(?)代表一个字符,方括号([abc])代表可选字符范围,大括号({string1,string2,...})代表可选的字符串等。
如果名称的最前面有一个感叹号(!),表示例外规则,将不被忽略。
如果名称的最前面是一个路径分隔符(/),表示要忽略的文件在此目录下,而子目录中的文件不忽略。
如果名称的最后面是一个路径分隔符(/),表示要忽略的是此目录下该名称的子目录,而非文件(默认文件或目录都忽略)
例如
#为注释*.txt #忽略所有 .txt结尾的文件,这样的话上传就不会被选中!!lib.txt #但lib.txt除外/temp #仅忽略项目根目录下的TODO文件,不包括其它目录tempbuild/ #忽略build/目录下的所有文件doc/*.txt #会忽略 doc/notes.txt 但不包括 doc/server/arch.txt
使用码云
生成SSH Key密钥
ssh-keygen -t rsa -C "你的邮箱"
设置本机绑定SSH公钥,实现免密码登录!
(免密码登录,这一步挺重要的,码云是远程仓库,我们是平时工作在本地仓库!) 进入 C:\Users\11200.ssh 目录,即可查看生成的秘钥
将公钥信息public key 添加到码云账户中即可!
使用码云创建一个代码仓库
上传
# 在当前目录新建一个Git代码库
git init
将所有的文件加入暂存区
git add . #.代表将所有内容全部提交
commit 提交暂存区文件到本地仓库
git commit -m "描述"
提交到远程仓库
git remote add origin https://gitee.com/soboy/testrepo.git git push -u origin "分支名称"
push到远程仓库
git push
注意
在用ssh-key后仍须输入密码的问题 1、使用ssh方式克隆 git clone git@gitee.com:Name/project.git 就是说,在项目克隆/下载处,选择ssh方式的下载地址 2、如果你已经用https方式克隆了仓库,不必删除仓库重新克隆,只需将当前项目中的 .git/config文件中的 url = https://gitee.com/Name/project.git 修改为 url = git@gitee.com:Name/project.git 再次提交就不需要密码了!
如果重新提交:2,3,4步即可
下载
克隆公共的
git clone https://gitee.com/haugus/automated-testing-keyword-driven.git
私有的
https地址: git clone https://用户名:密码gitee.com/soboy/testrepo.git
git clone https://soboy:mh030250@gitee.com/soboy/testrepo.git
ssh: git clone git@gitee.com:soboy/testrepo.git
输入后需输入密码
如何不是第一次下载,直接在项目目录 git pull
GIT分支
分支在实际中有什么用呢?假设你准备开发一个新功能,但是需要两周才能完成,第一周你写了50%的代码,如果立刻提交,由于代码还没写完,不完整的代码库会导致别人不能干活了。如果等代码全部写完再一次提交,又存在丢失每天进度的巨大风险。 现在有了分支,就不用怕了。你创建了一个属于你自己的分支,别人看不到,还继续在原来的分支上正常工作,而你在自己的分支上干活,想提交就提交,直到开发完毕后,再一次性合并到原来的分支上,这样,既安全,又不影响别人工作。 其他版本控制系统如SVN等都有分支管理,但是用过之后你会发现,这些版本控制系统创建和切换分支比蜗牛还慢,简直让人无法忍受,结果分支功能成了摆设,大家都不去用。 但Git的分支是与众不同的,无论创建、切换和删除分支,Git在1秒钟之内就能完成!无论你的版本库是1个文件还是1万个文件。
git分支中常用指令:
# 列出所有本地分支 git branch # 列出所有远程分支 git branch -r # 新建一个分支,但依然停留在当前分支 git branch [branch-name] # 新建一个分支,并切换到该分支 git checkout -b [branch] # 切换分支 git checkout [branch] # 合并指定分支到当前分支(注意:这里是一定切换到主分支,在合并其他分支),最后还需要 git push 提交 git merge [branch] # 删除分支 git branch -d [branch-name] # 删除远程分支 git push origin --delete [branch-name]$ git branch -dr [remote/branch] #将创建的dev分支提交到码云的远程仓库 git push --set-upstream origin dev