The London Perl and Raku Workshop takes place on 26th Oct 2024. If your company depends on Perl, please consider sponsoring and/or attending.

NAME

Mojo::MemoryMap - Safely use anonymous memory mapped segments

SYNOPSIS

use Mojo::MemoryMap;

my $map = Mojo::MemoryMap->new(4096);
say $map->usage;
$map->writer->store({foo => 123});
say $map->writer->fetch->{foo};
say $map->writer->change(sub { delete $_->{foo} });
say $map->usage;

DESCRIPTION

Mojo::MemoryMap uses File::Map to allow you to safely cache mutable data structures in anonymous mapped memory segments, and share it between multiple processes.

METHODS

Mojo::MemoryMap inherits all methods from Mojo::Base and implements the following new ones.

new

my $map = Mojo::MemoryMap->new;
my $map = Mojo::MemoryMap->new(4096);

Construct a new Mojo::MemoryMap object, defaults to a "size" of 52428800 bytes (50 MiB).

size

my $size = $map->size;

Size of anonymous memory segment in bytes.

usage

my $usage = $map->usage;

Current usage of anonymous memory segment in bytes.

writer

my $writer = $map->writer;

Acquire exclusive lock and return Mojo::MemoryMap::Writer object. Allowing the shared data structure to be retrieved and modified safely. The lock is released when the writer object is destroyed.

# Retrieve data
my $data = $map->writer->fetch;

# Modify data safely
my $writer = $map->writer;
my $data = $writer->fetch;
$data->{foo} += 23;
$writer->store($data);
undef $writer;

# Modify data safely (with less code)
$map->writer->change(sub { $_->{foo} += 23 });

SEE ALSO

Mojolicious::Plugin::Status, Mojolicious::Guides, https://mojolicious.org.