/minihost

Easily start and access servers

Primary LanguageJavaScriptMIT LicenseMIT

minihost Build Status npm version

When working with many dev servers, you have to increment and remember ports (e.g. http://localhost:3000, http://localhost:4000, ...).

With minihost, you don't have to think about that.

Works on Windows, Linux and OS X.

Usage

Install:

npm install -g minihost

Prefix your commands with h:

~/one$ h -- nodemon
~/two$ h -- npm start

You can then view your running servers on http://localhost:2000 and access them locally on http://<name>*:2000 using any host that resolves to 127.0.0.1.

For example:

# Using dnsmasq and a local .dev domain
# Or /etc/hosts
http://one.dev:2000
http://two.dev:2000

Public wildcard domain names that resolves to 127.0.0.1 are also supported and can be used without any system configuration:

# See til.io
http://one.til.io:2000
http://two.til.io:2000

# See xip.io
http://one.127.0.0.1.xip.io:2000
http://two.127.0.0.1.xip.io:2000

To set a custom name, add -n:

~/one$ h -n app -- nodemon

To set a custom port environment variable name (instead of default PORT), add it after colon in custom name:

~/one$ h -n app:APP_PORT -- nodemon

To enable multiple names and ports repeat -n option:

~/one$ h -n app1:APP1_PORT -n app2:APP_PORT1 -- nodemon

If custom env variable names for ports not defined, PORT_0, PORT_1, ... will be used.

To change the port minihost listens to, run:

echo 8000 > ~/.minihost

Supporting minihost

For minihost to work, your server need to listen on the PORT environment variable.

From your code:

// KO
app.listen(3000);

// OK
app.listen(process.env.PORT || 3000);

Or from the command-line:

h -- 'cmd -p $PORT'  # Linux, OS X
h -- "cmd -p %PORT%" # Windows

License

MIT - Typicode