From bae0ce3b6f8e85e02b81dc836fdc4b3b19d219f0 Mon Sep 17 00:00:00 2001 From: SimonCqk Date: Thu, 21 Mar 2024 15:32:02 +0800 Subject: [PATCH] stash --- Makefile | 4 +-- docker/Dockerfile.dataset | 2 +- docker/Dockerfile.jindoruntime | 2 +- pkg/ddc/jindocache/ufs.go | 48 ++++++++++++++++++++++++++++++++++ pkg/ddc/jindocache/utils.go | 5 ++++ 5 files changed, 57 insertions(+), 4 deletions(-) diff --git a/Makefile b/Makefile index 82ee2f6b3eb..6b64324f409 100644 --- a/Makefile +++ b/Makefile @@ -161,13 +161,13 @@ csi-build: CGO_ENABLED=0 GOOS=linux GOARCH=${ARCH} GO111MODULE=${GO_MODULE} go build ${GC_FLAGS} -a -o bin/fluid-csi -ldflags '${LDFLAGS}' cmd/csi/main.go dataset-controller-build: - CGO_ENABLED=0 GOOS=linux GOARCH=${ARCH} GO111MODULE=${GO_MODULE} go build ${GC_FLAGS} -a -o bin/dataset-controller -ldflags '${LDFLAGS}' cmd/dataset/main.go + CGO_ENABLED=0 GOOS=linux GOARCH=amd64 GO111MODULE=${GO_MODULE} go build ${GC_FLAGS} -a -o bin/dataset-controller -ldflags '${LDFLAGS}' cmd/dataset/main.go alluxioruntime-controller-build: CGO_ENABLED=0 GOOS=linux GOARCH=${ARCH} GO111MODULE=${GO_MODULE} go build ${GC_FLAGS} -a -o bin/alluxioruntime-controller -ldflags '${LDFLAGS}' cmd/alluxio/main.go jindoruntime-controller-build: - CGO_ENABLED=0 GOOS=linux GOARCH=${ARCH} GO111MODULE=${GO_MODULE} go build ${GC_FLAGS} -a -o bin/jindoruntime-controller -ldflags '${LDFLAGS}' cmd/jindo/main.go + CGO_ENABLED=0 GOOS=linux GOARCH=amd64 GO111MODULE=${GO_MODULE} go build ${GC_FLAGS} -a -o bin/jindoruntime-controller -ldflags '${LDFLAGS}' cmd/jindo/main.go goosefsruntime-controller-build: CGO_ENABLED=0 GOOS=linux GOARCH=${ARCH} GO111MODULE=${GO_MODULE} go build ${GC_FLAGS} -a -o bin/goosefsruntime-controller -ldflags '${LDFLAGS}' cmd/goosefs/main.go diff --git a/docker/Dockerfile.dataset b/docker/Dockerfile.dataset index c3a68692663..59c9366b1e3 100644 --- a/docker/Dockerfile.dataset +++ b/docker/Dockerfile.dataset @@ -19,7 +19,7 @@ RUN apk add --update curl tzdata iproute2 bash libc6-compat vim && \ echo "Asia/Shanghai" > /etc/timezone ARG TARGETARCH -RUN curl -o helm-v3.11.3-linux-${TARGETARCH}.tar.gz https://get.helm.sh/helm-v3.11.3-linux-${TARGETARCH}.tar.gz && \ +RUN export HTTPS_PROXY=socks5://host.docker.internal:13659 && curl -o helm-v3.11.3-linux-${TARGETARCH}.tar.gz https://get.helm.sh/helm-v3.11.3-linux-${TARGETARCH}.tar.gz && \ tar -xvf helm-v3.11.3-linux-${TARGETARCH}.tar.gz && \ mv linux-${TARGETARCH}/helm /usr/local/bin/ddc-helm && \ chmod u+x /usr/local/bin/ddc-helm && \ diff --git a/docker/Dockerfile.jindoruntime b/docker/Dockerfile.jindoruntime index 7348cfddc2f..1e10936b365 100644 --- a/docker/Dockerfile.jindoruntime +++ b/docker/Dockerfile.jindoruntime @@ -16,7 +16,7 @@ RUN apk add --update curl tzdata iproute2 bash libc6-compat vim && \ echo "Asia/Shanghai" > /etc/timezone ARG TARGETARCH -RUN curl -o helm-v3.11.3-linux-${TARGETARCH}.tar.gz https://get.helm.sh/helm-v3.11.3-linux-${TARGETARCH}.tar.gz && \ +RUN export HTTPS_PROXY=socks5://host.docker.internal:13659 && curl -o helm-v3.11.3-linux-${TARGETARCH}.tar.gz https://get.helm.sh/helm-v3.11.3-linux-${TARGETARCH}.tar.gz && \ tar -xvf helm-v3.11.3-linux-${TARGETARCH}.tar.gz && \ mv linux-${TARGETARCH}/helm /usr/local/bin/ddc-helm && \ chmod u+x /usr/local/bin/ddc-helm && \ diff --git a/pkg/ddc/jindocache/ufs.go b/pkg/ddc/jindocache/ufs.go index 34c17e49be3..3a26d53de54 100644 --- a/pkg/ddc/jindocache/ufs.go +++ b/pkg/ddc/jindocache/ufs.go @@ -17,6 +17,8 @@ limitations under the License. package jindocache import ( + "fmt" + "github.com/fluid-cloudnative/fluid/pkg/ddc/jindocache/operations" "github.com/fluid-cloudnative/fluid/pkg/utils" ) @@ -110,3 +112,49 @@ func (e *JindoCacheEngine) ShouldUpdateUFS() (ufsToUpdate *utils.UFSToUpdate) { func (e *JindoCacheEngine) UpdateOnUFSChange(*utils.UFSToUpdate) (updateReady bool, err error) { return } + +func (e *JindoCacheEngine) shouldRemountMountpoint() { + runtime, err := e.getRuntime() + if err != nil { + e.Log.Error(err, "failed to execute shouldRemountMountpoint", "runtime", e.name) + return + } + + masterPodName, masterContainerName := e.getMasterPodInfo() + masterPod, err := e.getMasterPod(masterPodName, e.namespace) + if err != nil { + e.Log.Error(err, "checkIfRemountRequired", "master pod", e.name) + return + } + + var startedAt *metav1.Time + for _, containerStatus := range masterPod.Status.ContainerStatuses { + if containerStatus.Name == masterContainerName { + if containerStatus.State.Running == nil { + e.Log.Error(fmt.Errorf("container is not running"), "checkIfRemountRequired", "master pod", masterPodName) + return + } else { + startedAt = &containerStatus.State.Running.StartedAt + break + } + } + } + + // If mounttime is earlier than master container starttime, remount is necessary + if startedAt != nil && runtime.Status.MountTime != nil && runtime.Status.MountTime.Before(startedAt) { + e.Log.Info("remount on master restart", "jindocache", e.name) + + unmountedPaths, err := e.FindUnmountedUFS() + if err != nil { + e.Log.Error(err, "Failed in finding unmounted ufs") + return + } + + if len(unmountedPaths) != 0 { + ufsToUpdate.AddMountPaths(unmountedPaths) + } else { + // if no path can be mounted, set mountTime to be now + e.updateMountTime() + } + } +} diff --git a/pkg/ddc/jindocache/utils.go b/pkg/ddc/jindocache/utils.go index b2b93a3531d..886e0bdd067 100644 --- a/pkg/ddc/jindocache/utils.go +++ b/pkg/ddc/jindocache/utils.go @@ -27,6 +27,7 @@ import ( "github.com/fluid-cloudnative/fluid/pkg/utils" appsv1 "k8s.io/api/apps/v1" "k8s.io/apimachinery/pkg/types" + v1 "k8s.io/client-go/applyconfigurations/core/v1" ) func (e *JindoCacheEngine) getTieredStoreType(runtime *datav1alpha1.JindoRuntime) int { @@ -109,6 +110,10 @@ func (e *JindoCacheEngine) getMasterPodInfo() (podName string, containerName str return } +func (e *JindoCacheEngine) getMasterPod() (*v1.Pod, error) { + +} + // return total storage size of Jindo in bytes func (e *JindoCacheEngine) TotalJindoStorageBytes() (value int64, err error) { podName, containerName := e.getMasterPodInfo()