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 set 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 yet, install and initialize it.
The folder specified when creating the CLI profile is used by default. To change the default folder, use the yc config set folder-id <folder_ID>
command. You can specify a different folder 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 may 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 set limit. This is an optional parameter. The default value is300
seconds. -
--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 documentation on the Terraform
If you do not have Terraform yet, install it and configure its Yandex Cloud provider.
To create an API gateway:
-
Describe
yandex_api_gateway
properties in the configuration file:-
name
: API gateway name. Follow these naming requirements:- It must be from 2 to 63 characters long.
- It may 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 is300
seconds. -
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
yes
in 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.
You can create an API gateway using the Yandex Cloud Toolkit plugin