rusolver

Crates.iorusolver
lib.rsrusolver
version0.1.1
sourcesrc
created_at2020-09-28 16:58:18.864846
updated_at2020-09-28 18:27:47.753058
descriptionFast DNS resolver written in Rust.
homepage
repositoryhttps://github.com/edu4rdshl/rusolver
max_upload_size
id293767
size68,758
Eduard Tolosa (Edu4rdSHL)

documentation

README

Rusolver

Fast DNS resolver written in Rust.

Goal

Offer the community an efficient host resolution tool.

Performance & speed

Rusolver is very resource friendly, you can use up to 1000 threads in an single core machine and this will work without any problem, the bottleneck for this tool is your network speed. By default, Rusolver is able to perform resolution for ~1226 hosts per second in good network conditions (tested in an AWS machine).

#
# hosts.txt is a list of 61309 Google subdomains. See https://gist.github.com/Edu4rdSHL/90ddc4742b816439a112a95039a95312
#
$ cat hosts.txt | rusolver
...
real	0m50.222s
user	0m17.152s
sys	0m10.064s

$ python
Python 2.7.12 (default, Jul 21 2020, 15:19:50) 
[GCC 5.4.0 20160609] on linux2
Type "help", "copyright", "credits" or "license" for more information.
>>> 61309/50
1226
>>> 

# 1226 hosts were resolved per second in average

Installation

Using precompiled binaries.

Download the asset from the releases page according to your platform.

Using the source code.

  1. You need to have the lastest stable Rust version insalled in your system.
  2. Clone the repo or download the source code, then run cargo build --release.
  3. Execute the tool from ./target/release/rusolver or add it to your system PATH to use from anywhere.

Usage

  • By default we only show the resolved hosts
cat hosts.txt | rusolver
  • If you want to see the discovered IP addresses:
cat hosts.txt | rusolver -i

You can tune the --timeout and -t/--threads options according to your needs. See rusolver --help

Commit count: 68

cargo fmt