A wrapper around Datomic Free that makes it easy to start Datomic Free transactors and upgrade to newer versions.
For first time users:
This npm install datomic-free
also auto-installs the bon dependency, globally.
If datomic-free
doesn't work - set / export $NODE_PATH
to the dir containing your global node_modules
. Run dirname $(which bon)
to find out where they go.
NOTE: please choose either the npm
approach above or the manual one below.
If you do both, the script may not run as it should.
Verify with type -a datomic-free
for which there should be only one datomic-free
.
If unhappy with this npm distribution just npm rm -g datomic-free
.
$ git clone https://github.com/cldwalker/datomic-free.git ~/.datomic-free
$ ~/.datomic-free/bin/datomic-free start
# To make it easy to use `datomic-free` add an alias to your bashrc/zshrc
$ echo 'alias datomic-free=$HOME/.datomic-free/bin/datomic-free' >> ~/.zshrc
$ . ~/.zshrc
The node package versions are independent of datomic-free releases or Datomic itself.
Just like with the manual install, the code is cloned to ~/.datomic-free/
and
upgrades would be manual too.
Some day there may be a datomic-free upgrade
command to git pull
as a convenience.
Upgrading Datomic is called datomic-free update
, covered in the Usage section below.
$ datomic-free start
To specify transactor.properties, only with an absolute path:
$ datomic-free start /absolute/path/to/transactor.properties
To migrate existing data/ to datomic-free:
$ rm -rf ~/.datomic-free/data
$ cp -R $OLD_DATOMIC_REPO/data ~/.datomic-free/
Whenever you'd like to update to the latest datomic-free:
$ datomic-free update
This new version is now the active datomic-free version. Since datomic-free keeps data outside of versions in ~/.datomic-free/data, you use the same data across versions by default.
To update to a specific version, pass a version:
$ datomic-free update 0.8.3627
To use another version you've already installed:
$ datomic-free use 0.8.3646
For npm test
to pass -- npm install -g batshit
is needed.
See datomic-free's TODO section about possible improvements. Some of these have already been implemented with dbin which makes it possible to run both datomic-free and datomic-pro servers - using optional JSON configuration.
See LICENSE.txt. This project is in no way affiliated with Datomic (Metadata Partners, LLC).
- Thanks to @cldwalker for the datomic-free script
- Thanks to @richhickey and @stuarthalloway for datomic
- Thanks to @rkneufeld for the downloading function of the shell script
- Bug fixes: @sherbondy