当前位置: 首页 > news >正文

【git 本地管理版本及与github合并】 Init Push Pull操作解决方案

文章目录
  • 创建本地仓库,并与远程仓库链接
  • 更新本地仓库并使用Push推送到远程仓库
        • 1. 几种基础命令介绍:
        • 2. git push操作流程
  • .gitignore
  • 删除本地仓库,断开本地与远程的链接
  • 设置用于提交commit的用户名,邮箱,以便github识别


使用环境: Ubuntu 20.04 & Git & GitHub


创建本地仓库,并与远程仓库链接

本地仓库:指在电脑硬盘中保存的项目文件夹
远程仓库:指在GitHub中保存的项目文件夹

首先创建一个新的空的文件夹:

mkdir YOUR_REPOSITORY_NAME # 创建自己的文件夹,可以任意命名
  • 1

进入该文件夹,并且初始化git

cd YOUR_REPOSITORY_NAME # 根据具体情况输入你的文件夹路径,不要直接复制粘贴
git init # 初始化本地git,完成后文件夹内会出现一个.git文件,通过显示隐藏文件可以看到
  • 1
  • 2

初始化之后,如果你的远程仓库是早前已经创建好的,可以跳过这一步,如果当前你的项目没用对应的远程仓库,那么在GitHub创建一个repo即可

接下来,将本地仓库与远程仓库链接

git remote add origin 'your_url_name'
  • 1

此处的 ‘your_url_name’ 指的是你远程仓库的http地址,通过仓库主页的code按钮下拉菜单可以看到自己的url地址
在这里插入图片描述

上述命令运行之后,会要求你输入github的账号和密码,有时输入密码的部分会需要输入Personal Access Token,这部分的教程可以参考以下网址:
solving ERROR: password authentication was removed please use a personal access token instead:

https://stackoverflow.com/questions/68775869/support-for-password-authentication-was-removed-please-use-a-personal-access-to
  • 1

after generating the Personal access tokens, save it and type it in the password blank when push & pull

完成后,此时本地仓库就和远程仓库相连了,我们就可以从terminal直接拉去远程仓库的代码到本地了,

但是在拉取之前,请确认是否有.gitignore文件

git pull origin master
  • 1

如果报错: Fatal: Refusing to merge unrelated histories
那么说明你本地可能有一些其他的文件,和远程仓库对应不上,这时我们可以使用强制合并命令:

git pull origin master --allow-unrelated-histories
  • 1

这样本地仓库就和远程仓库同步了

至此,配置部分结束

可以用以下命令来检查代码

git status # 查看本地仓库文件的跟踪状态
  • 1

本节参考:https://www.datacamp.com/community/tutorials/git-push-pull


更新本地仓库并使用Push推送到远程仓库

1. 几种基础命令介绍:
git add . # 将本地文件全部添加到暂存区
# git add作用是将代码提交到暂存区
# git add .:将已经跟踪的进行了修改的文件以及新增加的文件提交到暂存区
# git add -u .:将跟踪的修改或删除的文件提交
# git add -a .:包括了前两项
# git add -i .:作用范围同-u
git commit -m 'message' # 将更新后的被追踪代码提交到本地branch中,相当于修改了本地仓库的状态
  • 1
git push origin master # 将本地origin分支的代码推送到远程 master分支中
  • 1
2. git push操作流程

当拥有本地仓库和远程仓库之后,可以通过git pull直接拉取远程仓库并合并到local branch,方法如下:

git pull repo_address branch_name
  • 1

这里的repo_address指的是在Github clone http位置所显示的链接地址,branch_name指的是在remote repo中看到的branch的名字,通常是master,
所以一般如果拉取自己的仓库,命令就变成了:

# in a initialized dir ( after git init )
git pull https://github.com/XXX/XXX.git master
  • 1
  • 2
git status
git add
git commit -m 'message'
git push ORIGIN MASTER

ORIGIN is the branch that you have locally
MASTER is the branch on the remote repository


.gitignore


删除本地仓库,断开本地与远程的链接

step1 取消本地目录下关联的远程库:

git remote remove origin
  • 1

step2 重新初始化本地仓库

git init
rm -rf .git # -rf means --recursive and --force
  • 1
  • 2

这样本地仓库就和远程仓库完全无关并且被清空了

设置用于提交commit的用户名,邮箱,以便github识别

  1. 查看自己现在的邮箱和用户名
git config -l
or 
git config --global user.name
git config --global user.email
  1. 更改自己的邮箱或用户名
    如果是新装的系统,git中没有自己的用户信息,同样可以用这个方法创建自己的用户名和邮箱
git config --global user.name "YOUR NAME"
git config --global user.email "YOUR EMAIL"

NOTE: 如果发现自己的commit没有在github的commit history中出现,并且repo的commit用户名点开不是自己,那就要考虑是否是上述两个参数没设置或者写错了

http://www.lryc.cn/news/293830.html

相关文章:

  • JavaSE-项目小结-IP归属地查询(本地IP地址库)
  • 使用最大边界相关算法处理文章自动摘要
  • ref和reactive, toRefs的使用
  • 从源代码看Chrome 版本号
  • Vue 图片加载失败处理
  • Quartus IP学习之ISSP(In-System Sources Probes)
  • Vue组件通信讲解[父子组件通信]
  • Qt应用开发(安卓篇)——调用ioctl、socket等C函数
  • centos 安装docker CE
  • 某赛通电子文档安全管理系统 UploadFileList 任意文件读取漏洞复现
  • Kafka运维相关知识
  • 鸿蒙Native项目生产动态库(.so) 和静态库(.a)
  • B站课程评分
  • 【C++】拷贝构造函数和赋值运算符重载详解
  • BUUCTF-Real-[ThinkPHP]5-Rce
  • 物联网中基于WIFI的室内温度检测系统设计
  • 驱动开发-系统移植
  • MySQL数据存储
  • 带着问题读源码——Spring MVC是怎么找到接口实现类的?
  • [NAND Flash 7.1] 闪存系统性能优化方向集锦?AC timing? Cache? 多路并发?
  • 【数据结构】分治策略
  • 【PLC一体机】PLC一体机中如何实现触摸屏和PC电脑的通讯
  • 如何保证订单异步回调的幂等性
  • Linux下vim命令详解
  • 机器学习6-逻辑回归
  • 关于Clone
  • 【C++入门学习指南】:函数重载提升代码清晰度与灵活性
  • MySql主从同步,同步SQL_ERROR 1032解决办法
  • Webpack的性能优化
  • PyTorch中tensor.backward()函数的详细介绍