Git的常用命令

一,.gitignore文件的配置

在提交代码的时候,有些东西比如.idea这类本地的文件,是不需要提交到远程的,这个时候,我们就需要进行.gitignore文件的配置

1,在本地克隆仓库

2,进入仓库,创建.gitignore文件:vim .gitignore

3,编辑.gitignore文件

*.aa      忽略以.aa结尾的文件

idea/     忽略idea文件夹

/ignore     忽略根目录下的ignore文件,不代表忽略doc/ignore文件

/doc/*.txt    忽略doc目录下的任意txt文件,但不包括dir/doc/*.txt

doc/**/*/*.txt      忽略doc目录下任意位置的txt文件

**/dir     忽略任意文件夹下的dir文件 ,比如 doc/dir,doc/bin/doc ,前面有多少层都行

fiename      忽略指定的文件夹

! doc/filename     不忽略doc下的filename文件(用处:想要忽略除xx.txt外的任意txt,可以配合前面使用)

二,git的配置

1,HTTP方式

1,到github上创建一个项目

2,下载git并安装:

命令:sudo apt-get install git

验证是否装好:git --version

3,在linux系统里新建一个文件夹:

命令:mkdir xxx

4,切换到该文件夹目录下

命令:cd xxx

5,克隆仓库:

命令:git clone xxx(地址去github上的项目详情里面copy)

6,添加本地文件(追踪)

命令:git add xxx

7,查看状态

命令:git status

8,设置全局变量

命令:git config --global user.email "xxx@163.com" (在github账户设置的邮箱)

git config --global user.name "xxx"(在github账户设置的用户名)

9,提交文件(提交到本地.git 文件夹下)

命令:git commit -m "提交的内容"

10,提交代码到远程仓

命令:git push 

这时候git会提示输入用户名和密码,输入github的用户名和密码就好啦!

2,SSH的方式

这个方式相比http方式比较简洁,设置以后就不要经常输入用户名和密码了,推荐使用

1,生成ssh key

命令: ssh-keygen -t rsa -C "xxx@xxx.com"

再按两次回车,就可以生成秘钥了,页面会有提示具体放在哪儿

2,进入目录,找到秘钥并复制秘钥

命令:

cd ~  进入目录

pwd 显示当前目录

cd .ssh/ 进入ssh目录

ls -al   显示所有文件

cat id_rsa.pub  查看秘钥

3,复制秘钥到gitlab

进入gitlab--settings-ssh keys,把秘钥粘进去,并取个名字,点击添加

4,克隆仓库

git clone xxxx.ssh

这里会要求输入y/n,输入y

5,添加本地文件(追踪)

命令:git add xxx

6,提交文件(提交到本地.git 文件夹下)

命令:git commit -m "提交的内容"

7,提交代码到远程仓

命令:git push 

三,git常用命令

1,查看操作信息

1),查看提交历史

git log 

2),显示最近2次提交的内容

git -p -2 

3),将每一种提交都放在一行来显示

git log --pretty=oneline

4),查看各个分支的提交

2,提交代码

1)git add .  提交文件

2)git commit - m "xxx"  描述提交的内容

3)git push 推到远程仓

3,分支

1),创建并切换分支

git checkout -b branchname

2),查看本地分支

git branch

3),查看本地及远程分支

git branch -a 

4),切换到master分支

git checkout master

5),只想创建,不想切换分支

git branch a

6),合并代码到master分支

git checkout master    // 切换到master分支

git merge a     // 把a分支合并到master分支

7),删除分支

git branch -d a      //  删除a分支(本地)

git branch -D a     //  强制删除a分支(本地)

ps:如果一个分支已经提交远程分支,那么就需要删除本地和远程2个分支

git push origin -d a   删除远程分支

4,撤销文件

1)在添加后撤销提交

git reset HEAD a.txt 

2)在commit后撤销提交

1, git  reflog   // 查看所有分支的操作记录

2,git reset --hard xxx

5.版本回退

1,git log    // 查看版本

2,回退到指定版本

git reset --hard de21334 (在commit 后面有一串字符,我们取前7位就好)

6,冲突解决

如果本地有个a.txt文件,然后从远程拉代码的时候,也有a.txt,这样就会产生冲突,导致无法拉取;这个时候我们需要用暂存功能先缓存,然后在拉代码下来,解决冲突,然后再推上去。

这个时候,我们就需要用到文件暂存功能

git stash

1,查看暂存区内容

git stash list

2,把代码从暂存区拉出来并删除暂存区内容

git stash pop

3,从暂存区恢复某个暂存的内容(恢复完后会合并冲突,接着就需要自行去解决冲突了。)

git stash app xxx

4,清空暂存区

git stash clear

5,删除指定缓存

git stash drop xxx

6,查看缓存区的操作

git stash show

7,查看缓存区具体操作(增加,减少啥的)

git stash show -p

8,从暂存区创建分支(会丢弃缓存区存的内容)

git stash branch branchname

7,差异比对

1),比较本地工作目录和暂存区的差别

git diff filename

2),比较缓存区和远程仓的区别

git diff --cached filename

3),比较本地工作目录和远程仓的区别(查到远程的id号,然后再进行比对)

git diff commitID filename

比较本地和远程的文件的区别

4),比较2个远程仓之间的区别

git diff commitID1 commitID2

8,标签(版本上线了,需要用标签记录下)

1),创建一个标签

git tag -a v1 -m "v1 version online"

2),查看标签

git tag

3),查看某个版本的标签

git tag -l "v1*"     //查看v1版本的标签

4),显示某个标签的具体内容

git show v1

5)推标签到远程

git push origin v1    // 推v1标签到远程

git push origin --tags   // 推多个标签到远程

6)删除标签(本地)

git tag -d v1

删除远程标签

1,在界面删除

2,通过命令来删除

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

推荐阅读更多精彩内容

  • 1.git的安装 1.1 在Windows上安装Git msysgit是Windows版的Git,从https:/...
    落魂灬阅读 12,645评论 4 54
  • 安装Git Git的下载地址:Git官网下载地址 Git本地仓库和命令 配置用户 下载完Git后,右键会有一个Gi...
    TokyoZ阅读 4,485评论 1 7
  • 1. 安装 Github 查看是否安装git: $ git config --global user.name "...
    Albert_Sun阅读 13,626评论 9 163
  • 感赏我今天遇到了久违不见的朋友,她给我在有些问题上提出了宝贵的建议,让我懂得了如何去处理问题。 感赏朋友对我的信任...
    张元玲阅读 190评论 0 0
  • 《割裂》 我已知道 我的世界再无晴天 晴天是阳光 发散在世间 我偶尔落后了奔跑 来不及收集 忘记了微笑 甚至 连雨...
    二姐家的胖橘猫阅读 304评论 1 5