发布网友 发布时间:2022-03-25 22:28
共3个回答
懂视网 时间:2022-03-26 02:49
redis是单线程的。
Redis是一个开源的使用ANSI C语言编写、支持网络、可基于内存亦可持久化的日志型、KeyValue数据库,并提供多种语言的API。从2010年3月15日起,Redis的开发工作由VMware主持。从2013年5月开始,Redis的开发由Pivotal赞助。Redis支持主从同步。数据可以从主服务器向任意数量的从服务器上同步,从服务器可以是关联其他从服务器的主服务器。
热心网友 时间:2022-03-25 23:57
但不是一个简单的多线程,但每个线程都有自己的epoll模型,即多线程和混合多路复用。
我们通常以“但是”开头。但是,还要考虑Redis操作的对象。
它对内存中的数据结构进行操作。如果在多个线程中操作,则需要锁定对象。
最终,多线程性能得到了提高,但每个线程的效率显著下降。
这些操作也可以合成多/执行组。
这样的操作可能需要大量的锁,从而导致同步开销显著增加。
这也会增加吞吐量,但是响应延迟可能会增加。
Redis的选择是使用单个线程来突出其功能的灵活性。
单个线程上的任何原子操作都可以在几乎不需要成本的情况下实现,而且这样一个复杂的数据结构可以很容易地使用,即使有Lua脚本这样的功能。
单线程电源实际上非常强大,而且每个核心效率都非常高。
在今天的虚拟化环境中,您可以充分利用云环境来提高资源利用率。
多线程自然是能够比单线程更高的性能*,但在今天的计算环境中,即使是一个多线程的天花板也常常不能满足需要,需要进一步摸索更多的服务器集群方案。
多线程技术的方案还在不在,所以单线程,进程集群不失为一个现代的解决方案。
热心网友 时间:2022-03-26 01:15
我觉得你要是提这个问题说明你有一套固化的思维,所以我认为你这几个问题我还是可以帮你回答的。
单线程的选择
在权衡是使用一个线程来突出其自身功能的灵活性,Redis的选择。在单线程的基础上,任何原子操作都可以在几乎没有成本的情况下实现。如何在复杂的数据结构,可以很容易地应用,甚至使用Lua脚本的功能。多线程的价格要高得多。单线程的威力实际上非常强大,每核心效率也非常高,在今天的虚拟化环境当中可以充分利用云化环境来提高资源利用率。
对象的考虑
考虑使用对象操作。它运行的对象是内存中的数据结构。如果在多线程中操作,则需要锁定这些对象。最后,多线程性能得到改善,但每个线程的效率却严重下降。这个程序的逻辑很复杂。
程序多样执行
要知道redis数据结构不是一个简单的核心价值,还有列表,hash,map和一系列复杂的结构,这些结构可能是非常精细的操作,如添加一长串后面的一个元素,添加或删除一个对象的哈希值,等等。这些操作还可以合成一组多个/多个执行程序。在这样的操作中可能需要大量的锁,导致同步开销显著增加。一个糟糕的结果是吞吐量增加,但是响应延迟可能增加。
总结:我觉得未来也会是单线程的发展,而且越来越精细了。