面试 - 003

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6

CDN 什么是 CDN 为什么需要这个

在传统的互联网访问中如果所有用户的请求都打到一个服务器上面那么这个服务器肯定是受不了的所以说将资源分配到不同的服务器上面是有必要的。
用户连接 CDN 服务器的时候有那么多的服务器选择哪一个进行连接是需要选择的。这个时候便是需要使用 CDN 的算法使得用户访问到距离它最近的 CDN 服务器这样一来使得用户的体验感更好了。

TCP 粘包是什么

在客户端向服务器发送数据包的时候可能为了提升数据包传输的效率将多个包合并到一起发送这样就发生了粘包的现象。
数据包到达服务器服务器如果没有正确的解析包那么可能导致数据解析错误导致程序的运行错误。

为了保证 TCP 粘包的问题解决使用下面的方式可以解决
1、固定长度的消息
就是用户发送的消息的长度大小是固定的每个包就是只是发送 64 字节灵活不够高。

2、特殊字符作为边界在服务器收到数据的时候一旦发现某个特殊的字符说明这就是包之间的分界点就能正确的识别数据包。

3、自己定义数数据结构在发送数据的时候明确的写清楚每个包的大小到底是多少那么服务器在解析的时候就能正确的识别每一个包不会导致数据解析出问题。

select 和 epoll 之间的区别

多路复用就是使用一个进程同时监控多个客户端连接或者说同时监听多个文件描述符当发现某个 socket 发生事件时候就调用服务器的相关应用程序处理请求。

多路复用只是监听多个客户端连接的 socket 连接

这是不同的多路复用器里面维护已连接 sockets 的方式不同

select 使用数组维护所有的已连接 socket 每次会将数组中的所有 socket 集合拷贝到内核中检查是否有某个 socket 发生了可以读或者写的事件然后将时间发送到应用程序中处理请求并且返回数据。

epoll 是将所有的已连接 sockes 放置到内核中在内核中维护一个有事件发生的链表将有发生事件的 socket 发送给应用程序处理不需要一次性的全部拷贝提升了效率。

阿里云国内75折 回扣 微信号:monov8
阿里云国际,腾讯云国际,低至75折。AWS 93折 免费开户实名账号 代冲值 优惠多多 微信号:monov8 飞机:@monov6
返回列表

上一篇:02 KVM安装虚拟化

下一篇:Redis7