字节二面:细节拉满!回去等通知?

今天分享一位读者春招的字节二面面经,岗位是后端开发 。
一个编程语言都没问,都是问网络+项目+mysql+redis 。
问题记录使用消息中间件降低消息持久化的压力是怎么做的,为什么可以降低?
读者答:在突发大量消息的情况下可以做到流量削峰 , 在消费者消费能力达不到生产者产生消息的速度时也能够正常运行 。
怎么解决消息队列上的消息堆压?
【字节二面:细节拉满!回去等通知?】读者答:

  • (1)自身场景下 , 消息堆压是暂时的,消息堆压只是突发状况 , 就算不额外处理,随着时间流逝也可消费完毕 。
  • (2)假如存在持续性消息堆压,可以考虑临时增加消费者的数量,提升消费者的消费能力 。
小编补充:
如果是线上突发问题,要临时扩容,增加消费端的数量,与此同时,降级一些非核心的业务 。通过扩容和降级承担流量,这是为了表明你对应急问题的处理能力 。其次,才是排查解决异常问题,如通过监控,日志等手段分析是否消费端的业务逻辑代码出现了问题,优化消费端的业务处理逻辑 。
在并发编程时,在需要加锁时,不加锁会有什么问题?
读者答:两个线程使用同一个全局变量会有不一致的问题,比如a线程把全局变量加1 , b线程读的时候,如果还是从缓存中读的,那么会没有发现这个更新,就会产生不一致的问题 。
如何避免出现死锁?
读者答:在使用之前,考虑死锁产生的条件:互斥访问、占有并保持、循环等待 。
针对以上几点,可以:资源一次性分配、占有时可被打断、考虑资源分配顺序 。
HTTP状态码有哪些?
读者答:
  • 1xx信息的响应,比如100表示临时响应 。
  • 2xx成功 。
  • 3xx重定向,301永久更改,308临时更改(是308么?)哦不,是307 , 记得不是很清楚了 。
  • 4xx客户端问题,404 not found找不到资源,403 客户端没有访问权限 。
  • 5xx服务端问题,502网关问题 。
面试官:307其实是临时没错 , 他是比较新的版本,旧的是 302,现在业界还是旧的用的比较多 。
小编补充:
五大类 HTTP 状态码
1xx 类状态码属于提示信息 , 是协议处理中的一种中间状态,实际用到的比较少 。
2xx 类状态码表示服务器成功处理了客户端的请求,也是我们最愿意看到的状态 。
  • 「200 OK」是最常见的成功状态码,表示一切正常 。如果是非 HEAD 请求,服务器返回的响应头都会有 body 数据 。
  • 「204 No Content」也是常见的成功状态码,与 200 OK 基本相同,但响应头没有 body 数据 。
  • 「206 Partial Content」是应用于 HTTP 分块下载或断点续传,表示响应返回的 body 数据并不是资源的全部,而是其中的一部分,也是服务器处理成功的状态 。
3xx 类状态码表示客户端请求的资源发生了变动 , 需要客户端用新的 URL 重新发送请求获取资源,也就是重定向 。
  • 「301 Moved Permanently」表示永久重定向 , 说明请求的资源已经不存在了,需改用新的 URL 再次访问 。
  • 「302 Found」表示临时重定向,说明请求的资源还在,但暂时需要用另一个 URL 来访问 。
301 和 302 都会在响应头里使用字段 Location , 指明后续要跳转的 URL,浏览器会自动重定向新的 URL 。
  • 「304 Not Modified」不具有跳转的含义,表示资源未修改 , 重定向已存在的缓冲文件,也称缓存重定向,也就是告诉客户端可以继续使用缓存资源,用于缓存控制 。
4xx 类状态码表示客户端发送的报文有误,服务器无法处理,也就是错误码的含义 。
  • 「400 Bad Request」表示客户端请求的报文有错误,但只是个笼统的错误 。
  • 「403 Forbidden」表示服务器禁止访问资源,并不是客户端的请求出错 。
  • 「404 Not Found」表示请求的资源在服务器上不存在或未找到,所以无法提供给客户端 。
5xx 类状态码表示客户端请求报文正确,但是服务器处理时内部发生了错误 , 属于服务器端的错误码 。
  • 「500 Internal Server Error」与 400 类型,是个笼统通用的错误码,服务器发生了什么错误,我们并不知道 。
  • 「501 Not Implemented」表示客户端请求的功能还不支持,类似“即将开业,敬请期待”的意思 。
  • 「502 Bad Gateway」通常是服务器作为网关或代理时返回的错误码,表示服务器自身工作正常,访问后端服务器发生了错误 。
  • 「503 Service Unavailable」表示服务器当前很忙,暂时无法响应客户端,类似“网络服务正忙,请稍后重试”的意思 。
HTTP1.0和2.0的区别 , 或者2.0和3.0的区别?
读者答: