git结合github远程仓库使用

远程仓库github使用====================================

 

多人协作开发流程:

 

A在自己计算机创建本地仓库

 

Agithub中创建远程仓库

 

A将本地仓库推送到远程仓库

 

B克隆远程仓库到本地进行开发

 

B将本地仓库开发的内容推送到远程仓库

 

A将远程仓库内的最新内容拉取到本地

 

 

Github注册使用

 

一、访问github官网,进行注册sign up注册,sign in登录。

 

二、在github中创建项目

 

 

 

 github仓库创建完成后,可见基本使用命令介绍:

 

三、命令介绍

创建完成后,会自动进入到该远程仓库的命令介绍页面

如同:
https://github.com/qika2013/git-demo.git    这就是表示远程仓库的地址

git push  远程仓库地址  分支名称
git push  远程仓库地址别名  分支名称

git push  -u  远程仓库地址别名  分支名称
        -u表示记住推送地址和分支,下次推送只需要输入git push即可了

git remote  add 远程仓库地址别名  远程仓库地址

四、实际操作:

1、推送本地内容内容到远程仓库

输入:git push 远程仓库地址  自己要推送的本地分支名称

输入完成后,会弹框进行验证权限。正常进行操作即可

 

 

 

 

 完成后:git 的命令行界面展示出推送成功的信息,成功将master推送到远程仓库

并且:打开github可查看到自己本地推送的内容

2、给远程仓库地址起一个别名(否则每次都输入很长一大串,太长)

git remote  add 远程仓库地址别名  远程仓库地址

 

截图里的origin 就是对github远程仓库的地址设置的别名

然后,后面再进行将本地仓库内容推送至远程仓库时,只需要:

git push origin master

 

3、 -u命令记住推送地址和分支,下次直接输入git push就可以推送

 

 因为首次使用了-u命令后,后续进行推送本地仓库master分支内容到远程时,只需要输入git push即可(这样是否就像网站的记住账号密码功能?)

 

 

 克隆

克隆远程仓库数据到本地,命令: git clone 远程仓库地址

注意:
1一般用于第一次加入项目组内时使用,因为这时候你没有项目代码,直接先将远程仓库内所有克隆下来
2克隆是不需要像之前自己推送那样需要验证。克隆可以随便对远程仓库github的内容进行克隆拉取(只要仓库可见)

实际操作:

1打开github项目页面

在项目页面可见code(鼠标点击会看见当前项目的仓库地址,复制出来即可)

另:不会使用Git的可以直接点击download,下载项目的压缩包也可

 

 2在自己本地电脑新建文件夹(用来存放克隆项目,随便自己放),然后右键进入git命令行

github当中复制得到的仓库地址粘贴到自己的本地git命令行内:

输入即可:git   clone  远程仓库地址 

 3等待克隆完成,自己可在自己本地的某文件夹内查看到克隆下来的项目文件了

 

多人使用远程仓库(权限)

当设置了远程仓库后,A在一直使用,当B突然加入使用时,难道可以直接拉取项目就能推送本地仓库内容至远程仓库吗?

肯定是不可能的。那怎么办呢?就需要A去给B授权了

例--流程:

A授权B……(管理员加人到项目内)使用远程仓库:

1 人员A进入github远程仓库内,找到settings-->>Manage access页面,进行邀请合作人员

2 成功后,将会给被邀请的人发送邀请链接,被邀请人点击链接进行加入即可。

3 一切完成,正常使用即可

 

 

 成员互相拉取远程仓库内的最新版本内容

命令:git pull 远程仓库地址 分支名称

注意:这个是不需要进行验证身份的,直接操作即可

 

实际操作:

Git pull origin master        

这里就表示拉取的是origin(远程仓库地址的别名)内的master分支的内容

 拉取远程仓库内指定的分支最新版本内容完成后,可见git命令行内会显示提示信息

 

 

 

SSH免登陆

概念

之前我们使用的都是https的远程仓库地址,一般在使用时,推送等操作时都需要验证的(即用户名\密码验证)

而在github中还可进行使用ssh协议进行免登陆操作,如:github内可见ssh地址

 

 

作用:在身份验证时,不用输入用户名和密码,原因是因为在ssh协议里面,验证是通过“秘钥”来实现的,秘钥是成对出现的(私钥和公钥),ssh通过验证私钥和公钥的配对情况来验证是否通过。(如同钥匙和门锁一样的关系)

注意:!!! 一般秘钥是保存在电脑本地的,当我们通过SSH协议把本地仓库内容推送到远程仓库内时,就会验证我们本地的“私钥”和远程仓库内的“公钥”是否配对,这样才能实现推送

 

获取秘钥的方法:(私钥和公钥)

Git命令行内输入:ssh-keygen,然后一直回车默认即可,出现如下界面信息为止

 

从上可见秘钥的存储位置:C:\Users\Administrator\.ssh

 解释:

Id_rsa     私钥,一般默认保存在我们自己的本地电脑即可

Id_rsa.pub  公钥,一般是要手动设置在远程仓库所在的服务器的(步骤看后面)

 

配置秘钥(私钥和公钥)+++++++

私钥:保存在我们本地电脑就行了,不用管。

公钥:

先在本地找到秘钥所保存的位置路径,然后打开公钥文件,复制内容;

然后打开github,在界面找到用户设置的位置

 

 

 

 

跳转后,找到SSH key设置的位置,进行点击NEW SSH KEYS

 

 

 

 然后将本地电脑上获取到的“公钥”文件打开复制内容,在githubSSH KEYS新增页面,粘贴进去即可,

 

 

 

 

 保存即可(如果弹框验证登录密码,输入即可)

完成后可见,已经设置好了

 

 

 

 然后再github远程仓库内查看,可看到SSH的使用地址

 

 

 

 

 配置完成后,使用ssh协议来实现免登录验证,来实现推送本地内容到远程仓库

命令:

git remote add origin-ssh git@github.com:qika2013/git-demo.git 这表示给ssh协议的远程仓库地,起一个别名(不然每次都这么长输入,很麻烦)

git push origin-ssh master     然后进行推送即可

 

 

 

说明:!!!在推送时,命令行界面可能会弹出提示,根据提示输入yes即可。

可见结果是成功的(即:实现了使用SSH协议的远程仓库地址,来讲本地仓库的内容推送到远程仓库内,没有弹出验证就实现了本地推送至远程仓库。完美)

 

 

========================================================================

=========================================================================

注:

容易产生的冲突问题:一般在多人参与同一项目时,如果两人同时修改了同一个文件的同一个地方,会产生冲突。这时候是无法进行推送的

原因:第一个人操作了提交并推送至远程,此时远程仓库内容改变,第二个人再进行提交并推送时,就无法成功了(因为远程仓库版本比本地仓库版本高了,无法提交)

解决:先重新拉取远程仓库最新版本内容,然后再提交

 

 

posted on 2020-11-21 21:29  QiKa  阅读(131)  评论(0编辑  收藏  举报