第一轮面试题

 

一、描述下数据库中的事务--ACID各个的特点。

原子性:事务中的操作要么全部成功要么全部失败。

一致性:事务前后数据的完整性必须保持一致。

隔离性:多个并发的事务之间是相互隔离的,互不干扰的。

持久性:事务提交后,数据是永久改变的。

 

二、什么是springboot?你们公司是用的哪个版本?

SpringBoot是Spring推出用于解决传统框架配置文件冗余,装配组件繁杂的基于Maven的解决方案,旨在快速搭建单个微服务。

版本号:2.1.6

 

三、什么是redis?

Redis 是完全开源免费的,遵守BSD协议,是一个高性能的key-value数据库。

 

四、如何理解springcloud微服务项目中,eureka,provider,consumer它们之间的关系?

eureka:提供服务注册于发现

provider:服务提供方法将自身注册到eureka,让消费方找到

consumer:服务消费方从eureka获取注册服务列表,能够消费服务

 

五、mysql默认的存储引擎是什么?

Mysql在V5.1之前默认存储引擎是MyISAM;在此之后默认存储引擎是InnoDB。

MyISAM不支持事务,InnoDB支持事务。
MySIAM不支持外键,InnoDB支持外键,
MySIAM支持全文索引,InnoDB不支持全文索引。

 

六、什么是跨域?

要了解跨域,先要说说同源策略。所谓同源是指,域名,协议,端口相同,有一个不一样则是跨域。

 

七、什么是token?

Token是服务端生成的一串字符串,以作客户端进行请求的一个令牌。

当第一次登录后,服务器生成一个Token便将此Token返回给客户端,

以后客户端只需带上这个Token前来请求数据即可,无需再次带上用户名和密码。

 

八、什么是RESTful?

首先rest是一种API的模式,常以JSON格式编写。符合rest约束风格和原则的应用程序或设计就是RESTful。

 

九、SpringCloud解决了哪些问题?

与分布式系统相关的复杂性

处理服务发现的能力

解决冗余问题

负载平衡

减少性能问题

 

十、微服务中什么是熔断?什么是服务降级?

服务熔断的作用是当某服务出现不可用或响应超时的情况时,为了防止整个系统出现雪崩,暂时停止对该服务的调用。       

服务降级是为了预防某些功能(业务场景)出现负荷过载或者响应慢的情况,在其内部暂时舍弃对一些非核心的接口和数据的请求,而直接返回一个提前准备好的fallback(退路)错误处理信息。

 

十一、微服务的优缺点是什么?

优点:

易于开发和维护:因为一个服务只关注一个特定的业务,业务就变得比较清晰。同时维护起来也是比较方便。
单个服务启动比较快:单个服务代码量不会很多,启动起来就会很快。
便于伸缩:如果系统中有三个服务ABC,服务B的访问量比较大,我们可以将服务B集群部署。


缺点:
运维要求比较高:之前就一个war包,现在一个系统中会有很多的服务,每个服务都对应一个war包,维护起来就会变得很麻烦。
技术复杂性提高:微服务就会带来一系列的问题,事务问题,Session一致性问题,锁问题等。

 

十二、微服务之间如何独立通讯的?

同步通信:dobbo通过 RPC 远程过程调用、springcloud通过 REST接口json调用等。

异步:消息队列,如:RabbitMq、ActiveMq、Kafka 等。

 

十三、SpringCloud 和 Dubbo 有哪些区别?

首先,他们都是分布式管理框架。

    dubbo 是二进制传输,占用带宽会少一点。SpringCloud是http 传输,带宽会多一点,同时使用http协议一般会使用JSON报文,消耗会更大。

    SpringCloud 接口协议约定比较松散,需要强有力的行政措施来限制接口无序升级。

最大的区别:

    Spring Cloud抛弃了Dubbo 的RPC通信,采用的是基于HTTP的REST方式。

 

十四、SpringBoot 和 SpringCloud 之间关系?

SpringBoot:专注于快速方便的开发单个个体微服务(关注微观);

SpringCloud:关注全局的微服务协调治理框架,将SpringBoot开发的一个个单体微服务组合并管理起来(关注宏观);

SpringBoot可以离开SpringCloud独立使用,但是SpringCloud不可以离开SpringBoot,属于依赖关系。

 

