Git常见面试题

1.git常用命令

1.mkdir  创建文件夹

2.clear  清屏

3. git config --global user.name "Your Name"

   git config --global user.email "email@example.com"

  设置全局的用户名和邮箱

4.git init  把当前的文件夹初始化为本地仓库

5.git add 文件名/.  把文件存到暂存区

6.git commit -m "注释" 把文件存入到本地仓库

7.git diff  查看文件与上一个版本的不同

8.git status 查看当前的版本库的状态

9.git log 查看当前的提交信息

10.git reflog 查看提交命令的日志

11.git reset --hard 版本号  回退版本

12.git clone  远程的地址 把远程仓库克隆到本地并且创建出一个本地仓库

13.git push -u origin master  把本地仓库的内容推送到远程仓库  使用码云

14.git pull  从远程仓库更新内容到本地(它会自动更新内容 自动merge内容)

15.git branch dev  创建分支

16.git checkout dev/git switch 分支名称  切换分支

17.git checkout -b dev /git switch -c 分支名称 切换并创建分支

18.git branch  查看当前的分支

19.git merge 命令用于合并指定分支到当前分支

20.git branch -d  删除分支

21.git remote add origin 远程仓库的地址  把本地仓库和远程仓库连接起来

22.git push -u origin main(github)把本地仓库的内容推送到远程仓库使用github

23.git rm 文件名  删除git仓库中的文件

24.git fetch 从远程仓库更新内容到本地但是不会自动更新需要合并分支到本地(git merge 手动合并)

25.git stash

        保存当前的工作区与暂存区的状态,把当前的修改的保存到git 栈,等以后需要的时候再恢复,git stash 这个命令可以多次使用,每次使用都会新加一个stash@{num},num是编号

26.git stash pop

        默认恢复git栈中最新的一个stash@{num},建议在git栈中只有一条的时候使用,以免混乱

        注:该命令将堆栈中最新保存的内容删除

27.git stash list

        查看当前stash的所有内容

28.git stash apply

        将堆栈中的内容恢复到当前分支下。这个命令不同于 git stash pop。该命令不会将内容从对堆栈中删除,也就是该命令能够将堆栈的内容多次运用到工作目录,适合用与多个分支的场景

        使用方法:git stash apply stash@{$num}

29.git rebase 合并分支保证分支的完美线性

2.Git中git pull和git fetch的区别

git fetch只是将远程仓库的最新的版本下载到本地,但是不会自动merge,相当于工作区中的文件并没有更新

git pull会从远程仓库获取到最新的版本并merge到本地。

git pull origin dev=git fetch origin dev+git merge origin/dev;

git fetch更保险一些,git pull操作更简单

  1. git merge和git rebase的区别

git merge 操作合并分支会让两个分支的共同提交点之后每一次提交都按照提交时间(并不是push时间)排序,并且会将两个分支的最新一次commit点进行合并成一个新的commit,最终的分支树呈现非整条线性直线的形式

git rebase操作实际上是将当前执行rebase分支的所有基于原分支提交点之后的commit打散成一个一个的patch,并重新生成一个新的commit hash值,再次基于原分支目前最新的commit点上进行提交,并不根据两个分支上实际的每次提交的时间点排序,rebase完成后,切到基分支进行合并另一个分支时也不会生成一个新的commit点,可以保持整个分支树的完美线性

  1. GIT提交时发生冲突,如何解决?

为什么会产生冲突?

因为在合并分支的时候,master分支和dev分支恰好有人都修改了同一个文件,GIT不知道应该以哪一个人的文件为准,所以就产生了冲突了。 两个分支相同文件相同位置的的不同操作!

如何解决?

发生冲突,在IDE里面一般都是对比本地文件和远程分支的文件,然后把远程分支上文件的内容手工修改到本地文件,然后再提交冲突的文件使其保证与远程分支的文件一致,这样才会消除冲突,然后再提交自己修改的部分。特别要注意下,修改本地冲突文件使其与远程仓库的文件保持一致后,需要提交后才能消除冲突,否则无法继续提交。必要时可与同事交流,消除冲突。

发生冲突,也可以使用命令。

通过git stash命令,把工作区的修改提交到栈区,目的是保存工作区的修改;

通过git pull命令,拉取远程分支上的代码并合并到本地分支,目的是消除冲突;

通过git stash pop命令,把保存在栈区的修改部分合并到最新的工作空间中;

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
以下是 Spring Cloud 常见面试题及其答案: 1. 什么是 Spring Cloud? Spring Cloud 是一个基于 Spring Boot 实现的云应用开发工具,它提供了一整套分布式应用服务治理的解决方案,包括配置管理、服务发现、断路器、路由、微代理、事件总线、全局锁、分布式会话等等。 2. 什么是 Eureka? Eureka 是 Spring Cloud 的服务注册和发现组件,它提供了一种简单的方式来注册和发现服务。Eureka 通过 RESTful API 来实现服务注册和发现,它可以自动处理服务的故障转移,保证服务的高可用性。 3. 什么是 Ribbon? Ribbon 是 Spring Cloud 的负载均衡组件,它可以将请求分发到多个服务提供者中,并根据负载均衡策略选择合适的服务提供者。Ribbon 支持多种负载均衡策略(如轮询、随机、加权等),并且可以自定义负载均衡策略。 4. 什么是 Hystrix? Hystrix 是 Spring Cloud 的容错组件,它可以保护分布式系统中的服务免受故障的影响。Hystrix 通过断路器模式来实现容错处理,当某个服务发生故障时,它会将请求快速地熔断,避免故障的扩散,并提供降级方案,尽可能地保证服务的可用性。 5. 什么是 Feign? Feign 是 Spring Cloud 的声明式 REST 客户端,它可以让开发者更加方便地调用 RESTful API。Feign 提供了基于注解的编程模型,开发者可以使用简单的注解来定义 REST 接口,而无需编写繁琐的 HTTP 客户端代码。 6. 什么是 Zuul? Zuul 是 Spring Cloud 的网关组件,它可以将请求路由到不同的服务中,并提供了一些高级功能,如身份验证、流量控制、日志记录等。Zuul 可以作为一个独立的服务运行,也可以与 Eureka、Ribbon、Hystrix 等组件一起使用。 7. 什么是 Config? Config 是 Spring Cloud 的配置管理组件,它可以将配置信息集中管理,并提供动态刷新功能。Config 可以将配置信息存储在 Git、SVN 等版本控制系统中,通过 Spring Cloud Bus 实现配置信息的动态刷新。

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值