Ecosyste.ms: Awesome
An open API service indexing awesome lists of open source software.
https://github.com/qdm12/port-checker
Simple Docker container to test if a port works using a Golang server
https://github.com/qdm12/port-checker
docker network port utility-network
Last synced: 4 months ago
JSON representation
Simple Docker container to test if a port works using a Golang server
- Host: GitHub
- URL: https://github.com/qdm12/port-checker
- Owner: qdm12
- License: mit
- Created: 2018-09-09T17:38:23.000Z (over 6 years ago)
- Default Branch: master
- Last Pushed: 2021-06-23T01:07:47.000Z (over 3 years ago)
- Last Synced: 2024-10-04T12:53:51.386Z (5 months ago)
- Topics: docker, network, port, utility-network
- Language: Go
- Size: 219 KB
- Stars: 27
- Watchers: 3
- Forks: 4
- Open Issues: 4
-
Metadata Files:
- Readme: README.md
- Contributing: .github/CONTRIBUTING.md
- Funding: .github/FUNDING.yml
- License: LICENSE
- Codeowners: .github/CODEOWNERS
Awesome Lists containing this project
README
# Port Checker with Docker
*12.8MB container to check a TCP port works with a Golang HTTP server*
[data:image/s3,"s3://crabby-images/b3230/b3230b43df35a0045964020f82f79f536ddefc17" alt="Build status"](https://github.com/qdm12/port-checker/actions?query=workflow%3A%22Buildx+latest%22)
[data:image/s3,"s3://crabby-images/6d983/6d983fdde1eb10b384c2f0d4915203d5d04bd63e" alt="Docker Pulls"](https://hub.docker.com/r/qmcgaw/port-checker)
[data:image/s3,"s3://crabby-images/a0df0/a0df05a903d933c54cc2a9648355e344bf0d2820" alt="Docker Stars"](https://hub.docker.com/r/qmcgaw/port-checker)
[data:image/s3,"s3://crabby-images/20a55/20a55dfa3d66e34b58a386272e1f7a139557ac88" alt="Image size"](https://microbadger.com/images/qmcgaw/port-checker)
[data:image/s3,"s3://crabby-images/bc76a/bc76a5c7dcbfe49b54b51606ae5beb0c0c091394" alt="Image version"](https://microbadger.com/images/qmcgaw/port-checker)[data:image/s3,"s3://crabby-images/d2c0f/d2c0f6e792bfa43961d0108981063c0e5f529923" alt="Join Slack channel"](https://join.slack.com/t/qdm12/shared_invite/enQtOTE0NjcxNTM1ODc5LTYyZmVlOTM3MGI4ZWU0YmJkMjUxNmQ4ODQ2OTAwYzMxMTlhY2Q1MWQyOWUyNjc2ODliNjFjMDUxNWNmNzk5MDk)
[data:image/s3,"s3://crabby-images/66e44/66e44b6223bdeb448d0e9572ab7dec2ccf96f456" alt="GitHub last commit"](https://github.com/qdm12/port-checker/issues)
[data:image/s3,"s3://crabby-images/d03af/d03afa57fba1580cdcfd8a9b6ffc653b74ecb63f" alt="GitHub commit activity"](https://github.com/qdm12/port-checker/issues)
[data:image/s3,"s3://crabby-images/245d0/245d08b39ccecf9f28ecbff32309633147f4c13b" alt="GitHub issues"](https://github.com/qdm12/port-checker/issues)## Features
- HTTP lightweight server responding with information on your client:
- Client IP (public or private)
- Browser and version
- Device type
- OS and version
- Compatible with amd64, 386, armv6, armv7 and arm64 v8 cpu architectures## Setup
1. To test port 1234, use:
```bash
docker run -it --rm -p 1234:8000/tcp qmcgaw/port-checker
```To test port 1234 internally, use:
```bash
docker run -it --rm -e LISTENING_PORT=1234 qmcgaw/port-checker
```1. With a client, access [http://localhost:1234](http://localhost:1234).
You can also port forward with your router to test it is accessible remotely.### Binary
You can also download one of the binaries on the Github releases. For example:
```sh
wget -qO port-checker https://github.com/qdm12/port-checker/releases/download/v0.1.0/port-checker_0.1.0_linux_amd64
chmod +x port-checker
./port-checker
# Usage with
./port-checker -help
```## Environment variables
| Environment variable | Default | Possible values | Description |
| --- | --- | --- | --- |
| `LISTENING_PORT` | `8000` | `1025` to `65535` | TCP port to listen on internally |
| `ROOT_URL` | `/` | URL path string | Used if it is running behind a proxy for example |## Development
### Using VSCode and Docker
1. Install [Docker](https://docs.docker.com/install/)
- On Windows, share a drive with Docker Desktop and have the project on that partition
1. With [Visual Studio Code](https://code.visualstudio.com/download), install the [remote containers extension](https://marketplace.visualstudio.com/items?itemName=ms-vscode-remote.remote-containers)
1. In Visual Studio Code, press on `F1` and select `Remote-Containers: Open Folder in Container...`
1. Your dev environment is ready to go!... and it's running in a container :+1:## TO DOs
- [ ] Use GeoLite database and Google Maps to show the location
- [ ] Add CSS to the HTML template
- [ ] Precise external mapped port to check it can access itself at start
- [ ] Unit testing
- [ ] Notifications (Pushbullet, email, etc. ?)
- [ ] UDP port check, see [this](https://ops.tips/blog/udp-client-and-server-in-go/)