{ "$schema": "https://json-schema.org/draft/2020-12/schema", "$id": "https://raw.githubusercontent.com/api-evangelist/amazon-glue/refs/heads/main/json-schema/glue-create-dev-endpoint-request-schema.json", "title": "CreateDevEndpointRequest", "description": "CreateDevEndpointRequest schema from Amazon Glue API", "type": "object", "properties": { "EndpointName": { "allOf": [ { "$ref": "#/components/schemas/GenericString" }, { "description": "The name to be assigned to the new DevEndpoint." } ] }, "RoleArn": { "allOf": [ { "$ref": "#/components/schemas/RoleArn" }, { "description": "The IAM role for the DevEndpoint." } ] }, "SecurityGroupIds": { "allOf": [ { "$ref": "#/components/schemas/StringList" }, { "description": "Security group IDs for the security groups to be used by the new DevEndpoint." } ] }, "SubnetId": { "allOf": [ { "$ref": "#/components/schemas/GenericString" }, { "description": "The subnet ID for the new DevEndpoint to use." } ] }, "PublicKey": { "allOf": [ { "$ref": "#/components/schemas/GenericString" }, { "description": "The public key to be used by this DevEndpoint for authentication. This attribute is provided for backward compatibility because the recommended attribute to use is public keys." } ] }, "PublicKeys": { "allOf": [ { "$ref": "#/components/schemas/PublicKeysList" }, { "description": "

A list of public keys to be used by the development endpoints for authentication. The use of this attribute is preferred over a single public key because the public keys allow you to have a different private key per client.

If you previously created an endpoint with a public key, you must remove that key to be able to set a list of public keys. Call the UpdateDevEndpoint API with the public key content in the deletePublicKeys attribute, and the list of new keys in the addPublicKeys attribute.

" } ] }, "NumberOfNodes": { "allOf": [ { "$ref": "#/components/schemas/IntegerValue" }, { "description": "The number of Glue Data Processing Units (DPUs) to allocate to this DevEndpoint." } ] }, "WorkerType": { "allOf": [ { "$ref": "#/components/schemas/WorkerType" }, { "description": "

The type of predefined worker that is allocated to the development endpoint. Accepts a value of Standard, G.1X, or G.2X.

Known issue: when a development endpoint is created with the G.2X WorkerType configuration, the Spark drivers for the development endpoint will run on 4 vCPU, 16 GB of memory, and a 64 GB disk.

" } ] }, "GlueVersion": { "allOf": [ { "$ref": "#/components/schemas/GlueVersionString" }, { "description": "

Glue version determines the versions of Apache Spark and Python that Glue supports. The Python version indicates the version supported for running your ETL scripts on development endpoints.

For more information about the available Glue versions and corresponding Spark and Python versions, see Glue version in the developer guide.

Development endpoints that are created without specifying a Glue version default to Glue 0.9.

You can specify a version of Python support for development endpoints by using the Arguments parameter in the CreateDevEndpoint or UpdateDevEndpoint APIs. If no arguments are provided, the version defaults to Python 2.

" } ] }, "NumberOfWorkers": { "allOf": [ { "$ref": "#/components/schemas/NullableInteger" }, { "description": "

The number of workers of a defined workerType that are allocated to the development endpoint.

The maximum number of workers you can define are 299 for G.1X, and 149 for G.2X.

" } ] }, "ExtraPythonLibsS3Path": { "allOf": [ { "$ref": "#/components/schemas/GenericString" }, { "description": "

The paths to one or more Python libraries in an Amazon S3 bucket that should be loaded in your DevEndpoint. Multiple values must be complete paths separated by a comma.

You can only use pure Python libraries with a DevEndpoint. Libraries that rely on C extensions, such as the pandas Python data analysis library, are not yet supported.

" } ] }, "ExtraJarsS3Path": { "allOf": [ { "$ref": "#/components/schemas/GenericString" }, { "description": "The path to one or more Java .jar files in an S3 bucket that should be loaded in your DevEndpoint." } ] }, "SecurityConfiguration": { "allOf": [ { "$ref": "#/components/schemas/NameString" }, { "description": "The name of the SecurityConfiguration structure to be used with this DevEndpoint." } ] }, "Tags": { "allOf": [ { "$ref": "#/components/schemas/TagsMap" }, { "description": "The tags to use with this DevEndpoint. You may use tags to limit access to the DevEndpoint. For more information about tags in Glue, see Amazon Web Services Tags in Glue in the developer guide." } ] }, "Arguments": { "allOf": [ { "$ref": "#/components/schemas/MapValue" }, { "description": "A map of arguments used to configure the DevEndpoint." } ] } }, "required": [ "EndpointName", "RoleArn" ] }