02-Git远程仓库Github
1、Git远程仓库
(Gitgub网站作为远程代码仓库时的操作和本地代码仓库一样的,只是仓库位置不同而已)
需要准备的东西:
1、准备Git源代码仓库https://github.com/
2、准备李顺涛的文件F:/gitTest/lishuntao/
3、准备经理的文件F:/gitTest/manager/
创建远程仓库
1、登录注册Github
2、创建仓库入口

3、编辑仓库信息

4、仓库创建完成

5、查看仓库地址
远程仓库地址:https://github.com/lishuntao123/test1.git

2、配置SSH
如果某台电脑需要与Github上的仓库交互,那么就要把这台电脑的SSH公钥添加到这个Github账户上。
1、配置SSH公钥入口


2、修改电脑git配置
配置Github注册邮箱和用户名
vi .git/config
[user]
email = 1259553287@qq.com #github注册邮箱
name = lishuntao123 #github注册用户名
3、生成SSH公钥
ssh-keygen -t rsa -C "1259553287@qq.com"



备注:删除旧密钥
删除~/.ssh目录,这里存储了旧密钥
rm -r .ssh
3、克隆项目
准备项目经理的文件F:/gitTest/manager/
准备我的的文件F:/gitTest/lishuntao
经理的工作:
建立项目:克隆远程仓库+配置身份信息+创建项目+推送项目到远程仓库
1、克隆远程仓库的命令
cd F: cd gitTest cd manager git clone git@github.com:lishuntao123/test1.git
2、解决可能出现的密钥错误
提示错误信息:
sign_and_send_pubkey: signing failed: agent refused operation
错误原因:在ssh账户中没有加入新生成的密钥
解决:将密码加入ssh账户
eval "$(ssh-agent -s)"
ssh-add
3、克隆到本地

4、查看经理文件

5、配置经理信息
cd manager cd test1 git config user.name "经理"
git config user.email "manager@qq.com"

6、创建项目

7、推送项目到远程仓库
#工作区添加到暂存区
git add . #暂存区提交到仓库区
git commit -m "建立项目" #推送到远程仓库
git push


我的工作:
获取项目:克隆项目到本地、配置身份信息
1、克隆项目到本地
cd lishuntao git clone git@github.com:lishuntao123/test1.git


2、配置我的身份信息
cd test1
git config user.name '李顺涛'
git config user.email '1259553287@qq.com'
我的信息配置成功后,可以和项目经理协同开发同一个项目。

4、多人协同开发
1、代码编辑界面介绍:linux使用gedit做演示
2、模拟本人先编辑login.py文件代码

3、模拟经理编辑login.py文件代码

4、模拟自己同步服务器代码
本次可以把count=2同步到自己的本地服务器

接下来重复上面的代码,实现基本的协同开发
6、总结:
要使用git命令操作仓库,需要进入到仓库内部
要同步服务器代码到本地代码就执行:git pull
本地仓库记录版本就执行:git commit -am '版本描述'
推送代码到服务器就执行:git push
编辑代码前要先pull,编辑完再commit,最后推送是push
5、代码冲突
多个人协同开发的时候,避免不了会出现代码冲突的情况。因为多个人同时修改了同一个文件,危害会影响正常的开发进度。一旦出现了代码冲突,必须先解决在做后续开发,否则做苦力。
冲突的由来:共同编辑文件,一个推送到远程仓库,所在行已经被占位。所以后提交的会提示要先git pull才能够同步到本地仓库才可以进行编辑,
解决冲突:
原则:谁冲突谁解决,并且一定要协商解决
方案:保留所有代码 或者 保留一人代码
解决完冲突后,仍需要add、commit、push
补充:
容易冲突的操作方式
- 多个人同时操作了同一个文件
- 一个人一直写不提交
- 修改之前不更新最新代码
- 提交之前不更新最新代码
- 擅自修改同事代码
减少冲突的操作方式
- 养成良好的操作习惯,先
pull在修改,修改完立即commit和push - 一定要确保自己正在修改的文件是最新版本的
- 各自开发各自的模块
- 如果要修改公共文件,一定要先确认有没有人正在修改
- 下班前一定要提交代码,上班第一件事拉取最新代码
- 一定不要擅自修改同事的代码
- 养成良好的操作习惯,先
6、标签
当一个大版本完成之后,需要打一个标签。标签的作用就是记录大版本,备份大版本代码。
模拟项目经理打标签:
1、进入到经理的本地仓库test1
2、项目经理在本地打标签
git tag -a 标签名 -m '标签描述' 例子: git tag -a v1.0 -m 'version 1.0'
3、经理推送标签到远程仓库
git push origin 标签名 例子: git push origin v1.0
4、查看打标签结果

