Yandex Cloud
Search
Contact UsGet started
  • Blog
  • Pricing
  • Documentation
  • All Services
  • System Status
    • Featured
    • Infrastructure & Network
    • Data Platform
    • Containers
    • Developer tools
    • Serverless
    • Security
    • Monitoring & Resources
    • ML & AI
    • Business tools
  • All Solutions
    • By industry
    • By use case
    • Economics and Pricing
    • Security
    • Technical Support
    • Customer Stories
    • Gateway to Russia
    • Cloud for Startups
    • Education and Science
  • Blog
  • Pricing
  • Documentation
Yandex project
© 2025 Yandex.Cloud LLC
Tutorials
    • All tutorials
    • Setting up a Managed Service for PostgreSQL connection from a container in Serverless Containers
    • Creating a VM from a Container Optimized Image
    • Creating a VM from a Container Optimized Image with an additional volume for a Docker container
    • Creating an instance group from a Container Optimized Image with multiple Docker containers
    • Creating an instance group from a Container Optimized Image
    • Creating a VM from a Container Optimized Image with multiple Docker containers
    • Updating a Container Optimized Image VM
    • Configuring data output from a Docker container to a serial port

In this article:

  • Get your cloud ready
  • Required paid resources
  • Create a VM specification file
  • Create a Docker container specification file
  • Get the ID of the image to create a VM
  • Create a VM
  • Check the result
  • How to delete the resources you created
  1. Container infrastructure
  2. Configuring data output from a Docker container to a serial port

Configuring data output from a Docker container to a serial port

Written by
Yandex Cloud
Updated at May 5, 2025
  • Get your cloud ready
    • Required paid resources
  • Create a VM specification file
  • Create a Docker container specification file
  • Get the ID of the image to create a VM
  • Create a VM
  • Check the result
  • How to delete the resources you created

To create a VM from an image, such as a Container Optimized Image, and set up a redirect of the application output stream to the VM's serial port:

  1. Get your cloud ready.
  2. Create a VM specification file.
  3. Create a Docker container specification file.
  4. Get the ID of the image to create the VM.
  5. Create a VM.
  6. Check the result.

If you no longer need the resources you created, delete them.

Get your cloud readyGet your cloud ready

If the required Docker image is pushed to Container Registry, create a service account with the container-registry.images.puller role for the registry in use. A Container Optimized Image VM will pull the Docker image from the registry on behalf of this account.

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.

If you do not have a network or subnet, create them.

Required paid resourcesRequired paid resources

The infrastructure support cost includes:

  • Fee for a continuously running VM (see Yandex Compute Cloud pricing).
  • Fee for using a dynamic or static external IP address (see Yandex Virtual Private Cloud pricing).

Create a VM specification fileCreate a VM specification file

CLI

Create a VM specification file named cloud-config-ports.yaml and populate it with the following data:

#cloud-config
runcmd:
- [ sudo, chmod, 666, /dev/ttyS1]
users:
- name: <username>
  groups: sudo
  shell: /bin/bash
  sudo: 'ALL=(ALL) NOPASSWD:ALL'
  ssh_authorized_keys:
  - <public_SSH_key_for_connecting_to_VM>

In the file configuration, set the username and specify the public part of the SSH key required to connect to the VM. You need to create an SSH key pair yourself.

Create a Docker container specification fileCreate a Docker container specification file

CLI

Create the specification for a Docker container as a file named container-spec-ports.yaml and populate it with the following data:

spec:
containers:
- image: ubuntu
  name: app
  command: ["/bin/bash", "-c", "sleep 30 && echo 'Hello World!' > /dev/ttyS1"]
  securityContext:
    privileged: true
    stdin: false
    tty: false
    volumeMounts:
    - mountPath: /dev/ttyS1
      name: log-port
  restartPolicy: Always
  volumes:
  - name: log-port
    hostPath:
      path: /dev/ttyS1
  1. Create a VM with multiple disks.
    1. Get the ID of the image to create the VM:

      Bash
      PowerShell
      IMAGE_ID=$(yc compute image get-latest-from-family container-optimized-image --folder-id standard-images --format=json | jq -r .id)
      
      > $IMAGE_ID=(yc compute image get-latest-from-family container-optimized-image --folder-id standard-images --format=json | ConvertFrom-Json).id
      
    2. Create a VM:

      yc compute instance create \
        --name coi-vm-with-sp \
        --zone ru-central1-a \
        --network-interface subnet-name=<subnet_name>,nat-ip-version=ipv4 \
        --metadata-from-file user-data=cloud-config-ports.yaml,docker-container-declaration=container-spec-ports.yaml \
        --create-boot-disk image-id=$IMAGE_ID
      

      Where:

      • --name: VM name.

      • --zone: Availability zone.

      • --network-interface: VM network settings.

      • --metadata-from-file: YAML metadata files for creating the VM.

        Note

        The commands yc compute instance create | create-with-container | update | add-metadata support substitution of environment variable values into VM metadata. When you execute a Yandex Cloud CLI command, these values, specified in the user-data key in $<variable_name> format, will be substituted into the VM metadata from the environment variables of the environment the command is executed in.

        To change such behavior, i.e. to provide a variable name to the VM metadata in $<variable_name> format rather than take the variable value from the CLI command runtime environment, use the two-dollar syntax, e.g., $$<variable_name>.

        For more information, see Specifics of providing environment variables in metadata via the CLI.

      • --create-boot-disk: ID of the image to create a boot disk from.

      Once created, the VM will appear in the VM list under Compute Cloud in the management console.

    3. Check the result.

      1. In the management console, go to the folder page and select Compute Cloud.
      2. Click the VM name, coi-vm-with-sp.
      3. Under Serial port, select the COM2 port. In a few minutes, the screen will display Hello world!.

Get the ID of the image to create a VMGet the ID of the image to create a VM

To get the ID of the latest image to create a VM, run:

Linux (Bash)
Windows (PowerShell)
IMAGE_ID=$(yc compute image get-latest-from-family container-optimized-image \
  --folder-id standard-images \
  --format=json | jq -r .id)
$IMAGE_ID=(yc compute image get-latest-from-family container-optimized-image `
  --folder-id standard-images `
  --format=json | ConvertFrom-Json).id

Create a VMCreate a VM

CLI

Enter a name for the subnet to create your VM in and run:

yc compute instance create \
  --name coi-vm-with-sp \
  --zone ru-central1-d \
  --network-interface subnet-name=<subnet_name>,nat-ip-version=ipv4 \
  --metadata-from-file user-data=cloud-config-ports.yaml,docker-container-declaration=container-spec-ports.yaml \
  --create-boot-disk image-id=$IMAGE_ID

Where:

  • --name: VM name.
  • --zone: Availability zone.
  • --network-interface: VM network settings.
  • --metadata-from-file: YAML metadata files for creating the VM.
  • --create-boot-disk: ID of the image to create a boot disk from.

Once created, the VM will appear in the VM list under Compute Cloud in the management console.

Check the resultCheck the result

To check the result of configuring data output from the Docker container to the serial port:

  1. In the management console, go to the folder page and select Compute Cloud.
  2. Click the VM name, coi-vm-with-sp.
  3. Under Serial port, select the COM2 port. In a few minutes, the screen will display Hello world!.

For more information about working with VMs, see our step-by-step guides.

How to delete the resources you createdHow to delete the resources you created

To stop paying for the resources you created:

  1. Delete the VM.
  2. If you reserved a public static IP address for the VM, delete it.

Was the article helpful?

Previous
Updating a Container Optimized Image VM
Next
Creating a new Kubernetes project
Yandex project
© 2025 Yandex.Cloud LLC