学习linux_Day05——常用Git操作

Git

基本概念

git是用来进行项目版本控制的

主要包括项目版本的更新,项目版本的回滚,项目分支的创建,以及项目分支的合并,结合代码托管平台进行多人合作

  • 工作区:仓库的目录,也就是你的项目目录,是你进行工作的地方
  • 版本库:存放所有已经提交到本地仓库的代码版本(存放项目的所有版本)
  • 暂存区:作为工作区和版本库中间的桥梁,当我们更新项目中的某个文件时(此时是在工作区中进行修改),可以先将修改的文件存加到暂存区,之后如果又有文件修改,也可把文件加到暂存区,这个时候再将暂存区中所有修改的文件添加到版本库,那么这个时候版本库中就多出一个项目的新版本,完成一次版本更新。我们可以把“修改的文件放到暂存区”看作项目的更新准备,“将暂存区的文件放到版本库”就是完成对项目的一次更新。
  • 版本结构:树结构,树中的每个节点代表着一个项目版本,将代码从暂存区放到版本库,就会创建一个新节点
  • HEAD指针:这个指针指向“版本树”的哪个节点,我们就处于哪个版本中

初次配置

设置名称和邮箱

git config --global user.name "name"
git config --global user.email *******@**.com

设置github等代码托管平台的ssh

ssh-keygen #获取公钥和私钥
cat ~/.ssh/id_rsa.pub #获取公钥
#将公钥复制,粘贴到代码托管平台
git config --global credential.helper store #输入这段配置代码,以后pull和push就不需要密码了

常用命令

本地

  • git init:初始化一个仓库,文件夹就会多出一个.git文件

  • git status:获取当前仓库的状态(包括一些文件的增删,修改,文件在工作区还是暂存区等状态)

  • git add filename:将修改的文件记录添加到暂存区

  • git add .:将对当前版本做出的修改添加到暂存区

  • git commit -m "描述信息":将暂存区中的文件添加到本地版本库中

  • git diff filename:比较当前文件和暂存区中文件的区别

  • git rm --cached filename:将文件从暂存区中删除

  • git restore --staged filename:将加入到暂存区中的文件拿回到工作区,相当于git add filename的撤销操作

  • git restore filename:将还没加入到暂存区的文件中的修改全部撤销,恢复到暂存区文件中的状态

image-20220629151913051

  • git log:查看当前分支最开始到当前版本的所有版本,自上至下是自新到旧,git log --pretty=oneline将所有版本各自单独显示一行

image-20220629151655101

回滚相关


  • git reset --hard HEAD^:回滚到上一个版本
  • git reset --hard HEAD^^:回滚到上上个版本,^依次类推
  • git reset --hard HEAD~100:向上回滚100个版本
  • git reset --hard 版本号:回滚到指定版本,通过git log获取相应版本的版本号(前七位数字)
  • git reflog:获取HEAD指针的轨迹

image-20220629151721400

分支相关


  • git checkout -b branch_name:创建新的分支,并且移动到新的分支

  • git checkout branch_name:切换到另外一个分支

  • git merge brach_name:将另外一个分支的最新版本合并到当前分支中,如果两个分支中的某个文件内容有差异,需要自己手动解决冲突

  • git branch -d branch_name:删除一个本地分支

stash相关


  • git stash:将工作区和暂存区中尚未提交的修改存入栈中,当前做出的修改就看不见了

  • git stash list:查看栈中的所有元素(即所有修改)

  • git stash apply:将栈顶存储的修改恢复到当前分支,但不删除栈顶元素

  • git stash drop:删除栈顶存储的修改

  • git stash pop:将栈顶存储的修改恢复到当前分支,同时删除栈顶元素

远程

将本地现有的仓库推送到远程服务器

首先设置远程服务器的ssh

然后创建远程仓库,复制ssh地址

  • git clone git@git.acwing.com:xxx/XXX.git:将远端仓库下载到当前目录

  • git remote add origin git@git.acwing.com:xxx/XXX.git:将本地仓库与远程仓库关联,然后就可以使用git push进行远端仓库与本地的同步

  • git push -u (第一次需要-u以后不需要):将当前分支推送到远程仓库

    • git push origin branch_name:将本地某个分支推送到远程仓库
  • git push -d origin branch_name:删除一个远端的分支

  • git push --set-upstream origin branch_name:设置本地的branch_name分支对应远程仓库的branch_name分支,当远端没有这个分支,就会在远端创建这个分支

  • git pull:将远程仓库的当前分支与本地仓库的当前分支合并(这里说的当前分支是当前本地分支与远程所绑定二点分支)

    • git pull origin branch_name:将远程仓库的branch_name分支与本地仓库的当前分支合并
  • git branch --set-upstream-to=origin/branch_name1 branch_name2:将远程的branch_name1分支与本地的branch_name2分支对应,用于将远程的分支同步到本地

  • 0
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值