app后端开发面试题

1. 什么是RESTful API?

RESTful API是符合RESTful架构风格的API,它是基于HTTP协议的一种Web API,使用简单的HTTP;

RESTful架构风格是一种客户端/服务端之间基于HTTP协议进行通信的架构风格,其中客户端和服务端可以完全分离,客户端处理用户界面,服务端负责数据存储和业务逻辑处理,它可以支持多种数据格式,比如JSON、XML等,根据请求方式不同,对应不同的处理方式,如GET、POST等;

2. 什么是缓存?为什么要使用缓存?缓存一般有哪些种类?

缓存是将数据预先存放在内存或其他高速存储器中,以便快速响应后续的请求,提高系统性能;

使用缓存的主要原因是减轻服务器或数据库的负荷,避免重复请求和计算,提高请求速度、降低响应延迟、节省服务器资源;

缓存一般分为三大类:

1)本地缓存:存在客户端本地,比如浏览器缓存、本地存储(如cookie、Localstorage等)等;

2)服务器端缓存:存储在服务器内存中的缓存,比如常见的Memcached、Redis等;

3)CDN缓存:分布式缓存,存储在全球各地的CDN(Content Delivery Network)节点上,能够提供更快的访问速度;

3. 什么是分库分表?为什么需要分库分表?

分库分表指将数据库中的表按照一定规则拆分成多个库或多个表,以解决数据量大的问题,提升数据库性能和可扩展性;

分库分表的原因主要有以下几点:

1)数据规模增大,单个数据库的读写操作会面临性能瓶颈;

2)数据库容量不足,数据量的增加会引起存储储量的不足;

3)增加服务的可用性和灵活性,避免单点故障,提升系统的可扩展性,降低风险,实现高可用、高并发;

4)上述优化可以给系统的拓展性带来巨大的提升。

4. 什么是消息队列?使用场景有哪些?

消息队列是一种通信模式,分为生产者、消费者、队列三个部分,它可以异步处理、解耦和削峰;

消息队列的主要使用场景有以下几点:

1)异步处理:避免生产者和消费者直接交互,解耦设计,提高系统的灵活性。

2)削峰:通过缓存请求并将其放入消息队列,从而平衡高峰期的流量,并提高负载均衡能力。

3)解耦:使用消息队列可以在不同的系统或者服务间进行通信,实现松耦合的设计,降低系统间的依赖关系。

4)重试机制:如果产生了某些不可用或者失败的操作,可以将它交由消息队列进行重试,提高数据的成功率。

5. 什么是数据库事务?ACID是什么?

数据库事务是指一组SQL语句的执行,它为用户提供了访问和操作数据库的机制,由一个事务开始执行的SQL语句序列和一组提交和回滚操作组成;

ACID是事务的四个基本特性,即原子性、一致性、隔离性和持久性;

1)原子性(Atomicity):一个事务中的所有操作要么全部执行,要么全部不执行,同时成功或同时失败。

2)一致性(Consistency):事务开始和结束时,数据库都应该保持一致性状态。

3)隔离性(Isolation):多个事务并发执行时是相互隔离的,每个事务看到的状态是独立的,互不干扰。

4)持久性(Durability):事务提交后,它所做的更新操作将永久保存在数据库中,不会被回滚。

以上就是一些app后端开发的面试题,这些问题都是针对面试人员在理论知识方面的掌握程度,熟练掌握以上知识点对于app后端开发工程师非常重要。

川公网安备 51019002001185号