备注:删除本地和远程标签
# 删除本地标签
git tag -d 标签名
# 删除远程仓库标签
git push origin --delete tag 标签名
7、分支

- 作用:
- 研究新的功能或者攻关难题
- 解决线上bug
- 特点:
- 分支使每个员工开发期的代码互不干扰
- 项目开发中公用分支包括master、dev
- 分支master是默认分支,用于发布,当需要发布时将dev分支合并到master分支
- 分支dev是用于开发的分支,开发完阶段性的代码后,需要合并到master分支
- 项目中每个项目成员都可以单独建立分支用于的代码开发,实现不交叉
模拟项目经理分支操作
1、查看当前分支
没有创建其他的分支,因此只有master分支
2、项目经理创建并切换到dev分支
git checkout -b dev

3、项目经理在dev分支编辑代码
5、管理dev分支源代码:add、commit、push


5、dev分支合并到master分支
git checkout master
#1、先切换到master分支 只有当dev分支合并到master分支成功,别人才能获取到num3
git merge dev
#2 dev分支合并到master分支
git push
# 经理推送合并分支操作到远程仓库
6、别人同步经理合并后的num3(只有代码同步成功,分支合算才算成功)

BUG分支:重中之重
- 有时当我们正在开发新功能时,出现了线上BUG。此时,必须暂停正在开发的功能,新建临时分支先解决线上BUG。
以下代码为模拟张三解决线上BUG:v1.0版本出错
1.张三切换到dev分支

2.张三在dev分支上编辑代码

3.线上
v1.0版本突然发现bug- 张三暂停手中的工作,解决线上
v1.0版本bug 记录未提交的修改:保留现场
git stash #记录未提交的数据 也就是刚暂停手中的工作


- 张三暂停手中的工作,解决线上
4.张三解决线上
v1.0版本bug4.1 张三切换到
master分支
4.2 新建
fixbug分支,并下载v1.0版本的代码到fixbug分支git checkout -b fixbug v1.0


