Git的使用教程

Git的简介

Git是一个开源的分布式版本控制系统,可以有效、高速的处理从很小到非常大的项目版本管理。
它是 Linus Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

git的优势有:

  • 速度
  • 简单的设计
  • 能够容纳上千个并行分支
  • 分布式设计
    在了解Git是什么以及它的优势后,接下来我们将对git和GitHub的使用做简要了解

Git的使用教程

以window 10 系统为基础

注册GitHub及下载

在GitHub上创建新项目

注册完git 账号后,就能创建新的项目


GitHub个人账户首页
  • 点击该选项,按提示创建项目


    创建新项目页面

    项目创建好之后就可以在该项目里上传和下载文件了,但在这之前需要在本地创建同名项目,并且将两者进行关联。


    新项目页面

本地项目的创建和上传至GitHub项目将放在之后讲述,这里首先讲述如何将两个项目进行关联。

Github项目和本地项目关联

在往GIthub项目里推送代码之前,为了避免任何人都可以随意往我们GitHub账户进行代码推送,首先要将本地机器和GitHub账户进行关联,而这种关联实际是一种基于SSH的授权。

SSH是一种是一种网络协议,用于计算机之间的加密登录。目前是每一台 Linux 电脑的标准配置。而大多数 Git 服务器都会选择使用 SSH 公钥来进行授权。

GitHub账户和本地机器之间的关系

  • 每台机器都要可以创建公钥和私钥
  • 公钥的作用就在于,该账户接受了你的公钥,就将允许你进行文件推送

公钥和私钥对的创建

Linux 与 Mac 都是默认安装了 SSH ,而 Windows 系统安装了 Git Bash 后应该也安装了 SSH,否则可以通过在git bash 输入ssh进行检验。


看到以下代码证明已安装SSH
ssh-keygen -t rsa -b 4096 -C XXX@XX.com(GitHub登录帐号)

得到公钥(id_rsa.pub)和私钥(id_rsa)

  • 打开公钥文件
cd ~/.ssh(Windows系统公钥和私钥所在文件夹)
cat ~/.ssh/id_rsa.pub(显示公钥文件内容)
公钥内容
  • 复制公钥所有内容,打开GitHub setting,依次操作


    1
2
3
4

-最后点击 Add SSH Key即可,之后就可以往该GitHub账户对应项目内推送文件了

Git的初步使用

创建本地仓库

应用git的第一步就是在系统创建本地仓库

  • 首先打开git bash,输入以下代码:
cd ~(打开家目录)
cd desktop(打开桌面)
mkdir gitdemo(通过命令行创建在想要创建的文件夹,文件夹命名任意)
cd gitdemo(打开以git-demo文件夹为工作目录)
打开gitdemo文件夹
  • 此时先输入代码 git status 检查文件夹状态


    .git文件夹已经创建

    可见文件夹此时还不是git仓库,不能直接从GitHub项目里clone文件或上传文件至对应的GitHub项目中

  • 接下来再输入 git init,使文件夹变为git仓库,此时文件夹里会生成一个隐藏.git目录,该目录可通过输入ls -a进行查看


    git的使用2.png
  • 输入git status,检查文件夹此时的状态


    现行状态

    以上代码的意思是:

On branch master---当前分支master(git默认仓库名称是origin 默认主分支master)
Initial commit---出事的commit(当在仓库中修改文件要后需要commit,此时暂没有commit)
nothing to commit (create/copy files and use "git add" to track)---无需commit(没有修改或add)

我们通过以上操作,达到了以下目的:

  • 把一个文件夹初始成一个本地git 仓库
  • 注意仓库和和文件夹的区别在于仓库下有一个隐藏的 .git文件夹,里面有一些信息
  • 对于一个仓库,如果删除.git文件夹,就变成了一个普通的文件夹了

git仓库中所有文件都是以下三种状态之一

  • 已提交(mommitted)该文件已经被安全地保存在本地数据库中了
  • 已修改(modified)修改了某个文件,但还没有提交保存
  • 已暂存(staged)把已修改的文件放在下次提交时要保存的清单中

clone GitHub上的项目

  • 输入git clone git@github.com:XX(GitHub账户名称)/XX(对应项目名称).git
git clone git@github.com:XX/XX.git

克隆完成

注意:此时该新建项目中没有任何文件,所以会显示clone了一个空项目

通过在git bash 中输入以上代码即可完成将GitHub项目的内容克隆至本地对应的文件夹里,文件夹可以是任意指定的git仓库

在GitHub项目中创建文件并作修改或与本地同步

在git bash中输入以下代码即可

在GitHub项目中创建文件

