Git 基本使用

git相关

基本配置命令
  • git config --list或git config -l:查看配置
  • git config --global user.name "xxx":设置全局用户名
  • git config --global user.email "xxx":设置全局邮箱

更多配置参考:https://www.jianshu.com/p/f29ca723db4f

常用命令
基本操作相关
  • git init 仓库名:新建一个空仓库
  • git status:查看仓库状态
  • git add .:将当前目录所有文件添加到暂存区,也可以指定文件名,从而只提交指定文件
  • git commit -m "xxx":将暂存区数据上传并保存成一个节点,同时添加说明,要修改最后一次提交的备注可以通过git commit --amend,若要修改更早之前的,则需要通过git rebase -i HEAD~最近的几条数(例如最近3条就3)来进行修改,详细参考:https://www.jianshu.com/p/0f1fbd50b4be
  • git stash:将当前修改的文件添加到暂存区,然后内容会变成修改前的样式,此时可以通过git stash list查看暂存区的内容,当需要时可以通过+ git stash pop弹出暂存区的内容,详细参考:https://www.cnblogs.com/yangjingkang/p/9947744.html
日志回滚相关
  • git tag -a 标签名 -m "xxx":添加标签和说明,通过git taggit log都可以看
  • git show 标签名:查看某个标签号的详细信息
  • git log:查看日志,加-p参数查看每次版本的内容变化,--all查看所有日志(默认只有当前分支日志),--graph以更加图表化显示,--oneline使每条日志只显示一行信息
  • git reflog:查看本地操作日志,仅显示版本号和对应commit的说明
  • git reset HEAD:撤销上一次的add内容,如果只是想撤销某个文件,则可以后面加要撤销的文件名
  • git reset --hard:将代码回退成当前版本未修改过的状态,后面加上版本号可以回滚到指定版本
  • git reset --mixed origin/master:撤销主分支上次commit但还没push的内容,即变回本地文件修改后但还未提交的状态,如果希望撤销commit的同时,内容也变回主分支的状态,可以换成--hard参数
  • git checkout 标识号(通过log命令查看,复制前7位以上):退回到某个版本(回退到上一个版本则:git checkout -
分支相关
  • git branch:查看本地分支以及当前所在分支,加上--all则查看所有分支
  • git branch 分支名:创建分支,默认在master分支
  • git checkout 分支名:切换到某个分支,git checkout -代表切回上一个分支
  • git checkout -b 分支名:创建并切换到某个分支,-d代表删除某个分支
  • git merge 分支名:将指定分支和当前分支进行合并,如果两个分支内容一样则合并,不一样则会在分支内容追加到当前分支内容后面
远程相关
  • git clone 链接:下载仓库
  • git remote add github 链接:添加远程仓库链接,remove则删除链接
  • git remote:查看连接的远程仓库,-v查看详细信息
  • git push -u 远程仓库 分支名:上传代码到指定远程仓库
  • git pull:获取更新后的远程仓库
更多使用参考

https://www.jianshu.com/p/493bb782af4e
https://www.jianshu.com/p/a33ac63849da
https://www.jianshu.com/p/fb61299086b6

merge查看

<<<<<<< HEAD=======之间是本地写的内容,=======>>>>>>> 版本号是pull下来对应版本号的内容,或者说:前面的是你写的内容,后面的是更新的内容,举例:

init
<<<<<<< HEAD
我写了a
=======
pull下来了b
>>>>>>> f91ed8b52323dfb634d99abe43337cb440343bd2

那么说明init是原本的内容,没有冲突,后面第二行在本地是我写了a,而在pull下来的版本里是pull下来了b,此时只需要将内容修改成你想要的再提交就行了

集成IDE(idea)操作参考

https://blog.csdn.net/mayfla/article/details/78645332

托管平台相关

  • 这里拿github举例
本地项目托管github
第一次上传项目至github步骤
  1. 在github上新建一个仓库
  2. 在项目文件夹下输入命令:git init,初始化git项目
  3. 输入命令:git add .,将本地文件都添加至暂存区
  4. 输入命令:git commit -m "信息"将暂存区文件提交
  5. 输入命令:git remote add origin https://github.com/用户名/仓库名.git(可以在仓库链接里找到对应的地址)与github建立远程关联
  6. 输入命令:git push -u origin master,并验证账号密码后,项目将会上传至github
之后基本使用步骤
  1. 通过命令:git add .将文件添加到暂存区
  2. 通过命令:git commit -m "xxx",提交暂存区文件
  3. 通过命令:git push,提交项目(多人协作可能在提交前需要通过git pull拉取更新内容,当存在文件内容冲突时,则会自动merge,修改完成后再次add->commit->push提交即可,还有很多常用的如分支操作、stash操作等这里就不一一介绍了)

参考:https://www.cnblogs.com/yf-html/p/8635723.html

github高级搜索命令参考
in:name xxx 名字中有xxx
in:readme xxx   readme中有xxx
in:description xxx  描述中有xxx
language:xxx    用xxx语言编写的项目
stars:>1000
forks:>1000
created:>yyyy-mm-dd 创建时间大于...
pushed:>yyyy-mm-dd  推送时间大于...

更多参考:https://help.github.com/en/github/searching-for-information-on-github/searching-for-repositories

多分支协作

  • 创建一个新的分支,最好以yourname/feature方式进行命名,举例:
git checkout -b dawsonenjoy/testbranch
  • 在分支上进行开发,当开发完成后通过add/commit/push命令上传到自己的分支,举例:
git add xxx
git commit -m "branch test"
git push origin dawsonenjoy/testbranch
  • 当需要合并到主分支时,需要切换到主分支,然后通过merge操作进行合并,举例:
git checkout master
git merge dawsonenjoy/testbranch

参考:https://www.cnblogs.com/onelikeone/p/6857910.html

PR操作
  • 真正的多人项目开发时,往往不会允许个人主动在主分支上进行合并分支的操作,因此需要发送PR进行代码审查并通过后才能合并到主分支,具体操作拿github进行举例:打开对应的仓库页面,选择Pull requests并创建一个,选择code reviewer进行代码检查,通过后最终将合并到主分支
修改未提交内容时切换分支问题
  • 当开发过程中如果因为文件修改而无法切换到别的分支,则可以通过git stash将修改的内容存到暂存区再切换分支,之后回到开发分支时再通过git stash pop来恢复修改的内容

SSH配置相关

代码托管平台配置SSH
  • 创建公私钥:
ssh-keygen -t rsa -C "youremail@example.com"
  • xxx.pub的公钥传到托管平台即可
多平台SSH配置
  • 创建多平台配置文件~/.ssh/config,举例:
Host gitee.com
    HostName gitee.com
    PreferredAuthentications publickey
    IdentityFile ~/.ssh/gitee/id_rsa

Host github.com
    HostName github.com
    PreferredAuthentications publickey
    IdentityFile ~/.ssh/github/id_rsa

常见问题

每次push都需要输入密码
解决方式一
  • 输入下面命令配置:
git config --global credential.helper store

重启终端后只需要配置一次用户名密码即可。如果还出现错误Fatal: HttpRequestException encountered.,那么需要安装对应的凭证管理器(https://github.com/Microsoft/Git-Credential-Manager-for-Windows/releases/tag/v1.14.0

解决方式二
  • 使用HTTPS上传会需要输入账号密码,因此我们可以通过配置SSH来解决该问题
中文文件名乱码

输入如下命令进行配置:

git config --global core.quotepath false
日志内容乱码
git config --global i18n.commitencoding utf-8
git config --global i18n.logoutputencoding utf-8
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 216,692评论 6 501
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 92,482评论 3 392
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 162,995评论 0 353
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 58,223评论 1 292
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 67,245评论 6 388
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 51,208评论 1 299
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 40,091评论 3 418
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 38,929评论 0 274
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 45,346评论 1 311
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 37,570评论 2 333
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 39,739评论 1 348
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 35,437评论 5 344
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 41,037评论 3 326
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 31,677评论 0 22
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 32,833评论 1 269
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 47,760评论 2 369
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 44,647评论 2 354