Skip to content

Latest commit

 

History

History
197 lines (158 loc) · 7.23 KB

README.md

File metadata and controls

197 lines (158 loc) · 7.23 KB

gitreefs

Virtual file system, mapping from a directory of clones to all of their possible contents

icon

Packages

Executables

Core

  • git - Layer to access git data, using go-git.
  • bfs - Implementation of virtual git fs over go-billy.
  • inodefs - Implementation of virtual git fs using inodes abstraction, as suiting jacobsa/fuse.
/disk/git/               ===>  /mnt/git/
          | clone1/.git                 | clone1/
                                             | commit1/
                                                       | src/...
                                             | commit2/
                                                       | src/...
                                             | commit3/
                                                       | src/...
          | clone2/.git
          | clone3/.git
          | ...

Tests

go test -v ./...

NFS solution

go run gitreefs/nfs --help
go run gitreefs/nfs --log-level INFO /var/git /var/git-data
# then
mkdir -p /tmp/git
# for osx
mount -o port=2049,mountport=2049 -t nfs localhost:/ /tmp/git
# for linux
mount -o port=2049,mountport=2049,nfsvers=3,noacl,tcp -t nfs localhost:/ /tmp/git
# to unmount
umount /tmp/git
NAME:
   gitreefs-nfs - NFS server providing access to a forest of git trees as a virtual file system

USAGE:
   gitreefs-nfs [Options] clones-path storage-path [port]

ARGS:
    clones-path   path to a directory containing git clones (with .git in them)
    storage-path  path to a directory in which to keep persistent storage (file handler mapping)
    port          (optional) to serve the server at, defaults to 2049

OPTIONS:
   --log-file value   Output logs file path format. (default: "logs/gitreefs-%v-%v.log")
   --log-level value  Set log level. (default: "DEBUG")
   --help, -h         show help
   --version, -v      print the version

Docker

# build docker
docker build -f nfs/Dockerfile -t gitreefs-nfs .
# test docker
docker run --rm -it -p 2049:2049 gitreefs-nfs --log-level INFO /tmp /opt/gitfreefs
# push docker
TAG=$(go run gitreefs/nfs --version | cut -d" " -f 3)
docker tag gitreefs-nfs gcr.io/apiiro/tools/gitreefs-nfs:$TAG
docker push gcr.io/apiiro/tools/gitreefs-nfs:$TAG

Benchmark

Currently not that good

https://github.com/apiirolab/EVO-Exchange-BE-2019

+--------------------------------------------+------------+-------------+
|                 Operation                  | Time (sec) | Degradation |
+--------------------------------------------+------------+-------------+
| Walk physical clone                        |      0.002 |             |
| Walk physical clone + read all files       |       0.02 |             |
| Walk virtual #1 iteration                  |       0.14 | x70         |
| Walk virtual #2 iteration                  |       0.09 | x45         |
| Walk virtual + read all files #1 iteration |       0.28 | x14         |
| Walk virtual + read all files #2 iteration |       0.27 | x13.5       |
+--------------------------------------------+------------+-------------+

https://github.com/apiirolab/elasticsearch

+--------------------------------------------+------------+-------------+
|                 Operation                  | Time (sec) | Degradation |
+--------------------------------------------+------------+-------------+
| Walk physical clone                        |        0.4 |             |
| Walk physical clone + read all files       |        3.6 |             |
| Walk virtual #1 iteration                  |       44.85 | x112       |
| Walk virtual #2 iteration                  |       28.73 | x72        |
| Walk virtual + read all files #1 iteration |      109.96 | x30.5      |
| Walk virtual + read all files #2 iteration |      108.41 | x30.1      |
+--------------------------------------------+------------+-------------+

FUSE solution

go run gitreefs/fuse --help
go run gitreefs/fuse --log-level INFO /var/git /mnt/git
NAME:
   gitreefs-fuse - Mount a forest of git trees as a virtual file system

USAGE:
   gitreefs-fuse [Options] clones-path mount-point

ARGS:
    clones-path  path to a directory containing git clones (with .git in them)
    mount-point  path to target location to mount the virtual fuseserver at

OPTIONS:
   --log-file value   Output logs file path format. (default: "logs/gitreefs-%v-%v.log")
   --log-level value  Set log level. (default: "DEBUG")
   --help, -h         show help
   --version, -v      print the version

Open Issues

  • Performance - can add caching, either in memory of physical fs based
  • Memory usage - currently nothing allocated will ever be released. Can add interval clean up to swipe away unused roots (in repository or commitish level).

Docker

# build docker
docker build -f fuse/Dockerfile -t gitreefs-fuse .
# test docker
docker run --rm -it --device /dev/fuse --privileged gitreefs-fuse /tmp /mnt/gitfreefs
# push docker
TAG=$(go run gitreefs/fuse --version | cut -d" " -f 3)
docker tag gitreefs-fuse us-docker.pkg.dev/apiiro/tools/gitreefs-fuse:$TAG
docker push us-docker.pkg.dev/apiiro/tools/gitreefs-fuse:$TAG

Benchmark

Currently not that good

https://github.com/apiirolab/EVO-Exchange-BE-2019

+--------------------------------------------+------------+-------------+
|                 Operation                  | Time (sec) | Degradation |
+--------------------------------------------+------------+-------------+
| Walk physical clone                        |      0.002 |             |
| Walk physical clone + read all files       |       0.02 |             |
| Walk virtual #1 iteration                  |       0.07 | x35         |
| Walk virtual #2 iteration                  |       0.03 | x15         |
| Walk virtual + read all files #1 iteration |       0.18 | x9          |
| Walk virtual + read all files #2 iteration |       0.11 | x5.5        |
+--------------------------------------------+------------+-------------+

https://github.com/apiirolab/elasticsearch

+--------------------------------------------+------------+-------------+
|                 Operation                  | Time (sec) | Degradation |
+--------------------------------------------+------------+-------------+
| Walk physical clone                        |        0.4 |             |
| Walk physical clone + read all files       |        4.4 |             |
| Walk virtual #1 iteration                  |       35.3 | x88         |
| Walk virtual #2 iteration                  |       24.4 | x61         |
| Walk virtual + read all files #1 iteration |      161.3 | x36.6       |
| Walk virtual + read all files #2 iteration |      136.2 | x31         |
+--------------------------------------------+------------+-------------+

Credits

Icons made by Freepik from www.flaticon.com