cd XX(打开GitHub上的对应项目)
touch a.md(创建a.md文件)
echo “hello” >a.md(将"hello"写入该文件中)
git status
文件已存在

尚待进一步操作

把当前文件夹下的新增和修改的文件添加到暂存区

git add .(添加文件)
git status 
i该文件已存在

image.png

把暂存区的文件更新到本地库中

git commit –a “add file”(提交所有,然后进入提交上传信息页输入提交信息保存退出)
git status

commit完毕

注意:commit之前需设置好用户姓名和邮箱方便日后查看

git config  --global user.name “你的姓名”
git config  --global user.email “你的邮箱”
  • 输入 git log可以查看修改日志


    修改日志

把本地仓库的内容推送到git上

git push origin master( 第一次使用)
git push(第二次及以后)
推送完成

把远程仓库的变动更新到合并到本地仓库

git pull(把远程仓库的变动更新到合并到本地仓库)

在同一个项目由多人负责时,如果其他人已经对GitHub上的代码文件作了修改,后续我们再推送相关文件到github时将会报错,因为远程已做修改,而本地未作变更,不允许修改 故需执行命令 git pull

在GitHub上修改或删除文件

修改文件

vim a.md
git add .
  • 这里需要注意,如果提交信息包含大量字符串,提交参数不用加m
  • 此时输入该代码后会进入vim界面,按下i或a进入编辑状态,再进行编辑
  • 编辑完成后按下esc进入命令态,输入:wq 保存退出vim
    再输入以下代码
git commit –a
git push origin master(推送修改)

删除文件

rm –rf a.md(删除a.md文件,rm是remove的缩写)
git add .
git commit –am”删除a.md”(记录该修改)

如果之前已经git push origin master 过,后面可以直接简化成git push

Git复杂使用

本地创建一个git项目推送到远程空仓库

  • 分别在GitHub和本地创建新项目(新的git仓库)
    GitHub创建新项目参考前面所提及的内容发即可
    本地创建新项目流程如下:
mkdir new project(任意名称)
cd newproject
git init
git status
创建文件夹
  • 创建新文件
touch README.md(创建文件README.md)
git init
touch index.html(创建文件Index.html)
echo “hello”>index.html
ls (检查此时文件夹内的文件)
创建文件

可见此时本地该文件夹内已经有了README.md和index.html这两个文件

推送该项目

git add .
git remote add origin git@github.com:XXX/XXX.git(意思是添加一个远程仓库,地址是 git@github.com:XXX/XXX.git)
git push origin master(第一次推送)

给远程仓库取名字的原因是因为如果同一个本地仓库与多个GitHub账户作了关联,此时git push将会报错,故需确认具体推送的仓库名称

推送成功

当确认本地代码文件内容可以完全取替GitHub项目中的内容,可以进行强制推送,输入git push –f origin master即可(慎用,强制推送会覆盖别人的代码)

给GitHub仓库远程添加或删除一个标签

我们在实际操作中也可以给GitHub仓库远程添加或删除一个标签

添加并推送标签

  • 添加标签
git remote add gitlab git@gitlab.com:abd/lab(新标签名).git
  • 推送到该标签
git push gitlab master

删除标签

  • 删除该标签
git remote remove gitlab

修改origin标签对应的地址

git remote set-url origin git@girhub.com: XXX/XXX.git(把已经关联的名字叫origin的仓库的地址改成git@github.com:XXX/XXX..git)

分支操作

创建本地库dev(任意名称)分支,并切换到dev (任意名称)分支

git branch dev
git checkout dev
i创建并切换分支

输入

git branch

即可查看分支情况


目前有master和dev两个分支

创建文件并推送到origin地址的dev分支上

touch b.md
git add .
git commit –am "add b.md"
git push origin dev 
1
2

推送完成

此时同一文件夹切换不同分支就会显示不同文件数量,其中dev分支下会多出新建的文件b.md


dev分支下的文件情况

master分支下的文件情况

之所以要分支,实际是为了开发的便利考虑,我们如果将Master 代码视作线上代码,则通过master拉出一个分支dev进行开发,把dev上的内容部署到开发机进行预览,看是否存在异常,在无异常的情况再再将master和dev的内容进行合并,避免影响主分支即线上的代码

分支合并

验证无问题后即可将两个分支的文件进行合并

  • 把dev的内容合并到master上
git merge dev
合并完成
  • 再推送到master上
git push master

冲突

当自己和他人修改了同一个代码文件的同一处地方时,在执行 git pull进行本地和线上合并时将会出现冲突
此时我们需要进行以下操作:

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

推荐阅读更多精彩内容