学者谷

位置:首页 > 生活范文 > 休闲杂谈

Ubuntu系统中Git客户端的安装及使用教程

安装git

Ubuntu系统中Git客户端的安装及使用教程

sudo apt-get install git

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

git config --global "Your name"

git config --global l "

创建版本库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

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

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

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

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

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

删除文件

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

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

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

git br -r # 查看远程分支

git br# 创建新的分支

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

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

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

git co# 切换到某个分支

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

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

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

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

git br -d# 删除某个分支

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

分支合并和rebase

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

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

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

git co&& git rebase master && git co master && git merge

Git暂存管理

git stash # 暂存

git stash list # 列所有stash

git stash apply # 恢复暂存的内容

git stash drop # 删除暂存区

远程仓库

创建SSH key

ssh-keygen -t rsa -C "

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

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

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

将本地仓库推送到GitHub仓库

git remote add origin :pastqing/

git push -u origin mastercd

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

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

从远程仓库克隆

git clone :pastqing/

查看提交记录

git log

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

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

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

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