From b1a2e3d829a0e5c293c72ff90b0a44c77b1deb8e Mon Sep 17 00:00:00 2001 From: mhh Date: Thu, 21 Mar 2024 12:26:08 +0100 Subject: [PATCH] Limit rootfs size to not trigger message rejection --- packages/core/src/utils.ts | 6 ++++++ packages/message/src/instance/impl.ts | 6 ++++-- packages/message/src/utils/constants.ts | 3 +++ 3 files changed, 13 insertions(+), 2 deletions(-) diff --git a/packages/core/src/utils.ts b/packages/core/src/utils.ts index 4705372b..2c95db4e 100644 --- a/packages/core/src/utils.ts +++ b/packages/core/src/utils.ts @@ -45,3 +45,9 @@ export type JSExecutionEnvironment = 'node' | 'browser' export function delay(ms: number): Promise { return new Promise((resolve) => setTimeout(resolve, ms)) } + +export function gigabyteToMebibyte(n: number): number { + const mebibyte = 2 ** 20 + const gigabyte = 10 ** 9 + return Math.ceil((n * gigabyte) / mebibyte) +} diff --git a/packages/message/src/instance/impl.ts b/packages/message/src/instance/impl.ts index cae2c2ed..ee27f937 100644 --- a/packages/message/src/instance/impl.ts +++ b/packages/message/src/instance/impl.ts @@ -1,5 +1,5 @@ import { Blockchain, DEFAULT_API_V2, stripTrailingSlash } from '@aleph-sdk/core' -import { defaultResources, defaultExecutionEnvironment } from '../utils/constants' +import { defaultResources, defaultExecutionEnvironment, MAXIMUM_DISK_SIZE } from '../utils/constants' import { buildInstanceMessage } from '../utils/messageBuilder' import { prepareAlephMessage } from '../utils/publish' import { broadcast } from '../utils/signature' @@ -46,13 +46,15 @@ export class InstanceMessageClient { ...environment, } + const size_mib = mergedResources.memory * 10 > MAXIMUM_DISK_SIZE ? MAXIMUM_DISK_SIZE : mergedResources.memory * 10 + const rootfs = { parent: { ref: image as string, use_latest: true, }, persistence: VolumePersistence.host, - size_mib: mergedResources.memory * 10, + size_mib, } const instanceContent: InstanceContent = { diff --git a/packages/message/src/utils/constants.ts b/packages/message/src/utils/constants.ts index 804b96b4..297b8db6 100644 --- a/packages/message/src/utils/constants.ts +++ b/packages/message/src/utils/constants.ts @@ -1,4 +1,5 @@ import { FunctionEnvironment, MachineResources } from '../types' +import { gigabyteToMebibyte } from '@aleph-sdk/core' export const defaultExecutionEnvironment: FunctionEnvironment = { reproducible: false, @@ -12,3 +13,5 @@ export const defaultResources: MachineResources = { vcpus: 1, seconds: 30, } + +export const MAXIMUM_DISK_SIZE = gigabyteToMebibyte(100)