DHT 及 Chord

1.DHT

  DHT(distributed hash table)是一种分布式系统的存储和索引方案,DHT由<key,value>对组成,整个DHT表被分布在多个节点上。DHT网络中每个节点都有一个唯一的ID,通过某种算法使每个节点负责维护几个keys以及其所有value,不同的DHT系统拥有不同的节点ID和key映射算法。这样减少了节点的添加与删除所带来的破坏。

  Hash函数可以将不同空间的输入转换成相同空间的输出,而且这个过程是不可逆的,例如MD5和SHA-1。

  DHT网络中的资源被划分为许多小块,以它们作为存储的最小单位。新存储一块资源时,先对这块资源的某种标识(文件名、关键字)进行SHA-1 hash产生一个160比特的key,结合资源的内容value组成<key,value>对。发送消息put(key,value)至DHT网络中的所有节点,这条信息被节点不断转发直到到达负责维护这个key的节点,于是这个节点将key以及value存储起来。  当有客户端需要获取这块资源时,先同样计算出hash后的key,向DHT网络发送get(key)消息,当负责存储这个key的节点收到消息时即作出应答。

2.Chord

  令哈希后的节点ID和key均为m比特,这样它们就可以都分布在一个可以容纳2^m个节点的环上。Chord将key及其value存储在节点successor(key)中,successor(key)指的是环上从key开始顺时针查找,找到的中第一个存在的网络节点。这种哈希方法又被称为一致性哈希。

  如下图所示,蓝色为hash至环上网络节点ID的位置,红色为hash至环上的key的位置。箭头表示key和ID的映射关系。

3.若增加节点,网络中只有一个节点的负载减轻;而若减少节点,其维护的数据会全部交给后续的第一个节点。如果每个节点都代表一台服务器的话,那么增减节点会造成网络的负载不均衡。

  所以往往将一台服务器分为n个虚拟节点,并无规律地分布在环上。这样当一台服务器出现故障时,其维护的资源会均匀地分配到网络中的每个服务器中。

