Я собрал небольшой пример того, как я управляю своей средой разработки с помощью Docker из Emacs. Идея состоит в том, чтобы вместо нескольких файлов в папках, которые взаимосвязаны друг с другом и, таким образом, было трудно отслеживать переходные изменения, иметь один файл org и просто связывать отдельные файлы и даже выполнять некоторые блоки исходного кода внутри организации. файл для удобства использования некоторых пакетов Emacs. Ниже я пытаюсь описать свои рассуждения, и я благодарен за совет о том, как упорядочить вещи, а также альтернативы моему подходу. Может быть, это может оказаться полезным для тех, кто стремится к подобным рабочим процессам. Могу ли я что-то улучшить, следуя рекомендациям и тому подобному? Меня особенно беспокоит переменная локального файла, которая определяет имя docker -изображения для каждого файла и которую мне нужно прочитать в нескольких местах довольно громоздким способом
# -*- image_name: "test_env"; -*-
* Environment
:PROPERTIES:
:header-args: :results output :mkdirp yes
:END:
** requirements.txt
#+BEGIN_SRC conf :tangle requirements.txt
numpy
#+END_SRC
** Start docker
#+BEGIN_SRC sh :dir "/sudo::"
sudo service docker start
#+END_SRC
** Dockerfile
Use [ob-docker-build][1] to build the docker images upon pressing C-c C-c. The image
name is grabbed from the file-local variable at the top of this file. This file
can also be tangled to disk.
#+BEGIN_SRC docker-build :dir "." :tag (symbol-value 'image_name) :tangle Dockerfile
FROM python:3.8-slim-buster
ENV VIRTUAL_ENV=/opt/venv
RUN python3 -m venv $VIRTUAL_ENV
# Make sure we use the virtualenv:
ENV PATH="$VIRTUAL_ENV/bin:$PATH"
COPY requirements.txt .
RUN pip install --quiet --no-cache-dir -r requirements.txt
WORKDIR /app
# just for keeping the container running
CMD tail -f /dev/null
#+END_SRC
** run_docker.sh
This script can either be tangled to disk or is executed automatically by
org-sbe in the python application below
#+HEADER: :var image_name=(symbol-value 'image_name)
#+name: run_docker
#+BEGIN_SRC bash :tangle run_docker.sh :tangle-mode (identity #o755) :results output
#!/bin/bash
SBX_DIR=$(realpath $(dirname $0))
# generate some id for the container
CONTAINER_NAME=$(uuidgen | md5sum | awk '{ print $1 }' | cut -c -12)
if [ $# -eq 0 ]; then
ARGS=$SHELL
else
ARGS=$@
fi
DOCKER="docker run"
DOCKER_ARGS=(
--name "$CONTAINER_NAME"
-v $HOME:$HOME
-v "$SBX_DIR":"$SBX_DIR"
--rm
--user $(id -u):$(id -g)
-w $SBX_DIR
-itd ${image_name}
$ARGS
)
$DOCKER ${DOCKER_ARGS[@]}
#+END_SRC
** python
Use the [docker-tramp][1] package to attach to a running container. C-c C-c on the
block below causes the run-docker src-block to be executed. The resulting ID of
the container is then used here to attach to this running instance
#+BEGIN_SRC python :dir (concat "/docker:" (org-sbe run_docker) ":") :results output
print('hello')
#+END_SRC
Что имеет приоритет здесь?
# -*- foo: "one"; -*-
#+PROPERTY: header-args :var foo=two
#+PROPERTY: foo=three
* first
:PROPERTIES:
:foo: four
:END:
** second
:PROPERTIES:
:foo: five
:END:
#+HEADER: foo=(symbol-value 'foo)
#+BEGIN_SRC bash :var foo=(org-macro--get-property "foo" "")
echo $foo
#+END_SRC