forked from skypilot-org/skypilot
-
Notifications
You must be signed in to change notification settings - Fork 0
/
using_file_mounts.yaml
130 lines (101 loc) · 3.44 KB
/
using_file_mounts.yaml
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
# Example: using file mounts
#
# File mounts sync local files (or cloud URLs) to the VM where a Task will run.
# Syncing is done before the Task's execution so that it can access these files.
# After syncing, the paths can be opened, read, or written as usual.
#
# Caveat:
#
# Destination paths may be created as *symlinks* under the hood. Some
# commands may require flags to follow symlinks (e.g., ls -H; du -L).
resources:
cloud: aws
workdir: .
num_nodes: 2
# Format for file_mounts:
#
# [ destination on VM ]: [ source, local or cloud ]
#
file_mounts:
###############################################
# Sync from local files/directories (rsync) #
###############################################
/setup.py: ./setup.py
/sky: .
~/tmpfile: ~/tmpfile
~/a/b/c/tmpfile: ~/tmpfile
~/tmpfile2: ~/tmp-workdir/tmp file
# Intermediate dirs are created and chown-ed to $USER if they don't already
# exist. Thus they can be used too, e.g., 'mkdir -p /data/logs'. See 'run'.
/data/checkpoints/best.pt: ~/tmpfile
~/.ssh/id_rsa.pub: ~/.ssh/id_rsa.pub
# Syncing directories.
#
# Suppose the source has:
#
# ~/tmp-workdir/
# a/
# b
# c
#
# After syncing the target will be:
#
# /tmp/workdir/
# a/
# b
# c
/tmp/workdir: ~/tmp-workdir
# Relative paths are under ~/ (after sync, ~/relative_dir/ exists).
relative_dir: ~/tmp-workdir
./dotslash_relative_dir: ~/tmp-workdir
#############################################
# Sync from Google Cloud Storage (gsutil) #
#############################################
# Syncing a regular object.
/train-00001-of-01024: gs://cloud-tpu-test-datasets/fake_imagenet/train-00001-of-01024
/data/train-00001-of-01024: gs://cloud-tpu-test-datasets/fake_imagenet/train-00001-of-01024
~/data/train-00001-of-01024: gs://cloud-tpu-test-datasets/fake_imagenet/train-00001-of-01024
/s3-data-test: s3://fah-public-data-covid19-cryptic-pockets/human/il6/PROJ14534/RUN999/CLONE0/results0
/s3-data-file: s3://fah-public-data-covid19-cryptic-pockets/human/il6/PROJ14534/RUN999/CLONE0/results0/frame0.xtc
# Test access to private bucket
# /my-bucket: s3://sky-detectron2-outputs
# /test-my-gcs: gs://cloud-storage-test-zhwu-2
# If a source path points to a "directory", its contents will be recursively
# synced (subdirectories included).
# Commenting out as this takes a while.
# /data/fake_imagenet: gs://cloud-tpu-test-datasets/fake_imagenet
setup: |
sudo apt update
sudo apt install -y tree
run: |
set -ex
ls -lthr ~/tmpfile
ls -lthr ~/a/b/c
mkdir -p /data/logs
touch /data/logs/test.log
touch /data/checkpoints/last.pt
echo hi >> /tmp/workdir/new_file
tree /tmp/workdir
ls -lthr ~/.ssh
ls -l /setup.py
cd /sky
pip3 install -e .
ls -lthr ~/.ssh/
ls -lthr ~/
ls -lthr ~/sky_workdir/relative_dir
ls -lthr ~/sky_workdir/relative_dir/
ls -lthr ~/sky_workdir/dotslash_relative_dir/
du -schL /train-00001-of-01024
wc -l /train-00001-of-01024
ls -l /data/train-00001-of-01024
ls -l ~/data/train-00001-of-01024
ls -l /s3-data-test
cat /s3-data-file > /dev/null
# ls -lH /data/fake_imagenet | head -n10
# sky.egg-info/ should not exists on remote due to the .gitingore
cd ~/sky_workdir
! ls sky.egg-info/
# Symlinks should be copied, but they will be broken
# Assumes symlink named circle-link in /tmp/workdir (created by test_smoke.py)
ls /tmp/workdir/circle-link
! readlink -e /tmp/workdir/circle-link