content/influxdb3/clustered/get-started/write.md
This tutorial walks you through the fundamental of creating line protocol data and writing it to InfluxDB.
InfluxDB provides many different options for ingesting or writing data, including the following:
influxctl CLIinflux3 data CLIIf using tools like Telegraf or InfluxDB client libraries, they can build the line protocol for you, but it's good to understand how line protocol works.
All data written to InfluxDB is written using line protocol, a text-based format that lets you provide the necessary information to write a data point to InfluxDB. This tutorial covers the basics of line protocol, but for detailed information, see the Line protocol reference.
Each line of line protocol contains the following elements:
<!-- vale InfluxDataDocs.v3Schema = NO -->{{< req type="key" >}}
\n). Line protocol is
whitespace sensitive.{{< influxdb/line-protocol >}}
For schema design recommendations, see InfluxDB schema design.
With a basic understanding of line protocol, you can now construct line protocol and write data to InfluxDB. Consider a use case where you collect data from sensors in your home. Each sensor collects temperature, humidity, and carbon monoxide readings. To collect this data, use the following schema:
home
room: Living Room or Kitchentemp: temperature in °C (float)hum: percent humidity (float)co: carbon monoxide in parts per million (integer)The following line protocol sample represents data collected hourly beginning at {{% influxdb/custom-timestamps-span %}}2022-01-01T08:00:00Z (UTC) until 2022-01-01T20:00:00Z (UTC){{% /influxdb/custom-timestamps-span %}}.
{{% influxdb/custom-timestamps %}}
home,room=Living\ Room temp=21.1,hum=35.9,co=0i 1641024000
home,room=Kitchen temp=21.0,hum=35.9,co=0i 1641024000
home,room=Living\ Room temp=21.4,hum=35.9,co=0i 1641027600
home,room=Kitchen temp=23.0,hum=36.2,co=0i 1641027600
home,room=Living\ Room temp=21.8,hum=36.0,co=0i 1641031200
home,room=Kitchen temp=22.7,hum=36.1,co=0i 1641031200
home,room=Living\ Room temp=22.2,hum=36.0,co=0i 1641034800
home,room=Kitchen temp=22.4,hum=36.0,co=0i 1641034800
home,room=Living\ Room temp=22.2,hum=35.9,co=0i 1641038400
home,room=Kitchen temp=22.5,hum=36.0,co=0i 1641038400
home,room=Living\ Room temp=22.4,hum=36.0,co=0i 1641042000
home,room=Kitchen temp=22.8,hum=36.5,co=1i 1641042000
home,room=Living\ Room temp=22.3,hum=36.1,co=0i 1641045600
home,room=Kitchen temp=22.8,hum=36.3,co=1i 1641045600
home,room=Living\ Room temp=22.3,hum=36.1,co=1i 1641049200
home,room=Kitchen temp=22.7,hum=36.2,co=3i 1641049200
home,room=Living\ Room temp=22.4,hum=36.0,co=4i 1641052800
home,room=Kitchen temp=22.4,hum=36.0,co=7i 1641052800
home,room=Living\ Room temp=22.6,hum=35.9,co=5i 1641056400
home,room=Kitchen temp=22.7,hum=36.0,co=9i 1641056400
home,room=Living\ Room temp=22.8,hum=36.2,co=9i 1641060000
home,room=Kitchen temp=23.3,hum=36.9,co=18i 1641060000
home,room=Living\ Room temp=22.5,hum=36.3,co=14i 1641063600
home,room=Kitchen temp=23.1,hum=36.6,co=22i 1641063600
home,room=Living\ Room temp=22.2,hum=36.4,co=17i 1641067200
home,room=Kitchen temp=22.7,hum=36.5,co=26i 1641067200
{{% /influxdb/custom-timestamps %}}
The following examples show how to write the preceding sample data, already in line protocol format, to an {{% product-name %}} database.
To learn more about available tools and options, see Write data.
[!Note] Some examples in this getting started tutorial assume your InfluxDB credentials (URL, organization, and token) are provided by environment variables.
{{< tabs-wrapper >}}
{{% tabs %}} influxctl CLI Telegraf v1 API v2 API Python Go Node.js C# Java {{% /tabs %}}
{{% tab-content %}}
<!---------------------------- BEGIN INFLUXCTL CLI CONTENT ---------------------------->Use the influxctl write command
to write the home sensor sample data to your
{{< product-name omit=" Clustered" >}} cluster.
Provide the following:
--database flag--token flag (use the INFLUX_TOKEN environment variable created in
Get started--Set up {{< product-name >}})s) using the --precision flag{{% influxdb/custom-timestamps %}} {{% code-placeholders "get-started" %}}
influxctl write \
--database get-started \
--token $INFLUX_TOKEN \
--precision s \
'home,room=Living\ Room temp=21.1,hum=35.9,co=0i 1641024000
home,room=Kitchen temp=21.0,hum=35.9,co=0i 1641024000
home,room=Living\ Room temp=21.4,hum=35.9,co=0i 1641027600
home,room=Kitchen temp=23.0,hum=36.2,co=0i 1641027600
home,room=Living\ Room temp=21.8,hum=36.0,co=0i 1641031200
home,room=Kitchen temp=22.7,hum=36.1,co=0i 1641031200
home,room=Living\ Room temp=22.2,hum=36.0,co=0i 1641034800
home,room=Kitchen temp=22.4,hum=36.0,co=0i 1641034800
home,room=Living\ Room temp=22.2,hum=35.9,co=0i 1641038400
home,room=Kitchen temp=22.5,hum=36.0,co=0i 1641038400
home,room=Living\ Room temp=22.4,hum=36.0,co=0i 1641042000
home,room=Kitchen temp=22.8,hum=36.5,co=1i 1641042000
home,room=Living\ Room temp=22.3,hum=36.1,co=0i 1641045600
home,room=Kitchen temp=22.8,hum=36.3,co=1i 1641045600
home,room=Living\ Room temp=22.3,hum=36.1,co=1i 1641049200
home,room=Kitchen temp=22.7,hum=36.2,co=3i 1641049200
home,room=Living\ Room temp=22.4,hum=36.0,co=4i 1641052800
home,room=Kitchen temp=22.4,hum=36.0,co=7i 1641052800
home,room=Living\ Room temp=22.6,hum=35.9,co=5i 1641056400
home,room=Kitchen temp=22.7,hum=36.0,co=9i 1641056400
home,room=Living\ Room temp=22.8,hum=36.2,co=9i 1641060000
home,room=Kitchen temp=23.3,hum=36.9,co=18i 1641060000
home,room=Living\ Room temp=22.5,hum=36.3,co=14i 1641063600
home,room=Kitchen temp=23.1,hum=36.6,co=22i 1641063600
home,room=Living\ Room temp=22.2,hum=36.4,co=17i 1641067200
home,room=Kitchen temp=22.7,hum=36.5,co=26i 1641067200'
{{% /code-placeholders %}} {{% /influxdb/custom-timestamps %}}
If successful, the output is the success message; otherwise, error details and the failure message.
<!----------------------------- END INFLUXCTL CLI CONTENT ----------------------------->{{% /tab-content %}} {{% tab-content %}}
<!------------------------------- BEGIN TELEGRAF CONTENT ------------------------------>{{% influxdb/custom-timestamps %}}
Use Telegraf to consume line protocol, and then write it to {{< product-name >}}.
If you haven't already, follow the instructions to download and install Telegraf.
Copy and save the home sensor data sample
to a file on your local system--for example, home.lp.
cat <<- EOF > home.lp
home,room=Living\ Room temp=21.1,hum=35.9,co=0i 1641024000
home,room=Kitchen temp=21.0,hum=35.9,co=0i 1641024000
home,room=Living\ Room temp=21.4,hum=35.9,co=0i 1641027600
home,room=Kitchen temp=23.0,hum=36.2,co=0i 1641027600
home,room=Living\ Room temp=21.8,hum=36.0,co=0i 1641031200
home,room=Kitchen temp=22.7,hum=36.1,co=0i 1641031200
home,room=Living\ Room temp=22.2,hum=36.0,co=0i 1641034800
home,room=Kitchen temp=22.4,hum=36.0,co=0i 1641034800
home,room=Living\ Room temp=22.2,hum=35.9,co=0i 1641038400
home,room=Kitchen temp=22.5,hum=36.0,co=0i 1641038400
home,room=Living\ Room temp=22.4,hum=36.0,co=0i 1641042000
home,room=Kitchen temp=22.8,hum=36.5,co=1i 1641042000
home,room=Living\ Room temp=22.3,hum=36.1,co=0i 1641045600
home,room=Kitchen temp=22.8,hum=36.3,co=1i 1641045600
home,room=Living\ Room temp=22.3,hum=36.1,co=1i 1641049200
home,room=Kitchen temp=22.7,hum=36.2,co=3i 1641049200
home,room=Living\ Room temp=22.4,hum=36.0,co=4i 1641052800
home,room=Kitchen temp=22.4,hum=36.0,co=7i 1641052800
home,room=Living\ Room temp=22.6,hum=35.9,co=5i 1641056400
home,room=Kitchen temp=22.7,hum=36.0,co=9i 1641056400
home,room=Living\ Room temp=22.8,hum=36.2,co=9i 1641060000
home,room=Kitchen temp=23.3,hum=36.9,co=18i 1641060000
home,room=Living\ Room temp=22.5,hum=36.3,co=14i 1641063600
home,room=Kitchen temp=23.1,hum=36.6,co=22i 1641063600
home,room=Living\ Room temp=22.2,hum=36.4,co=17i 1641067200
home,room=Kitchen temp=22.7,hum=36.5,co=26i 1641067200
EOF
Run the following command to generate a Telegraf configuration file
(telegraf.conf) that enables the inputs.file and outputs.influxdb_v2
plugins:
mkdir -p iot-project \
&& telegraf --sample-config \
--input-filter file \
--output-filter influxdb_v2 \
> iot-project/telegraf.conf
In your editor, open iot-project/telegraf.conf and configure the following:
file input plugin: In the [[inputs.file]].files list, replace
"/tmp/metrics.out" with your sample data filename. If Telegraf can't
find a file when started, it stops processing and exits.
[[inputs.file]]
## Files to parse each interval. Accept standard unix glob matching rules,
## as well as ** to match recursive files and directories.
files = ["home.lp"]
# Set the timestamp precision to the precision in your data.
influx_timestamp_precision = '1s'
## Optionally, use the newer, more efficient line protocol parser
influx_parser_type = 'upstream'
output-influxdb_v2 output plugin: In the [[outputs.influxdb_v2]]
section, replace the default values with the following configuration for
your {{% product-name %}} database:
[[outputs.influxdb_v2]]
# InfluxDB cluster URL
urls = ["${INFLUX_HOST}"]
# INFLUX_TOKEN is an environment variable you assigned to your database token
token = "${INFLUX_TOKEN}"
# An empty string (InfluxDB ignores this parameter)
organization = ""
# Database name
bucket = "get-started"
The example configuration uses the following InfluxDB credentials:
urls: an array containing your INFLUX_HOST environment
variabletoken: your INFLUX_TOKEN environment variableorganization: an empty string (InfluxDB ignores this parameter)bucket: the name of the database to write toTo write the data, start the telegraf daemon with the following options:
--config: Specifies the path of the configuration file.--once: Runs a single Telegraf collection cycle for the configured
inputs and outputs, and then exits.Enter the following command in your terminal:
telegraf --once --config iot-project/telegraf.conf
If the write is successful, the output is similar to the following:
2023-05-31T20:09:08Z D! [agent] Starting service inputs
2023-05-31T20:09:19Z D! [outputs.influxdb_v2] Wrote batch of 52 metrics in 348.008167ms
2023-05-31T20:09:19Z D! [outputs.influxdb_v2] Buffer fullness: 0 / 10000 metrics
Telegraf and its plugins provide many options for reading and writing data. To learn more, see how to use Telegraf to write data.
{{% /influxdb/custom-timestamps %}}
<!------------------------------- END TELEGRAF CONTENT ------------------------------>{{% /tab-content %}} {{% tab-content %}}
<!----------------------------- BEGIN v1 API CONTENT ----------------------------->{{% influxdb/custom-timestamps %}}
Write data with your existing workloads that already use the InfluxDB v1 /write
API endpoint.
[!Note] If migrating data from InfluxDB 1.x, see the Migrate data from InfluxDB 1.x to InfluxDB {{% product-name %}} guide.
To write data to InfluxDB using the
InfluxDB v1 HTTP API, send a
request to the
InfluxDB API /write endpoint
using the POST request method.
{{% api-endpoint endpoint="https://{{< influxdb/host >}}/write" method="post" api-ref="/influxdb3/clustered/api/#operation/PostLegacyWrite"%}}
Include the following with your request:
ns)[!Note] With the {{% product-name %}} v1 API
/writeendpoint,Authorization: BearerandAuthorization: Tokenare equivalent and you can use either scheme to pass a database token in your request. Include the wordBearerorToken, a space, and your token value (all case-sensitive). For more information about HTTP API token schemes, see how to authenticate API requests.
The following example uses cURL and the InfluxDB v1 API to write line protocol to InfluxDB:
{{% code-placeholders "DATABASE_TOKEN" %}}
response=$(curl --silent --write-out "%{response_code}:-%{errormsg}" \
"https://{{< influxdb/host >}}/write?db=get-started&precision=s" \
--header "Authorization: Bearer DATABASE_TOKEN" \
--header "Content-type: text/plain; charset=utf-8" \
--header "Accept: application/json" \
--data-binary "
home,room=Living\ Room temp=21.1,hum=35.9,co=0i 1641024000
home,room=Kitchen temp=21.0,hum=35.9,co=0i 1641024000
home,room=Living\ Room temp=21.4,hum=35.9,co=0i 1641027600
home,room=Kitchen temp=23.0,hum=36.2,co=0i 1641027600
home,room=Living\ Room temp=21.8,hum=36.0,co=0i 1641031200
home,room=Kitchen temp=22.7,hum=36.1,co=0i 1641031200
home,room=Living\ Room temp=22.2,hum=36.0,co=0i 1641034800
home,room=Kitchen temp=22.4,hum=36.0,co=0i 1641034800
home,room=Living\ Room temp=22.2,hum=35.9,co=0i 1641038400
home,room=Kitchen temp=22.5,hum=36.0,co=0i 1641038400
home,room=Living\ Room temp=22.4,hum=36.0,co=0i 1641042000
home,room=Kitchen temp=22.8,hum=36.5,co=1i 1641042000
home,room=Living\ Room temp=22.3,hum=36.1,co=0i 1641045600
home,room=Kitchen temp=22.8,hum=36.3,co=1i 1641045600
home,room=Living\ Room temp=22.3,hum=36.1,co=1i 1641049200
home,room=Kitchen temp=22.7,hum=36.2,co=3i 1641049200
home,room=Living\ Room temp=22.4,hum=36.0,co=4i 1641052800
home,room=Kitchen temp=22.4,hum=36.0,co=7i 1641052800
home,room=Living\ Room temp=22.6,hum=35.9,co=5i 1641056400
home,room=Kitchen temp=22.7,hum=36.0,co=9i 1641056400
home,room=Living\ Room temp=22.8,hum=36.2,co=9i 1641060000
home,room=Kitchen temp=23.3,hum=36.9,co=18i 1641060000
home,room=Living\ Room temp=22.5,hum=36.3,co=14i 1641063600
home,room=Kitchen temp=23.1,hum=36.6,co=22i 1641063600
home,room=Living\ Room temp=22.2,hum=36.4,co=17i 1641067200
home,room=Kitchen temp=22.7,hum=36.5,co=26i 1641067200
")
# Format the response code and error message output.
response_code=${response%%:-*}
errormsg=${response#*:-}
# Remove leading and trailing whitespace from errormsg
errormsg=$(echo "${errormsg}" | tr -d '[:space:]')
echo "$response_code"
if [[ $errormsg ]]; then
echo "$errormsg"
fi
{{% /code-placeholders %}}
Replace the following:
DATABASE_TOKEN{{% /code-placeholder-key %}}:
a database token with
sufficient permissions to the specified databaseIf successful, the output is an HTTP 204 No Content status code; otherwise,
the error status code and failure message.
204
{{% /influxdb/custom-timestamps %}}
<!------------------------------ END v1 API CONTENT ------------------------------>{{% /tab-content %}} {{% tab-content %}}
<!----------------------------- BEGIN v2 API CONTENT ----------------------------->{{% influxdb/custom-timestamps %}}
To write data to InfluxDB using the
InfluxDB v2 HTTP API, send a request
to the InfluxDB API /api/v2/write endpoint using the POST request method.
{{< api-endpoint endpoint="https://{{< influxdb/host >}}/api/v2/write" method="post" api-ref="/influxdb3/clustered/api/#operation/PostWrite" >}}
Include the following with your request:
<!-- vale InfluxDataDocs.v3Schema = NO -->ns)[!Note] The {{% product-name %}} v2 API
/api/v2/writeendpoint supportsBearerandTokenauthorization schemes and you can use either scheme to pass a database token in your request. For more information about HTTP API token schemes, see how to authenticate API requests.
The following example uses cURL and the InfluxDB v2 API to write line protocol to InfluxDB:
{{% code-placeholders "DATABASE_TOKEN"%}}
response=$(curl --silent --write-out "%{response_code}:-%{errormsg}" \
"https://{{< influxdb/host >}}/api/v2/write?bucket=get-started&precision=s" \
--header "Authorization: Bearer DATABASE_TOKEN" \
--header "Content-Type: text/plain; charset=utf-8" \
--header "Accept: application/json" \
--data-binary "
home,room=Living\ Room temp=21.1,hum=35.9,co=0i 1641024000
home,room=Kitchen temp=21.0,hum=35.9,co=0i 1641024000
home,room=Living\ Room temp=21.4,hum=35.9,co=0i 1641027600
home,room=Kitchen temp=23.0,hum=36.2,co=0i 1641027600
home,room=Living\ Room temp=21.8,hum=36.0,co=0i 1641031200
home,room=Kitchen temp=22.7,hum=36.1,co=0i 1641031200
home,room=Living\ Room temp=22.2,hum=36.0,co=0i 1641034800
home,room=Kitchen temp=22.4,hum=36.0,co=0i 1641034800
home,room=Living\ Room temp=22.2,hum=35.9,co=0i 1641038400
home,room=Kitchen temp=22.5,hum=36.0,co=0i 1641038400
home,room=Living\ Room temp=22.4,hum=36.0,co=0i 1641042000
home,room=Kitchen temp=22.8,hum=36.5,co=1i 1641042000
home,room=Living\ Room temp=22.3,hum=36.1,co=0i 1641045600
home,room=Kitchen temp=22.8,hum=36.3,co=1i 1641045600
home,room=Living\ Room temp=22.3,hum=36.1,co=1i 1641049200
home,room=Kitchen temp=22.7,hum=36.2,co=3i 1641049200
home,room=Living\ Room temp=22.4,hum=36.0,co=4i 1641052800
home,room=Kitchen temp=22.4,hum=36.0,co=7i 1641052800
home,room=Living\ Room temp=22.6,hum=35.9,co=5i 1641056400
home,room=Kitchen temp=22.7,hum=36.0,co=9i 1641056400
home,room=Living\ Room temp=22.8,hum=36.2,co=9i 1641060000
home,room=Kitchen temp=23.3,hum=36.9,co=18i 1641060000
home,room=Living\ Room temp=22.5,hum=36.3,co=14i 1641063600
home,room=Kitchen temp=23.1,hum=36.6,co=22i 1641063600
home,room=Living\ Room temp=22.2,hum=36.4,co=17i 1641067200
home,room=Kitchen temp=22.7,hum=36.5,co=26i 1641067200
")
# Format the response code and error message output.
response_code=${response%%:-*}
errormsg=${response#*:-}
# Remove leading and trailing whitespace from errormsg
errormsg=$(echo "${errormsg}" | tr -d '[:space:]')
echo "$response_code"
if [[ $errormsg ]]; then
echo "$errormsg"
fi
{{% /code-placeholders %}}
Replace the following:
DATABASE_TOKEN{{% /code-placeholder-key %}}:
a database token with
sufficient permissions to the specified databaseIf successful, the output is an HTTP 204 No Content status code; otherwise,
the error status code and failure message.
204
{{% /influxdb/custom-timestamps %}}
<!------------------------------ END v2 API CONTENT ------------------------------>{{% /tab-content %}} {{% tab-content %}}
<!---------------------------- BEGIN PYTHON CONTENT --------------------------->{{% influxdb/custom-timestamps %}}
To write data to {{% product-name %}} using Python, use the
influxdb_client_3 module.
The following steps include setting up a Python virtual environment to scope
dependencies to your current project.
Create a module directory and navigate into it--for example:
mkdir -p influxdb_py_client && cd influxdb_py_client
Setup your Python virtual environment. Inside of your module directory, enter the following command:
<!--pytest-codeblocks:cont-->python -m venv envs/virtual-env
Activate the virtual environment.
<!--pytest-codeblocks:cont-->source ./envs/virtual-env/bin/activate
Install the client library package:
<!--pytest-codeblocks:cont-->pip install influxdb3-python
The influxdb3-python package provides the influxdb_client_3 module and
also installs the
pyarrow package for
working with Arrow data returned from queries.
In your terminal or editor, create a new file for your code--for example:
write.py.
touch write.py
Inside of write.py, enter the following sample code:
from influxdb_client_3 import InfluxDBClient3
import os
# INFLUX_TOKEN is an environment variable you assigned to your
# database WRITE token value.
token = os.getenv('INFLUX_TOKEN')
# host is the URL hostname without protocol or trailing slash
client = InfluxDBClient3(
host='{{< influxdb/host >}}',
org='',
token=token,
database='get-started'
)
lines = [
"home,room=Living\ Room temp=21.1,hum=35.9,co=0i 1641024000",
"home,room=Kitchen temp=21.0,hum=35.9,co=0i 1641024000",
"home,room=Living\ Room temp=21.4,hum=35.9,co=0i 1641027600",
"home,room=Kitchen temp=23.0,hum=36.2,co=0i 1641027600",
"home,room=Living\ Room temp=21.8,hum=36.0,co=0i 1641031200",
"home,room=Kitchen temp=22.7,hum=36.1,co=0i 1641031200",
"home,room=Living\ Room temp=22.2,hum=36.0,co=0i 1641034800",
"home,room=Kitchen temp=22.4,hum=36.0,co=0i 1641034800",
"home,room=Living\ Room temp=22.2,hum=35.9,co=0i 1641038400",
"home,room=Kitchen temp=22.5,hum=36.0,co=0i 1641038400",
"home,room=Living\ Room temp=22.4,hum=36.0,co=0i 1641042000",
"home,room=Kitchen temp=22.8,hum=36.5,co=1i 1641042000",
"home,room=Living\ Room temp=22.3,hum=36.1,co=0i 1641045600",
"home,room=Kitchen temp=22.8,hum=36.3,co=1i 1641045600",
"home,room=Living\ Room temp=22.3,hum=36.1,co=1i 1641049200",
"home,room=Kitchen temp=22.7,hum=36.2,co=3i 1641049200",
"home,room=Living\ Room temp=22.4,hum=36.0,co=4i 1641052800",
"home,room=Kitchen temp=22.4,hum=36.0,co=7i 1641052800",
"home,room=Living\ Room temp=22.6,hum=35.9,co=5i 1641056400",
"home,room=Kitchen temp=22.7,hum=36.0,co=9i 1641056400",
"home,room=Living\ Room temp=22.8,hum=36.2,co=9i 1641060000",
"home,room=Kitchen temp=23.3,hum=36.9,co=18i 1641060000",
"home,room=Living\ Room temp=22.5,hum=36.3,co=14i 1641063600",
"home,room=Kitchen temp=23.1,hum=36.6,co=22i 1641063600",
"home,room=Living\ Room temp=22.2,hum=36.4,co=17i 1641067200",
"home,room=Kitchen temp=22.7,hum=36.5,co=26i 1641067200"
]
client.write(lines,write_precision='s')
The sample does the following:
Imports the InfluxDBClient3 object from the influxdb_client_3 module.
Calls the InfluxDBClient3() constructor to instantiate an InfluxDB
client configured with the following credentials:
host: {{% product-name omit=" Clustered" %}} cluster hostname (URL
without protocol or trailing slash)org: an empty or arbitrary string (InfluxDB ignores this
parameter)token: a
database token
with write access to the specified database. Store this in a secret
store or environment variable to avoid exposing the raw token string.database: the name of the {{% product-name %}} database to write
toDefines a list of line protocol strings where each string represents a data record.
Calls the client.write() method with the line protocol record list and
write options.
Because the timestamps in the sample line protocol are in second
precision, the example passes the write_precision='s' option to set the
timestamp precision
to seconds.
To execute the module and write line protocol to your {{% product-name %}} database, enter the following command in your terminal:
<!--pytest.mark.skip-->python write.py
{{% /influxdb/custom-timestamps %}}
If successful, the output is the success message; otherwise, error details and the failure message.
<!----------------------------- END PYTHON CONTENT ---------------------------->{{% /tab-content %}} {{% tab-content %}}
<!----------------------------- BEGIN GO CONTENT ------------------------------>{{% influxdb/custom-timestamps %}}
To write data to {{% product-name %}} using Go, use the InfluxDB 3 influxdb3-go client library package.
Inside of your project directory, create a new module directory and navigate into it.
<!-- Using bash here is required when running with pytest. I don't know why, but sh evaluates $_ to /usr/bin/pytest. -->mkdir -p influxdb_go_client && cd influxdb_go_client
Initialize a new Go module in the directory.
<!--pytest-codeblocks:cont-->go mod init influxdb_go_client
In your terminal or editor, create a new file for your code--for example:
write.go.
touch write.go
Inside of write.go, enter the following sample code:
package main
import (
"context"
"os"
"fmt"
"log"
"github.com/InfluxCommunity/influxdb3-go/v2/influxdb3"
)
// Write line protocol data to InfluxDB
func WriteLineProtocol() error {
// INFLUX_TOKEN is an environment variable you assigned to your
// database WRITE token value.
token := os.Getenv("INFLUX_TOKEN")
database := os.Getenv("INFLUX_DATABASE")
// Initialize a client with URL and token,
// and set the timestamp precision for writes.
client, err := influxdb3.New(influxdb3.ClientConfig{
Host: "https://{{< influxdb/host >}}",
Token: token,
Database: database,
WriteOptions: &influxdb3.WriteOptions{Precision: lineprotocol.Second},
})
// Close the client when the function returns.
defer func(client *influxdb3.Client) {
err := client.Close()
if err != nil {
panic(err)
}
}(client)
// Define line protocol records to write.
// Use a raw string literal (denoted by backticks)
// to preserve backslashes and prevent interpretation
// of escape sequences--for example, escaped spaces in tag values.
lines := [...]string{
`home,room=Living\ Room temp=21.1,hum=35.9,co=0i 1641124000`,
`home,room=Kitchen temp=21.0,hum=35.9,co=0i 1641124000`,
`home,room=Living\ Room temp=21.4,hum=35.9,co=0i 1641127600`,
`home,room=Kitchen temp=23.0,hum=36.2,co=0i 1641127600`,
`home,room=Living\ Room temp=21.8,hum=36.0,co=0i 1641131200`,
`home,room=Kitchen temp=22.7,hum=36.1,co=0i 1641131200`,
`home,room=Living\ Room temp=22.2,hum=36.0,co=0i 1641134800`,
`home,room=Kitchen temp=22.4,hum=36.0,co=0i 1641134800`,
`home,room=Living\ Room temp=22.2,hum=35.9,co=0i 1641138400`,
`home,room=Kitchen temp=22.5,hum=36.0,co=0i 1641138400`,
`home,room=Living\ Room temp=22.4,hum=36.0,co=0i 1641142000`,
`home,room=Kitchen temp=22.8,hum=36.5,co=1i 1641142000`,
`home,room=Living\ Room temp=22.3,hum=36.1,co=0i 1641145600`,
`home,room=Kitchen temp=22.8,hum=36.3,co=1i 1641145600`,
`home,room=Living\ Room temp=22.3,hum=36.1,co=1i 1641149200`,
`home,room=Kitchen temp=22.7,hum=36.2,co=3i 1641149200`,
`home,room=Living\ Room temp=22.4,hum=36.0,co=4i 1641152800`,
`home,room=Kitchen temp=22.4,hum=36.0,co=7i 1641152800`,
`home,room=Living\ Room temp=22.6,hum=35.9,co=5i 1641156400`,
`home,room=Kitchen temp=22.7,hum=36.0,co=9i 1641156400`,
`home,room=Living\ Room temp=22.8,hum=36.2,co=9i 1641160000`,
`home,room=Kitchen temp=23.3,hum=36.9,co=18i 1641160000`,
`home,room=Living\ Room temp=22.5,hum=36.3,co=14i 1641163600`,
`home,room=Kitchen temp=23.1,hum=36.6,co=22i 1641163600`,
`home,room=Living\ Room temp=22.2,hum=36.4,co=17i 1641167200`,
`home,room=Kitchen temp=22.7,hum=36.5,co=26i 1641167200`,
}
// Iterate over the lines array and write each line
// separately to InfluxDB
for _, record := range lines {
err = client.Write(context.Background(), []byte(record))
if err != nil {
log.Fatalf("Error writing line protocol: %v", err)
}
}
if err != nil {
panic(err)
}
fmt.Println("Data has been written successfully.")
return nil
}
The sample does the following:
Imports required packages.
Defines a WriteLineProtocol() function that does the following:
To instantiate the client, calls the
influxdb3.New(influxdb3.ClientConfig) function and passes the
following:
Host: the {{% product-name omit=" Clustered" %}} cluster URL
Database: The name of your {{% product-name %}} database
Token: a
database token
with write access to the specified database. Store this in a
secret store or environment variable to avoid exposing the raw
token string.
WriteOptions: influxdb3.WriteOptions options for writing
to InfluxDB.
Because the timestamps in the sample line protocol are in second
precision, the example passes the Precision: lineprotocol.Second
option to set the
timestamp precision
to seconds.
Defines a deferred function that closes the client when the function returns.
Defines an array of line protocol strings where each string represents a data record.
Iterates through the array of line protocol and calls the write
client's Write() method to write each line of line protocol
separately to InfluxDB.
In your editor, create a main.go file and enter the following sample code
that calls the WriteLineProtocol() function:
package main
// Module main function
func main() {
WriteLineProtocol()
}
To install dependencies and write the data to your {{% product-name %}} database, enter the following command into your terminal:
<!--pytest.mark.skip-->go mod tidy && go run influxdb_go_client
If successful, the output is the success message; otherwise, error details and the failure message.
{{% /influxdb/custom-timestamps %}}
<!------------------------------- END GO CONTENT ------------------------------>{{% /tab-content %}} {{% tab-content %}} {{% influxdb/custom-timestamps %}}
<!---------------------------- BEGIN NODE.JS CONTENT --------------------------->If you haven't already, follow the instructions for Downloading and installing Node.js and npm for your system.
In your terminal, enter the following command to create a
influxdb_js_client directory for your project:
mkdir influxdb_js_client && cd influxdb_js_client
Inside of influxdb_js_client, enter the following command to initialize a
package. This example configures the package to use
ECMAScript modules (ESM).
npm init -y; npm pkg set type="module"
Install the @influxdata/influxdb3-client JavaScript client library as a
dependency to your project.
npm install --save @influxdata/influxdb3-client
In your terminal or editor, create a write.js file.
touch write.js
Inside of write.js, enter the following sample code:
// write.js
import { InfluxDBClient } from '@influxdata/influxdb3-client';
/**
* Set InfluxDB credentials.
*/
const host = '{{< influxdb/host >}}';
const database = 'get-started';
/**
* INFLUX_TOKEN is an environment variable you assigned to your
* WRITE token value.
*/
const token = process.env.INFLUX_TOKEN;
/**
* Write line protocol to InfluxDB using the JavaScript client library.
*/
export async function writeLineProtocol() {
/**
* Instantiate an InfluxDBClient
*/
const client = new InfluxDBClient({ host, token });
/**
* Define line protocol records to write.
*/
const records = [
`home,room=Living\\ Room temp=21.1,hum=35.9,co=0i 1641124000`,
`home,room=Kitchen temp=21.0,hum=35.9,co=0i 1641124000`,
`home,room=Living\\ Room temp=21.4,hum=35.9,co=0i 1641127600`,
`home,room=Kitchen temp=23.0,hum=36.2,co=0 1641127600`,
`home,room=Living\\ Room temp=21.8,hum=36.0,co=0i 1641131200`,
`home,room=Kitchen temp=22.7,hum=36.1,co=0i 1641131200`,
`home,room=Living\\ Room temp=22.2,hum=36.0,co=0i 1641134800`,
`home,room=Kitchen temp=22.4,hum=36.0,co=0i 1641134800`,
`home,room=Living\\ Room temp=22.2,hum=35.9,co=0i 1641138400`,
`home,room=Kitchen temp=22.5,hum=36.0,co=0i 1641138400`,
`home,room=Living\\ Room temp=22.4,hum=36.0,co=0i 1641142000`,
`home,room=Kitchen temp=22.8,hum=36.5,co=1i 1641142000`,
`home,room=Living\\ Room temp=22.3,hum=36.1,co=0i 1641145600`,
`home,room=Kitchen temp=22.8,hum=36.3,co=1i 1641145600`,
`home,room=Living\\ Room temp=22.3,hum=36.1,co=1i 1641149200`,
`home,room=Kitchen temp=22.7,hum=36.2,co=3i 1641149200`,
`home,room=Living\\ Room temp=22.4,hum=36.0,co=4i 1641152800`,
`home,room=Kitchen temp=22.4,hum=36.0,co=7i 1641152800`,
`home,room=Living\\ Room temp=22.6,hum=35.9,co=5i 1641156400`,
`home,room=Kitchen temp=22.7,hum=36.0,co=9i 1641156400`,
`home,room=Living\\ Room temp=22.8,hum=36.2,co=9i 1641160000`,
`home,room=Kitchen temp=23.3,hum=36.9,co=18i 1641160000`,
`home,room=Living\\ Room temp=22.5,hum=36.3,co=14i 1641163600`,
`home,room=Kitchen temp=23.1,hum=36.6,co=22i 1641163600`,
`home,room=Living\\ Room temp=22.2,hum=36.4,co=17i 1641167200`,
`home,room=Kitchen temp=22.7,hum=36.5,co=26i 1641167200`,
];
/**
* Creates an array that contains separate write request promises
* for all the records.
*/
const writePromises = records.map((record) => {
return client.write(record, database, '', { precision: 's' }).then(
() => `Data has been written successfully: ${record}`,
() => `Failed writing data: ${record}`
);
});
/**
* Wait for all the write promises to settle, and then output the results.
*/
const writeResults = await Promise.allSettled(writePromises);
writeResults.forEach((write) => console.log(write.value));
/** Close the client to release resources. */
await client.close();
}
The sample code does the following:
Imports the InfluxDBClient class.
Calls the new InfluxDBClient() constructor and passes a
ClientOptions object to instantiate a client configured with InfluxDB
credentials.
host: your {{% product-name omit=" Clustered" %}} cluster URLtoken: a
database token
with write access to the specified database. Store this in a secret
store or environment variable to avoid exposing the raw token string.Defines a list of line protocol strings where each string represents a data record.
Calls the client's write() method for each record, defines the success
or failure message to return, and collects the pending promises into the
writePromises array. Each call to write() passes the following
arguments:
record: the line protocol recorddatabase: the name of the {{% product-name %}} database to write
to{precision}: a WriteOptions object that sets the precision
value.Because the timestamps in the sample line protocol are in second
precision, the example passes s as the precision value to set the
write
timestamp precision
to seconds.
Calls Promise.allSettled() with the promises array to pause execution
until the promises have completed, and then assigns the array containing
success and failure messages to a writeResults constant.
Iterates over and prints the messages in writeResults.
Closes the client to release resources.
In your terminal or editor, create an index.js file.
Inside of index.js, enter the following sample code to import and call
writeLineProtocol():
// index.js
import { writeLineProtocol } from './write.js';
/**
* Execute the client functions.
*/
async function main() {
/** Write line protocol data to InfluxDB. */
await writeLineProtocol();
}
main();
In your terminal, execute index.js to write to {{% product-name %}}:
node index.js
{{% /influxdb/custom-timestamps %}}
If successful, the output is the success message; otherwise, error details and the failure message.
<!---------------------------- END NODE.JS CONTENT --------------------------->{{% /tab-content %}} {{% tab-content %}}
<!---------------------------- BEGIN C# CONTENT --------------------------->{{% influxdb/custom-timestamps %}}
If you haven't already, follow the
Microsoft.com download instructions
to install .NET and the dotnet CLI.
In your terminal, create an executable C# project using the .NET console template.
<!--pytest.mark.skip-->dotnet new console --name influxdb_csharp_client
Change into the generated influxdb_csharp_client directory.
cd influxdb_csharp_client
Run the following command to install the latest version of the InfluxDB 3 C# client library.
<!--pytest.mark.skip-->dotnet add package InfluxDB3.Client
In your editor, create a Write.cs file and enter the following sample
code:
// Write.cs
using System;
using System.Threading.Tasks;
using InfluxDB3.Client;
using InfluxDB3.Client.Query;
namespace InfluxDBv3;
public class Write
{
/**
* Writes line protocol to InfluxDB using the C# .NET client
* library.
*/
public static async Task WriteLines()
{
// Set InfluxDB credentials
const string host = "https://{{< influxdb/host >}}";
string? database = "get-started";
/**
* INFLUX_TOKEN is an environment variable you assigned to your
* WRITE token value.
*/
string? token = System.Environment
.GetEnvironmentVariable("INFLUX_TOKEN");
// Instantiate the InfluxDB client with credentials.
using var client = new InfluxDBClient(
host, token: token, database: database);
/**
* Define an array of line protocol strings to write.
* Include an additional backslash to preserve backslashes
* and prevent interpretation of escape sequences---for example,
* escaped spaces in tag values.
*/
string[] lines = new string[] {
"home,room=Living\\ Room temp=21.1,hum=35.9,co=0i 1641024000",
"home,room=Kitchen temp=21.0,hum=35.9,co=0i 1641024000",
"home,room=Living\\ Room temp=21.4,hum=35.9,co=0i 1641027600",
"home,room=Kitchen temp=23.0,hum=36.2,co=0i 1641027600",
"home,room=Living\\ Room temp=21.8,hum=36.0,co=0i 1641031200",
"home,room=Kitchen temp=22.7,hum=36.1,co=0i 1641031200",
"home,room=Living\\ Room temp=22.2,hum=36.0,co=0i 1641034800",
"home,room=Kitchen temp=22.4,hum=36.0,co=0i 1641034800",
"home,room=Living\\ Room temp=22.2,hum=35.9,co=0i 1641038400",
"home,room=Kitchen temp=22.5,hum=36.0,co=0i 1641038400",
"home,room=Living\\ Room temp=22.4,hum=36.0,co=0i 1641042000",
"home,room=Kitchen temp=22.8,hum=36.5,co=1i 1641042000",
"home,room=Living\\ Room temp=22.3,hum=36.1,co=0i 1641045600",
"home,room=Kitchen temp=22.8,hum=36.3,co=1i 1641045600",
"home,room=Living\\ Room temp=22.3,hum=36.1,co=1i 1641049200",
"home,room=Kitchen temp=22.7,hum=36.2,co=3i 1641049200",
"home,room=Living\\ Room temp=22.4,hum=36.0,co=4i 1641052800",
"home,room=Kitchen temp=22.4,hum=36.0,co=7i 1641052800",
"home,room=Living\\ Room temp=22.6,hum=35.9,co=5i 1641056400",
"home,room=Kitchen temp=22.7,hum=36.0,co=9i 1641056400",
"home,room=Living\\ Room temp=22.8,hum=36.2,co=9i 1641060000",
"home,room=Kitchen temp=23.3,hum=36.9,co=18i 1641060000",
"home,room=Living\\ Room temp=22.5,hum=36.3,co=14i 1641063600",
"home,room=Kitchen temp=23.1,hum=36.6,co=22i 1641063600",
"home,room=Living\\ Room temp=22.2,hum=36.4,co=17i 1641067200",
"home,room=Kitchen temp=22.7,hum=36.5,co=26i 1641067200"
};
// Write each record separately.
foreach (string line in lines)
{
// Write the record to InfluxDB with timestamp precision in seconds.
await client.WriteRecordAsync(
record: line, precision: WritePrecision.S);
Console.WriteLine(
"Data has been written successfully: {0,-30}", line);
}
}
}
The sample does the following:
Calls the new InfluxDBClient() constructor to instantiate a client
configured with InfluxDB credentials.
host: your {{% product-name omit=" Clustered" %}} cluster URLdatabase: the name of the {{% product-name %}} database to write
totoken: a
database token
with write access to the specified database. Store this in a secret
store or environment variable to avoid exposing the raw token string.The using statement ensures that the program disposes of the
client when it's no longer needed.
Defines an array of line protocol strings where each string represents a data record.
Calls the client's WriteRecordAsync() method to write each line
protocol record to InfluxDB.
Because the timestamps in the sample line protocol are in second
precision, the example passes the
WritePrecision.S enum value
to the precision: option to set
thetimestamp precision
to seconds.
In your editor, open the Program.cs file and replace its contents with the
following:
// Program.cs
using System;
using System.Threading.Tasks;
namespace InfluxDBv3;
public class Program
{
public static async Task Main()
{
await Write.WriteLineProtocol();
}
}
The Program class shares the same InfluxDBv3 namespace as the Write
class you defined in the preceding step and defines a Main() function that
calls Write.WriteLineProtocol(). The dotnet CLI recognizes
Program.Main() as the entry point for your program.
To build and execute the program and write the line protocol to your {{% product-name %}} database, enter the following command in your terminal:
<!--pytest.mark.skip-->dotnet run
If successful, the output is the success message; otherwise, error details and the failure message.
<!---------------------------- END C# CONTENT --------------------------->{{% /influxdb/custom-timestamps %}} {{% /tab-content %}} {{% tab-content %}} {{% influxdb/custom-timestamps %}}
<!-------------------------- BEGIN JAVA CONTENT --------------------------->The tutorial assumes using Maven version 3.9 and Java version >= 15.
If you haven't already, follow the instructions to download and install the Java JDK and Maven for your system.
In your terminal or editor, use Maven to generate a project--for example:
mvn org.apache.maven.plugins:maven-archetype-plugin:3.1.2:generate \
-DarchetypeArtifactId="maven-archetype-quickstart" \
-DarchetypeGroupId="org.apache.maven.archetypes" -DarchetypeVersion="1.4" \
-DgroupId="com.influxdbv3" -DartifactId="influxdb_java_client"
-Dversion="1.0"
Maven creates the <artifactId> directory (./influxdb_java_client) that
contains a pom.xml and scaffolding for your
com.influxdbv3.influxdb_java_client Java application.
In your terminal or editor, change into the ./influxdb_java_client
directory--for example:
cd ./influxdb_java_client
In your editor, open the pom.xml Maven configuration file and add the
com.influxdb.influxdb3-java client library into dependencies.
...
<dependencies>
...
<dependency>
<groupId>com.influxdb</groupId>
<artifactId>influxdb3-java</artifactId>
<version>0.1.0</version>
</dependency>
...
</dependencies>
To check your pom.xml for problems, run Maven's validate command--for example,
enter the following in your terminal:
mvn validate
In your editor, navigate to the
./influxdb_java_client/src/main/java/com/influxdbv3 directory and create a
Write.java file.
In Write.java, enter the following sample code:
// Write.java
package com.influxdbv3;
import java.util.List;
import com.influxdb.v3.client.InfluxDBClient;
import com.influxdb.v3.client.write.WriteOptions;
import com.influxdb.v3.client.write.WritePrecision;
/**
* Writes line protocol to InfluxDB using the Java client
* library.
*/
public final class Write {
/**
* Write data to InfluxDB 3.
*/
private Write() {
//not called
}
/**
* @throws Exception
*/
public static void writeLineProtocol() throws Exception {
// Set InfluxDB credentials
final String host = "https://{{< influxdb/host >}}";
final String database = "get-started";
/**
* INFLUX_TOKEN is an environment variable you assigned to your
* WRITE token value.
*/
final char[] token = (System.getenv("INFLUX_TOKEN")).
toCharArray();
// Instantiate the InfluxDB client.
try (InfluxDBClient client = InfluxDBClient.getInstance(host,
token, database)) {
// Create a list of line protocol records.
final List<String> records = List.of(
"home,room=Living\\ Room temp=21.1,hum=35.9,co=0i 1641024000",
"home,room=Kitchen temp=21.0,hum=35.9,co=0i 1641024000",
"home,room=Living\\ Room temp=21.4,hum=35.9,co=0i 1641027600",
"home,room=Kitchen temp=23.0,hum=36.2,co=0i 1641027600",
"home,room=Living\\ Room temp=21.8,hum=36.0,co=0i 1641031200",
"home,room=Kitchen temp=22.7,hum=36.1,co=0i 1641031200",
"home,room=Living\\ Room temp=22.2,hum=36.0,co=0i 1641034800",
"home,room=Kitchen temp=22.4,hum=36.0,co=0i 1641034800",
"home,room=Living\\ Room temp=22.2,hum=35.9,co=0i 1641038400",
"home,room=Kitchen temp=22.5,hum=36.0,co=0i 1641038400",
"home,room=Living\\ Room temp=22.4,hum=36.0,co=0i 1641042000",
"home,room=Kitchen temp=22.8,hum=36.5,co=1i 1641042000",
"home,room=Living\\ Room temp=22.3,hum=36.1,co=0i 1641045600",
"home,room=Kitchen temp=22.8,hum=36.3,co=1i 1641045600",
"home,room=Living\\ Room temp=22.3,hum=36.1,co=1i 1641049200",
"home,room=Kitchen temp=22.7,hum=36.2,co=3i 1641049200",
"home,room=Living\\ Room temp=22.4,hum=36.0,co=4i 1641052800",
"home,room=Kitchen temp=22.4,hum=36.0,co=7i 1641052800",
"home,room=Living\\ Room temp=22.6,hum=35.9,co=5i 1641056400",
"home,room=Kitchen temp=22.7,hum=36.0,co=9i 1641056400",
"home,room=Living\\ Room temp=22.8,hum=36.2,co=9i 1641060000",
"home,room=Kitchen temp=23.3,hum=36.9,co=18i 1641060000",
"home,room=Living\\ Room temp=22.5,hum=36.3,co=14i 1641063600",
"home,room=Kitchen temp=23.1,hum=36.6,co=22i 1641063600",
"home,room=Living\\ Room temp=22.2,hum=36.4,co=17i 1641067200",
"home,room=Kitchen temp=22.7,hum=36.5,co=26i 1641067200"
);
/**
* Write each record separately to InfluxDB with timestamp
* precision in seconds.
* If no error occurs, print a success message.
* */
for (String record : records) {
client.writeRecord(record, new WriteOptions(null, null,
WritePrecision.S));
System.out.printf("Data has been written successfully:
%s%n", record);
}
}
}
}
The sample code does the following:
Imports the following classes:
java.util.List;com.influxdb.v3.client.InfluxDBClientcom.influxdb.v3.client.write.WriteParameterscom.influxdb.v3.client.write.WritePrecisionCalls InfluxDBClient.getInstance() to instantiate a client configured
with InfluxDB credentials.
host: your {{% product-name omit=" Clustered" %}} cluster URLdatabase: the name of the {{% product-name %}} database to write
totoken: a
database token
with write access to the specified database. Store this in a secret
store or environment variable to avoid exposing the raw token string.Defines a list of line protocol strings where each string represents a data record.
Calls the client's writeRecord() method to write each record
separately to InfluxDB.
Because the timestamps in the sample line protocol are in second
precision, the example passes the
WritePrecision.S enum value
as the precision argument to set the write
timestamp precision
to seconds.
In your editor, open the App.java file (created by Maven) and replace its
contents with the following sample code:
// App.java
package com.influxdbv3;
/**
* Execute the client functions.
*
*/
public class App {
/**
* @param args
* @throws Exception
*/
public static void main(final String[] args) throws Exception {
// Write data to InfluxDB 3.
Write.writeLineProtocol();
}
}
App class and Write class are part of the same com.influxdbv3
package (your project groupId).App defines a main() function that calls Write.writeLineProtocol().In your terminal or editor, use Maven to install dependencies and compile the project code--for example:
<!--pytest.mark.skip-->mvn compile
In your terminal or editor, execute App.main() to write to InfluxDB--for
example, using Maven:
mvn exec:java -Dexec.mainClass="com.influxdbv3.App"
If successful, the output is the success message; otherwise, error details and the failure message.
<!---------------------------- END JAVA CONTENT --------------------------->{{% /influxdb/custom-timestamps %}} {{% /tab-content %}} {{< /tabs-wrapper >}}
{{< expand-wrapper >}} {{% expand "View the written data" %}}
{{% influxdb/custom-timestamps %}}
| time | room | co | hum | temp |
|---|---|---|---|---|
| 2022-01-01T08:00:00Z | Kitchen | 0 | 35.9 | 21 |
| 2022-01-01T09:00:00Z | Kitchen | 0 | 36.2 | 23 |
| 2022-01-01T10:00:00Z | Kitchen | 0 | 36.1 | 22.7 |
| 2022-01-01T11:00:00Z | Kitchen | 0 | 36 | 22.4 |
| 2022-01-01T12:00:00Z | Kitchen | 0 | 36 | 22.5 |
| 2022-01-01T13:00:00Z | Kitchen | 1 | 36.5 | 22.8 |
| 2022-01-01T14:00:00Z | Kitchen | 1 | 36.3 | 22.8 |
| 2022-01-01T15:00:00Z | Kitchen | 3 | 36.2 | 22.7 |
| 2022-01-01T16:00:00Z | Kitchen | 7 | 36 | 22.4 |
| 2022-01-01T17:00:00Z | Kitchen | 9 | 36 | 22.7 |
| 2022-01-01T18:00:00Z | Kitchen | 18 | 36.9 | 23.3 |
| 2022-01-01T19:00:00Z | Kitchen | 22 | 36.6 | 23.1 |
| 2022-01-01T20:00:00Z | Kitchen | 26 | 36.5 | 22.7 |
| 2022-01-01T08:00:00Z | Living Room | 0 | 35.9 | 21.1 |
| 2022-01-01T09:00:00Z | Living Room | 0 | 35.9 | 21.4 |
| 2022-01-01T10:00:00Z | Living Room | 0 | 36 | 21.8 |
| 2022-01-01T11:00:00Z | Living Room | 0 | 36 | 22.2 |
| 2022-01-01T12:00:00Z | Living Room | 0 | 35.9 | 22.2 |
| 2022-01-01T13:00:00Z | Living Room | 0 | 36 | 22.4 |
| 2022-01-01T14:00:00Z | Living Room | 0 | 36.1 | 22.3 |
| 2022-01-01T15:00:00Z | Living Room | 1 | 36.1 | 22.3 |
| 2022-01-01T16:00:00Z | Living Room | 4 | 36 | 22.4 |
| 2022-01-01T17:00:00Z | Living Room | 5 | 35.9 | 22.6 |
| 2022-01-01T18:00:00Z | Living Room | 9 | 36.2 | 22.8 |
| 2022-01-01T19:00:00Z | Living Room | 14 | 36.3 | 22.5 |
| 2022-01-01T20:00:00Z | Living Room | 17 | 36.4 | 22.2 |
| {{% /influxdb/custom-timestamps %}} |
{{% /expand %}} {{< /expand-wrapper >}}
Congratulations! You've written data to InfluxDB. Next, learn how to query your data.
{{< page-nav prev="/influxdb3/clustered/get-started/setup/" next="/influxdb3/clustered/get-started/query/" keepTab=true >}}