git基本使用


git下载 搭建git服务器

git基本概念

基本概念:git有工作区与暂存区的概念,工作区及创建git仓库的系统目录(就是你在电脑里能看到的目录)工作区有一个隐藏目录.git,这个不算工作区,而是Git的版本库。 Git的版本库里存了很多东西,其中最重要的就是称为stage(或者叫index)的暂存区,还有Git为我们自动创建的第一个分支master,以及指向master的一个指针叫HEAD。

我们把文件往Git版本库里添加的时候,是分两步执行的:

第一步是用git add把文件添加进去,实际上就是把文件修改添加到暂存区;

第二步是用git commit提交更改,实际上就是把暂存区的所有内容提交到当前分支。

因为我们创建Git版本库时,Git自动为我们创建了唯一一个master分支,所以,现在,git commit就是往master分支上提交更改。 每次准备提交前,先用git status 看下,是不是都已暂存起来了,然后再运行提交命令git commit 另外,git commit 加上-a 选项,Git就会自动把所有已经跟踪过的文件暂存起来一并提交,从而跳过git add 步骤。


git样例
  1. 首先,选择一个合适的地方,创建一个空目录 mkdir learngit

  2. 通过git init命令把这个目录变成Git可以管理的仓库: cd learngit git init

  3. 添加(修改)文件(可连续多次修改,一次提交) git add readme.txt git add . 添加当前目录所有文件,--force强制添加
  4. 提交修改 git commit -m "add readme"git commit -a直接提交
  5. 查看日志 git reflog或者git log
  6. 查看文件状态 git status可查看是否提交到了工作区
  7. 版本回退reset、撤销修改checkout git reset hard readme.txt 撤销修改暂存区 git reset --hard commit_id 可回退到指定版本,commit_id通过git reflog获取 git reset --hard HEAD^ 回退到上一版本
    首先,Git必须知道当前版本是哪个版本,在Git中,用HEAD表示当前版本,也就是最新的提交3628164...882e1e0(注意我的提交ID和你的肯定不一样),上一个版本就是HEAD^,上上一个版本就是HEAD^^,当然往上100个版本写100个^比较容易数不过来,所以写成HEAD~100。

    穿梭前,用git log可以查看提交历史,以便确定要回退到哪个版本。
    要重返未来,用git reflog查看命令历史,以便确定要回到未来的哪个版本。

    git checkout -- readme.txt 把readme.txt文件在工作区的修改全部撤销 8. 删除文件(重命名) git rm readme.txt 删除工作区和暂存区 git rm --cached readme.txt 删除暂存区,不删工作区 git mv readme.txt readme.md 移动或重命名 9. 分支管理 git checkout -b dev git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:

    git branch dev --创建分支 git branch -d dev --删除分支 git checkout dev --切换分支 git merge dev --git merge命令用于合并指定分支到当前分支


git分支

首先,我们创建dev分支,然后切换到dev分支: git checkout -b dev git checkout命令加上-b参数表示创建并切换,相当于以下两条命令:

git merge dev --git merge命令用于合并指定分支到当前分支 git branch dev --创建分支 git branch -d dev --删除分支 git checkout dev --切换分支 git log dev ^master --查看 dev 有,而 master 中没有的

因为创建、合并和删除分支非常快,所以Git鼓励你使用分支完成某个任务,合并后再删掉分支,这和直接在master分支上工作效果是一样的,但过程更安全。

git stash --Git还提供了一个stash功能,可以把当前工作现场“储藏”起来,等以后恢复现场后继续工作。 git stash list --查看stash列表
Git把stash内容存在某个地方了,但是需要恢复一下,有两个办法: 一是用git stash apply恢复,但是恢复后,stash内容并不删除,你需要用git stash drop来删除;另一种方式是用git stash pop,恢复的同时把stash内容也删了:


git关联github
  1. 创建ssh key,以便关联远程仓库 ssh-keygen -t rsa -C "youremail@example.com"
  2. 关联一个远程库,使用命令: git remote add origin git@server-name:path/repo-name.git

  3. 关联后,使用命令git push -u origin master第一次推送master分支的所有内容;

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

  5. git remote或者git remote -v 查看远程仓库


git clone

git clone git@github.com:michaelliao/gitskills.git
- 实际上,Git支持多种协议,默认的git://使用ssh,但也可以使用https等其他协议。 - 使用https除了速度慢以外,还有个最大的麻烦是每次推送都必须输入口令,但是在某些只开放http端口的公司内部就无法使用ssh协议而只能用https。


标签管理

在Git中打标签非常简单,首先,切换到需要打标签的分支上,然后,敲命令 git tag <name>就可以打一个新标签,默认标签是打在最新提交的commit上的。

可以用git show <tagname>查看标签信息。 命令git tag <name>用于新建一个标签,默认为HEAD,最新提交的commit上;
git tag v0.9 "commit id"也可以指定一个commit id;
git tag -a <tagname> -m "blablabla..."可以指定标签信息;
git tag -s <tagname> -m "blablabla..."可以用PGP签名标签;
命令git tag可以查看所有标签。
命令git push origin <tagname>可以推送一个本地标签;
命令git push origin --tags可以推送全部未推送过的本地标签;
命令git tag -d <tagname>可以删除一个本地标签;
命令git push origin :refs/tags/<tagname>可以删除一个远程标签。


.gitignore的文件忽略设置

【例子】

忽略.o和.a文件

*.[oa]

忽略.b和.B文件,my.b除外

*.[bB] !my.b

忽略dbg文件和dbg目录

dbg

只忽略dbg目录,不忽略dbg文件

dbg/

只忽略dbg文件,不忽略dbg目录

dbg !dbg/

只忽略当前目录下的dbg文件和目录,子目录的dbg不在忽略范围内

/dbg


git常用命令

设置标识 git config --global user.name "Your Name" git config --global user.email "email@example.com"

git init --创建管理仓库,目录初始化 git add --创建跟踪文件/暂存文件 git status --检查当前文件状态 git commit --提交修改 git commit -a --不暂存,直接提交 git diff --比对文件 git reset --恢复 git rm --删除工作区和暂存区 git rm --cached --删除暂存区,不删工作区 git mv --移动或重命名 git log --查看日志 git log --pretty=oneline --简洁日志

用命令git add告诉Git,把文件添加到仓库: git add readme.txt

用命令git commit告诉Git,把文件提交到仓库 : git commit -m "wrote a readme file"

git status git diff git log 如果嫌输出信息太多,看得眼花缭乱的,可以试试加上--pretty=oneline参数: git log --pretty=oneline

Git提供了一个命令git reflog用来记录你的每一次命令

从工作区和暂存区删除 git rm 从暂存区删除 git rm --cached

git checkout -- file可以丢弃工作区的修改: $ git checkout -- readme.txt

列出master目录结构 git ls-tree master

git教程

git服务器搭建
  1. 安装gityum install git
  2. 创建用户useradd sopuy
  3. 在目录/home/sopuy/下执行git init --bare web.git,会生成一个web.git的目录
  4. 更改目录权限chown -R sopuy:sopuy web.git
  5. 禁用用户sopuyshell登录,修改/etc/passwd,修改为sopuy:x:501:501::/home/sopuy:/bin/git-shell
  6. 克隆远程仓库git clone git@server-ip:/home/sopuy/web.git
  7. 管理公钥:把每个人的公钥放到/home/sopuy/.ssh/authorized_keys

  8. 管理公钥可以使用Gitosis

  9. 管理权限可以使用gitolite