occlum/tools/copy_bom
2023-10-11 10:03:09 +08:00
..
src Enable copy_bom to find dependences directories which ends with '/' 2023-10-11 10:03:09 +08:00
.gitignore Modify flink demo with copy_bom 2021-09-23 15:42:15 +08:00
Cargo.lock Bump regex from 1.5.4 to 1.5.5 in /tools/copy_bom 2022-06-15 18:59:06 +08:00
Cargo.toml [deps/rust-sgx-sdk] Upgrade rust-sgx-sdk to 1.1.5 2022-09-14 20:05:04 +08:00
example.yaml Enable copy_bom to find dependences directories which ends with '/' 2023-10-11 10:03:09 +08:00
Makefile Parse command line options 2021-09-17 15:50:15 +08:00
README.md Enable copy_bom to find dependences directories which ends with '/' 2023-10-11 10:03:09 +08:00

Introduction

This crate provides a tool named copy_bom. This tool is designed to copy files described in a bom file to a given dest root directory.

Bom file

Bom file is used to describe which files should be copied to the root directory(usually, the image directory). A bom file contains all files, directories that should be copied to the root directory. We also can define symbolic links and directories that should be created in a bom file. The meanings of each entry in the bom file can be seen in RFC: bom file. Also, a bom example with all optional entries can be seen in example.yaml.

copy_bom

overview

copy_bom is the tool designed to create directories and symbolic links, copy all files and directories defined in a bom file to the root directory. Internally, copy_bom will use rsync to do the real file operations. copy_bom will copy each file and directory incrementally, i.e., only changed parts will be copied. The permission bits and modification times will be reserved. This is done by the -a option of rsync. copy_bom will not ensure the whole image directory as described in bom file (sync behavior) because it will not try to delete old files. To pursue a sync behavior, one can delete the old image directory and copy files again.

dependencies

copy_bom will analyze all dependencies(shared objects) of each ELF file. copy_bom will analyze dependencies for each user-defined file in files entry as well as files in user-defined directory in dirs entry. For user-defined elf file, it will report error and abort the program if we can't find the dependent shared objects. For files in user-defined directories, we will report warning if autodep fails. We analyze dependencies via the dynamic loader defined in the .interp section in elf files and automatically copy dependencies to the root directory. If there's no .interp section for an elf file, copy_bom will try to infer the loader if all other elf files have the same loader. Currently, copy_bom only copy dependencies with absolute paths. We support only one dependency pattern in the result of dynamic loader.

  • name => path e.g., libc.so.6 => /lib/x86_64-linux-gnu/libc.so.6
    All dependencies will be copied to the corresponding directory in root directory. For example, if root directory is image, then the dependency /lib64/ld-linux-x86-64.so.2 will be copied to image/lib64/ld-linux-x86-64.so.2. An entry named autodep with value false can be added to each file to avoid finding and copying dependencies automatically.

log

copy_bom uses the same log setting as occlum. One can set OCCLUM_LOG_LEVEL=trace to see all logs printed by copy_bom. To only view real file operations, OCCLUM_LOG_LEVEL=info is a proper level.

prepare and install

1.prepare. Since copy_bom relies on rsync to copy files. We need to install rsync at first. On ubuntu, this can be done by apt install rsync -y. 2.install. copy_bom can be installed via cargo. e.g., cargo install --path ..

basic usage

copy_bom [FLAGS] [OPTIONS] --file <bom-file> --root <root-dir>

  • bom-file: The bom file which describes files we want to copy.
  • root-dir: The destination root directory we want to copy files to. Usually the image directory for occlum.

options

  • dry run mode: pass an option --dry-run to copy_bom will enable dry run mode. Dry run mode will output all file oprations in log but does not do real oprations. It is useul to check whether copy_bom performs as expected before doing real operations.

flags

  • -i, --include-dir: This flag is used to indicate which directory to find included bom files. This flag can be set multiple times. If the include-dir is set as a relative path, it is a path relative to the current path where you run the copy_bom command.
  • -h, --help: print help message

About the occlum_elf_loader.config file

This file is put in /etc/template. This file is used to define where to find occlum-specific loaders and occlum-specific libraries. If you want to find libraries in different paths, you should modify this config file.

The file content looks like as below:

/opt/occlum/glibc/lib/ld-linux-x86-64.so.2 /usr/lib/x86_64-linux-gnu:/lib/x86_64-linux-gnu 
/lib/ld-musl-x86_64.so.1 /opt/occlum/toolchains/gcc/x86_64-linux-musl/lib

Each line in this file represents a loader. Since occlum supports both musl and glibc loader, there are two loaders in the config file now.
Each line contains two parts, which is seperated with a space. The first part is the path of occlum-specific loader. This loader is used to analyse dependencies of elf file.
The second part in the line indicates where to find shared libraries. All paths should be separated by colons. The loader will first try to find libraries in the loader path, then will try to find libraries in user-provided path. This is done by set the LD_LIBRARY_APTH environmental variables. The order of paths matters, since we will find libraries in the order of given path.

known limitations

  • The use of wildcard(like *) in files or directories is not supported. It may result in copy_bom behaving incorrectly. To achieve a similar purpose, directly add / after the directory name to copy all contents in the directory while not copying the directory itself.
  • If we create symbolic link in bom file, it will always delete the old link and create a new one. It will change the modification time of the symbolic link.
  • Environmental variables pointing to an empty value may fail to resolve.

demos

  1. We have modify several demos with copy_bom.
  2. Before using these demos, rsync and copy_bom should be installed. There should be at least base.yaml and occlum_elf_loader.config in /opt/occlum/etc/template.