4.3 修复线上
v1.0版本bug
4.4 管理
fixbug分支代码add、commit、push
4.5 合并
fixbug分支到master分支,并推送到远程仓库# 切换到master分支
git checkout master
# 合并fixbug分支到master分支
git merge fixbug
# 推送合并到远程仓库
git push
4.6 经理打标签
v1.1,发布v1.1版本git tag -a v1.1 -m 'version 1.1'
git push origin v1.14.7 张三恢复dev分支未提交的修改(切换到dev分支)
- 恢复到发现线上bug的那个节点
v2.0开发中...git stash list
git stash pop
4.8 张三将
fixbug分支合并到dev分支- 当把未提交的修改提交后,即可将
fixbug合并到dev 保证张三现在开发的版本不会有
v1.0版本遗留问题# 切换到dev分支
git checkout dev
# 合并fixbug分支到dev分支
git merge fixbug
# 推送
git push
- 当把未提交的修改提交后,即可将
4.9 张三将
dev分支合并到master分支,并推送到目前为止:
v1.0版本bug解决了,v2.0也开发完成了
合并分支禁用Fast Forward模式
- 在合并分支时,默认采用
Fast Forward模式 - 该模式没有分支合并的版本记录
如果需要在合并分支时记录版本需要禁用
Fast Forward模式git merge --no-ff -m '合并描述' 分支名
02-Git远程仓库Github的更多相关文章
- 【第十篇】- Git 远程仓库(Github)之Spring Cloud直播商城 b2b2c电子商务技术总结
Git 远程仓库(Github) Git 并不像 SVN 那样有个中心服务器. 目前我们使用到的 Git 命令都是在本地执行,如果你想通过 Git 分享你的代码或者与其他开发人员合作. 你就需要将数据 ...
- Git远程仓库(github
一.创建远程仓库(github) 首先到https://github.com注册一个账号,创建自己的Git,点击repositories,再点new 名字自定义,比如叫fansik,选择public点 ...
- learn git(远程仓库github)
|由于本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以,需要一点设置: 第1步:创建SSH Key.在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsa ...
- git远程仓库Github
一.克隆项目 git clone 网址 1.配置信息 git config user.name '用户名' git config user.email '邮箱号' 2.推送项目到远程仓库 # 工作区代 ...
- git 远程仓库-github
第1步:创建SSH Key.在用户主目录下,看看有没有.ssh目录,如果有,再看看这个目录下有没有id_rsa和id_rsa.pub这两个文件,如果已经有了,可直接跳到下一步.如果没有,打开Shell ...
- Linux下Git远程仓库的使用详解
Git远程仓库Github 提示:Github网站作为远程代码仓库时的操作和本地代码仓库一样的,只是仓库位置不同而已! 准备Git源代码仓库 https://github.com/ 准备经理的文件 D ...
- Git版本控制工具(三)----远程仓库GitHub的使用
[声明] 欢迎转载,但请保留文章原始出处→_→ 生命壹号:http://www.cnblogs.com/smyhvae/ 文章来源:http://www.cnblogs.com/smyhvae/p/4 ...
- GitHub进阶之利用Git远程仓库篇
#在上一篇文章,相信大家对GitHub已经有了一个基础的理解 接下来我们来学习一下如何利用git来远程仓库 一,git是什么 git:一个免费的开源版本控制软件 用途:利用Git管理GitHub上的代 ...
- Git应用详解第五讲:远程仓库Github与Git图形化界面
前言 前情提要:Git应用详解第四讲:版本回退的三种方式与stash 这一节将会介绍本地仓库与远程仓库的一些简单互动以及几款常用的Git图形化界面,让你更加方便地使用git. 一.Git裸库 简单来说 ...
- git远程库GitHub
首先,注册一个GitHub(github.com)帐号,免费获得Git远程仓库 由于本地Git仓库和GitHub仓库之间的传输是通过SSH加密的,所以,需要一点设置: 第1步:创建SSH Key.在用 ...
随机推荐
- 论文阅读:EGNet: Edge Guidance Network for Salient Object Detection
论文地址:http://openaccess.thecvf.com/content_ICCV_2019/papers/Zhao_EGNet_Edge_Guidance_Network_for_Sali ...
- 剑指Offer-45.扑克牌顺子(C++/Java)
题目: LL今天心情特别好,因为他去买了一副扑克牌,发现里面居然有2个大王,2个小王(一副牌原本是54张^_^)...他随机从中抽出了5张牌,想测测自己的手气,看看能不能抽到顺子,如果抽到的话,他决定 ...
- (绿色)修正版gooflow流程解决方案(源码分享+在线演示+UI地址下载)
gooflow出现挖矿机木马,请勿随意去其他网站下载!!! 一.功能简介 gooflow功能清单1.自定义流程绘制2.自定义属性添加3.支持3种步骤类型普通审批步骤自动决策步骤手动决策步骤 4.决策方 ...
- windows本地连不上虚拟机redis服务完美解决
检查本机与虚拟机是否可以互相ping通,如本机IP:192.168.22.111 虚拟机IP:192.168.44.129 (设置虚拟机静态IP已设置) 本机 win+R 输入cmd 进入dos 输 ...
- Oracle - SPM固定执行计划(二)
一.前言 前面文章(https://www.cnblogs.com/ddzj01/p/11365541.html)给大家介绍了当一条sql有多个执行计划时,如何通过spm去绑定其中一条执行计划.本文将 ...
- 利用 python 分析基金,合理分析数据让赚钱赢在起跑线!
前言 本文的文字及图片来源于网络,仅供学习.交流使用,不具有任何商业用途,版权归原作者所有,如有问题请及时联系我们以作处理. 作者: 白玉无冰 PS:如有需要Python学习资料的小伙伴可以加点击下方 ...
- spark SQL、RDD、Dataframe总结
- HTML基础——表格的应用
一.表格标签 1.基本格式: 每个表格由 table 标签开始. 每个表格行由 tr 标签开始. 每个表格数据由 td 标签开始. 例如: <html> <head> < ...
- 使用npm link 加速调试
我们在把包发布到npm上时,如果需要对本地的包进行修改,我们需要改变一个版本,重新发布.然后测试时需要更新这个包进行测试.这样的话,每一次的调试都特别麻烦.我们可以使用npm link来加速这个调试过 ...
- 【Gradle】Groovy基础
Groovy基础 Groovy是基于JVM虚拟机的一种动态语言.每个Gradle的build脚本文件都是一个Groovy脚本文件. 字符串 在Groovy中,分号不是必需的.在Groovy中,单引号和 ...
