使用环境: Ubuntu 20.04 & Git & GitHub
本地仓库:指在电脑硬盘中保存的项目文件夹
远程仓库:指在GitHub中保存的项目文件夹
首先创建一个新的空的文件夹:
mkdir YOUR_REPOSITORY_NAME # 创建自己的文件夹,可以任意命名
进入该文件夹,并且初始化git
cd YOUR_REPOSITORY_NAME # 根据具体情况输入你的文件夹路径,不要直接复制粘贴
git init # 初始化本地git,完成后文件夹内会出现一个.git文件,通过显示隐藏文件可以看到
初始化之后,如果你的远程仓库是早前已经创建好的,可以跳过这一步,如果当前你的项目没用对应的远程仓库,那么在GitHub创建一个repo即可
接下来,将本地仓库与远程仓库链接
git remote add origin 'your_url_name'
此处的 ‘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
after generating the Personal access tokens, save it and type it in the password blank when push & pull
完成后,此时本地仓库就和远程仓库相连了,我们就可以从terminal直接拉去远程仓库的代码到本地了,
但是在拉取之前,请确认是否有.gitignore文件
git pull origin master
如果报错: Fatal: Refusing to merge unrelated histories
那么说明你本地可能有一些其他的文件,和远程仓库对应不上,这时我们可以使用强制合并命令:
git pull origin master --allow-unrelated-histories
这样本地仓库就和远程仓库同步了
至此,配置部分结束
可以用以下命令来检查代码
git status # 查看本地仓库文件的跟踪状态
本节参考:https://www.datacamp.com/community/tutorials/git-push-pull
git add . # 将本地文件全部添加到暂存区
# git add作用是将代码提交到暂存区
# git add .:将已经跟踪的进行了修改的文件以及新增加的文件提交到暂存区
# git add -u .:将跟踪的修改或删除的文件提交
# git add -a .:包括了前两项
# git add -i .:作用范围同-u
git commit -m 'message' # 将更新后的被追踪代码提交到本地branch中,相当于修改了本地仓库的状态
git push origin master # 将本地origin分支的代码推送到远程 master分支中
当拥有本地仓库和远程仓库之后,可以通过git pull直接拉取远程仓库并合并到local branch,方法如下:
git pull repo_address branch_name
这里的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
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
step1 取消本地目录下关联的远程库:
git remote remove origin
step2 重新初始化本地仓库
git init
rm -rf .git # -rf means --recursive and --force
这样本地仓库就和远程仓库完全无关并且被清空了
git config -l
or
git config --global user.name
git config --global user.email
git config --global user.name "YOUR NAME"
git config --global user.email "YOUR EMAIL"
NOTE: 如果发现自己的commit没有在github的commit history中出现,并且repo的commit用户名点开不是自己,那就要考虑是否是上述两个参数没设置或者写错了