原文地址:http://cozyshu.blog.51cto.com/blog/1462511/573542

  • 1
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
### 回答1: 51单片机dht11代码及仿真,可分为三个步骤进行实现:引脚连接、编写代码、仿真验证。 引脚连接: 51单片机需要连接到DHT11的三个引脚:VCC、DATA、GND。其中VCC为正电压引脚,连接至单片机的5V电源;GND为负电压引脚,连接至单片机的GND引脚;DATA为数据引脚,连接至单片机的P3.0引脚。连接好三个引脚之后,就可以开始编写代码。 编写代码: 首先需要在代码中定义P3.0为输入引脚,并对DHT11进行初始化。然后通过单片机向DHT11发送起始信号,并读取DHT11返回的数据。接着,根据DHT11返回的数值,计算出温度和湿度的值,最后将计算出的数据显示在LCD屏幕上。完整的代码如下所示: #include <8051.h> #define DHT11_IO P3_0 unsigned char humiture_data[6]; void DHT11_init(void)//DHT11初始化 { DHT11_IO = 1; delay_ms(20); DHT11_IO = 0; delay_ms(30); DHT11_IO = 1; } void read_humidity_temperature(void) { unsigned char i, j; for (j = 0; j < 5; j++) { humiture_data[j] = 0; } DHT11_init(); while (DHT11_IO); //等待DHT11的response while (!DHT11_IO); //等待DHT11拉低DATA引脚 for (i = 0; i < 40; i++) { while (!DHT11_IO); delay_us(30); if (DHT11_IO) humiture_data[i / 8] |= (unsigned char)(1 << (7 - i % 8)); while (DHT11_IO); } } void main() { unsigned char value; P3_0 = 1; while (1) { read_humidity_temperature(); if (!humiture_data[0] && !humiture_data[1] && !humiture_data[2] && !humiture_data[3]) { value = humiture_data[0] + humiture_data[1] + humiture_data[2] + humiture_data[3]; if (humiture_data[4] == value) //校验数据 { lcd_write_cmd(0x01); lcd_write_string(0, 0, "Humidity:"); //显示湿度 lcd_write_char(0, 9, humiture_data[0] / 10 + 0x30); lcd_write_char(0, 10, humiture_data[0] % 10 + 0x30); lcd_write_char(0, 11, '%'); lcd_write_string(1, 0, "Temperature:"); //显示温度 if (humiture_data[2] & 0x80) //表示温度为负数 { humiture_data[2] &= 0x7f; lcd_write_char(1, 12, '-'); } lcd_write_char(1, 9, humiture_data[2] / 10 + 0x30); lcd_write_char(1, 10, humiture_data[2] % 10 + 0x30); lcd_write_char(1, 11, '.'); lcd_write_char(1, 12, humiture_data[3] / 10 + 0x30); lcd_write_char(1, 13, humiture_data[3] % 10 + 0x30); lcd_write_char(1, 14, 0xDF); lcd_write_char(1, 15, 'C'); } } delay_ms(1000); } } 仿真验证: 可以使用仿真软件进行验证,如Proteus等。在Proteus软件中,将51单片机和DHT11进行组装,并连接正确的引脚。然后在IDE中编译上传代码到单片机中。最后,启动仿真并观察LCD屏幕上显示的结果是否与实际测量结果相同。 以上就是51单片机dht11代码及仿真的全部内容。需要注意的是,由于DHT11对于温度和湿度的计量误差较大,因此在实际应用中需要考虑到这些误差,并进行相应的校正。 ### 回答2: 51单片机是一款常用的微控制器,它具有成本低廉、易于学习和应用广泛等优点,因此在各种电子器件和控制系统中都得到了广泛应用。而dht11是一款数字温湿度传感器,可以在各种环境下测量并输出温度和湿度数据。本文将介绍51单片机和dht11的使用方法,包括代码及仿真方面的内容。 首先,需要了解dht11的原理和使用方法。它包含一个温湿度传感器和一个运算放大器,在使用时需要使用单片机对其进行读取并解码输出数据。dht11数据格式为40位二进制数据,其中前8位为湿度整数,接下来8位为湿度小数,再接下来8位为温度整数,再接下来8位为温度小数,最后8位是校验和。因此,需要使用单片机对其进行正确的读取和解码,才能获取准确的温湿度数据。 其次,需要了解51单片机的相关知识。它具有丰富的外设接口和指令系统,可以用来控制各种电子器件和运算。在使用dht11时,需要通过单片机的GPIO口读取数据,并使用定时器对时序进行控制,从而实现对dht11的读取和解码。具体来说,需要使用GPIO口输出低电平或高电平,等待一段时间后读取GPIO口的电平值,并根据时序规定对其进行解码。 最后,需要了解51单片机的代码编写和仿真方法。对于代码编写方面,需要使用KEIL或其他汇编语言编写,根据具体需求进行修改和调试,从而实现对dht11的读取和输出。对于仿真方面,需要使用Proteus或其他模拟软件,通过添加dht11模块和单片机模块,并建立相应的连接关系,来模拟单片机和dht11的工作过程,从而验证代码的正确性和稳定性。 综上所述,51单片机和dht11的使用方法需要掌握相应的原理和编程知识,而代码和仿真则是验证和调试的重要手段。通过深入了解它们的工作原理和方法,可以更好地应用于各种电子控制系统中,从而实现更加便捷、高效和精确的控制效果。 ### 回答3: DHT11是一种数字温湿度传感器,可以测量环境的温度和相对湿度。在51单片机中,可以通过编写简单的代码来读取来自DHT11的数据。 在编写代码之前,我们需要了解DHT11的工作方式。DHT11使用单线数字信号进行通信,并从51单片机接收计量传感器的数据。在51单片机上,可以使用定时器来计算从传感器接收到的脉冲的宽度,并根据脉冲的宽度计算温度和湿度。 以下是用于读取DHT11数据的基本代码: #include <reg52.h> #define DHT11_PIN P3_2 unsigned char Humidity,Humidity1,Temp,Temp1; void delay_us(unsigned int us) { while(us--); } void delay_ms(unsigned int ms) { unsigned int i,j; for(i=0;i<ms;i++) for(j=0;j<125;j++); } void StartSignal_DHT11() { DHT11_PIN=0; delay_ms(20); DHT11_PIN=1; delay_us(30); DHT11_PIN=0; } unsigned char ReadByte_DHT11() { unsigned char i, DATA=0; for(i=0;i<8;i++) { while(!DHT11_PIN); delay_us(30); if(DHT11_PIN==1) DATA=(DATA<<1)|1; else DATA=DATA<<1; while(DHT11_PIN); } return DATA; } void ReadData_DHT11() { while(DHT11_PIN==1); while(DHT11_PIN==0); while(DHT11_PIN==1); Temp=ReadByte_DHT11(); Humidity=ReadByte_DHT11(); Humidity1=ReadByte_DHT11(); Temp1=ReadByte_DHT11(); } void main() { StartSignal_DHT11(); ReadData_DHT11(); } 代码中的StartSignal_DHT11函数用于向传感器发送开始信号以启动传感器。ReadByte_DHT11函数用于读取传感器发送的每个字节。最后,ReadData_DHT11函数用于初始化传感器和读取传感器数据。在此示例中,我们只读取了温度和湿度的整数部分。如果需要,可以使用相应的公式计算小数部分。 在仿真方面,可以使用Proteus设计软件来模拟DHT11的工作方式。在Proteus中包含了DHT11的模型,可以将其添加到模拟电路中并进行仿真。在仿真过程中,可以模拟从传感器接收的脉冲,然后使用相应的代码计算温度和湿度。通过这种方式,我们可以在实际部署之前测试我们的代码,并确保其准确性。 总的来说,使用51单片机和DHT11传感器测量环境温度和湿度的过程并不复杂。我们可以编写简单的代码,或在仿真环境中进行测试并确保其准确性。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值