- What it does
- Getting started
- Basic commands
- Advanced commands
- How it works
- What it costs
- Troubleshooting
- Notes
- License
Minecrab provisions a fully configured Minecraft server on a Joyent's Public Cloud, specifically on a SmartOS virtual machine. You can play on the server, invite friends, build stuff, and so on. When you're finished playing and shut down the server, Minecrab saves your world to the cloud Joyent Manta Storage Service.
Next time you want to play, just have Minecrab provision your server again. Your world will be there, just as you left it.
Note that we don't make any money off of the Minecrab software directly, and you can run it in any compatible cloud (e.g. Telefonica or private instances).
If you do choose to use it on our public virtual machine service, we do charge users for our normal cloud hosting and storage costs.
See What it costs later in this README to find out more about our virtual machine and storage charges.
Also see minecrab.io.
First you need to get your gear together. This is the hardest part of the whole operation. Then you can play.
- Get the Minecraft software: minecraft.net
Minecrab makes it easy to run servers. To play in them, you need to buy the software from Mojang. - Get a Joyent Cloud or compatible account.
You can sign up for a free trial. (The rest of this guide assumes that you're using a Joyent Cloud account.) - If you are on Mac OS X:
1. Install node, npm, node-manta and smartdc tools using the [Mac OS X Installer](https://us-east.manta.joyent.com/manta/public/sdks/joyent-node-latest.pkg). 1. Install the jsontool `sudo npm install jsontool -g` 1. Install [git](http://git-scm.com) 2. Otherwise: (Tested on Ubuntu 13.10. It will probably work on other platforms):
1. Install [Node](http://nodejs.org/) 1. Install [Manta](http://apidocs.joyent.com/manta/#getting-started) 1. Install [CloudAPI](http://apidocs.joyent.com/cloudapi/#getting-started) 1. Install the jsontool `sudo npm install jsontool -g` 1. Install [git](http://git-scm.com) 1. Make sure [ssh-agent](#problems-with-ssh-agent) is running and has access to your ssh key and password. 1. Set up your CloudAPI and Manta environment variables: Run these commands in a Terminal window. (Pro-tip: save them in a file for later use, and `source ` to run them as needed, or put them in your `.bash_profile`.)
export MANTA_USER=<your Joyent Cloud name>
export MANTA_URL=https://us-east.manta.joyent.com
export MANTA_KEY_ID=$(ssh-keygen -l -f ~/.ssh/id_rsa.pub | awk '{print $2}' | tr -d '\n')
export SDC_URL=<URL of a Joyent Cloud datacenter> (see below)
export SDC_ACCOUNT=<your Joyent Cloud name>
export SDC_KEY_ID=$(ssh-keygen -l -f ~/.ssh/id_rsa.pub | awk '{print $2}' | tr -d '\n')
Use the MANTA_URL
as given. For SDC_URL
choose the closest datacenter:
https://us-east-1.api.joyentcloud.com
https://us-west-1.api.joyentcloud.com
https://us-sw-1.api.joyentcloud.com
https://eu-ams-1.api.joyentcloud.com
MANTA_KEY_ID
and SDC_KEY_ID
are fingerprints of one of your SSH keys in the Joyent Cloud.
The ssh-keygen
command just makes it easier to get your fingerprints.
-
Clone this repo
git clone [email protected]:joyent/minecrab.git
-
Create your first server
cd minecrab bin/minecrab-launch <new server name>
-
Add players
bin/minecrab-add-friends <server name> <minecraft friend name>
-
Play Minecraft
-
Put your server away
bin/minecrab-shutdown <server name>
-
Time passes
-
Restore your server to play again
bin/minecrab-launch <old server name>
These are command-line commands you use to manage your server.
minecrab-launch [-p first-player] [-f flavor] <server-name>
Create or restore the server named server-name
.
If provided first-player
is added to the white list.
This is useful when launching a server for this first time.
flavor
lets you specify a Minecraft distribution.
Possible values are minecraft, craftbukkit, ftb_ultimate, and voltz.
minecrab-shutdown [-M] [-W] <server-name>
Saves the world to Manta, tears down the Minecraft server, and starts generating a map.
-W
shuts down without saving the world to Manta.
This is useful if you're shutting down and annihilating.
-M
shuts down without generating a map.
This is useful if you you do not want to incur job charges.
minecrab-add-friend <server-name> <player-name>
Adds player-name
to server-name
's white list.
minecrab-kick-friend <server-name> <friend-name> [reason]
Removes friend-name
from server-name
's white list and
kicks them off the server. You can provide a reason
.
minecrab-list-friends <server-name>
Lists the players in server-name
's white list.
minecrab-list
Lists all the minecrab servers running in your Joyent account.
Running servers are listed first.
You can restart servers that are offline with the
minecrab-launch
command.
Use minecrab-annihilate
to
destroy a server forever.
$ bin/minecrab-list
IP STATE NAME
165.225.151.29 running nate
165.225.149.97 running joyent
165.225.148.207 stopping beans
8.19.32.162 running cigar
n/a offline carrot
n/a offline filips
n/a offline darkplace
n/a offline filip
minecrab-backup <server-name>
Backs up server-name
's world to Manta.
minecrab-copy <server-name> <copy-name>
Copies server-name
to copy-name
.
If copy-name
exists,
you'll get a chance to cancel or overwrite the existing server.
$ minecrab-copy cigar pipe
Checking if server is up...
Taking latest backup of cigar...
tar: ./world/region/r.-1.0.mca: file changed as we read it
Copying cigar to pipe...
Done!
Now you can use minecrab-launch to launch the new server.
$ minecrab-launch pipe
Launching pipe ................... done
Server pipe running on 165.225.148.207 id: be9f2f8b-8716-4677-d98b-cf0d93762c18
Setting up...
Installing git...
Cloning repo...
Warning: Permanently added 'github.com,192.30.252.130' (RSA) to the list of known hosts.
Installing server...
Connect to server at 165.225.148.207!
minecrab-annihilate <server-name>
Utterly and completely annihilates server-name
.
If server-name
is running,
you must shut it down first.
This command removes the saved world from Manta. Once the world is annihilated, you can never get it back.
minecrab-get <server-name>
Gets information about server-name
.
If a map of the world is available,
its URL is listed here.
$ minecrab-get cigar
id: eee95b34-dc8a-4b6e-cf5e-b1cad46cecdc
name: ac9294e
image: 17c98640-1fdb-11e3-bf51-3708ce78e75a
memory: 4096 mb
disk: 134144 gb
dataset: sdc:sdc:base64:13.2.1
ip addr: 8.19.32.162
map: http://us-east.manta.joyent.com/Joyent_Dev/public/minecrab/servers/cigar/map/view/index.html
manta: /Joyent_Dev/public/minecrab/servers/cigar/server/world.tar.gz
minecrab-map <server-name>
Creates a map of the world in server-name
and
makes it available through a URL.
The map is rendered on Manta. A small world may take 15 minutes to map. Larger worlds take longer to render.
$ minecrab-map cigar
Finding server...
Taking latest backup of cigar...
tar: ./world/region/r.-1.0.mca: file changed as we read it
Running map command from cigar...
added 1 input to 14e13f31-ea6d-eab7-f924-ace497431bff
Kicking off job...
Job 14e13f31-ea6d-eab7-f924-ace497431bff running!
Done!
Use mjob get
to check on the progress of the mapping:
$ mjob get b042006a-bae8-6d77-a061-99f2abe12e37 | json state
running
. . .
$ mjob get b042006a-bae8-6d77-a061-99f2abe12e37 | json state
done
When the rendering job ends, the state will be done. Use minecrab-get to get the URL of the map.
These commands let you work directly with your Minecraft server and with the instance that your server is on.
Be careful.
minecrab-command <server-name> <minecraft-command>
Runs a single Minecraft command as if you were at the console.
minecrab-console <server-name>
Logs in to the instance hosting server-name
and
connects to the Minecraft server's console.
WARNING
DO NOT use Ctrl-C
to exit from the console,
or you will shut down your server.
Use Ctrl-B d
instead.
minecrab-exec <server-name> <shell-command>
Run a single shell command (as root) on the instance hosting server-name
.
minecrab-login <server-name>
Logs in as root to the instance hosting server-name
.
Minecrab uses SSH agent forwarding to give the instances it creates
access to your authorization.
If you look at the code in the bin
directory,
you'll see that all calls to ssh
use the -A
switch.
In order for all this to work,
you must be using ssh-agent
.
On OS X, SSH is set up to use agents by default.
If you're having trouble with ssh-agent
,
see Problems with SSH agent
in the Troubleshooting section.
To learn more about agent forwarding, see Steve Freidl's An Illustrated Guide to SSH Agent Forwarding.
Using Minecrab on the Joyent Cloud service incurs three kinds of charges:
- Compute time charges while a Minecraft server is running on an instance
- Storage charges for your Minecraft world when it's offline
- Job charges for rendering a map of your world
When you launch a server Minecrab provisions a SmartOS instance using the base64 13.2.1 image with 4 GB of RAM and 131 GB of disk space.
This virtual machine instance size is billed at $0.128 per hour.
When you run minecrab-shutdown, the Minecraft server stops, the instance that is hosting the Minecraft server is deleted, and billing for the instance ends.
As long as you remember to shut down your instance, you won't pay for an idle server.
Storage for your Minecraft world on Manta is billed at $0.086 per GB per month. Most Minecraft worlds are less than 100 MB, which would be less than a penny a month.
Map rendering takes place on Manta using a 4 GB job. This job is billed at $0.00016 * number of seconds of wall-clock time.
For example:
- A 15-minute job costs $0.144.
- A two-hour job costs $1.152.
If you don't want to pay for map rendering,
use the -M
option
in minecrab-shutdown.
Note that all prices are as of the writing of this guide.
To see if ssh-agent
is running properly,
use ssh-add
:
$ ssh-add -L
ssh-rsa AAAAB3N ... so much text ... PQ== /Users/yourname/.ssh/id_rsa
If you don't see your key, you may need to add it like this:
$ ssh-add ~/.ssh/id_rsa
If you see something like:
$ ssh-add -L
Could not open a connection to your authentication agent.
You'll need to start ssh-agent
with something like this:
$ eval $(ssh-agent -s) # if you are using bash and related shells
... or ...
$ eval `ssh-agent -c` # if you are using csh and related shells
There may be times when a minecrab server fails to come up. Here's an example:
$ bin/minecrab-launch -p user persephone
Launching persephone.............................. Done!
Server persephone running on 72.2.119.193 id: 058b1756-ba7c-40a9-ef9c-a9e26019a64a
Setting up...
minecrab-launch: fatal error: Failed to execute echo -e "Host github.com\n\tStrictHostKeyChecking no\n" >> ~/.ssh/config on 72.2.119.193
There's a good chance that the instance was created. If you just leave it running, you'll get charged for it.
Find the machine you want to kill. Use its tags to find the instances ID:
$ sdc-listmachines --tag "minecrab=*" | json -a id tags
17e4ab29-85d5-46a6-b246-f81c80e1c4c7 {
"minecrab": "alcyone"
}
058b1756-ba7c-40a9-ef9c-a9e26019a64a {
"minecrab": "persephone"
}
In this case we have two minecrab servers.
"Persephone" is the one that failed to launch,
so lets kill it.
Use sdc-deletemachine
to delete the instance.
Then use sdc-getmachine
to monitor its death.:
$ sdc-deletemachine 058b1756-ba7c-40a9-ef9c-a9e26019a64a
$ sdc-getmachine 058b1756-ba7c-40a9-ef9c-a9e26019a64a | json state
Running
$ sdc-getmachine 058b1756-ba7c-40a9-ef9c-a9e26019a64a | json state
Object is Gone (410)
- Minecraft Overviewer - The renderer we use.
- aboron/minecraft-smartos-smf - Used as the basis for running the minecraft server.
- Minecraft Minecraft ®/TM & © 2009-2013 Mojang / Notch
- The error
tar: ./world/region/r.-1.0.mca: file changed as we read it
is benign. You can ignore it. - The warning
Warning: Permanently added 'github.com,192.30.252.130' (RSA) to the list of known hosts.
is benign. - The error
socket hang up
means that we were unable to provision an instance for your server. Try the command again. - On Ubuntu 13 (and probably other Linuxes) there were Node.js build EACCES warnings that were safe to ignore.
The code for Minecrab is MIT, see LICENSE.