03 【远程库操作】
1.推送到远程库
1.1 创建github仓库
创建新仓库 (github.com)
data:image/s3,"s3://crabby-images/9ed45/9ed450bd82108746a9f3aa776f3349a3fab61923" alt="image-20221006163144237"
1.2 创建远程库地址别名
git remote -v 查看当前所有远程地址别名
git remote add [别名] [远程地址]
data:image/s3,"s3://crabby-images/4e897/4e897a4b03b1de055616904c700a0768b2929cdf" alt="image-20221006163319039"
1.3 推送
git push [别名] [分支名]
data:image/s3,"s3://crabby-images/5a791/5a79134e49bb0e1b1f38e411628fba576d16136f" alt="image-20221006163529176"
data:image/s3,"s3://crabby-images/b3767/b37670d8f0c308245800376512a046a51b2c9201" alt="image-20221006163609629"
2.加入团队并推送
2.1 克隆项目到本地
git clone 仓库地址
data:image/s3,"s3://crabby-images/656e5/656e50b39e1bb22a7a3a5d68a9c1d8ad5f498558" alt="image-20221006164655915"
效果
-
完整的把远程库下载到本地 -
创建 origin 远程地址别名 -
初始化本地库
2.2 添加新成员加入团队
data:image/s3,"s3://crabby-images/1b301/1b301c5735c5c182e6fde2f73e2d16676fcb70b5" alt="image-20221006164837999"
data:image/s3,"s3://crabby-images/63423/6342317ffc259ef2affcc02a633f676e6f604b1a" alt="image-20221006164827658"
data:image/s3,"s3://crabby-images/84fb2/84fb25fa8b445bf61b55414253ba3b87477d9e63" alt="image-20221006165016543"
data:image/s3,"s3://crabby-images/1ef4c/1ef4ce9a1ef875837dd404445a5005879e1d5b3b" alt="image-20221006165030823"
2.3 推送更新到远程库
1.更改用户名
data:image/s3,"s3://crabby-images/c4c69/c4c696adf642977628d5e9e123d30e7ff184c8ff" alt="image-20221006184421259"
2.修改文件并提交到本地库
data:image/s3,"s3://crabby-images/388af/388afa389ea95a10563b03d363328f32a85b3aaa" alt="image-20221006170100066"
3.推送到远程库
data:image/s3,"s3://crabby-images/6390f/6390f8314293ddc1f110374a98cdd64489d57a26" alt="image-20221006184352833"
data:image/s3,"s3://crabby-images/813f8/813f859221ed27cb3906ad97d4990e6619991584" alt="image-20221006184333691"
data:image/s3,"s3://crabby-images/a4a0d/a4a0dcb72187c63f67bd9a4b853691884c54a628" alt="image-20221006184344102"
3.远程库的 SSH 登录
在 Windows 10 系统中,凭据管理器 为我们记录了 GitHub 的 Windows 凭据,再次从终端经过 GitHub 写数据时,可自动保持登录状态。但其他 OS 不一定有这样的功能,因此不便于频繁地提交版本。 为此,可以使用 SSH 登录的方式访问远程库。
不同于 SSH 登录,使用 HTTPS 的方式可以在多个 GitHub 帐号间管理仓库。
data:image/s3,"s3://crabby-images/0b4a9/0b4a9ff212279b31f4aaa985d26ef9ab0b02b658" alt="image-20220827231735884"
3.1 在本地 Home 目录生成 GitHub 公/私钥
cd ~ 进入当前用户的根目录
rm -rvf .ssh 删除.ssh 目录
使用命令ssh-keygen -t <KeyType> -C <Annotation|AccountEmailAddress> 在本地 Home 目录生成 GitHub 公/私钥。
ssh-keygen -t rsa -C dselgent@qq.com
data:image/s3,"s3://crabby-images/cd568/cd56856795e92dd97a19a5e3adad41d8858a4549" alt="image-20220827232018116"
3.2 查看 .ssh 目录下的文件
cd .ssh
cat id_rsa.pub
data:image/s3,"s3://crabby-images/71857/718574e949378f53734d047d6cf7ceb9025a7ed8" alt="image-20220827232355616"
将秘钥全部复制
3.3 在 GitHub 配置该 SSH 公钥
登录 GitHub 账户后,进入Settings中的SSH and GPG keys项执行配置:
data:image/s3,"s3://crabby-images/2a183/2a18367a70e89c0bd710a853cd0c5e0aaa0720be" alt="image-20220827232156887"
data:image/s3,"s3://crabby-images/4346e/4346eb0e97c179cae4ee0670e80ea7e0b69c1edb" alt="image-20220827232550986"
3.4 更改在本地的远程库地址
使用git remote set-url <Alias4RemoteRepositoryAddress> <RemoteRepositoryAddress> 命令,将远程库地址由 HTTPS 方式切换为 SSH 方式:
data:image/s3,"s3://crabby-images/4bb1c/4bb1c77c13d294a32b20a1169c55667c548d93ae" alt="image-20220827233228262"
也可以直接添加一个新的别名origin_ssh
data:image/s3,"s3://crabby-images/6ed95/6ed95c58cef2cfc905c4c68f5a85e07e85d6fb3b" alt="image-20221006192328180"
随后,即可使用 SSH 的方式免密读写 GitHub 的内容。
data:image/s3,"s3://crabby-images/9297e/9297e8bbf670e9888676a25f39b12deb514e6dfe" alt="image-20221006192705628"
data:image/s3,"s3://crabby-images/307ee/307eeeb2bb718d20b25b47704825521fb5d6bdb1" alt="image-20221006192719254"
4.解决冲突
4.1 冲突的产生
冲突的产生:本地仓库与线上不一致时未git pull就开始编写代码 并且在编写完代码后试图git push
data:image/s3,"s3://crabby-images/7d111/7d111138ea8800d4abb06e4020abab8433327d7a" alt="image-20221006193046462"
4.2 解决冲突
- 要点
- 如果不是基于 GitHub 远程库的最新版所做的修改,不能推送,必须先拉取。
- 拉取下来后如果进入冲突状态,则按照“分支冲突解决”操作解决即可。
- 首先我要在两个本地库更改
test2.txt 中的内容
dselegent
data:image/s3,"s3://crabby-images/5b2a6/5b2a6dfe61d84e5e18093ce32b573476f3dceea3" alt="image-20221006194022775"
dselegent-gmail
data:image/s3,"s3://crabby-images/f71e3/f71e3f1ba77446d7291017d3c980ec4ffb60ccd4" alt="image-20221006194132829"
dselegent 推送到远程库
data:image/s3,"s3://crabby-images/78cc7/78cc7a1f175035d2581d74f2adce601ed08f7a0a" alt="image-20221006194251330"
data:image/s3,"s3://crabby-images/e9153/e9153899921aa8bd89905ecdc41f26ba7d929b08" alt="image-20221006194305353"
data:image/s3,"s3://crabby-images/8db62/8db62d383fc1e3f0ecbb1c02aaf16100e8533032" alt="image-20221006194313397"
dselegent-gmail 推送到远程库
data:image/s3,"s3://crabby-images/588b7/588b78085480aa149f3e966b878bc338c8fb2b65" alt="image-20221006194350085"
- 在
dselegent-gmail 中使用git pull origin master 拉取最新的内容
pull=fetch+merge
git fetch [远程库地址别名]
git merge [远程库地址别名/远程分支名】
git pull [远程库地址别名] [远程分支名]
data:image/s3,"s3://crabby-images/537d6/537d6fc393318224835b05e290627e14528a69c8" alt="image-20221006194801202"
data:image/s3,"s3://crabby-images/5cbbf/5cbbfecfe64fcb29e563406734b83818fac5aa6f" alt="image-20221006194846829"
data:image/s3,"s3://crabby-images/5bbfa/5bbfaaec77a3cb3e18ffa78d83f2140667573ee8" alt="image-20221006195232425"
dselegent-gmail 推送到远程库
data:image/s3,"s3://crabby-images/f945a/f945afb50993bc397a097c4cbd0b568de36d40fb" alt="image-20221006195309995"
data:image/s3,"s3://crabby-images/4e8ac/4e8ac2fc5d90e3d969afc501c8ca3ffacf62be69" alt="image-20221006195326732"
data:image/s3,"s3://crabby-images/db7e8/db7e8d7742d79b0f04cdfc4ac80671527417aaa7" alt="image-20221006195334121"
5.跨团队协作
这里先把dselegent-gmail 退出团队用来做示例
- 点击右上角
fork
data:image/s3,"s3://crabby-images/61c60/61c60369141092861aea95d310822709ce4e2012" alt="image-20221006195537205"
data:image/s3,"s3://crabby-images/fcf85/fcf85bb3f6c5405eee6f48184ed963b155747f69" alt="image-20221006200645023"
- 克隆到本地
data:image/s3,"s3://crabby-images/9231c/9231c80d72d8791c45f702f358b6a1d8743b244c" alt="image-20221006200507493"
- 修改文件推送到远程库
data:image/s3,"s3://crabby-images/a6051/a60519538f55c58d5e16ee51e464767b2c0fba2d" alt="image-20221006200627526"
Pull Request
data:image/s3,"s3://crabby-images/c2b36/c2b368292f70b6082c6b1383ce9a2db2dd06cca0" alt="image-20221006200928505"
data:image/s3,"s3://crabby-images/9e6d2/9e6d2073aa7400d056014fa25499f3a3a1f424b1" alt="image-20221006200916957"
-
在dselegent 中接收 data:image/s3,"s3://crabby-images/660a2/660a20cd00531acd59b4448a14af1f2ed4168267" alt="image-20221006201438135"
data:image/s3,"s3://crabby-images/dcbda/dcbda93939973f5a790ceaa3a7cc47f9b99ef07e" alt="image-20221006201507387"
data:image/s3,"s3://crabby-images/980b0/980b09c7500c76dab948df32a3643713e5fafdb3" alt="image-20221006201542512"
|