GIT 使用

git 操作

https://www.cnblogs.com/mengdd/p/3447464.html

廖雪峰的git网站
https://www.liaoxuefeng.com/wiki/1252599548343744/1260452774408320

git remote add origin <origin>
git remote add origin https://gitee.com/guo_fei/gf_file.git

此时如果origin的master分支上有一些本地没有的提交,push会失败.

  • 刷新线上分支情况
    git fetch origin
    查看线上列表
    git branch -a
    查看本地列表
    git branch --list

所以解决的办法是, 首先设定本地master的上游分支:

git branch --set-upstream-to=origin/master
git push --set-upstream origin master

然后pull:

git pull --rebase
git pull <remote> <branch>
git pull https://gitee.com/guo_fei/gf_file.git master

最后再push:

git push

https://blog.csdn.net/wh_19910525/article/details/7784901
缓存代码
git stash
git stash save "work in progress for foo feature"
获取上一次缓存的代码
git stash pop
命令可以将当前的Git栈信息打印出来
git stash list
可以将指定版本号为stash@{1}的工作取出来
git stash apply stash@{1}
来将栈清空
git stash clear
克隆代码到本地
git clone <remote>

https://blog.csdn.net/qq_23864697/article/details/80102480
git 放弃本地修改,强制拉取更新
git reset --hard origin/master

当前配置为本地环境的配置

由于每个人可能存在不同的配置情况 , 修改该目录文件需要排除修改文件的上传,执行命令:
git update-index --assume-unchanged src\main\resources\properties\local\redis.properties

如果需要恢复文件为排除状态:
git update-index --no-assume-unchanged src\main\resources\properties\local\redis.properties

git

  • git命令:

      查看分支列表: `git branch -a`
      查看分支列表: `git branch --list`
      查看分支:`git branch` 同上
      创建分支:`git branch <name>`
      切换分支:`git checkout <name>`
      创建+切换分支:`git checkout -b <name>`
      合并某分支到当前分支:`git merge <name>`
      删除分支:`git branch -d <name>`
      默认分支管理,需要去对应的托管网站,登录账号,然后进行设置。
    
  • 新建git分支

    # 查看本地分支列表
    git branch --list
    
    # 查看所有分支列表
    git branch -a
    
    # 新建分支
    git branch <branch>
    
    # 切换分支
    git checkout <branch>
    
    # 和本地分支建立联系
    git branch --set-upstream-to=origin/<old branch> <new branch>
    
    # 和远程分支建立联系
    git pull <remote> <branch>
    
    # 推到远程新分支
    git push origin HEAD:test
    
    # 推到远程已有分支或新分支
    git push origin <branch>
    
  • git修改推送使用的用户名

    修改用户名

    # 获取当前的用户名
    git config user.name
    
    # 修改用户名
    git config --global user.name "新改用户名"
    
  • git 控制台保存账号密码

    在idea中设置记住git的用户名和密码

    git config --global credential.helper store
    

git 修改本地密码
在控制面板————用户账号————windows凭证管理————编辑

  • 强行覆盖
开发时,对于本地的项目中修改不做保存操作(或代码改崩),可以用到Git pull的强制覆盖,具体代码如下:

git fetch --all
git reset --hard origin/master
git pull //可以省略

git fetch 指令是下载远程仓库最新内容,不做合并
git reset 指令把HEAD指向master最新版本
  • 清缓存
    git .ignore 清除缓存方法

    D:\workspace\mark_doc>git rm -r --cached .
    rm '.gitignore'
    rm 'README.md'
    rm 'markdown/database/存储过程.md'
    
    Warning: Your console font probably doesn't support Unicode. If you experience strange characters in the ou
    tput, consider switching to a TrueType font such as Consolas!
    
    D:\workspace\mark_doc>git add .
    warning: LF will be replaced by CRLF in .idea/inspectionProfiles/Project_Default.xml.
    The file will have its original line endings in your working directory.
    
    D:\workspace\mark_doc>
    

    git 新增忽略提交文件

    git rm -r --cached .
    git add .
    git commit -m  .gitignore
    git status
    
      - mkdir [文件夹名]
      - git init
      - git init [文件夹名]
      - git clone [gitUrl]
      - git clone [gitUrl] [本地地址及名称]
      - git status
      - git status -s
          -s,获得简短的结果输出
      - git diff
      - git diff --cached
      - git diff HEAD
      - git diff --stat
      - git add .
      - git add [文件名]
    
      - git commit
      - git reset HEAD
          用于取消已缓存的内容。(已经被add,可以取出commit行列)
          执行 git reset HEAD 以取消之前 git add 添加,但不希望包含在下一提交快照中的缓存。
    
      - git rm [文件名]
          直接删除文件
      - git rm --cache [文件名]
      - git rm -f [文件名]
      - git rm -r *
          可以递归删除,即如果后面跟的是一个目录做为参数,则会递归删除整个目录中的所有子目录和文件
      - git mv del.md test.md 命令用于移动或重命名一个文件、目录、软连接。(将del.md重命名为test.md)
    
      git 分支
      - git branch [branchName] 创建分支命令
      - git checkout [branchName] 切换分支命令
      - git merge [branchName] 将branchName分支合并到当前分支
    
      - git branch 列出本地分支列表
      - git branch --list 同上
      - git
      - ls 列出文件列表
      - ll 列出文件列表(包含权限)
      - git checkout -b [newBranchName] 创建newBranchName并切换到新分支
      - git branch -a 查看所有分支列表
      - git branch -d [branchName] 删除分支
      - git log 查看提交历史
      - git log --oneline 查看历史记录简介版本
      - git log --oneline --graph 查看log树
      - git log --reverse --oneline
      也可以用 '--reverse'参数来逆向显示所有日志。
    
      git log --author=guofei --oneline -5
      只查看guofei提交的日志,5行
      --no-merges 选项以隐藏合并提交
      - vim [文件名] 编辑某文件
      - git tag -a v1.0 给当前提交添加标签
      - git tag -a v0.9 [da6835e] 给某个提交插入标签
      - git tag 查看tag
      - git tag -a test
      - git tag -d v1.0 删除标签
      - git show v1.0 查看v1.0提交的内容
    

    git-菜鸟教程

