Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/ycd/dstp
๐งช Run common networking tests against any site.
https://github.com/ycd/dstp
dns golang network-monitoring networking ping
Last synced: 4 days ago
JSON representation
๐งช Run common networking tests against any site.
- Host: GitHub
- URL: https://github.com/ycd/dstp
- Owner: ycd
- License: mit
- Created: 2021-11-07T14:24:44.000Z (about 3 years ago)
- Default Branch: main
- Last Pushed: 2022-02-08T17:17:55.000Z (almost 3 years ago)
- Last Synced: 2025-01-09T05:47:07.222Z (10 days ago)
- Topics: dns, golang, network-monitoring, networking, ping
- Language: Go
- Homepage:
- Size: 3.43 MB
- Stars: 983
- Watchers: 7
- Forks: 29
- Open Issues: 1
-
Metadata Files:
- Readme: README.md
- License: LICENSE
Awesome Lists containing this project
- awesome-repositories - ycd/dstp - ๐งช Run common networking tests against any site. (Go)
README
dstp
[dstp](https://github.com/ycd/dstp), run common networking tests against your site.
![dstp gif](assets/dstp.png)
---
## Usage
```
Usage: dstp [OPTIONS] [ARGS]
Options:
-a, --addr The URL or the IP address to run tests against [REQUIRED]
-o, --out The type of the output, either json or plaintext [Default: plaintext]
-p Number of ping packets [Default: 3]
-t Give up on ping after this many seconds [Default: 2s per ping packet]
--port Port for testing TLS and HTTPS connectivity [Default: 443]
--dns Custom DNS server to use for DNS resolution [No default]
-h, --help Show this message and exit.
```## Motivation
A comment on [lobste.rs](https://lobste.rs/s/qtsklv/how_do_you_tell_if_problem_is_caused_by_dns#c_1nqkdp), in a thread
about DNS gave a great idea and thought a robust tool like that might come in handy!## Installation
### Packages
#### Homebrew
For Homebrew on macOS, install the [`ycd/tap/dstp`](https://github.com/ycd/homebrew-tap#readme) formula.
```zsh
brew install ycd/tap/dstp
```#### Go Install
```zsh
go install github.com/ycd/dstp/cmd/dstp@latest
```#### NixOS/nix
You can install dstp using one of these methods:
1. Using `nix-shell` or `nix shell` (recommended for trying it out):
```bash
nix shell nixpkgs#dstp
```2. Adding to your NixOS configuration (system-wide installation):
```nix
# configuration.nix or home-manager configuration
{
# ...
environment.systemPackages = with pkgs; [
dstp
];
}
```3. Or using `nix profile` (for individual user installation):
```bash
nix profile install nixpkgs#dstp
```#### Arch Linux
```bash
git clone https://aur.archlinux.org/dstp.git
cd dstp
makepkg -sri
```### Downloads
Binary downloads of example are available from [the releases section on GitHub](https://github.com/ycd/dstp/releases/)
for 64-bit Windows, macOS, and Linux targets. They contain the compiled executable.| platform |
| ----------- |
| [macOS ARM 64 Bit](https://github.com/ycd/dstp/releases/download/v0.4.23/dstp_0.4.23_Darwin_arm64.tar.gz)
| [macOS 64 Bit](https://github.com/ycd/dstp/releases/download/v0.4.23/dstp_0.4.23_Darwin_amd64.tar.gz)
| [Linux 32-Bit](https://github.com/ycd/dstp/releases/download/v0.4.23/dstp_0.4.23_Linux_386.tar.gz)
| [Linux ARM 64 Bit](https://github.com/ycd/dstp/releases/download/v0.4.23/dstp_0.4.23_Linux_arm64.tar.gz)
| [Linux 64 Bit](https://github.com/ycd/dstp/releases/download/v0.4.23/dstp_0.4.23_Linux_amd64.tar.gz)
| [Windows 64 Bit](https://github.com/ycd/dstp/releases/download/v0.4.23/dstp_0.4.23_Windows_amd64.zip)
| [Windows 32 Bit](https://github.com/ycd/dstp/releases/download/v0.4.23/dstp_0.4.23_Windows_386.zip)
| [Windows ARM 64 Bit](https://github.com/ycd/dstp/releases/download/v0.4.23/dstp_0.4.23_Windows_arm64.zip)### Installation from source
0. Verify that you have Go 1.17+ installed (The source code uses _( `//go:build` )_ conditional compilation directives
that is introduced in Go 1.17.)```
$ go version
```If `go` is not installed, follow instructions on [the Go website](https://golang.org/doc/install).
1. Clone this repository
```
$ git clone https://github.com/ycd/dstp
$ cd dstp
```2. Build and install
#### Unix/Linux
```
# May require you to use sudo
$ go build cmd/dstp/dstp.go
$ cp dstp /usr/local/bin/dstp
```#### Mac/BSD
```
# May require you to use sudo
$ make
$ cp dstp /usr/local/bin/dstp
```3. Verify installation
```
$ dstp -hUsage: dstp [OPTIONS] [ARGS]
Options:
-a, --addr The URL or the IP address to run tests against [REQUIRED]
-o, --out The type of the output, either json or plaintext [Default: plaintext]
-p Number of ping packets [Default: 3]
-t Give up on ping after this many seconds [Default: 2s per ping packet]
--port Port for testing TLS and HTTPS connectivity [Default: 443]
-h, --help Show this message and exit.
```---
## Appendix
The command `dstp` may collide with `docker stop`command if you are using the docker plugin with oh-my-zsh.
To fix this, you can add the following command at the end of your `.zshrc` file:
```zsh
unalias dstp
```## Contributing
All kinds of Pull Requests and Feature Requests are welcomed!
## Licence
dstp's source code is licenced under the [MIT License](https://choosealicense.com/licenses/mit/).