- Enhancements
- Line protocol encoder sorts fields/tags before generating the payload
- Bug fixes
- The configurable UDP writer pool timeout is now working as expected/intended (#81)
-
Enhancements
- Configuration access for a connection now returns the configured
:otp_app
used (nil
if none) - Starting a connection will now issue a warning if the configured
:otp_app
contains no configuration
- Configuration access for a connection now returns the configured
-
Bug fixes
- Read queries now send the proper
Content-Type: application/json
header for InfluxDB v2.x connections without having to explicitly passquery_language: :flux
as an option (#76)
- Read queries now send the proper
- Enhancements
- Log entries for write requests (
%Instream.Log.WriteEntry{}
) now contain the actual HTTP response status returned from the writer - Support for deleting points using the InfluxDB v2.x "delete" (predicate) API (#75)
- Log entries for write requests (
-
Enhancements
- Initial query/write support for InfluxDB
2.x
added - Logging configuration fetched at runtime instead of during compilation
- The HTTP client library can be replaced by providing a custom implementation of the
Instream.HTTPClient
behaviour
- Initial query/write support for InfluxDB
-
Backwards incompatible changes
- Minimum required Elixir version is now
~> 1.9
- Passing a host to
ping/1,2
,status/1,2
,version/1,2
is now longer supported. Only the hostname configured in the connection module will be used. - Support for the InfluxDB versions earlier than
1.7.x
is no longer guaranteed
- Minimum required Elixir version is now
-
Enhancements
- Documentation is now available inline (
@moduledoc
, ...) with theREADME.md
file targeting the repository (development) instead of releases - Hydrating query results into series structs now parses RFC3339 times into
:nanosecond
timestamps. If you are usingOTP 21.0
or later you will get the full precision, earlier versions are truncated to the:microsecond
precision supported byDateTime
! - Read queries (everything except writes) are now executed directly in the calling process
- Sending asynchronous queries is now limited to write queries
- Writers can modify the worker state during
init
andterminate
by implementing the callbacksinit_worker/1
andterminate_worker/1
- Documentation is now available inline (
-
Backwards incompatible changes
- All "administrative query modules" have been removed
- Minimum required Elixir version is now
~> 1.7
- Support for accessing the system environment for configuration has been removed in favor of initializer functions/modules
- Support for implementing
use Instream.Writer
has been removed in favor of@behaviour Instream.Writer
- Support for plural time units (e.g.
:seconds
instead of:second
) has been removed - The default JSON decoder has been switched from
:poison
to:jason
- The query builder has been removed
-
Bug fixes
:influxql
has been moved from:included_applications
to:applications
to avoid potential problems with release tooling (#53)
- Enhancements
- Errors from
:hackney.body/1
are now passed to the caller instead of raising aMatchError
- Unix socket usage has been documented
- Errors from
- Enhancements
- Read queries can now use parameter binding
- The configuration option
:json_encoder
for the library used for JSON encoding has been added
-
Enhancements
- Queries can be sent as Flux language queries to InfluxDB using
[query_language: :flux]
in the connection or query options
- Queries can be sent as Flux language queries to InfluxDB using
-
Soft deprecations (no warnings)
- The query builder has been removed from documentation and will be eventually removed completely. This will be done because of the current limitations of the builder implementation and the InfluxDB move from InfluxQL to Flux as the query language of choice
-
Deprecations
- Accessing the system environment by configuring
{:system, var}
or{:system, var, default}
will now result in aLogger.info/1
message and will stop working in a future release - Implementing
use Instream.Writer
has been deprecated in favor of the more explicit@behaviour Instream.Writer
. Old implementations will trigger a compile time warning until the old macro is removed - The already (soft) deprecated time units with plural names (e.g.
:seconds
) will now issueLogger.info/1
messages when used
- Accessing the system environment by configuring
-
Backwards incompatible changes
- Support for the InfluxDB versions earlier than
1.4.x
is no longer guaranteed
- Support for the InfluxDB versions earlier than
-
Enhancements
- Connections can be declared with compile time configuration defaults that are later overwritten by the application environment
- The library used for JSON decoding can be changed by using the
:json_decoder
configuration
-
Soft deprecations (no warnings)
- All "administrative query modules" have been removed from the documentation. They will eventually be removed completely after a proper deprecation phase
- Support for
{:system, "ENV_VARIABLE"}
configuration has been removed from the documentation. It will eventually be removed completely after a proper deprecation phase
-
Backwards incompatible changes
- Default configuration has been extended with
host: "localhost"
- Minimum required Elixir version is now
~> 1.5
- Missing application configuration will no longer raise during compilation
- Public access to the internal pool module name has been removed
- Default configuration has been extended with
-
Enhancements
- Configuration can be done on connection (re-) start by setting a
{mod, fun}
tuple for the config key:init
. This method will be called with the connection module name as the first (and only) parameter and is expected to return:ok
- Experimental support to convert plain maps or query results into series structs has been added
- Passwords are automatically redacted from logged queries when using the default logger
- Supporting rules for the Elixir formatter are available
- Configuration can be done on connection (re-) start by setting a
-
Bug fixes
- Special characters in url parameter values (like
&
or?
in a query) are now properly escaped (#43)
- Special characters in url parameter values (like
-
Backwards incompatible changes
- Quoting of identifiers/values has been extracted to the package
influxql
(hex)
- Quoting of identifiers/values has been extracted to the package
- Enhancements
- Support for Elixir 1.5 style
child_spec
has been added (#39)
- Support for Elixir 1.5 style
- Backwards incompatible changes
- Minimum required Elixir version is now
~> 1.3
- Minimum required Elixir version is now
-
Enhancements
- Queries can be executed with an additional option
:pool_timeout
used to wait for an available worker process. This option is independent of other configured/passed timeouts - System environment configuration can set an optional default value to be used if the environment variable is unset
- Queries can be executed with an additional option
-
Bug fixes
- All queries now use a
GenServer.call/3
timeout of:infinity
. This allows raising the timeouts for a call above the default of5_000
(#38)
- All queries now use a
-
Enhancements
- Every connection method (like
read
orwrite
) can set per-callhttp_opts
passed on to thehackney
client - Querying for data can now return an
{:error, term}
style tuple if the communication with the server failed. For example{:error, :nxdomain}
if the host that is queried cannot be resolved byhackney
(#33) - The line writer now accepts a retention policy used for writing (#34)
- The line writer will now return an
{:error, term}
style tuple if a problem occurs. For example{:error, :nxdomain}
if the host that should receive data cannot be resolved byhackney
(#33) - Timeouts occurring when executing a query are now returned as
{:error, :timeout}
instead of raising (#33)
- Every connection method (like
-
Backwards incompatible changes
- Series definitions raise upon compilation if the contain a tag and a field with the same name. This is done to prevent the InfluxDB behavior of adding
_1
to such fields when storing them
- Series definitions raise upon compilation if the contain a tag and a field with the same name. This is done to prevent the InfluxDB behavior of adding
-
Enhancements
- Connections can be configured with a default database used when no value is found in method call or series definition
- Fields and tags with the name
:time
will raise after compilation. They are unqueryable and will be dropped by InfluxDB v1.1.0 when trying to write them. - Queries can return CSV formatted responses from the server when running InfluxDB >= 1.1.0
- Series definitions are now automatically associated with typespecs
-
Backwards incompatible changes
- Minimum required Elixir version is now
~> 1.2
- Minimum required Erlang version is now
~> 18.0
- Query builder support for
IF NOT EXISTS
has been removed - Series definitions now require to contain at least one field
- Minimum required Elixir version is now
-
Soft deprecations (no warnings)
- The plural names for precision units have been soft deprecated to be in line with the similar new naming in
Erlang 19.1
and the upcomingElixir 1.4.0
. The old types will continue to work but their usage is discouraged. They will be completely deprecated in an upcoming release.
- The plural names for precision units have been soft deprecated to be in line with the similar new naming in
-
Enhancements
- Configuration has been split into "compile time" and "runtime" parts. This readds the possibility to change configuration values without recompiling the connection modules (#22)
- Configuration values can be fetched from the system environment using
{:system, ENV_VAR}
- Timeouts for queries (individual and connection wide) can be configured (#21)
- Query builder supports
LIMIT
andOFFSET
for queries (#19) - Writing a series struct with one or more empty tags will now properly construct an entry without these tags present
-
Soft deprecations (no warnings)
- The precision units
:micro_seconds
,:milli_seconds
and:nano_seconds
have been renamed to:microseconds
,:milliseconds
and:nanoseconds
to matches the upcomingSystem.time_unit
definition ofElixir 1.3.0
. Old variables will continue to work but are highly discouraged and will be completely deprecated in an upcoming release.
- The precision units
-
Deprecations
- Defining a series without fields is deprecated and will raise in a future version
-
Backwards incompatible changes
- Configuring a connection with multiple hosts is no longer supported
- The otp app of a connection is no longer returned when calling
MyConnection.config/0,1
. It is now only available by specifically requesting it viaMyConnection.config([:otp_app])
- Writer modules now get a map passed with the connection module registered at key
:module
and (if configured) a udp socket for writing at:udp_socket
- The
Cluster
namespace of queries has been removed
-
Enhancements
- Namespace of administrational convenience modules has been changed from
Cluster
to the better matchingAdmin
- Namespace of administrational convenience modules has been changed from
-
Deprecations
- Configuring a connection with multiple hosts has been deprecated. Instead of multiple
:hosts
only a single:host
is now expected - The
Cluster
namespace of queries has been changed toAdmin
. For some backwards compatibility the old modules are delegated to the new ones until removed in the next release
- Configuring a connection with multiple hosts has been deprecated. Instead of multiple
-
Backwards incompatible changes
- Atoms for defining a series' database are no longer supported
- Atoms for defining a series' measurement are no longer supported
- Support for the JSON protocol has been removed matching its removal in InfluxDB v0.12.0
- Support for the
SHOW SERVERS
statement has been removed matching its removal in InfluxDB v0.13.0
-
Enhancements
- Hackney options can be configured (#17)
- Line writer now prefers a database passed via arguments over the one passed in the datapoint payload
- Logging for requests is available
- Pings can be send to specific servers
- Status requests can be send to a cluster
-
Bug fixes
- Series are now compiled with full environment information preventing "/path/to/lib/nofile" to be compiled as the source of
MySeries.Fields
orMySeries.Tags
- Series are now compiled with full environment information preventing "/path/to/lib/nofile" to be compiled as the source of
-
Backwards incompatible changes
- Runtime connection configuration reading has been removed in favor of compile time inlining
-
Enhancements
- Default precision (
:rfc3339
) can be explicitly set - Query builder can construct
CREATE DATABASE
statements - Query builder can construct
CREATE RETENTION POLICY
statements - Query builder can construct
DROP DATABASE
statements - Query builder can construct
DROP RETENTION POLICY
statements - Query builder can construct
SHOW
statements - Series database definitions allow anything "evaluating to a string" (#14)
- Series measurement definitions allow anything "evaluating to a string" (#14)
- Default precision (
-
Deprecations
- Atoms for defining a series' database are deprecated
- Atoms for defining a series' measurement are deprecated
- Using
if_not_exists
(CREATE DATABASE
) has been deprecated and will be completely removed once InfluxDB removes it
-
Backwards incompatible changes
:cluster
query type has been removed in favor of regular:read
queries- Retention policy convenience function has been replaced with a more detailed version
-
Enhancements
- Error messages are returned without leading/trailing whitespace
- Experimental query builder
- Incomplete or missing series definitions raise an error during compilation
- Ping a connection using
Instream.Connection.ping/0
- Reading queries can be executed directly using
Instream.Connection.query/2
- Writing query can be executed directly using
Insream.Connection.write/2
-
Deprecations
- Using
Instream.Data.Read
orInstream.Data.Write
directly is discouraged and will eventually be removed
- Using
-
Backwards incompatible changes
- The measurement of a series is no longer optional
- The parameter
opts
forInstream.Data.Read
andInstream.Data.Write
is no longer optional use
-ingInstream.Series
without a complete series definition raises during compilation
- Enhancements
- Batch writing using
Line
andUDP
writers (#10) - Fields can be defined with default values
- Tags can be defined with default values
- Writing can be done over UDP using
Instream.Writer.UDP
- Batch writing using
-
Enhancements
- Convenience module for "SHOW DIAGNOSTICS" queries
- Convenience module for "SHOW STATS" queries
- Precision (= epoch) can be passed to read queries
- Precision can be passed to write queries
-
Bug fixes
- Pool configuration (size, overflow) is now properly taken from configuration
-
Deprecations
- Support of the JSON protocol is deprecated and will be removed once InfluxDB removes it
-
Enhancements
IF NOT EXISTS
can be passed to database creation queries- Points can be written with explicit timestamps (#8)
- Switched default write method to the line protocol
- Tags are optional when writing with the line protocol
-
Backwards incompatible changes
- Switched default write method to the line protocol
-
Enhancements
- Convenience module for
SHOW SERVERS
queries - Queries can be executed asynchronously
- Support for line protocol
- Convenience module for
-
Backwards incompatible changes
- Write queries return
:ok
instead ofnil
- Write queries return
-
Enhancements
- Allows using header authentication (basic auth)
- Allows using pre-defined series modules for write queries
- Provides a way to define series as a module (struct)
-
Backwards incompatible changes
- Authentication uses headers by default
-
Enhancements
- Allows managing retention policies
- Dependencies not used in production builds are marked as optional
-
Bug fixes
- Authentication is passed using query parameters by default
-
Backwards incompatible changes
- Auth configuration is now expected to be a
Keyword.t
- Queries of type
:host
are now of type:cluster
- Remapped
Admin
namespace toCluster
to match query types
- Auth configuration is now expected to be a
- Enhancements
- Allows accessing raw query results (undecoded binaries) using
Instream.Connection.execute/2
- Read queries (binaries) can be executed on a database
- Write queries (map data) can be executed on a database
- Allows accessing raw query results (undecoded binaries) using
- Initial Release