In order to ensure the performance of the application when accessing the data, the data in the remote storage system can be pulled to the distributed cache engine that is close to the computing node through data preloading beofre the application starts. Then the application that consumes the data can enjoy the acceleration effect brought by distributed cache even at the first time.
For the great benefit mentioned above, we provide DataLoad CRD. This is a CRD which offers you a clear and easy way to controll data preloading behaviors.
This document will introduce you two different ways about how to use DataLoad CRD:
- Fluid(version >= 0.4.0)
Please refer to the installation guide to complete the installation of fluid.
$ mkdir <any-path>/warmup
$ cd <any-path>/warmup
Check the Dataset and AlluxioRuntime objects to be created
cat << EOF > dataset.yaml
apiVersion: data.fluid.io/v1alpha1
kind: Dataset
metadata:
name: spark
spec:
mounts:
- mountPoint: https://mirrors.tuna.tsinghua.edu.cn/apache/spark/
name: spark
---
apiVersion: data.fluid.io/v1alpha1
kind: AlluxioRuntime
metadata:
name: spark
spec:
replicas: 2
tieredstore:
levels:
- mediumtype: MEM
path: /dev/shm
quota: 2Gi
high: "0.95"
low: "0.7"
EOF
Notes: Here, we use THU's tuna Apache mirror site as our
mountPoint
. If your environment isn't in Chinese mainland, please replace it withhttps://downloads.apache.org/spark/
.
Here, we'd like to create a resource object with kind Dataset
. Dataset
is a Custom Resource Definition(CRD) defined by Fluid and used to tell Fluid where to find all the data you'd like to access.
In this guide, we'll use WebUFS for its simplicity.
For more information about UFS, please refer to Alluxio Docs - Storage Integrations
We use Apache Spark on a mirror site of Apache downloads as an example of remote file. It's nothing special, you can change it to any remote file you like. But please note that, if you are going to use WebUFS like we do, files on Apache sites are highly recommended because you might need some advanced configurations due to current implementation of WebUFS.
Create the Dataset and AlluxioRuntime
kubectl create -f dataset.yaml
Wait for the Dataset and AlluxioRuntime to be ready
You can check their status by running:
kubectl get datasets spark
Dataset and Runtime are all ready if you see something like this:
NAME UFS TOTAL SIZE CACHED CACHE CAPACITY CACHED PERCENTAGE PHASE AGE
spark 1.92GiB 0.00B 4.00GiB 0.0% Bound 4m4s
Check the DataLoad object to be created
cat <<EOF > dataload.yaml
apiVersion: data.fluid.io/v1alpha1
kind: DataLoad
metadata:
name: spark-dataload
spec:
dataset:
name: spark
namespace: default
EOF
spec.dataset
specifies the target dataset that needs to be preloaded. In this example, our target is the Dataset named spark
under the default
namespace.
Feel free to change the configuration above if it doesn't match your actual environment
By default, it'll preload all the data in the target dataset. If you'd like to controll the data preloading behaviors in a more find-grained way(e.g. preload data under some specified path only), please refer to DataLoad Advanced Configurations
Create the DataLoad object
kubectl create -f dataload.yaml
Check DataLoad's status
kubectl get dataload spark-dataload
You shall see something like:
NAME DATASET PHASE AGE
spark-dataload spark Loading 2m13s
In addition, you can get detailed info about the DataLoad object by:
kubectl describe dataload spark-dataload
and you shall see something like this:
Name: spark-dataload
Namespace: default
Labels: <none>
Annotations: <none>
API Version: data.fluid.io/v1alpha1
Kind: DataLoad
...
Spec:
Dataset:
Name: spark
Namespace: default
Status:
Conditions:
Phase: Loading
Events:
Type Reason Age From Message
---- ------ ---- ---- -------
Normal DataLoadJobStarted 80s DataLoad The DataLoad job spark-dataload-loader-job started
The data preloading process may take serveral minutes according to your network environment.
Wait for the data preloading to complete
Check its status by running:
kubectl get dataload spark-dataload
If the data preloading is already done, you should find that the Phase
of the DataLoad has turned to Complete
:
NAME DATASET PHASE AGE
spark-dataload spark Complete 5m17s
Now check the status of the dataset again:
kubectl get dataset spark
You'll find that all data in the remote file storage has already been preloaded into the distributed cache engine:
NAME UFS TOTAL SIZE CACHED CACHE CAPACITY CACHED PERCENTAGE PHASE AGE
spark 1.92GiB 1.92GiB 4.00GiB 100.0% Bound 7m41s
Besides the basic data preloading feature showed in the above example, with a little bit more configurations, you can enable some advanced features that the DataLoad CRD offers, including:
- Preload data under some specified path only
- Set cache replicas when preloading data
- Sync metadata before preloading data
With some extra configurations, DataLoad will only preload data under some specified path (or file) instead of the whole dataset. For example:
apiVersion: data.fluid.io/v1alpha1
kind: DataLoad
metadata:
name: spark-dataload
spec:
dataset:
name: spark
namespace: default
target:
- path: /spark/spark-2.4.7
- path: /spark/spark-3.0.1/pyspark-3.0.1.tar.gz
Instead of the whole dataset, the above DataLoad will only preload /spark/spark-2.4.7
and /spark/spark-3.0.1/pyspark-3.0.1.tar.gz
When preloading data, you can set cache replicas by simple configuration. For example:
apiVersion: data.fluid.io/v1alpha1
kind: DataLoad
metadata:
name: spark-dataload
spec:
dataset:
name: spark
namespace: default
target:
- path: /spark/spark-2.4.7
replicas: 1
- path: /spark/spark-3.0.1/pyspark-3.0.1.tar.gz
replicas: 2
The above DataLoad will preload all the files under /spark/spark-2.4.7
with only one cache replicas in the distributed cache engine, while it will
preload the file /spark/spark-3.0.1/pyspark-3.0.1.tar.gz
with two cache replicas.
Under many circumstances, files in the remote storage system has changed. Distributed cache engine like Alluxio needs to sync metadata to update its view of the remote file storage. It is very common to sync metadata before preloading data from remote file storage, DataLoad CRD offers you a simple way to do this:
apiVersion: data.fluid.io/v1alpha1
kind: DataLoad
metadata:
name: spark-dataload
spec:
dataset:
name: spark
namespace: default
loadMetadata: true
target:
- path: /
replicas: 1
By setting loadMetadata
to true, you can sync metadata before the data preload starts.
Notes: Syncing metadata from remote under storage is usually expensive. We do not suggest you enable it if it's not necessary.
$ kubectl delete -f .