git 创建git仓库到指定目录

mayn@DESKTOP-L7PRRDN MINGW64 ~/Desktop/test_git
$ git init repo
Initialized empty Git repository in C:/Users/mayn/Desktop/test_git/repo/.git/

mayn@DESKTOP-L7PRRDN MINGW64 ~/Desktop/test_git
$

git clone 代码到当前目录以... 命名文件夹

mayn@DESKTOP-L7PRRDN MINGW64 ~/Desktop/test_git
$ git clone https://gitee.com/guo_fei/gf_learn.git learn
Cloning into 'learn'...
remote: Enumerating objects: 837, done.
remote: Counting objects: 100% (837/837), done.
remote: Compressing objects: 100% (676/676), done.
remote: Total 837 (delta 337), reused 119 (delta 56)0 KiB/s
Receiving objects: 100% (837/837), 26.52 MiB | 315.00 KiB/s, done.
Resolving deltas: 100% (337/337), done.

mayn@DESKTOP-L7PRRDN MINGW64 ~/Desktop/test_git
$

查看git状态

mayn@DESKTOP-L7PRRDN MINGW64 ~/Desktop/test_git/learn (test)
$ git status
On branch test
Your branch is ahead of 'origin/test' by 1 commit.
  (use "git push" to publish your local commits)

nothing to commit, working tree clean
  • 上传本地代码到远程仓库
# 创建本地仓库
git init
# 添加所有文件到缓存里
git add .
# 提交本地代码到本地仓库
git commit -m <message>
# 解除现有的git仓库关联
git remote rm origin
# 添加新的git仓库关联
git remote add origin https://gitee.com/guo_fei/gf_netty.git
# 设置默认的推送参数(全部分支)
git config --global push.default matching
# 设置默认的推送参数(当前分支)
git config --global push.default simple
# 强制推送代码到远程仓库分支
git push -u origin master -f
# 拉取分支代码(idea 文件不变色)
git checkout master
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 212,542评论 6 493
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 90,596评论 3 385
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 158,021评论 0 348
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 56,682评论 1 284
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 65,792评论 6 386
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 49,985评论 1 291
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 39,107评论 3 410
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 37,845评论 0 268
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 44,299评论 1 303
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 36,612评论 2 327
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 38,747评论 1 341
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 34,441评论 4 333
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 40,072评论 3 317
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 30,828评论 0 21
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,069评论 1 267
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 46,545评论 2 362
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 43,658评论 2 350

推荐阅读更多精彩内容

  • git 使用笔记 git原理: 文件(blob)对象,树(tree)对象,提交(commit)对象 tree对象 ...
    神刀阅读 3,760评论 0 10
  • (预警:因为详细,所以行文有些长,新手边看边操作效果出乎你的预料) 一:Git是什么? Git是目前世界上最先进的...
    axiaochao阅读 1,927评论 1 8
  • 声明:这篇文章来源于廖雪峰老师的官方网站,我仅仅是作为学习之用 Git简介 Git是什么? Git是目前世界上最先...
    横渡阅读 3,946评论 3 27
  • 一:Git是什么? Git是目前世界上最先进的分布式版本控制系统。 二:SVN与Git的最主要的区别? SVN是集...
    傲慢二锅头阅读 411评论 0 0
  • 今天中午放学我和妈妈去公司写作业,我一会儿就写完了数学,我对妈妈说:“妈妈我的语文午写作业没有页了”,妈妈说:“你...
    王辰溪阅读 311评论 0 1