github网站介绍、并使用git命令管理github(详细描述)

本文转载自:https://www.cnblogs.com/lifexy/p/8353040.html

本章学习:

1)熟悉github网站

2)通过git命令远程管理github,

3)git命令使用ssh key密钥无需输入账号密码

 1.首先我们来熟悉github网站

1.1 注册github

登录http://github.com/,然后点击sign up,来注册账户:

注册好了,以及验证邮箱后,然后进入github主页:

1.2点击start a project(启动第一个项目)

1.3创建好后,就会跳转到刚刚创建好的test2仓库(项目)主页,如下两张图所示

图1:

图2:

先来介绍下上图常用的几个单词

repostory

  仓库,也就是项目的意思,有多个项目就代表有多个仓库

star

  收藏项目,收藏的数目越多,说明项目越好

fork

  将源作者的项目克隆一份到自己的项目中

pull request

  拉请求,指如上图的pull request.

  比如:别人通过fork你的项目后,并改进了项目,向你发送了new pull request请求,

然后你点击pull request按钮,进去后,会出现如下图所示:

  再点击Merge pull request,则可以将改进的内容合并到自己的项目里,

watch

  关注项目,当你关注的某个仓库更新时,便会通知在你的github主页上

lssues

  问题,点击进去就可以看到所有人提出的问题,比如项目有bug等.

  当自己想发表问题时,则点击lssues->new lssues,如下图所示:

1.4接下来,我们点击仓库主页的create new file,来创建一个文件:

提交后,便会返回我们test2仓库主页里:

然后点击commits提交按钮,便可以看到刚刚创建main.c的详细信息:

PS:当我们错误删除了一个文件,也可以通过commits按钮,来找到以前删除的文件

1.5 学习如何来更改仓库名称和删除仓库

在仓库主页里点击settings(仓库设置),如下图所示(以test3为例):

然后便会跳转到下个界面,就可以更改仓库名称了:

继续往下翻,就可以找到删除仓库了:

2.使用git管理github

2.1安装git

下载地址:https://www.git-scm.com/download/win

(若慢的话,则进入http://www.wmzhe.com/soft-38801.html下载)

下载好后,直接默认安装即可,若只喜欢命令行模式,则在组件界面取消git gui here即可,如下图所示:

安装好后,如下图所示,即可通过linux命令来操作git命令:

若在linux上安装git,直接输入:

apt-getinstall git

(linux下载时,若出现error:403,可以试试vi /etc/resolv.conf,将nameserver地址改为: 114.114.114.114)


2.2 配置git

git config --globaluser.name"lifeyx"//个人账号git config --globaluser.email123456@qq.com//个人邮箱地址

上面的--global选项,表示以后管理git库时,默认使用上面的用户信息,也可以通过git config -l 来查看配置信息

2.3 git命令介绍

1)介绍之前,首先来讲解下git的3个区域如下图所示

上图的git仓库,是指本地仓库,不会更新到远程仓库(github网页上的仓库),需要使用git push -u origin master命令才行

2)然后来讲解下git常用命令

git init 

对当前目录进行git管理,该目录便会成为工作区,并在当前目录下会出现个.git隐藏目录.

该.git里会保存git所需要的数据和资源,也就是git仓库和暂存区都会保存在.git里


git clone https://github.com/lifeyx/test2.git

克隆复制远程仓库到当前目录,生成test2文件夹,里面会自动创建.git目录,并保存远程仓库信息

该远程仓库地址通过下图的红框里获取:


git status

查看工作目录下文件的状态,是否add添加到了暂存区,以下图为例:



git add file

将工作区修改的文件添加到暂存区,也可以使用git add .  将所有修改的文件进行添加


git rm file 

将暂存区的文件删除掉,若工作区文件存在,则需要使用git rm -f file来强制删除掉


git commit -m “提交描述”

将暂存区里的文件提交到本地仓库,若暂存区某个文件被删除掉,则会删除仓库里的文件


git commit -am “提交描述”

-a:跳过暂存区,git自动将工作区里记录的所有文件添加到暂存区并一起提交,从而跳过git add步骤


git reset HEAD^1

撤销commit,如果想修改commit时的文件,则使用上面命令撤销


git remote add origin https://github.com/lifeyx/test3.git

添加远程仓库(origin),也就是关联本地仓库和github仓库,该远程仓库地址通过下图的红框里获取:


git push origin master

推送(同步)数据到远程仓库,若是本地上传,必须先使用上个命令来指定远程仓库地址(origin),

若是从远程仓库克隆复制的,则不需要,因为.git里会自动保存远程仓库地址.

2.4  git管理远程仓库-实例1

实例1步骤,通过创建新的远程仓库,然后将本地的数据推送(同步)到远程仓库里

1)首先创建新的远程仓库,以test3为例

然后找到远程仓库地址为: https://github.com/lifeyx/test3.git

2)进入github命令行,输入

mkdir test3

cd test3

echo "项目描述test3">> README.md     

git init                      //初始化gitvi 1.txt//创建1.txtgit add README.md              //添加README.md    git add 1.txt//添加1.txtgit commit -m"第一次提交文件"//提交到本地仓库git remote add origin https://github.com/lifeyx/test3.git  //连接远程仓库地址git pushorigin master//上传到远程仓库地址,并输入账号密码

