铠甲网络面试(部分)

所以可能需要五六十个结点。

  • 哪些场景会导致索引失效?使用OR一定会失效吗,什么情况下使用OR不会失效?

    相关知识:[1](#1) or语句前后没有同时使用索引,会发生索引失效。将key<>0 改为 key>0 or key<0,会用到索引;

    为了可以用到索引,可将 OR 运算符拆分成多个查询条件,并使用 UNION进行组合[2](#2),[3](#3)

    但是也有可能会发生索引合并[4](#4) : The Index Merge[5](#5) access method retrieves rows with multiple range scans and merges their results into one. This access method merges index scans from a single table only, not scans across multiple tables.

  • Redis在存储方面有哪些优化?采取了一些特殊编码。epoll的底层有了解吗?相关知识(参考bing与[6](#6)):

epoll是Linux下的一种高效的IO多路复用机制,它可以监听多个文件描述符(fd)(一个IO连接是通过套接字(socket)来实现的,套接字是一种特殊的文件描述符) 的事件,如可读、可写、异常等。epoll的底层原理主要有三个方面:

  1. epoll使用一个红黑树来管理所有的fd,每个fd对应一个epoll_event结构体,存储了fd的信息和事件类型。
  2. epoll使用一个双向链表来存储就绪的fd,每次调用epoll_wait时,只需要遍历这个链表,而不需要像select那样遍历所有的fd。
  3. epoll使用内核回调函数 来通知用户空间的进程或线程,当某个fd发生了感兴趣的事件 时,内核会将该fd插入到就绪链表中,并唤醒等待在epoll_wait上的进程或线程。
    • epoll的流程,和它的几个关键的函数?Answer by bing:
      epoll的流程大致如下:
      调用epoll_create()函数创建一个epoll对象,返回一个文件描述符(fd)。
      调用epoll_ctl()函数将要监听的fd添加到epoll对象中,指定感兴趣的事件类型(如读、写、异常等)。
      调用epoll_wait()函数等待epoll对象中的fd发生事件,返回就绪的fd和事件类型。
      处理就绪的fd和事件,然后重复第三步,直到不需要监听了。
      调用close()函数关闭epoll对象的fd,释放资源。

epoll的关键函数有:

epoll_create():创建一个epoll对象,返回一个fd。

epoll_ctl():向epoll对象中添加、修改或删除要监听的fd和事件类型。

epoll_wait():等待epoll对象中的fd发生事件,返回就绪的fd和事件类型。

  • TCP如何实现流量控制?相关知识from bing: 发送窗口的大小取决于接收方窗口和拥塞窗口的最小值。接收端通过TCP首部的通告窗口字段来向发送端通告接收窗口。Q:发送方超时重传后,有没有可能导致接收方重复接收数据

  • JDK从哪个版本开始使用G1作为默认垃圾回收器的?A:JDK9


  1. Mysql索引失效的场景 ↩︎

  2. or为什么会导致索引失效 ↩︎

  3. Stackoverflow : MySQL: how to index an "OR" clause ↩︎

  4. https://dev.mysql.com/doc/refman/8.0/en/index-merge-optimization.html ↩︎

  5. 为什么where条件中使用or索引不起作用? ↩︎

  6. 知乎----深入理解 Linux 的 epoll 机制及epoll原理 ↩︎

相关推荐
利刃大大2 天前
【高并发服务器】十三、TcpServer服务器管理模块
服务器·高并发·项目·cpp
Lucky小小吴7 天前
开源项目解读4-高性能并发缓存库Ristretto
缓存·开源·高并发·高性能缓存·实时数据处理·ristretto·tinylfu
利刃大大8 天前
【高并发服务器】十、Connection连接管理模块设计与实现
服务器·c++·高并发·项目
白帽子黑客罗哥9 天前
Redis实战深度剖析:高并发场景下的架构设计与性能优化
redis·网络安全·性能优化·高并发·分布式锁·秒杀系统·缓存架构
扶尔魔ocy10 天前
【Linux C/C++开发】epoll模式的开源库及原生socket实现
linux·网络编程·epoll
Javatutouhouduan13 天前
2025Java高质量面试真题汇总!
java·高并发·java面试·java面试题·后端开发·java架构师·java八股文
递归尽头是星辰17 天前
Java成长之路 | 技术专栏导航页
高并发·微服务架构·flink实时计算·java架构师·olap分析
冰 河20 天前
《高性能SQL引擎》总结-高性能SQL引擎整体专栏总结
性能优化·程序员·高并发·架构师·高性能
虫师c1 个月前
分布式系统实战:电商平台架构演进
微服务·架构·高并发·架构演进·分布式系统·电商架构
charlie1145141911 个月前
理解C++20的革命特性——协程引用之——利用协程做一个迷你的Echo Server
网络·学习·socket·c++20·协程·epoll·raii