安装

下载

下载页面:全平台

本地配置

git config --global user.name "tianyun"

git config --global user.email "tianyunperfect@163.com"

创建用户凭证ssh

#windows下:

ssh-keygen.exe -t rsa -C "tianyunperfect@163.com"

#mac下

ssh-keygen -trsa -C "tianyunperfect@163.com"

忽略文件

所有语言的忽略文件

java忽略文件

  • 忽略规则
# 注释

# 具体文件
dlldata.c # 通配符
*.suo # 复杂情况
[Dd]ebug/
x64/
[Tt]est[Rr]esult*/
  • 全局忽略

先切换到用户目录

# window
touch .gitignore_global # mac
cd ~
touch .gitignore_global
  • 本地忽略

在git目录下,创建.ignore文件即可

  • 忽略规则使生效
git config --global core.excludesfile ~/.gitignore_global

git rm -r --cached . //清空缓存,后面需要添加所有并提交

基础操作

新建仓库

# 初始化
git init
# 关联远程仓库
git remote add origin git@server-name:path/repo-name.git
# 强制推送
git push -u origin master -f

克隆仓库

git clone git@github.com:tianyunlaila/tianyunlaila.github.git

获取更新

  • 直接覆盖(常用)
git pull origin master
  • 强制覆盖(删除一切不一样的)
git fetch --all
git reset --hard origin/master
git pull
  • 手动查看不一样,再覆盖
git fetch origin master:tmp  #先获取保存到tmp
git diff tmp #查看区别
git merge tmp #再融合

推送更新

git add . //添加修改

git commit -m "message" //提交

git push origin master //推送修改的内容

git status //查看状态

git diff //修改内容

查看历史

git log //可以查看提交历史,以便确定要回退到哪个版本。

git reflog //查看命令历史,以便确定要回到未来的哪个版本。

# 美化历史:
git config --global alias.lg "log --color --graph --pretty=format:'%Cred%h%Creset -%C(yellow)%d%Creset %s %Cgreen(%cr) %C(bold blue)<%an>%Creset' --abbrev-commit" 以后git lg就可以显示branch变化了

版本回退

git checkout . #本地所有修改的。没有的提交的,都返回到原来的状态

git stash #把所有没有提交的修改暂存到stash里面。可用git stash pop恢复到当前状态。

git reset --hard HASH #返回到某个节点,不保留修改。

git reset --soft HASH #返回到某个节点。保留修改

分支

创建新分支:git branch branchName

切换到分支:git checkout branchName

创建并切换到分支:git checkout -b branchName

合并某分支到当前分支:git merge branchName

删除分支:git branch -d branchName

别名

git config --global alias.co checkout
git config --global alias.ci commit
git config --global alias.br branch # 使用
git co
git ci

linux服务器

# 安装git
yum -y install git # 添加git用户
adduser git # 收集所有需要登录的用户的公钥,就是他们自己的id_rsa.pub文件,把所有公钥导入到/home/git/.ssh/authorized_keys文件里,一行一个。 mkdir /home/git/.ssh/
touch /home/git/.ssh/authorized_keys cat >> /home/git/.ssh/authorized_keys << EOF
ssh-rsa AAAAB3NzaC1yc2EAAAADAQABAAABAQC7p3r2VGOEE8JI4jUD4vuWj7QxXsZGne5AUcPXaHcCfX0ZarATxR2EeqEwTJvUAz0t/m/wq1DzugasUFWrUvUmEEBVh8RXXXXX@163.com
EOF # 仓库暂定放在/home/git目录下
# 创建git仓库
git init --bare sample.git # 修改权限
chown -R git:git sample.git # 禁用shell登录:
vim /etc/passwd
git:x:1001:1001:,,,:/home/git:/bin/bash 改为:
git:x:1001:1001:,,,:/home/git:/usr/bin/git-shell # 客户机clone即可
git clone git@192.168.63.128:/home/git/sample.git

公钥管理工具:gitosis

权限管理工具:gitolite

疑难问题

清除历史大文件

工作中不可避免引用一些大文件,当我们不需要时仍会占用大量内存,所以,必须清除!

# 找出排名前五的大文件
git verify-pack -v .git/objects/pack/pack-*.idx | sort -k 3 -g | tail -5 # 找出对应的文件名
git rev-list --objects --all | grep 8f10eff91bb6aa2de1f5d096ee2e1687b0eab007 # 删除记录
git filter-branch --index-filter 'git rm --cached --ignore-unmatch 文件名(可以*)'
rm -Rf .git/refs/original \$ rm -Rf .git/logs/ \$ git gc # 彻底删除!!!
git prune # 查看空间
git count-objects -v
或者du -ah

