首先进入一个目录之后,使用这个命令是先初始化一个git仓库
git init 它会默认创建一个名为master的分支
下面这个用于查看是否有修改的文件,如果有就会报红
git status
下面这个用于查看文件修改的细节
git diff test.txt
下面这个是提交到暂存区
git add test.txt
下面这个是提交修改,记住每操作一次都要进行add 和commit
git commit -m "提交信息"
以列表的形式展示所有分支
git branch -a
切换分支
git checkout branchname 分支名称,用于切换分支 发现每次切换分支,内部的仓库内容会随之发生改变
创建新的分之
git checkout -b new-dev
用来查看历史提交,可以根据commit_id来回退到历史提交
git log
强制回退指定版本,回退后 一旦提交 不可逆
git reset --harh commit_id
已经修改文件之后,但是还没有add提交,可以通过下面命令回退 撤销修改
git checkout -- test.txt
若干修改文件之后,已经 add 了,但是还没有commit,那么可以先取消暂存 然后回退
git reset HEAD test.txt
git checkout -- test.txt
如果需要删除git库中的文件
git rm test.txt 表示删除库中文件,需要commit完成命令
负责直接回退到历史最近版本
记住 git status 是用来查看暂存区的命令
用它可以查看所有被修改的文件状态,如果为绿色则可以提交,红色需要先 add 再提交
github远程仓库使用
如何链接远程仓库,并将自己的本地仓库上传到远程仓库管理
首先将本机的sshkey添加到github账号
ssh-keygen -t rsa -C "youremail@example.com"
将生成的.ssh里面的id_rsa.pub里面的内容复制到sshkey的值里面 只是使用ssh上传仓库的必备条件
然后新建一个github仓库,然后使用ssh的方式将本地仓库push到远程仓库
git remote add origin git@github.com:aeasringnar/newfile.git
注意如果这里初夏错误那么就git remote rm origin后重新上传
最后
git push -u origin master 将本地仓库直接push到远程仓库(这里是将master分支上传)
先创建远程仓库然后克隆到本地进行协作开发。
git clone git@github.com:aeasringnar/gitskills.git
克隆到本地
然后修改里面文件之后,可以
git add filename
git commit -m "描述"
git push -u origin master 推送修改到远程仓库
分支的合并,有一种情况会发生冲突,当每个分支都有自己的提交的时候就会产生冲突,需要手动修改这些冲突之后再次提交即可,
注意:不产生冲突的合并,不需要提交,直接删除无用分支即可
回到主分支后的,合并命令
git merge (branchname)
如果有冲突,手动将冲突的地方修改之后再次提交,
git add test.txt
git commit -m "conflict fixed"
git log --graph --pretty=oneline --abbrev-commit这个可以查看分支的合并情况
git log --graph 查看分支合并图
最后,删除无用的分支
git branch -d newtest
git merge --no-ff -m "merge with no-ff" branchname 实际开发中的合并
在实际开发中,我们应该按照几个基本原则进行分支管理:
首先,master分支应该是非常稳定的,也就是仅用来发布新版本,平时不能在上面干活;
那在哪干活呢?干活都在dev分支上,也就是说,dev分支是不稳定的,到某个时候,比如1.0版本发布时,再把dev分支合并到master上,在master分支发布1.0版本;
你和你的小伙伴们每个人都在dev分支上干活,每个人都有自己的分支,时不时地往dev分支上合并就可以了。
合并分支时,加上–no-ff参数就可以用普通模式合并,合并后的历史有分支,能看出来曾经做过合并,而fast forward合并就看不出来曾经做过合并。
多人协作
工作中,首先建立一个空的远程仓库,然后将本地的仓库全部上传到远程仓库,注意将主要分支和开发分支全部上传。
当你从远程仓库克隆时,实际上Git自动把本地的master分支和远程的master分支对应起来了,并且,远程仓库的默认名称是origin。
要查看远程库的信息,用git remote:
$ git remote
origin
或者,用git remote -v显示更详细的信息:
$ git remote -v
origin git@github.com:michaelliao/learngit.git (fetch)
origin git@github.com:michaelliao/learngit.git (push)
上面显示了可以抓取和推送的origin的地址。如果没有推送权限,就看不到push的地址。
推送分支
推送分支,就是把该分支上的所有本地提交推送到远程库。推送时,要指定本地分支,这样,Git就会把该分支推送到远程库对应的远程分支上:
$ git push origin master
抓取分支
多人协作时,大家都会往master和dev分支上推送各自的修改。
现在,模拟一个你的小伙伴,可以在另一台电脑(注意要把SSH Key添加到GitHub)或者同一台电脑的另一个目录下克隆:
$ git clone git@github.com:michaelliao/learngit.git
Cloning into 'learngit'...
remote: Counting objects: 46, done.
remote: Compressing objects: 100% (26/26), done.
remote: Total 46 (delta 16), reused 45 (delta 15)
Receiving objects: 100% (46/46), 15.69 KiB | 6 KiB/s, done.
Resolving deltas: 100% (16/16), done.
当你的小伙伴从远程库clone时,默认情况下,你的小伙伴只能看到本地的master分支。不信可以用git branch命令看看:
$ git branch
* master
现在,你的小伙伴要在dev分支上开发,就必须创建远程origin的dev分支到本地,于是他用这个命令创建本地dev分支:
$ git checkout -b dev origin/dev
现在,他就可以在dev上继续修改,然后,时不时地把dev分支push到远程:
$ git commit -m "add /usr/bin/env"
[dev 291bea8] add /usr/bin/env
1 file changed, 1 insertion(+)
$ git push origin dev
Counting objects: 5, done.
Delta compression using up to 4 threads.
Compressing objects: 100% (2/2), done.
Writing objects: 100% (3/3), 349 bytes, done.
Total 3 (delta 0), reused 0 (delta 0)
To git@github.com:michaelliao/learngit.git
fc38031..291bea8 dev -> dev