Setup a Local Exporter¶
This guide walks you through the process of using Jumpstarter with a local exporter (the client and the exporter running on the same host)
Create Exporter Configuration¶
Create a text file with the following content
# /etc/jumpstarter/exporters/demo.yaml
apiVersion: jumpstarter.dev/v1alpha1
kind: ExporterConfig
# endpoint and token are intentionally left empty
endpoint: ""
token: ""
# mock drivers for demo purpose
export:
storage:
type: jumpstarter.drivers.storage.driver.MockStorageMux
power:
type: jumpstarter.drivers.power.driver.MockPower
Once the exporter configuration is ready it should be placed at /etc/jumpstarter/exporters/demo.yaml
.
Enter Exporter Shell¶
Now we can run the following command to enter the “Exporter Shell”, inside which we can interact with the local exporter with Jumpstarter client.
$ jmp-exporter shell demo
Use j Command¶
The j
command is available in the exporter shell for controlling the exporter with shell commands.
# running inside exporter shell
$ j
Usage: j [OPTIONS] COMMAND [ARGS]...
Generic composite device
Options:
--help Show this message and exit.
Commands:
power Generic power
storage Generic storage mux
$ j power on
ok
Use Python API¶
Or we can use the Jumpstarter Python API to programmatically control the exporter.
# running inside exporter shell
$ python - <<EOF
from jumpstarter.common.utils import env
with env() as client:
print(client.power.on())
EOF
ok
Exit Exporter Shell¶
Once you are done with the exporter, simply exit the exporter shell and the local exporter would be terminated.