本文是对《GitHub入门与实践》一本书的总结和归纳,方便日后查看Git
各种命令的使用
git config --global user.name # 姓名
git config --global user.email # 邮箱
让输出命令具有更好的可读性:
$ git config --global color.ui auto
GitHub上连接已有仓库是通过SSH Key来进行的,创建SSH Key:
$ ssh-keygen -t rsa -C
两个重要的文件:
在GitHub中添加公开密钥,就可以用私有密钥来访问的
$ cat ~/.ssh/id_rsa.pub
完成设置之后,用手中的私有密钥与GitHub进行通信:
$ ssh -T git@github.com
下面是实际操作部分:
新建一个git上的\color{red}{远程仓库},见下图,不要勾选初始化的read.me文件
在本地新建一个和远程仓库同名字的本地仓库,进行初始化
git init # 生成.git目录
git status
向缓存区添加文件。上面的栗子中有使用git add
命令。缓存区是提交前的一个临时区域。
提交指的是激励工作树中所有文件的当前状态。通过参数m
可以加上本次的提交信息。还可以修改提交信息。
git commit -m "first commit"
git commit --amend "重新提交"
将上面的两个动作同时进行的语句
git commit -am "添加和提交同时进行"
q
即可退出git log
在后面直接跟上文件名称即可
如果想看到提交带来的改动,加上参数-p
。
$ git log -p README.md
查看当前仓库执行过的操作日志
只要不进行Git的GC(Garbage Collection,垃圾回收),就可以通过日志随意调取近期的历史状态。
前面表示的是哈希值。哈希值只要输入4位以上就可以执行的
git diff
查看更改前后的差别
git diff head # 查看和最新提交的差别
养成好的习惯:在执行git commit命令之前,先执行git diff命令,查看本次提交和上次提交的差别,确认完毕再提交
master分支是git的主分支,其他分支都是以这个分支为中心进行的。
git branch # 分支名列表显示,同时显示现在所处的分支
git branch -a # 同时显示远程仓库和本地仓库的分支信息
当前只有master分支,星号表示当前所处的分支
git checkout -b feature-A # 创建的同时切换到分支feature-A
上面?的语句等同于:
git branch feature-A # 创建分支
git checkout feature-A # 切换分支
git checkout - # 短横线表示切换到上一个分支
git checkout master # 先切换到主分支
git merge --no-ff feature-A # 合并分支:创建合并并提交,记录本次合并
用图表的形式输出提交日志,非常直观
git log --graph
Git的另一个特征是可以灵活地操作历史版本。
要让仓库的HEAD、暂存区、当前工作树回溯到指定状态,需要使用git reset --hard
命令。
需要目标时间点的哈希值。什么是哈希值???
git reset --hard 9154998...... # 恢复到该时间点的状态
使用场景:如果发现已经提交的内容中有错误(拼音、内容等小错误),可以提交一个修改,将这个修改包含到前一个提交之中,压缩成一个历史记录
git rebase -i HEAD~2 # 压缩最近的两个历史记录
git log --graph # 树形查看提交日志
Git是分散性版本管理系统。为了防止和其他仓库混淆,远程的仓库名尽量保持和本地仓库相同
创建远程仓库的时候不要勾选添加初始化文件
现在假设有个test的本地仓库,现在创建了一个同名的远程仓库,将通过如下的语句将该其设置成本地仓库的远程仓库
git remote add origin git@github.com:username/test.git
将当前分支下本地仓库中的内容推送到远程仓库中,使用如下语句:
git push -u origin master # -u参数是指在推送的同时,将origin仓库的master分支设置成本地仓库当前分支的上游
-u参数是指在推送的同时,将origin仓库的master分支设置成本地仓库当前分支的上游。好处:将来能够直接从远程仓库拉取:
git pull
如果不是推送到master分支,比如是feature-D
git checkout -b feature-D # 先切换到该分支
git push -u origin feature-D # 推送该分支
默认处在maste分支下面
git clone "仓库地址"
假设远程有个分支feature-A,我们想获取该分支下的内容:
git checkout -b feature-A origin/feature-A # -b后面的feature-A 是本地的分支,和远程同名
# 修改内容之后进行推送
git push
假设本地中有个分支feature-A,想把它更新到最新远程仓库的状态
git pull origin feature-A
$ brew install hub
$ echo 'export PATH=“~/bin:$PATH”'
>> ~/.bash_profile
$ hub --version # 查看版本
$ vim /.bash_profile
# add
eval "$(hub alias -s)"