3)查看结果


2.5 git管理远程仓库-实例2

实例2步骤,就是通过克隆来将远程仓库下载到本地,然后本地修改数据后,并推送(同步)数据到远程仓库

1)通过以前的远程仓库test2为例

如下图所示,可以看到test2仓库更新时间都是处于1天前的:

然后通过上图的绿色按钮,找到test2地址为: https://github.com/lifeyx/test2.git

2)进入github命令行,输入

git clone https://github.com/lifeyx/test2.git//下载test2仓库cd test2                                      //进入仓库vi 1.txt//创建1.txtgit add 1.txt//添加1.txtgit commit -m"第二天提交文件"//提交到本地仓库git pushorigin master//上传到远程仓库地址,并输入账号密码

PS:

由于git clone会自动生成.git隐藏目录,所以上面无需git init命令初始化。

而且.git目录里保存了远程仓库地址,所以上面无需git remote命令连接远端。

3)查看结果


3.每次上传到远程仓库地址时,都要输入账号密码,是不是很麻烦?

接下来便通过ssh key密钥,使主机与服务器连接连接, 这样就不用每次输入账号密码

3.1生成ssh key

首先通过ls ~/.ssh命令,查看是否已有ssh key,若有的话,先备份,然后通过rm -rf ~/.ssh来删除

1)输入,创建密钥

ssh-keygen -t rsa -C"123456@qq.com"// "..."里输入邮箱号

2)然后会提示设置密码,直接连按3个回车,表示密码为空

3)将新生成的key添加到ssh-agent中

eval"ssh-agent -s"ssh-add ~/.ssh/id_rsa

4)若显示Could not open a connection to your authentication agent.,则继续输入

ssh-agent bash

ssh-add ~/.ssh/id_rsa

如下图所示,出现Identity added字段,则表示写入成功,ssh key公钥便保存在id_rsa.pub文件中了:

5)然后通过cat ~/.ssh/id_rsa.pub 将ssh key公钥打印出来,并复制

3.2将复制的ssh key公钥添加到github中

跳转页面后,title标题随意写,将ssh key复制到key框里即可

3.3测试ssh key

输入ssh git@github.com,如下图所示,显示Hi  youname!,则表示成功了


3.4成功后,就可以使用git协议来下载仓库. 还是以test2仓库为例

1)首先查看test2仓库的ssh协议的地址(之前是http协议地址)

如上图所示,点击红框后, 前缀https://变为了git@

2)然后进入github命令行,来测试

git clone git@github.com:lifeyx/test2.git//下载test2仓库cd test2                                    //进入仓库vi 2.txt//创建2.txtgit add 2.txt//添加2.txtgit commit -m"第二天提交文件"//提交到本地仓库git push  origin master                //无需输入密码来上传


4.git管理仓库

打补丁:

git diff >new.patch

如果是当前仓库有了新文件,想把新文件也打进补丁(新文件必须需要git add之后才行),则输入:

git diff --cached  >new.patch


查看状态:

Git status   

查看本地修改的哪些东西

git diff Makefile//以查看上图的Makefile为例

添加暂存区

git add kernel/arch/mips/xburst/soc-x1000/chip-x1000/ap60pro/ap60pro/board.h//添加到暂存区git add .                            //添加所有修改过的文件


撤回修改过的文件

git checkout Makefile//撤回Makefile的修改,如果是之前不存在的文件,则会撤销失败

将暂存区里的文件撤回到 修改文件中

git reset HEAD u-boot/drivers/video/jz_lcd/jz_lcd_v13.c//将jz_lcd_v13.c从暂存区撤销掉

提交到本地仓库

git commit  -m"ap60pro update: compatible with old and new screens"//添加到本地仓库(但未上传)  -m 后面跟提交的信息描述

撤销commit提交

git reset HEAD^1

同步远程仓库(当别人在远程仓库进行修改后,本地没有更新时)

git pull --rebase origin master

上传远程仓库

git push origin master

    //上传远程仓库,由于是使用git clone,所以不需要使用git remote连接远程仓库    //如果git push失败,打印: error: failed to push some refs to 'git@192.168.1.8:X1000.git',则使用git pull 同步一次

查看提交远程仓库的历史记录

tig//如下图所示:

其中” [master] {origin/master} {origin/HEAD} Merge branch 'master' of 192.168.1.8:X1000”,是使用git pull解决分支不同(Merge branch)时候提交的


如果想查看提交的某一次具体信息,也可以使用”git show  [hash值]“来查看

git show示例:

1)通过tig,找到近期提交一次的记录hash值:

2)使用git show 17c7a097834439d0e9bf659e5e71ce313832c032,便可以查看具体提交的内容了


 git pull如果打印error: You have not concluded your merge (MERGE_HEAD exists).时

1. 直接commit,再提交一次,之后再pull或merge就可以顺利进行。

2.放弃本地其它修改,直接覆盖,输入:

git reset --hard

git pull


查看每一行是哪次提交最后修改的

git blame filename  


列出文件的所有修改记录

git log -p filename 

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

推荐阅读更多精彩内容