Creating an API gateway
Before you start, prepare an API specification file based on the OpenAPI 3.0
Example of the hello-world.yaml specification file
openapi: "3.0.0"
info:
version: 1.0.0
title: Test API
paths:
/hello:
get:
summary: Say hello
operationId: hello
parameters:
- name: user
in: query
description: User name to appear in greetings.
required: false
schema:
type: string
default: 'world'
responses:
'200':
description: Greeting.
content:
'text/plain':
schema:
type: "string"
x-yc-apigateway-integration:
type: dummy
http_code: 200
http_headers:
'Content-Type': "text/plain"
content:
'text/plain': "Hello, {user}!\n"
-
In the management console
, go to the folder where you want to create an API gateway. -
From the list of services, select API Gateway.
-
Click Create API gateway.
-
Enter a name for the API gateway in the Name field.
-
Optionally, in the Description field, enter a description for the API gateway.
-
In the Request execution timeout field, specify the execution timeout. The value must not exceed the specified limit.
-
Under Specification, add the text of the OpenAPI specifications
.To add the x-yc-apigateway-integration extension to a specification, you can use the specification constructor.
-
Configure additional API gateway settings if needed.
-
Click Create.
If you do not have the Yandex Cloud CLI installed yet, install and initialize it.
By default, the CLI uses the folder specified when creating the profile. To change the default folder, use the yc config set folder-id <folder_ID> command. You can also set a different folder for any specific command using the --folder-name or --folder-id parameter.
To create an API gateway:
-
View the description of the CLI command for creating an API gateway:
yc serverless api-gateway create --help -
Specify API gateway parameters in the create command (not all the supported parameters are listed):
yc serverless api-gateway create \ --name <API_gateway_name> \ --execution-timeout <request_execution_timeout> \ --spec=<specification_file_path>Where:
-
--name: API gateway name:- It must be from 2 to 63 characters long.
- It can only contain lowercase Latin letters, numbers, and hyphens.
- It must start with a letter and cannot end with a hyphen.
-
--execution-timeout: Request execution timeout. The value is specified in seconds and must not exceed the specified limit. This is an optional parameter. The default value is300seconds. -
--spec: Path to the specification file you created earlier.
-
With Terraform
Terraform is distributed under the Business Source License
For more information about the provider resources, see the relevant documentation on the Terraform
If you do not have Terraform yet, install it and configure the Yandex Cloud provider.
To create an API gateway:
-
Describe
yandex_api_gatewayproperties in the configuration file:-
name: API gateway name. Follow these naming requirements:- It must be from 2 to 63 characters long.
- It can only contain lowercase Latin letters, numbers, and hyphens.
- It must start with a letter and cannot end with a hyphen.
-
description: API gateway description. -
labels: Labels for the API gateway. Specify a key-value pair. -
execution_timeout: Request execution timeout. The value is specified in seconds and must not exceed the set limit. This is an optional parameter. The default value is300seconds. -
spec: API gateway specification.
Here is an example of the configuration file structure:
resource "yandex_api_gateway" "test-api-gateway" { name = "<API_gateway_name>" description = "<API_gateway_description>" labels = { label = "label" empty-label = "" } execution_timeout = "<request_execution_timeout>" spec = <<-EOT openapi: "3.0.0" info: version: 1.0.0 title: Test API paths: /hello: get: summary: Say hello operationId: hello parameters: - name: user in: query description: User name to appear in greetings required: false schema: type: string default: 'world' responses: '200': description: Greeting content: 'text/plain': schema: type: "string" x-yc-apigateway-integration: type: dummy http_code: 200 http_headers: 'Content-Type': "text/plain" content: 'text/plain': "Hello, {user}!\n" EOT }For more information about resource properties in Terraform, see the relevant Terraform documentation.
-
-
Make sure the configuration files are correct.
-
In the command line, go to the directory where you created the configuration file.
-
Run a check using this command:
terraform plan
If the configuration is correct, the terminal will display a list of new resources with their properties. If the configuration contains any errors, Terraform will point them out.
-
-
Deploy the cloud resources.
-
If the configuration does not contain any errors, run this command:
terraform apply -
Confirm creating the resources: type
yesin the terminal and press Enter.This will create all the resources you need in the specified folder. You can check the new resources and their settings using the management console
or these CLI commands:yc serverless api-gateway get <API_gateway_name>
-
To create an API gateway, use the create REST API method for the ApiGateway resource or the ApiGatewayService/Create gRPC API call.