标签(空格分隔): git、github
实践1
1. 创建git仓库
初始化一个Git仓库,使用
git init
命令。
2. 工作区提交至缓存区
使用命令
git add <file>
,可反复多次使用,添加多个文件,
使用git add .
添加当前目录下全部文件;
3. 缓存区提交至本地仓库区
使用命令
git commit -m <message>
,完成。
4. 本地仓库区提交至远程仓库区
- 创建SSH key
ssh-keygen -t rsa -C "[email protected]"
- id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人。
- 要关联一个远程库,使用命令
git remote add origin git@server-name:path/repo-name.git
;- 关联后,使用命令
git push -u origin master
第一次推送master分支的所有内容;- 此后,每次本地提交后,只要有必要,就可以使用命令
git push origin master
推送最新修改;
5. 从远程仓库区到工作区
克隆一个本地库
git clone [email protected]:ool456/gitskills.git
Git支持多种协议,包括https,但通过ssh支持的原生git协议速度最快。
6. 从缓存区撤回工作区
场景1:当你改乱了工作区某个文件的内容,想直接丢弃工作区的修改时,用命令
git checkout -- file
。
场景2:当你不但改乱了工作区某个文件的内容,还添加到了暂存区时,想丢弃修改,分两步,第一步用命令git reset HEAD <file>
,就回到了场景1,第二步按场景1操作。
场景3:已经提交了不合适的修改到版本库时,想要撤销本次提交,参考版本回退
一节,不过前提是没有推送到远程库。
7. 代码回滚
直接丢弃工作区的修改时,用命令
git checkout -- file
。
知识
要随时掌握工作区的状态,使用
git status
命令。
如果git status
告诉你有文件被修改过,用git diff
可以查看修改内容。
git log --pretty=oneline
HEAD指向的版本就是当前版本,因此,Git允许我们在版本的历史之间穿梭,使用命令
git reset --hard commit_id
。
穿梭前,用
git log
可以查看提交历史,以便确定要回退到哪个版本。
要重返未来,用
git reflog
查看命令历史,以便确定要回到未来的哪个版本。