Environment configuration

Eden is able to control different environments. 

The environment should contain one EVE block at least and one controller block.

It may contain other blocks with other services, such as eserver, redis and any other service



Environment is launched by command

eden start

Environment can be stopped by the command

eden stop

Environment can be restarted by the command 

eden restart.

It is an equivalent of eden stop/ eden start



I can have a small config. 



Use case: 

I want to test different eve bundles and be able to switch between them. 

eden config  == help 

eden config add 

mkdir ./conf

eden config get  –-all  >  ./conf/config2.yml

<edit something in ./conf/config2.yml>

eden config add --name config2 --file ./conf/config2.yml   (if omitted - will create default) 

eden config list 

      --default

      –-config2

eden config set --name config2 

eden setup

eden start

eden test

eden stop

eden config set 

eden start 

eden test

eden stop

eden config delete --name config2

Config commands

About configs:

  • Default configs are generated by default. Default config is generated upon make build.

  • eden config init - generates default config and replaces it if exists

  • eden config add <name>  - adds the new config copied from default context.  Name is required.

    • --file option - adds from file.

    • If the config with <name> exists return that it already exists

    • --usediff If we have config.yml then we push the difference to config.

  • eden config delete <name> - removes the config. Name is required.

  • eden config set <name> - sets the config to <name>.  Name is required.

  • eden config list  - displays the config

  • eden config get  <name> - gets the  config <name>.

    • Omitted <name>- gets the current config 

    • --all -gets the config from file

    • --key - shows the param

  • eden start has the option of --config <name> or --config-file <path>

On eden init:

eden config init







Now context is stored in ./eden/contexts/<name.yml> 



Local tests- should be stored in context-aware directories

local files that are downloaded or used for environment/context are stored in ./eden/context-files/<context-name>/



make clean - cleans all 

eden clean - cleans all except eden

eden config clean - cleans all configs (asks yes /no) 



#config is generated by eden adam: #tag on adam container to pull tag: 0.0.36 #location of adam dist: adam #port of adam port: 3333 #domain of adam domain: mydomain.adam #ip of adam for EVE access eve-ip: 192.168.0.2 #ip of adam for EDEN access ip: 192.168.1.241 #force adam rebuild force: true #certificate for communication with adam ca: adam/run/config/root-certificate.pem #use remote adam remote: true #use v1 api v1: true eve: #devmodel devmodel: Qemu #EVE arch (amd64/arm64) arch: amd64 #EVE os (linux/darwin) os: linux #EVE acceleration (set to false if you have problems with qemu) accel: true #variant of hypervisor of EVE (kvm/xen) hv: kvm #serial number in SMBIOS serial: 31415926 #onboarding certificate of EVE to put into adam cert: certs/onboard.cert.pem #EVE pid file pid: eve.pid #EVE log file log: eve.log #EVE firmware firmware: eve/dist/amd64/OVMF.fd #eve repo used in clone mode (eden.download = false) repo: https://github.com/lf-edge/eve.git #eve tag tag: 5ee6043906449f7fa3447c96fd38dc9a536c5693 #eve tag for base os base-tag: 571d94a11fa19d79805a0465030175b7257d343b #eve version (without hv and os) base-version: 0.0.0-snapshot-master-93c2dbb2-2020-05-08.13.15 #forward of ports in qemu [(HOST:EVE)] hostfwd: 2222: 22 5912: 5901 5911: 5900 8027: 8027 8028: 8028 #location of eve directory dist: eve #location of EVE base os directory base-dist: evebaseos #file to save qemu config qemu-config: /home/fleandr/.eden/qemu.conf #uuid of EVE to use in cert uuid: 54236a31-7ddb-4610-ba68-9d9a1db17e24 #live image of EVE image-file: eve/dist/amd64/live.qcow2 #dtb directory of EVE dtb-part: #config part of EVE config-part: adam/run/config eden: #root directory of eden root: /home/fleandr/eden2/eden/dist images: #directory to save images dist: images #yml to build docker image docker: /home/fleandr/eden2/eden/images/docker/alpine/alpine.yml #yml to build vm image vm: /home/fleandr/eden2/eden/images/vm/alpine/alpine.yml #download eve instead of build download: true #eserver is tool for serve images eserver: #ip (domain name) of eserver for EVE access ip: mydomain.adam #port for eserver port: 8888 #pid for eserver pid: eserver.pid #log of eserver log: eserver.log #directory to save certs certs-dist: certs #directory to save binaries bin-dist: bin #ssh-key to put into EVE ssh-key: certs/id_rsa.pub #observe logs in tests logs: false #eden binary eden-bin: eden #test binary test-bin: eden.integration.test #test script test-script: eden.integration.tests.txt