settimeout是异步吗 js函数settimeout
- 开发语言
- 2023-08-13
- 83
大家好,今天来为大家分享settimeout是异步吗的一些知识点,和js函数settimeout的问题解析,大家要是都明白,那么可以忽略,如果不太清楚的话可以看看本篇文...
大家好,今天来为大家分享settimeout是异步吗的一些知识点,和js函数settimeout的问题解析,大家要是都明白,那么可以忽略,如果不太清楚的话可以看看本篇文章,相信很大概率可以解决您的问题,接下来我们就一起来看看吧!
Redis集群是什么工作做这个前景如何
Redis是单线程,但是一般的作为缓存使用的话,redis足够了,因为它的读写速度太快了。
官方的一个简单测试:
测试完成了50个并发执行100000个请求。
设置和获取的值是一个256字节字符串。
结果:读的速度是110000次/s,写的速度是81000次/s
在这么快的读写速度下,对于一般程序来说足够用了,但是对于访问量特别大的网站来说,还是稍有不足。那么,如何提升redis的性能呢?看标题就知道了,搭建集群。
3.0版本之前
3.0版本之前的redis是不支持集群的,我们的徐子睿老师说,那个时候,我们的redis如果想要集群的话,就需要一个中间件,然后这个中间件负责将我们需要存入redis中的数据的key通过一套算法计算得出一个值。然后根据这个值找到对应的redis节点,将这些数据存在这个redis的节点中。
在取值的时候,同样先将key进行计算,得到对应的值,然后就去找对应的redis节点,从对应的节点中取出对应的值。
这样做有很多不好的地方,比如说我们的这些计算都需要在系统中去进行,所以会增加系统的负担。还有就是这种集群模式下,某个节点挂掉,其他的节点无法知道。而且也不容易对每个节点进行负载均衡。
3.0版本及以后
先来一张redis集群的架构图:
在这个图中,每一个蓝色的圈都代表着一个redis的服务器节点。它们任何两个节点之间都是相互连通的。客户端可以与任何一个节点相连接,然后就可以访问集群中的任何一个节点。对其进行存取和其他操作。
那么redis是怎么做到的呢?首先,在redis的每一个节点上,都有这么两个东西,一个是插槽(slot)可以理解为是一个可以存储两个数值的一个变量这个变量的取值范围是:0-16383。还有一个就是cluster我个人把这个cluster理解为是一个集群管理的插件。当我们的存取的key到达的时候,redis会根据crc16的算法得出一个结果,然后把结果对16384求余数,这样每个key都会对应一个编号在0-16383之间的哈希槽,通过这个值,去找到对应的插槽所对应的节点,然后直接自动跳转到这个对应的节点上进行存取操作。
还有就是因为如果集群的话,是有好多个redis一起工作的,那么,就需要这个集群不是那么容易挂掉,所以呢,理论上就应该给集群中的每个节点至少一个备用的redis服务。这个备用的redis称为从节点(slave)。那么这个集群是如何判断是否有某个节点挂掉了呢?
首先要说的是,每一个节点都存有这个集群所有主节点以及从节点的信息。
它们之间通过互相的ping-pong判断是否节点可以连接上。如果有一半以上的节点去ping一个节点的时候没有回应,集群就认为这个节点宕机了,然后去连接它的备用节点。如果某个节点和所有从节点全部挂掉,我们集群就进入faill状态。还有就是如果有一半以上的主节点宕机,那么我们集群同样进入发力了状态。这就是我们的redis的投票机制,具体原理如下图所示:
(1)投票过程是集群中所有master参与,如果半数以上master节点与master节点通信超时(cluster-node-timeout),认为当前master节点挂掉.
(2):什么时候整个集群不可用(cluster_state:fail)?
a:如果集群任意master挂掉,且当前master没有slave.集群进入fail状态,也可以理解成集群的slot映射[0-16383]不完整时进入fail状态.ps:redis-3.0.0.rc1加入cluster-require-full-coverage参数,默认关闭,打开集群兼容部分失败.
b:如果集群超过半数以上master挂掉,无论是否有slave,集群进入fail状态.
timeouterror解决方案
setuptimeouterror通常是指在设置超时时间时出现了错误。如果您遇到了这个问题,可以尝试以下方法解决:
1.检查代码中设置超时时间的部分,确保语法正确、参数正确。
2.检查网络连接是否正常,如果网络连接不稳定或者存在问题,可能会导致超时错误。
3.尝试增加超时时间,有时候超时时间设置过短也会导致超时错误。
4.如果您使用的是第三方库或者框架,可以查阅相关文档或者寻求帮助,看看是否有解决方案。
5.如果以上方法都无法解决问题,可以考虑升级相关组件或者重装软件,有时候版本过旧也会导致超时错误。
python modbus_tk如何获得客户端信息
利用Pythonmodbus工具实现modbus从站的数据采集,很方便简单。pythonModbus协议工具目前有下面三种:
pymodbus
MinimalModbus
Modbus-tk
modbus_tk:完整modbus协议栈的实现,支持modbustcp/rtu{1.提供slave模拟器,即模拟modbusserver:502),web-basedhmimaster支持}
pymodbus:使用twisted实现的modbus完整协议(支持异步通讯)
MinimalModbus:只支持modbusrtu
至于那个更好,可以参考stackoverflaw上的一个回答http://stackoverflow.com/questions/17081442/python-modbus-library
Modbus_tk是很简单易用的工具。相关资料查看:https://pypi.python.org/pypi/modbus_tk
Modbsu_tk库使用
execute(slave,功能代码,开始地址,quantity_of_x=0,output_value=0,data_format="",指定长度=-1)
实现数据读与写,用功能码很容易实现。
READ_COILS=1读线圈READ_DISCRETE_INPUTS=2读离散输入READ_HOLDING_REGISTERS=3【读保持寄存器】READ_INPUT_REGISTERS=4读输入寄存器WRITE_SINGLE_COIL=5写单一线圈WRITE_SINGLE_REGISTER=6写单一寄存器WRITE_MULTIPLE_COILS=15写多个线圈【强制多点线圈】WRITE_MULTIPLE_REGISTERS=16写多寄存器【写乘法寄存器】
master.execute(1,cst.READ_HOLDING_REGISTERS,0,3)
1—从设备地址
cst.READ_HOLDING_REGISTERS—读保持寄存器
0—开始地址
3—读三个字节
下面来一个简单的例子。
[python]viewplaincopy#!/usr/bin/envpython#-*-coding:utf_8-*-"""ModbusTestKit:ImplementationofModbusprotocolinpython(C)2009-LucJean-luc.jean@gmail.com(C)2009-Apidev-http://www.apidev.frThisisdistributedunderGNULGPLlicense,seelicense.txt"""importserialimportmodbus_tkimportmodbus_tk.definesascstfrommodbus_tkimportmodbus_rtu#PORT=1PORT="/dev/ttyUSB0"defmain():"""main"""logger=modbus_tk.utils.create_logger("console")try:#Connecttotheslavemaster=modbus_rtu.RtuMaster(serial.Serial(port=PORT,baudrate=9600,bytesize=8,parity='N',stopbits=1,xonxoff=0))master.set_timeout(5.0)master.set_verbose(True)logger.info("connected")logger.info(master.execute(1,cst.READ_HOLDING_REGISTERS,1,1))#sendsomequeries#logger.info(master.execute(1,cst.READ_COILS,0,10))#logger.info(master.execute(1,cst.READ_DISCRETE_INPUTS,0,8))#logger.info(master.execute(1,cst.READ_INPUT_REGISTERS,100,3))#logger.info(master.execute(1,cst.READ_HOLDING_REGISTERS,100,12))#logger.info(master.execute(1,cst.WRITE_SINGLE_COIL,7,output_value=1))#logger.info(master.execute(1,cst.WRITE_SINGLE_REGISTER,100,output_value=54))#logger.info(master.execute(1,cst.WRITE_MULTIPLE_COILS,0,output_value=[1,1,0,1,1,0,1,1]))#logger.info(master.execute(1,cst.WRITE_MULTIPLE_REGISTERS,100,output_value=xrange(12)))exceptmodbus_tk.modbus.ModbusErrorasexc:logger.error("%s-Code=%d",exc,exc.get_exception_code())if__name__=="__main__":main()用modsim在window下充当slave设置如下:
在树莓派下运行结果如下:
如果你还想了解更多这方面的信息,记得收藏关注本站。
本文链接:http://www.xinin56.com/kaifa/5168.html