diff options
author | Frederick Muriuki Muriithi | 2022-09-13 03:03:13 +0300 |
---|---|---|
committer | Frederick Muriuki Muriithi | 2022-09-13 03:03:13 +0300 |
commit | 1b8bbfdeaedba80aa429308b23e7522c019570b3 (patch) | |
tree | b2eb267cab181c5e421120eb374fffa20194270c | |
parent | affdd3301ffe821734e69af8dcbebb93ba5d6fdf (diff) | |
download | gn-gemtext-1b8bbfdeaedba80aa429308b23e7522c019570b3.tar.gz |
topics: add documentation on guix pack
* topics/building-a-guix-pack-for-sharing.gmi: documentation
-rw-r--r-- | topics/building-a-guix-pack-for-sharing.gmi | 30 |
1 files changed, 30 insertions, 0 deletions
diff --git a/topics/building-a-guix-pack-for-sharing.gmi b/topics/building-a-guix-pack-for-sharing.gmi new file mode 100644 index 0000000..b82e81b --- /dev/null +++ b/topics/building-a-guix-pack-for-sharing.gmi @@ -0,0 +1,30 @@ +# Building a ~guix pack~ for Environment Sharing + +## Motivation + +Sometimes, you might +* not have access to guix where you want to deploy +* not be able to run a guix shell (due to space constraints on the /gnu/store partition, etc) +* not be able to create a guix profile (due to space constraints on the /gnu/store partition, etc) +but you still need to have a similar environment for running your application. + +In such cases, ~guix pack~ can come in handy. + +I will use the process I used for +=> gnqc_py https://gitlab.com/fredmanglis/gnqc_py +for demonstration + +> guix pack -RR -S /mybin=bin -S /mylib=lib \ +> -L /home/frederick/genenetwork/guix-bioinformatics \ +> python redis mariadb genenetwork-qc + +* The `-RR` option ensures `guix pack` produces relocatable[1] binaries +* The `-S` adds the symbolic links to the pack[1] +* The `-L`[2] option adds the ~guix-bioinformatics~ directory to the front of the module load path + +We then add python, redis, mariadb, and genenework-qc packages (and their dependencies) to the pack. + +## Footnotes + +=> [1] https://guix.gnu.org/manual/en/html_node/Invoking-guix-pack.html +=> [2] https://www.gnu.org/software/guile/manual/guile.html#Command_002dline-Options |