git操作合集的更多相关文章

  1. SQL用法操作合集

    SQL用法操作合集   一.表的创建 1.创建表 格式: 1 CREATE TABLE 表名 2 (列名 数据类型(宽度)[DEFAULT 表达式][COLUMN CONSTRAINT], 3 ... ...

  2. git常用操作合集

    基本操作git status 查看文件处于什么状态 git status -s 带上-s参数,可以以更紧凑的格式输出文件状态信息 git add 开始追踪该文件或者暂存已修改的文件. .gitigno ...

  3. git命令合集及github的克隆推送

    安装git 初始化仓库 提交相关 撤销相关 远程推送 分支相关 其他 遇到的错误 github的克隆上传 此文章只是对命令的一个统计,起备忘和复习git只是的作用,不建议从没接触过git的同学通过它来 ...

  4. git命令合集

    ##快捷键 ##一. 快捷键 1. 清屏快捷键 control+L 2. vim快捷操作 * control+b 往上翻页 * Control+f 往下翻页 * shift+g 回到末尾 3. oh ...

  5. javascript 最全面的数组操作合集

    一.数组添加.删除.替换.截取操作 1.arr.unshift(1) 在数组头部添加一个元素 1 (直接改变原数组,返回值为添加元素后数组的length) 2.arr.shift() 在数组的头部删除 ...

  6. Java文件复制删除操作合集

    import java.io.*; public class FileOperate { public FileOperate() { } /** * 新建目录 * @param folderPath ...

  7. git使用合集

    1.git 克隆时重命名本地文件夹或目录 如:git clone https://github.com/torvalds/linux.git linux_kernel 2.git查看tag git t ...

  8. 插头DP智障操作合集

    今天一共四道插头DP[其实都差不多],智障错误出了不下五个:D 来,让我好好数落我自己一下 直接写代码注释里吧 Eat the Trees #include<iostream> #incl ...

  9. Git 经常使用命令合集

    ====== Git 经常使用命令合集 ====== === 1.Git 文档 ===     Git 中文文档观看地址:http://git.oschina.net/progit/      === ...

随机推荐

  1. win7 免安装MariaDB

    1.  官网下载MariaDB的windows版本 地址:https://downloads.mariadb.org/mariadb/10.0.17/ 目前最新版本是10.0.17 2.  下载完成后 ...

  2. res/raw与assets目录的区别

    1.相同点: 两者都会原封不动的保存在apk包中,不会被编译成二进制码. 2.不同点: raw目录下只能存放文件,不能存放下一级的文件夹,而assets可以存放下一级的文件夹. raw目录下的资源会映 ...

  3. Git学习系列之Git基本操作拉取项目(图文详解)

    前面博客 Git学习系列之Git基本操作推送项目(图文详解) 当然,如果多人协作,或者多个客户端进行修改,那么我们还要拉取(Pull ... )别人推送到在线仓库的内容下来. 大神们是不推荐使用 pu ...

  4. 机器学习 损失函数(Loss/Error Function)、代价函数(Cost Function)和目标函数(Objective function)

    损失函数(Loss/Error Function): 计算单个训练集的误差,例如:欧氏距离,交叉熵,对比损失,合页损失 代价函数(Cost Function): 计算整个训练集所有损失之和的平均值 至 ...

  5. 文本相似度分析(基于jieba和gensim)

    基础概念 本文在进行文本相似度分析过程分为以下几个部分进行, 文本分词 语料库制作 算法训练 结果预测 分析过程主要用两个包来实现jieba,gensim jieba:主要实现分词过程 gensim: ...

  6. QT下载地址大全

    1. 所有Qt版本下载地址: http://download.qt.io/archive/qt/ 2. 所有Qt Creator下载地址: http://download.qt.io/archive/ ...

  7. OpenStack Object Storage(Swift)概述

    概述 OpenStack Object Storage(Swift)是OpenStack开源云计算项目的子项目之一,被称为对象存储,提供了强大的扩展性.冗余和持久性. Swift并不是文件系统或者实时 ...

  8. HA_Mirror 数据库镜像

    环境准备: 虚拟机3台,INTER-DC, INTER-SQLA, INTER-SQLB 创建域帐户 INTER\MSSQLSERVER.SERVICE,分别添加到INTER-SQLA和INTER-S ...

  9. visual studio清理nuget包缓存

    最近在使用nuget包的时候发现一个问题.昨天我组长明明发了一个新版本的包上去,可在我电脑上死活找不到这个新版本的包.刷新,重启vs,重启电脑,好长时间才出来.今天又碰到这个问题了,在同事电脑上都能搜 ...

  10. ashx 绝对路径得到物理路径

    //先得到模板页所在的路径 string phyPath = context.Server.MapPath("/p02style.html"); //得到模板的所有内容 strin ...