十五、eureka和zookeeper的区别?

eureka和zookeeper都可以提供服务注册与发现的功能,zookeeper 是CP原则,强一致性和分区容错性。eureka 是AP 原则 可用性和分区容错性。

zookeeper当主节点故障时,zk会在剩余节点重新选择主节点,耗时过长,虽然最终能够恢复,但是选取主节点期间会导致服务不可用,这是不能容忍的。

eureka各个节点是平等的,一个节点挂掉,其他节点仍会正常保证服务。

 

十六、mycat是什么?你们公司分库分表的分片规则是什么?

Mycat是基于MySQL的数据库中间件,用来协调切分后的数据库,使其可以进行统一管理。

分片规则:取模分片 PartitionByMode

 

十七、什么是集合?

集合有两个父接口,一个collection,一个Map;

而collection有两个子接口,一个List,一个Set;

List有两个常见的实现类 ArrayList,LinkedList;

Set有两个常见的实现类 HashSet,TreeSet;

Map有两个常见的实现类 HashMap,HashTable。

 

十八、什么是dubbo?

Dubbo和Springcloud都是分布式服务中常用的框架。dubbo与cloud不同,dubbo基于RPC协议。它提供了三大核心功能: 面向接口的远程方法调用,

智能容错和负载均衡, 以及服务自动注册和发现。

 

十九、什么是spring?

Spring是一个开源的轻量级的Java开发框架。是一种简化应用程序的开发。

在spring出来之前,service层调用dao层都是用new的方式,在spring出来之后,service层和到dao层都会放在spring容器去管理,
这是spring的第一种特性,我们称之为IOC,控制反转。

spring还有一种特性,我们称之为AOP,大白话,所谓“面向切面”,说白了就是专门的人干专门的事。
在项目很多公有的或是要被重复被调用的模块可以被抽取出来,利用的就AOP的特性,例如日志模块。

 

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 1
    评论
引用\[1\]:这是一个相对艰难的多线程面试,它能达到很多的目的。第一,它可以检测侯选者是否能实际的用Java线程写程序;第二,可以检测侯选者对并发场景的理解,并且你可以根据这个问很多问。如果他用wait()和notify()方法来实现阻塞队列,你可以要求他用最新的Java 5中的并发类来再写一次。\[1\] 引用\[2\]:这是一道出现在多线程面试的高级阶段的问。大多数的面试官会问最近你遇到的竞争条件,以及你是怎么解决的。有些时间他们会写简单的代码,然后让你检测出代码的竞争条件。可以参考我之前发布的关于Java竞争条件的文章。在我看来这是最好的java线程面试之一,它可以确切的检测候选者解决竞争条件的经验,orwriting code which is free of data race or any otherrace condition。关于这方面最好的书是《Concurrency practices in Java》。\[2\] 引用\[3\]:这是另一个非常经典的java多线程面试。这也是我刚开始写线程程序时候的困惑。现在这个问通常在电话面试或者是在初中级Java面试的第一轮被问到。这个问的回答应该是这样的,当你调用start()方法时你将创建新的线程,并且执行在run()方法里的代码。但是如果你直接调用run()方法,它不会创建新的线程也不会执行调用线程的代码。阅读我之前写的《start与run方法的区别》这篇文章来获得更多信息。\[3\] 问: 2023java 多线程面试 回答: 2023年的Java多线程面试可能会涉及到多个方面的问。其中一个可能是要求候选者用Java线程编写程序,以检测他们的实际操作能力和对并发场景的理解。另一个可能是关于竞争条件的问面试官可能会询问候选者最近遇到的竞争条件以及他们是如何解决的。还有一个经典的问是关于start()方法和run()方法的区别,候选者需要知道调用start()方法会创建一个新的线程并执行run()方法中的代码,而直接调用run()方法则不会创建新的线程。对于这些问,候选者可以参考相关的书籍和文章来加深理解和准备面试。\[1\]\[2\]\[3\] #### 引用[.reference_title] - *1* *2* *3* [15个顶级Java多线程面试及答案](https://blog.csdn.net/2301_78102191/article/details/131085355)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v91^control_2,239^v3^insert_chatgpt"}} ] [.reference_item] [ .reference_list ]

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值