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后端开发工程师非常重要。