
中间件
文章平均质量分 91
飞奔的码赛克
做个俗人,吃百家饭,集百家长
展开
-
Redis
Redis是单线程吗? Redis 的单线程主要是指 Redis 的网络 IO 和键值对读写是由一个线程来完成的,这也是 Redis 对外提供键值存储服务的主要流程。但 Redis 的其他功能,比如持久化、异步删除、集群数据同步等,其实是由额外的线程执行的。不过6.x之后io的的读写是多线程的,但是计算部分不是。 Redis 单线程为什么还能这么快? 因为它所有的数据都在内存中,所有的运算都是内存级别的运算,而且单线程避免了多线程的切换性能损耗问题。正因为 Redis 是单线程,所以要小心使用 Red原创 2021-07-25 19:02:35 · 195 阅读 · 0 评论 -
从NIO到Netty
Netty的使用其实难度不到,其关键的点是了解IO的编程模型。了解其编程模型再对应看Netty就会容易的很多。 Java的网络编程IO模式:BIO,NIO,AIO。 BIO:同步阻塞模型,一个线程处理一个连接。(时代发展,现在已经弃用) 缺点明显,阻塞线程资源浪费,一个线程处理一个客户端,吞吐量有限。唯一的好处:架构简单。 代码示例: 1、accept 方法是一个阻塞方法,执行过后启动服务端,阻塞等待用户连接 2、read方法也是一个阻塞方法,没有数据可读时则阻塞 当客户端没有数据时,处理原创 2021-07-17 23:55:11 · 214 阅读 · 0 评论