pcbodev / laravel-aws-timestream
Library to interact with AWS Timestream service via API
Requires
- php: ^8.0
- aws/aws-sdk-php: ^3.209
- illuminate/support: ^8.0|^9.52|^10.0
Requires (Dev)
- guzzlehttp/guzzle: ^7.4
- nunomaduro/larastan: ^1.0|^2.0
- orchestra/testbench: ^6.24|^7.0|^8.0
- phpunit/phpunit: ^9.5|^10.0
- vlucas/phpdotenv: ^5.4
This package is not auto-updated.
Last update: 2025-01-06 14:01:31 UTC
README
AWS Timestream is a fast, scalable, and serverless time series database service. This package is an opinionated implementation to query timestream and ingest data into timestream.
It provides a query builder class which has common timeseries sql function. This was inspired by Laravel Eloquent ORM.
See supported query functions NorbyBaru\AwsTimestream\Contract\QueryBuilderContract
It also provide a payload builder class to format your data correctly to ingest into timestream.
See NorbyBaru\AwsTimestream\Contract\PayloadBuilderContract
Info
We forked the repository of norbybaru because he built an awesome basis for timestream query builder, but we needed some additional features and therefore have implemented those in our fork.
Install
composer require pcbodev/laravel-aws-timestream
Configuration
- Publish config
php artisan vendor:publish --provider="NorbyBaru\AwsTimestream\TimestreamServiceProvider" --tag="timestream-config"
- Open
timestream.php
config file and setup your databse name and tables - Setup you AWS Timestream keys and permissions with the following enviroment variable
AWS_TIMESTREAM_KEY=
AWS_TIMESTREAM_SECRET=
AWS_TIMESTREAM_PROFILE=
Basic Usage
Query Timestream
Using TimestreamBuilder::query()
will give autocomplete of all available functions
- Using
TimestreamBuilder
to build query to be passed ontoTimestreamReaderDto
which generate am object that can be consumed byTimestreamService
query function
<?php use NorbyBaru\AwsTimestream\TimestreamService; use NorbyBaru\AwsTimestream\TimestreamBuilder; use NorbyBaru\AwsTimestream\Dto\TimestreamReaderDto; public function overview(TimestreamService $timestreamService) { $queryBuilder = TimestreamBuilder::query() ->select('*') ->from("database-name", 'table-name') ->whereAgo('time', '24h', '>=') ->whereNotIn('measure_value::varchar', ['reviewer', 'open', 'closed']) ->orderBy('time', 'desc'); TimestreamReaderDto::make($queryBuilder); // response from Aws timestream return $timestreamService->query($timestreamReader) }
- Use
TimestreamReaderDto
to injectfrom
query with defaultdatabase
name and on demandtable
name. NB. No need to add->from()
query on your query builder.
<?php use NorbyBaru\AwsTimestream\TimestreamService; use NorbyBaru\AwsTimestream\TimestreamBuilder; use NorbyBaru\AwsTimestream\Dto\TimestreamReaderDto; public function overview(TimestreamService $timestreamService) { $queryBuilder = TimestreamBuilder::query() ->select('*') ->whereAgo('time', '24h', '>=') ->whereNotIn('measure_value::varchar', ['reviewer', 'open', 'closed']) ->orderBy('time', 'desc'); TimestreamReaderDto::make($queryBuilder, 'table-name'); // response from Aws timestream return $timestreamService->query($timestreamReader) }
Timestream Ingestion
We need to build our payload that Timestream will accept for ingestion.
- Use
TimestreamBuilder
to build ingestion payload
<?php use NorbyBaru\AwsTimestream\TimestreamService; use NorbyBaru\AwsTimestream\Dto\TimestreamWriterDto; use NorbyBaru\AwsTimestream\TimestreamBuilder; public function ingest(TimestreamService $timestreamService) { $metrics = [ 'measure_name' => 'cpu_usage', 'measure_value' => 80, 'time' => Carbon::now(), 'dimensions' => [ 'mac_address' => 'randomstring', 'ref' => 'refs', ], ]; $payload = TimestreamBuilder::payload( $metrics['measure_name'], $metrics['measure_value'], $metrics['time'], 'VARCHAR', $metrics['dimensions'], )->toArray(); $timestreamWriter = TimestreamWriterDto::make($payload)->forTable('table-name'); return $timestreamService->write($timestreamWriter); }
- Ingestion data in batch using Common Attributes to reduce ingestion cost with Timestream
<?php use NorbyBaru\AwsTimestream\TimestreamService; use NorbyBaru\AwsTimestream\Dto\TimestreamWriterDto; use NorbyBaru\AwsTimestream\Support\TimestreamPayloadBuilder; public function ingest(TimestreamService $timestreamService) { $metrics = [ [ 'measure_name' => 'cpu_usage', 'measure_value' => 80, 'time' => Carbon::now(), 'dimensions' => [ 'ref' => 'ref_1', ], ], [ 'measure_name' => 'memory_usage', 'measure_value' => 20, 'time' => Carbon::now(), 'dimensions' => [ 'ref' => 'ref_2', ], ] ]; $commonAttributes['device_name'] = 'device_1'; $commonAttributes['mac_address'] = 'randomstring'; $payload = TimestreamBuilder::batchPayload($metrics); $common = TimestreamBuilder::commonAttributes($commonAttributes); $timestreamWriter = TimestreamWriterDto::make($payload, $common, 'table-name'); return $timestreamService->write($timestreamWriter); }