禁用Dropbear中DNS反向查询连接客户端地址补丁
来源:互联网 发布:返利机器人软件多少钱 编辑:程序博客网 时间:2024/04/29 19:15
Dropbear 是一套来自澳大利亚的轻量的sshd服务器,与OpenSSH相比,他更简洁,更小巧,运行起来占用的内存也更少,因此在嵌入式环境被广泛中使用.
Dropbear 与 OpenSSH在客户端连接到服务器时都有一个相同的动作:就是会向设备配置的DNS Server反向查询客户端地址. 如果设备配置的DNS服务器地址有问题或速度比较慢, 就会导致客户端连接时产生延时,在客户端产生停顿了感觉. 而OpenSSH 可以通过在sshd_config中配置"UseDNS No"来禁用此动作,而Dropbear却没有可配置的选项.
通过查看Dropbear代码, 发现Dropbear在每次客户端连接成功后都会调用getnameinfo去获取客户端连接信息(svr-main.c:main_noinetd/main_inetd->dbutils.c:getaddrstring/getaddrhostname). 所以只要将dbutils.c:getaddrstring/getaddrhostname两个函数代码中调用getnameinfo获取地址信息修改为获取简单的地址端口即可.
这里采用了kernel中的宏NIPQUAD来打印ipv4网络字节序地址:
#define NIPQUAD(addr) /
((unsigned char *)&addr)[0], /
((unsigned char *)&addr)[1], /
((unsigned char *)&addr)[2], /
((unsigned char *)&addr)[3]
以下是patch:
- 禁用Dropbear中DNS反向查询连接客户端地址补丁
- DNS反向正向查询
- 域名系统(DNS)反向查询
- 禁用windows DNS客户端缓存
- 如何在 Windows XP 和 Windows Server 2003 中禁用客户端 DNS 缓存
- 如何在 Windows XP 和 Windows Server 2003 中禁用客户端 DNS 缓存
- Linux中DNS服务器地址查询命令nslookup使用教程
- DNS反向查询站点收集整理
- 用Perl进行DNS反向查询
- Mysql DNS反向解析导致连接超时
- 在反向代理中Java获取客户端真实IP地址的两种方法
- 多级反向代理下,Java获取请求客户端的真实IP地址多中方法整合
- 多级反向代理下,Java获取请求客户端的真实IP地址多中方法整合
- 多级反向代理下,Java获取请求客户端的真实IP地址多中方法整合
- 多级反向代理下,Java获取请求客户端的真实IP地址多中方法整合
- 多级反向代理下,Java获取请求客户端的真实IP地址多中方法整合
- 多级反向代理下,Java获取请求客户端的真实IP地址多中方法整合
- 多级反向代理下,Java获取请求客户端的真实IP地址多中方法整合
- ext tree控件 使用
- WinCE6.0bootloader的研究
- 有关希望
- DbUnit入门实战(转载)
- JDK 1.5增加for循环
- 禁用Dropbear中DNS反向查询连接客户端地址补丁
- 一个哈希码计算类
- FireBird数据库设计技巧
- c# .net 不规则窗体,无毛边
- 在vc中如何用post方法提交表单
- 八大Flex布局规则
- Delphi的IDHTTP的基本用法
- ASP.NET 导出Excel 80070005错误
- linux --time_t类型