@aws-cdk/aws-glue-alpha
Version:
The CDK Construct Library for AWS::Glue
144 lines • 18.3 kB
JavaScript
;
var __esDecorate = (this && this.__esDecorate) || function (ctor, descriptorIn, decorators, contextIn, initializers, extraInitializers) {
function accept(f) { if (f !== void 0 && typeof f !== "function") throw new TypeError("Function expected"); return f; }
var kind = contextIn.kind, key = kind === "getter" ? "get" : kind === "setter" ? "set" : "value";
var target = !descriptorIn && ctor ? contextIn["static"] ? ctor : ctor.prototype : null;
var descriptor = descriptorIn || (target ? Object.getOwnPropertyDescriptor(target, contextIn.name) : {});
var _, done = false;
for (var i = decorators.length - 1; i >= 0; i--) {
var context = {};
for (var p in contextIn) context[p] = p === "access" ? {} : contextIn[p];
for (var p in contextIn.access) context.access[p] = contextIn.access[p];
context.addInitializer = function (f) { if (done) throw new TypeError("Cannot add initializers after decoration has completed"); extraInitializers.push(accept(f || null)); };
var result = (0, decorators[i])(kind === "accessor" ? { get: descriptor.get, set: descriptor.set } : descriptor[key], context);
if (kind === "accessor") {
if (result === void 0) continue;
if (result === null || typeof result !== "object") throw new TypeError("Object expected");
if (_ = accept(result.get)) descriptor.get = _;
if (_ = accept(result.set)) descriptor.set = _;
if (_ = accept(result.init)) initializers.unshift(_);
}
else if (_ = accept(result)) {
if (kind === "field") initializers.unshift(_);
else descriptor[key] = _;
}
}
if (target) Object.defineProperty(target, contextIn.name, descriptor);
done = true;
};
var __runInitializers = (this && this.__runInitializers) || function (thisArg, initializers, value) {
var useValue = arguments.length > 2;
for (var i = 0; i < initializers.length; i++) {
value = useValue ? initializers[i].call(thisArg, value) : initializers[i].call(thisArg);
}
return useValue ? value : void 0;
};
Object.defineProperty(exports, "__esModule", { value: true });
exports.RayJob = void 0;
const jsiiDeprecationWarnings = require("../../.warnings.jsii.js");
const JSII_RTTI_SYMBOL_1 = Symbol.for("jsii.rtti");
const aws_glue_1 = require("aws-cdk-lib/aws-glue");
const job_1 = require("./job");
const constants_1 = require("../constants");
const metadata_resource_1 = require("aws-cdk-lib/core/lib/metadata-resource");
const prop_injectable_1 = require("aws-cdk-lib/core/lib/prop-injectable");
const core_1 = require("aws-cdk-lib/core");
/**
* Ray Jobs class
*
* Glue Ray jobs use worker type Z.2X and Glue version 4.0.
* These are not overrideable since these are the only configuration that
* Glue Ray jobs currently support. The runtime defaults to Ray2.4 and min
* workers defaults to 3.
*/
let RayJob = (() => {
let _classDecorators = [prop_injectable_1.propertyInjectable];
let _classDescriptor;
let _classExtraInitializers = [];
let _classThis;
let _classSuper = job_1.Job;
var RayJob = class extends _classSuper {
static { _classThis = this; }
static {
const _metadata = typeof Symbol === "function" && Symbol.metadata ? Object.create(_classSuper[Symbol.metadata] ?? null) : void 0;
__esDecorate(null, _classDescriptor = { value: _classThis }, _classDecorators, { kind: "class", name: _classThis.name, metadata: _metadata }, null, _classExtraInitializers);
RayJob = _classThis = _classDescriptor.value;
if (_metadata) Object.defineProperty(_classThis, Symbol.metadata, { enumerable: true, configurable: true, writable: true, value: _metadata });
}
static [JSII_RTTI_SYMBOL_1] = { fqn: "@aws-cdk/aws-glue-alpha.RayJob", version: "2.225.0-alpha.0" };
/** Uniquely identifies this class. */
static PROPERTY_INJECTION_ID = '@aws-cdk.aws-glue-alpha.RayJob';
jobArn;
jobName;
role;
grantPrincipal;
/**
* RayJob constructor
*/
constructor(scope, id, props) {
super(scope, id, {
physicalName: props.jobName,
});
try {
jsiiDeprecationWarnings._aws_cdk_aws_glue_alpha_RayJobProps(props);
}
catch (error) {
if (process.env.JSII_DEBUG !== "1" && error.name === "DeprecationError") {
Error.captureStackTrace(error, RayJob);
}
throw error;
}
// Enhanced CDK Analytics Telemetry
(0, metadata_resource_1.addConstructMetadata)(this, props);
this.jobName = props.jobName ?? '';
// Set up role and permissions for principal
this.role = props.role;
this.grantPrincipal = this.role;
// Enable CloudWatch metrics and continuous logging by default as a best practice
const continuousLoggingArgs = this.setupContinuousLogging(this.role, props.continuousLogging);
// Conditionally include metrics arguments (default to enabled for backward compatibility)
const profilingMetricsArgs = (props.enableMetrics ?? true) ? { '--enable-metrics': '' } : {};
const observabilityMetricsArgs = (props.enableObservabilityMetrics ?? true) ? { '--enable-observability-metrics': 'true' } : {};
// Combine command line arguments into a single line item
const defaultArguments = {
...this.checkNoReservedArgs(props.defaultArguments),
...continuousLoggingArgs,
...profilingMetricsArgs,
...observabilityMetricsArgs,
};
if (props.workerType && props.workerType !== constants_1.WorkerType.Z_2X) {
throw new core_1.ValidationError('Ray jobs only support Z.2X worker type', this);
}
const jobResource = new aws_glue_1.CfnJob(this, 'Resource', {
name: props.jobName,
description: props.description,
role: this.role.roleArn,
command: {
name: constants_1.JobType.RAY,
scriptLocation: this.codeS3ObjectUrl(props.script),
runtime: props.runtime ? props.runtime : constants_1.Runtime.RAY_TWO_FOUR,
},
glueVersion: constants_1.GlueVersion.V4_0,
workerType: props.workerType ? props.workerType : constants_1.WorkerType.Z_2X,
numberOfWorkers: props.numberOfWorkers ? props.numberOfWorkers : 3,
maxRetries: props.jobRunQueuingEnabled ? 0 : props.maxRetries,
jobRunQueuingEnabled: props.jobRunQueuingEnabled ? props.jobRunQueuingEnabled : false,
executionProperty: props.maxConcurrentRuns ? { maxConcurrentRuns: props.maxConcurrentRuns } : undefined,
timeout: props.timeout?.toMinutes(),
connections: props.connections ? { connections: props.connections.map((connection) => connection.connectionName) } : undefined,
securityConfiguration: props.securityConfiguration?.securityConfigurationName,
tags: props.tags,
defaultArguments,
});
const resourceName = this.getResourceNameAttribute(jobResource.ref);
this.jobArn = this.buildJobArn(this, resourceName);
this.jobName = resourceName;
}
static {
__runInitializers(_classThis, _classExtraInitializers);
}
};
return RayJob = _classThis;
})();
exports.RayJob = RayJob;
//# sourceMappingURL=data:application/json;base64,{"version":3,"file":"ray-job.js","sourceRoot":"","sources":["ray-job.ts"],"names":[],"mappings":"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","sourcesContent":["import { CfnJob } from 'aws-cdk-lib/aws-glue';\nimport * as iam from 'aws-cdk-lib/aws-iam';\nimport { Job, JobProps } from './job';\nimport { Construct } from 'constructs';\nimport { JobType, GlueVersion, WorkerType, Runtime } from '../constants';\nimport { addConstructMetadata } from 'aws-cdk-lib/core/lib/metadata-resource';\nimport { propertyInjectable } from 'aws-cdk-lib/core/lib/prop-injectable';\nimport { ValidationError } from 'aws-cdk-lib/core';\n\n/**\n * Properties for creating a Ray Glue job\n */\nexport interface RayJobProps extends JobProps {\n  /**\n   * Sets the Ray runtime environment version\n   *\n   * @default - Runtime version will default to Ray2.4\n   */\n  readonly runtime?: Runtime;\n\n  /**\n   * Specifies whether job run queuing is enabled for the job runs for this job.\n   * A value of true means job run queuing is enabled for the job runs.\n   * If false or not populated, the job runs will not be considered for queueing.\n   * If this field does not match the value set in the job run, then the value from\n   * the job run field will be used. This property must be set to false for flex jobs.\n   * If this property is enabled, maxRetries must be set to zero.\n   *\n   * @default - no job run queuing\n   */\n  readonly jobRunQueuingEnabled?: boolean;\n\n  /**\n   * Enable profiling metrics for the Glue job.\n   *\n   * When enabled, adds '--enable-metrics' to job arguments.\n   *\n   * @default true\n   */\n  readonly enableMetrics?: boolean;\n\n  /**\n   * Enable observability metrics for the Glue job.\n   *\n   * When enabled, adds '--enable-observability-metrics': 'true' to job arguments.\n   *\n   * @default true\n   */\n  readonly enableObservabilityMetrics?: boolean;\n}\n\n/**\n * Ray Jobs class\n *\n * Glue Ray jobs use worker type Z.2X and Glue version 4.0.\n * These are not overrideable since these are the only configuration that\n * Glue Ray jobs currently support. The runtime defaults to Ray2.4 and min\n * workers defaults to 3.\n */\n@propertyInjectable\nexport class RayJob extends Job {\n  /** Uniquely identifies this class. */\n  public static readonly PROPERTY_INJECTION_ID: string = '@aws-cdk.aws-glue-alpha.RayJob';\n  public readonly jobArn: string;\n  public readonly jobName: string;\n  public readonly role: iam.IRole;\n  public readonly grantPrincipal: iam.IPrincipal;\n\n  /**\n   * RayJob constructor\n   */\n  constructor(scope: Construct, id: string, props: RayJobProps) {\n    super(scope, id, {\n      physicalName: props.jobName,\n    });\n    // Enhanced CDK Analytics Telemetry\n    addConstructMetadata(this, props);\n\n    this.jobName = props.jobName ?? '';\n\n    // Set up role and permissions for principal\n    this.role = props.role;\n    this.grantPrincipal = this.role;\n\n    // Enable CloudWatch metrics and continuous logging by default as a best practice\n    const continuousLoggingArgs = this.setupContinuousLogging(this.role, props.continuousLogging);\n\n    // Conditionally include metrics arguments (default to enabled for backward compatibility)\n    const profilingMetricsArgs = (props.enableMetrics ?? true) ? { '--enable-metrics': '' } : {};\n    const observabilityMetricsArgs = (props.enableObservabilityMetrics ?? true) ? { '--enable-observability-metrics': 'true' } : {};\n\n    // Combine command line arguments into a single line item\n    const defaultArguments = {\n      ...this.checkNoReservedArgs(props.defaultArguments),\n      ...continuousLoggingArgs,\n      ...profilingMetricsArgs,\n      ...observabilityMetricsArgs,\n    };\n\n    if (props.workerType && props.workerType !== WorkerType.Z_2X) {\n      throw new ValidationError('Ray jobs only support Z.2X worker type', this);\n    }\n\n    const jobResource = new CfnJob(this, 'Resource', {\n      name: props.jobName,\n      description: props.description,\n      role: this.role.roleArn,\n      command: {\n        name: JobType.RAY,\n        scriptLocation: this.codeS3ObjectUrl(props.script),\n        runtime: props.runtime ? props.runtime : Runtime.RAY_TWO_FOUR,\n      },\n      glueVersion: GlueVersion.V4_0,\n      workerType: props.workerType ? props.workerType : WorkerType.Z_2X,\n      numberOfWorkers: props.numberOfWorkers ? props.numberOfWorkers: 3,\n      maxRetries: props.jobRunQueuingEnabled ? 0 : props.maxRetries,\n      jobRunQueuingEnabled: props.jobRunQueuingEnabled ? props.jobRunQueuingEnabled : false,\n      executionProperty: props.maxConcurrentRuns ? { maxConcurrentRuns: props.maxConcurrentRuns } : undefined,\n      timeout: props.timeout?.toMinutes(),\n      connections: props.connections ? { connections: props.connections.map((connection) => connection.connectionName) } : undefined,\n      securityConfiguration: props.securityConfiguration?.securityConfigurationName,\n      tags: props.tags,\n      defaultArguments,\n    });\n\n    const resourceName = this.getResourceNameAttribute(jobResource.ref);\n    this.jobArn = this.buildJobArn(this, resourceName);\n    this.jobName = resourceName;\n  }\n}\n"]}