---
title: "getReader() | Grafana k6 documentation"
description: "Creates a reader and locks the stream to it."
---

> For a curated documentation index, see [llms.txt](/llms.txt). For the complete documentation index, see [llms-full.txt](/llms-full.txt).

# getReader()

Creates a reader and locks the [stream](/docs/k6/latest/javascript-api/k6-experimental/streams/readablestream/) to it. While the stream is locked, no other reader can be acquired until this one is released.

## Arguments

The `getReader` method takes a single optional `options` argument, which is an object with the following properties:

Expand table

| Name | Type   | Default value | Description                                                                                               |
|------|--------|---------------|-----------------------------------------------------------------------------------------------------------|
| mode | string | `undefined`   | A property that specifies the type of reader to create. It currently only supports the `undefined` value. |

## Return value

A [ReadableStreamDefaultReader](/docs/k6/latest/javascript-api/k6-experimental/streams/readablestreamdefaultreader/) object instance.

## Example

JavaScript ![Copy code to clipboard](/media/images/icons/icon-copy-small-2.svg) Copy

```javascript
import { ReadableStream } from 'k6/experimental/streams';
import { setTimeout } from 'k6/timers';

export default async function () {
  // Define a number stream that emits numbers from 1 to 10 every second
  const stream = numbersStream();

  // We use the getReader method to create a reader and lock the stream to it
  const reader = stream.getReader();

  while (true) {
    const { done, value } = await reader.read();
    if (done) break;
    console.log(`received number ${value} from stream`);
  }
}

function numbersStream() {
  let currentNumber = 0;

  return new ReadableStream({
    start(controller) {
      const fn = () => {
        if (currentNumber < 10) {
          controller.enqueue(++currentNumber);
          setTimeout(fn, 1000);
          return;
        }

        controller.close();
      };
      setTimeout(fn, 1000);
    },
  });
}
```
