This CLI provides a set of commands to manage containerized services, OpenFaaS functions, and Metta operations. It includes functionalities to start and stop db services, manage OpenFaaS functions, load Metta files, and validate Metta file syntax.
Before using the DAS Toolbox, make sure you have the following prerequisites installed:
- Docker
You can install the das-cli
package through apt:
- If this is your first time installing the DAS Toolbox on your computer, you'll need to set up our repository by executing the following command:
sudo bash -c "wget -O - http://45.77.4.33/apt-repo/setup.sh | bash"
- Once you've completed that step, you can proceed to install the das-cli package:
sudo apt install das-cli
- This will install the DAS CLI package, allowing you to start using the DAS Toolbox's command-line interface
das-cli --help
To install the DAS Toolbox from the source code, you require the following prerequisites, in addition to those outlined in the Prerequisites section:
- Python 3.10.x
- Virtualenv (optional but recommended)
- Pip (Python package installer)
You can follow these steps:
- Clone the repository:
git clone https://github.com/singnet/das-toolbox.git
- To ensure a clean and isolated environment for running the DAS Toolbox, it is recommended to use a virtual environment. This command will create a virtual environment named
env
in the current directory.:
python3 -m venv env
- Now you need to activate the virtual environment. After activation, your shell prompt should change to indicate that you are now working within the virtual environment.
source env/bin/activate
- Navigate to the source code directory:
cd das-toolbox/src
- This command will install all the required dependencies for the DAS Toolbox within the virtual environment.:
pip3 install -r requirements.txt
- Run the
das_cli.py
file directly:
python3 das_cli.py --help
- When you've finished using the DAS Toolbox, you can deactivate the virtual environment, and your shell prompt will revert to its usual state. To activate the virtual environment again, simply execute the command from the third step.
deactivate
You can also download the das-cli
binary available in the releases of GitHub.
Before delving into usage, it's crucial to comprehend the two distinct deployment options available: LOCAL and REMOTE.
LOCAL deployment will setup the database backend required to use a redis_mongo DAS locally, i.e. a DAS instantiated like this:
das = DistributedAtomSpace(query_engine='local', atomdb='redis_mongo', ... )
Both databases (Redis and MongoDB) will be set up in docker containers with (configurable) exposed ports. This deployment is supposed to be used by one single client locally, i.e. there's no concurrency management other than the ones provided by each DBMS and no DAS cache optimization will take place.
LOCAL deployment is meant for Python applications which uses DAS running in the same machine with a knowledge base which is large enough to not fit entirely in RAM but small enough to fit in one single machine. Once deployed, the user can either load a knowledge base (see instructions below) or use DAS api to populate it.
If you want to access a DAS from a remote machine, you need to deploy the REMOTE version of DAS.
FAAS deployment will setup an OpenFaaS server to answer connection requests as well as the database backend. A REMOTE deployment can be connected using a DAS instantiated like this:
das = DistributedAtomSpace(query_engine='remote', host=<host>, port=<port>, ...)
FAAS deployment is meant for creation of a DAS knowledge base which is supposed to be used concurrently by several clients in different remote machines.
The commands outlined below should be executed within the "src" directory if you're running the code directly from its source using Python. Alternatively, if you're utilizing the package available from apt, you can simply run das-cli
instead of python3 das_cli.py
.
python3 das_cli.py <command> <subcommand> [options]
--help
: Package help (global flag).--version
: Package Version (global flag).update-version
: Update Package Version.example local
: Echo commands for local setup.example faas
: Echo commands for OpenFaaS setup.config list
: Display the current configuration settings.config set
: Set Redis and MongoDB configuration settings.db start
: Start Redis and MongoDB containers.db stop
: Stop and remove Redis and MongoDB containers.db restart
: Restart Redis and MongoDB containers.db count-atoms
: Display the total Atoms within the databases.faas start
: Start an OpenFaaS service inside a docker container.faas stop
: Stop and remove the OpenFaaS container.faas restart
: Restart OpenFaaS container.faas update-version
: Update an OpenFaaS service to a newer version.faas version
: Get OpenFaaS function version.metta load
: Load a MeTTa file into the databasesmetta check
: Check the syntax of a Metta file or directory.logs redis
: Display Docker container log for Redislogs mongodb
: Display Docker container log for MongoDB.logs faas
: Display Docker container log for OpenFaas.logs das
: Display logs for das.jupyter-notebook start
: Start a Jupyter Notebook.jupyter-notebook restart
: Restart Jupyter Notebook.jupyter-notebook stop
: Stop a Jupyter Notebook.python-library list
: List all major/minor versions of hyperon-das and hyperon-das-atomdb.python-library set
: Allow setting specific versions for both hyperon-das and hyperon-das-atomdb librariespython-library version
: Show currently installed and newest available versions of both, hyperon-das and hyperon-das-atomdbpython-library update
: Update both hyperon-das and hyperon-das-atomdb to the newest available version.release-notes
: List available release notes versions.dbms-adapter das-peer start
: Start a DAS peer container as a server for Atoms collection and storage.dbms-adapter das-peer stop
: Stop and remove a DAS peer container.dbms-adapter das-peer restart
: Restart a DAS peer container.dbms-adapter dbms-peer run
: Start a DBMS peer client with specified database and context that connects to the DAS peer server.
These steps provide a detailed guide on how to run the Distributed Atom Space, ensuring a smooth deployment process.
Follow these steps:
# Install Hyperon-DAS:
pip3 install hyperon-das
# Set the configuration file
python3 das_cli.py config set
# Start db services
python3 das_cli.py db start
# Check a Metta file (absolute path to a single file)
python3 das_cli.py metta check $PWD/examples/data/animals.metta
# Load a Metta file (absolute path to a single file)
python3 das_cli.py metta load $PWD/examples/data/animals.metta
# Start OpenFaaS Service
python3 das_cli.py faas start
# Start DAS peer server service
python3 das_cli.py dbms_adapter das_peer start
# Start DBMS peer client
python3 das_cli.py dbms_adapter dbms_peer run --client-hostname example.io --client-port 1234 --client-database myDatabase --client-username John --context $(pwd)/context.txt
To view help information for any command or subcommand, you can use the --help
option. This option provides detailed information about the usage, options, and arguments associated with the specified command.
# View help for the main script
python3 das_cli.py --help
# View help for a specific subcommand (e.g., start within the db command)
python3 das_cli.py db start --help
# View help for the OpenFaaS start command
python3 das_cli.py faas start --help
The --help
option is a powerful tool to understand how to use each command effectively. Use it at any level in the command hierarchy to access relevant documentation and ensure correct command execution.
For users who install the deb package, a man page is available for additional reference. You can access it using the man command. This provides comprehensive documentation, including usage examples, descriptions of options, and more.
# View help for the main command
man das-cli
# View help for a specific subcommand (e.g., start within the db command)
man das-cli-db-start
# View help for the OpenFaaS start command
man das-cli-faas-start
To execute the integration tests, use the following commands:
-
Without Cluster Tests:
make integration_tests
This command runs all integration tests, excluding those that require a configured Redis cluster.
-
With Cluster Tests:
DAS_CLI_TEST_CLUSTER=true make integration_tests
Make sure you have configured the
tests/integration/fixtures/config/redis_cluster.json
file. Replace theusername
andip
for the cluster nodes. For the first node, you don't need to replace theusername
as it will automatically use the current server's user where the tests are running withdas-cli
. Do not change thecontext
as it will be created during test execution.
If you encounter errors or issues when running Docker commands, follow these steps to troubleshoot common problems.
If you receive a permission error when executing Docker commands, make sure that your user is in the docker
group. Run the following command to add your user to the group:
sudo usermod -aG docker $USER
After adding your user to the docker
group, it is necessary to start a new bash session for the changes to take effect.
This error occurs because the das-cli
executable includes a compressed support file that is unpacked into a temporary directory during execution. When the storage is full, the extraction process fails. Ensure you have at least 32 MB of free space in your disk. With sufficient free space, you should be able to execute the commands as expected.