git知识总结

要知道

本地回退后,反悔了,可以恢复。前提是已经提交了,提交了就丢不了。

git reflog + git reset --hard commitId


以前git push不让推,就是没有对应关系。第一次推要setxxx参数。


前奏



设置用户名和邮箱,设置错了,可以重新输入,重新设置

git config --global user.name "gzy"

git config --global user.email "xxxx163.com"

查看用户名和邮箱。邮箱可以是不存在的邮箱

git config --global user.name

git config --global user.email

给指令设置别名 。自己无法用鼠标创建.开头的文件,可以用指令。必须设置在用户根目录下 ~/表示根路径下

1.创建.bashrc文件

touch ~/.bashrc

2.在.bashrc文件中输入如下内容

java 复制代码
#用于输出git提交日志

alias git-log ='git log --pretty=oneline --all --graph --abbrev-commit'

#用于输出当前目录所有文件及其基本信息

alias ll='ls -al'

3.打开gitBash , 执行. 告诉shell从~/.bashrc文件中读取并执行其中的命令

source ~/.bashrc

解决gitBash乱码问题

1.打开gitBash执行

java 复制代码
git config --global core.quotepath false

2.git安装目录下文件中修改文件,添加两行代码 git_home是git安装目录

java 复制代码
export LANG="zh_CN.UTF-8"
export LC_ALL="zh_CN.UTF-8"

初始化仓库

git init

查看内容 配置完别名的

ll

状态

我们的文件所在区域就是工作区

缓存区就是提交本地仓库之前的缓存区

工作区进入暂存区用add,暂存区进入仓库用commit。


git流程中的状态

untracked未跟踪:新创建的文件,还没有与git产生联系。

unstaged未暂存:修改已经有的文件,但是没有进入暂存区

staged已暂存:已经在暂存区。暂存区就是提交本地仓库之前的缓存区。

to be committed即将被提交:已经进入暂存区,还没被提交

命令

基础指令

touch file01.txt 创建文件

git status 查看状态

git add . 添加所有到暂存区

git commit -m "add file01" 提交 在本地提交了肯定丢不了

git log 查看日志

vi file01.txt(文件名) 键盘insert变为可编辑状态,esc退出,:wq退出保存

git reset --hard commitId 回退版本

git reflog 查看操作记录 可以查看历史,即使回退完,也可以返回 。查看已删除的记录

git-log 查看提交记录 这个是别名指令

当git add 不想将所有的文件都添加到缓存区时。

touch .gitignore 创建忽略文件 .固定名称

vi .gitignore insert :wq

输入 *.a 就是git add . 不会添加.a结尾的文件。

git clone 克隆

远端分支,也是一个分支。

git fetch origin master 抓取远端master到本地

git pull 拉取远端

推送远程

git remote add origin git@gitee.com:ayu--66/git_test.git 关联远程仓库 origin是远端分支名可以自定义,一般都默认是origin

git remote 查看是否有远程仓库

git push origin master 将master推到远程仓库,每次都这么写也可以 因为名称一致,所以省略了 :master

git push 推送远端 不让推,是因为不知道绑定关系,本地与远端。

git branch -vv 查看本地与远端的对应关系

git push --set-upstream origin master:master 设置对应关系 第一次推的时候要加setxxx

git push 有了对应关系就可以使用了。

分支

git branch 查看分支 head指向谁,谁就是当前分支

git branch dev01(分支名) 创建分支

git checkout dev01(分支名) 切换分支

git checkout -b dev02 切换并创建 没有这个分支就创建出来在切换。

git merge 分支名称(要合并的分支) 合并分支 合并到master,现在就要在master。

git branch -d b1 删除分支,需要做各种检查

git branch -D b1 强制删除 (删除的分支有内容没有完全合并到master上,-d就无法删除)

常用命令

git init

git clone 地址

git add .

git commit -m 'xxx'

git remote add origin 地址 与远程建立连接

git push origin master 不统一配置,每次都要这么写

git push --set-upstream origin master 统一建立关联

git push 建立关联后,就可以直接用了

git pull = git fetch + git merge 先抓取到本地,再合并也行。

git checkout 分支名

git checkout -b 分支名

git-log 别名日志 配置的

git merge

git status

git reset --hard commitId

本地解决冲突:

dev修改 file01文件 内容:abcdev

master修改file01文件 内容:abcmaster

切换到master,执行 git merge dev

冲突,合并失败。

此时,打开冲突文件file01。这个文件就变样了。

git无法合并,交给提交人来解决冲突。

找到冲突文件,解决后,重新提交。


远端解决冲突

远端与你本地不一致,远端被别人推送了,并且正好是你修改的那一行代码。

之所以产生冲突就是因为 git merge操作,合并操作,不知取你的还是他的。

git pull = git fetch + git merge。

这时候一样的操作,找到冲突的文件,进行修改(解决冲突) add commit 重新推送。

图1:B是本地的master进行了修改。A是远端,修改了master。

图2:B要推代码之前,先拉取(抓取+合并),此步骤会解决冲突。

图3:远端完成同步


两个人都有需求,改的是同一个文件。后推送的人会推送失败,产生冲突。这时候只需拉取,找到冲突文件,add,commit,push,就可以了。A只需再pull就可以和远端一样了。

解决冲突的本质操作

找到冲突文件,本地进行修改,然后add ,commit ,再推送

每次推送前,要进行pull操作。 不拉取有可能会覆盖别人代码(但是git会有提示不让推送)

ssh仓库

ssh-keygen -t rsa 生成秘钥 一路回车

cat ~/.ssh/id_rsa.pub 查看秘钥 复制 粘贴到这里。

ssh -T git@gitee.com 验证秘钥是否配置成功

如果是秘钥,就用ssh

修改Terminal

铁律

用idea切换分支之前,一定要提交代码,只要代码提交了,代码就丢不了。

相关推荐
xianwu54331 分钟前
反向代理模块。开发
linux·开发语言·网络·c++·git
前端_库日天2 小时前
部署自己的git托管平台
git·ubuntu·docker
神仙别闹4 小时前
基于C#实现的(WinForm)模拟操作系统文件管理系统
java·git·ffmpeg
刘大辉在路上14 小时前
突发!!!GitLab停止为中国大陆、港澳地区提供服务,60天内需迁移账号否则将被删除
git·后端·gitlab·版本管理·源代码管理
落落鱼20131 天前
cenos如何升级git到2以上版本
git
Domain-zhuo1 天前
Git常用命令
前端·git·gitee·github·gitea·gitcode
sin22011 天前
git自己模拟多人协作
git
大猫和小黄1 天前
Windows、CentOS环境下搭建自己的版本管理资料库:GitBlit
linux·服务器·windows·git
孤水寒月1 天前
Git忽略文件.gitignore
git·elasticsearch
DN金猿2 天前
git命令恢复/还原某个文件、删除远程仓库中的文件
git