git是一个版本管理的仓库,接下来就是版本的一些实战信息。
git 中文件的状态有 :暂存(staged)、已经修改(modified)、已经提交(commited)
下载安装好我们的git后,创建一个空文件夹1.然后进入这个文件夹里面,使用 **git init **创建仓库,使用命令后就会存在.git的文件夹
[外链图片转存失败,源站可能有防盗链机制,建议将图片保存下来直接上传(img-5pSjjbMc-1637327120959)(GIT的使用.assets/image-20211119110856301.png)]
创建一个文件1.txt
这个时候文件并不属于这个版本管理仓库,因为还没有执行文件的三个状态。使用git status查看这个目录中的文件状态。表示这个文件还没有被追踪。使用 git add 1.txt将文件加到暂存区中。
再次查询状态,发现暂存区中已经有了一个文件,现在我们可以对这个文件进行提交或者删除。
但我们修改这个文件中的内容后,再次查看状态,会发现这个已经被修改了。但是我们依旧可以提交我们暂存区的内容git commit -m ‘first use’ 。命令中的m表示注释,这里的注释的内容是文本中的内容。
再次查询状态,发现暂存区中已经没有文件了,因为已经被提交了。
通过命令git log可以看到我们的提交日志
接下来将修改的文件第二次提交git commit -m ‘first use1’ 。注释依旧是文本中的内容。查看提交日志可以看到我们每次提交的信息
当我们提交的次数很多的时候,我们可以对git log -条数 --pretty=oneline进行参数的控制。
上图我们会发现我们的head指针是指向我们最后一次提交的,所以要想控制版本,我们将head指向其他的就行。
我们的版本目前有2个:first use1和first use。**git reset --hard HEAD^该命令表示将指针指向上一次的提交:first use。^**控制版本回退的次数:**git reset --hard HEAD^^**表示退回到当前版本的前2个版本【3->1】
也可以使用git reset --hard HEAD~数量,表示回退的版本数量
这个时候我们的1.txt中的内容也发生了改变
当我们跳到之前的版本的时候,使用git log会显示不出未来的日志的,所以使用新的命令查看操作日志 reglog
#查看所有的执行log
git reflog
df4c499 (HEAD -> master) HEAD@{
0}: reset: moving to HEAD^
ba1a4f1 HEAD@{
1}: commit: first use1
df4c499 (HEAD -> master) HEAD@{
2}: commit (initial): first use
找到想要跳的版本号,执行命令就可
$ git reset --hard "ba1a4f1"
HEAD is now at ba1a4f1 first use1
查询日志,可以看到Head指向了first use1。此时我们的文件内容已经发生了改变
$ git log -2 --pretty=oneline
ba1a4f1f40bde45fdf3f9cbbfbdaa0695d350625 (HEAD -> master) first use1
df4c49908a0ea3d3372fd8f38621d7309f3c6707 first use
当我们本地文件的1.txt文件被删除的时候,我们可以使用checkout 命令将删除的文件进行恢复
$ git checkout -- 1.txt(文件名)
先将一个新的文件2.txt提交到仓库。使用 git ls-files查看仓库中的所有文件
$ git ls-files
1.txt
2.txt
使用命令rm删除仓库的内容,同时删除我们本地的内容。此时就不能再检出了
$ git rm 2.txt
rm '2.txt'
$ git ls-files
1.txt
$ git commit
$ git clone url
然后和上面一样操作一些commit
百度ssh配置git
#验证SSH是否成功
$ ssh -T [email protected]
如果有提示,直接yes,再次执行会提示 successful
git init
git add .
git commit -m '注释'
#远程的url绑定到该项目,同时取别名 origin
git remote add origin url
#将本地的仓库推送到url上
git push -u origin master
#查看本地仓库对应的远程仓库
$ git remote -v
当我们使用远程地址绑定的时候,需要注意远程仓库的地址:https还有ssh,如果配置类ssh就可以使用ssh
$ git remote add feature1 [email protected]:P65782152/java_study_heima.git
执行推送的时候报错:需要我们先pull一下
$ git push -u feature1 master
To gitee.com:P65782152/java_study_heima.git
! [rejected] master -> master (non-fast-forward)
error: failed to push some refs to '[email protected]:P65782152/java_study_heima.git'
hint: Updates were rejected because the tip of your current branch is behind
hint: its remote counterpart. Integrate the remote changes (e.g.
hint: 'git pull ...') before pushing again.
hint: See the 'Note about fast-forwards' in 'git push --help' for details.
使用pull报错:说明两个仓库不相关,拒绝merge 不相关的历史, 因为本地也有提交。
$ git pull feature1 feature #第一个feature1是地址的别名,feature是远程地址的分支名
From gitee.com:P65782152/java_study_heima
* branch feature -> FETCH_HEAD
fatal: refusing to merge unrelated histories
使用允许无关联的历史记录的参数拉取之后再 push
$ git pull feature1 feature --allow-unrelated-histories
From gitee.com:P65782152/java_study_heima
* branch feature -> FETCH_HEAD
Merge made by the 'recursive' strategy.
.gitignore | 23 +++++++++++++++++++++++
1 file changed, 23 insertions(+)
create mode 100644 .gitignore
或者使用如下命令
git push -u origin master -f
再次执行push
$ git push feature1 master
Enumerating objects: 13, done.
Counting objects: 100% (13/13), done.
Delta compression using up to 8 threads
Compressing objects: 100% (7/7), done.
Writing objects: 100% (12/12), 1.08 KiB | 553.00 KiB/s, done.
Total 12 (delta 0), reused 0 (delta 0)
remote: Powered by GITEE.COM [GNK-6.2]
To gitee.com:P65782152/java_study_heima.git
6263f15..f58c100 master -> master
git checkout branch #切换分支
git checkout -b new_brach #新建分支且切换到新分支
git checkout -d brach #删除分支
git branch # 查看所有的分支 *为当前分支
git merge branch # 合并分支
git branch -m|-M oldbranch newbranch #重命名分支
$ git branch
* master
$ git checkout -b dev
$ git branch
* dev
master
#创建文件2
$ touch 2.txt
$ git add 2.txt
$ git commit -m '分支dev的提交文件2'
$ git ls-files
.gitignore
1.txt
2.txt
#切换到master分支
$ git checkout master
Switched to branch 'master'
$ git ls-files
.gitignore
1.txt
#可以看到主分支是没有2.txt文件的,所以我们可以执行合并 merge
$ git merge dev
Updating f58c100..6cf309b
Fast-forward
2.txt | 0
1 file changed, 0 insertions(+), 0 deletions(-)
create mode 100644 2.txt
$ git ls-files
.gitignore
1.txt
2.txt
git branch -a #查看所有的分支
git push origin beanchname #推送本地分支到远程
gti push origin :remotebranch #删除远程分支(本地分支还在)
git checkout -b localbranch origin/remotebranch # 拉取远程的分支并且在本地创建分支
tag
idea中创建仓库->add->commit->remote->push