Ubuntu系统中Git客户端的安装与基本命令使用教程
Ubuntu系统中Git客户端的安装与基本命令使用教程
发布时间:2016-12-27 来源:查字典编辑
摘要:安装gitsudoapt-getinstallgitgitconfig命令的--global参数,用了这个参数,表示你这台机器上所有的Git...

安装git

sudo apt-get install git

git config命令的--global参数,用了这个参数,表示你这台机器上所有的Git仓库都会使用这个配置,当然也可以对某个仓库指定不同的用户名和Email地址

git config --global user.name "Your name"

git config --global user.email "email@XX.com"

创建版本库repository

首先找一个地方,创建一个空目录,然后使用git init 命令

git init

将文件放到建好的仓库目录下使用如下命令

用add将文件添加到仓库

git add filename

用commit告诉git, 把文件提交到仓库

git commit -m "input something "

git commit命令执行成功后会告诉你,文件被改动的情况。commit可以一次提交很多文件

查看仓库历史

git status命令可以让我们时刻掌握仓库当前的状态

git status

git diff filename 可以查看该文件时如何被修改的

版本回退

用git log 命令查看历史记录

git reset --hard +版本号

其中**HEAD表示当前版本,HEAD^表示上一个版本,HEAD^^表示上上一个版本 也可写成HEAD~100上一百个版本。版本号不用全写,写前几位就行。git会自动帮你找到

用git reflog 可以查看你每一次的操作记录

撤销修改

使用

git checkout --xxx.txt

命令git checkout -- readme.txt意思就是,把readme.txt文件在工作区的修改全部撤销,这里有两种情况:

一种是readme.txt自修改后还没有被放到暂存区,现在,撤销修改就回到和版本库一模一样的状态;

一种是readme.txt已经添加到暂存区后,又作了修改,现在,撤销修改就回到添加到暂存区后的状态。

总之,就是让这个文件回到最近一次git commit或git add时的状态

使用git reset HEAD +filename可以把暂存区的修改撤销掉,重新放回工作区。git reset命令既可以回退版本,也可以把暂存区的修改撤销掉

删除文件

** 使用git rm filename**删除文件

若删错了,可用 git checkout -- filename进行恢复

查看、切换、创建和删除分支

git br -r # 查看远程分支

git br <new_branch> # 创建新的分支

git br -v # 查看各个分支最后提交信息

git br --merged # 查看已经被合并到当前分支的分支

git br --no-merged # 查看尚未被合并到当前分支的分支

git co <branch> # 切换到某个分支

git co -b <new_branch> # 创建新的分支,并且切换过去

git co -b <new_branch> <branch> # 基于branch创建新的new_branch

git co $id # 把某次历史提交记录checkout出来,但无分支信息,切换到其他分支会自动删除

git co $id -b <new_branch> # 把某次历史提交记录checkout出来,创建成一个分支

git br -d <branch> # 删除某个分支

git br -D <branch> # 强制删除某个分支 (未被合并的分支被删除的时候需要强制)

分支合并和rebase

git merge <branch> # 将branch分支合并到当前分支

git merge origin/master --no-ff # 不要Fast-Foward合并,这样可以生成merge提交

git rebase master <branch> # 将master rebase到branch,相当于:

git co <branch> && git rebase master && git co master && git merge <branch>

Git暂存管理

git stash # 暂存

git stash list # 列所有stash

git stash apply # 恢复暂存的内容

git stash drop # 删除暂存区

远程仓库

创建SSH key

ssh-keygen -t rsa -C "email@xx.com"

如果一切顺利的话,可以在用户主目录里找到.ssh目录,里面有id_rsa和id_rsa.pub两个文件,这两个就是SSH Key的秘钥对,id_rsa是私钥,不能泄露出去,id_rsa.pub是公钥,可以放心地告诉任何人

登陆GitHub,打开“Account settings”,“SSH Keys”页面:

然后,点“Add SSH Key”,填上任意Title,在Key文本框里粘贴id_rsa.pub文件的内容

将本地仓库推送到GitHub仓库

git remote add origin git@github.com:pastqing/wangdao.git

git push -u origin mastercd

由于远程库是空的,我们第一次推送master分支时,加上了-u参数,Git不但会把本地的master分支内容推送的远程新的master分支,还会把本地的master分支和远程的master分支关联起来,在以后的推送或者拉取时就可以简化命令

此后,每次本地提交后,只要有必要,就可以使用命令git push origin master推送最新修改

从远程仓库克隆

git clone git@github.com:pastqing/wangdao.git

查看提交记录

git log

git log <file> # 查看该文件每次提交记录

git log -p <file> # 查看每次详细修改内容的diff

git log -p -2 # 查看最近两次详细修改内容的diff

git log --stat #查看提交统计信息

推荐文章
猜你喜欢
附近的人在看
推荐阅读
拓展阅读
相关阅读
网友关注
最新Ubuntu/Debian学习
热门Ubuntu/Debian学习
操作系统子分类