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
版本bug4.4 管理
fixbug
分支代码add、commit、push
4.5 合并
fixbug
分支到master
分支,并推送到远程仓库# 切换到master分支
git checkout master
# 合并fixbug分支到master分支
git merge fixbug
# 推送合并到远程仓库
git push4.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 '合并描述' 分支名
最新文章
- 创建版本库-GIT
- 《The Linux Command Line》 读书笔记01 基本命令介绍
- 并发编程 13—— 线程池的使用 之 配置ThreadPoolExecutor 和 饱和策略
- 怎么样excel其产生的条形码(10分钟的时间excel)从而出现了条形码
- office文件的预览
- Linux平台 Oracle 12cR2 RAC安装Part2:GI配置
- YPbPr 和 YCbCr的区别 .
- mysql面试题集
- Prime Test(POJ 1811)
- WebApp专家评委打分的两种进入模式
- 【刷题】BZOJ 3144 [Hnoi2013]切糕
- Google Ads原理
- C语言:字符串输出流输出文件中的数据。
- VIM显示utf-8文档乱码解决方法
- CodeForces 154A Hometask dp
- atitit.为什么笔记本跟个手机不能组装而pc可以
- css样式margin padding border
- IM开发基础知识补课(四):正确理解HTTP短连接中的Cookie、Session和Token
- Hbase 学习笔记5----hbase region, store, storefile和列簇的关系
- Mysql错误积累001-load data导入文件数据出现1290错误