diff --git a/instrumentation/opentelemetry_ecto/lib/opentelemetry_ecto.ex b/instrumentation/opentelemetry_ecto/lib/opentelemetry_ecto.ex index 28f2321a..6ec1be78 100644 --- a/instrumentation/opentelemetry_ecto/lib/opentelemetry_ecto.ex +++ b/instrumentation/opentelemetry_ecto/lib/opentelemetry_ecto.ex @@ -20,6 +20,8 @@ defmodule OpentelemetryEcto do require OpenTelemetry.Tracer + alias OpenTelemetry.SemConv.Incubating.DBAttributes + @typedoc """ Option that you can pass to `setup/2`. """ @@ -65,7 +67,7 @@ defmodule OpentelemetryEcto do this config will have precedence. * `:db_statement` - `:disabled` (default), `:enabled`, or a function. Whether or not to include DB statements in the **span attributes** (as the - `db.statement` attribute). + `#{DBAttributes.db_statement()}` attribute). Optionally provide a function that takes a query string and returns a sanitized version of it. This is useful for removing sensitive information from the query string. Unless this option is `:enabled` or a function, @@ -91,6 +93,7 @@ defmodule OpentelemetryEcto do total_time = measurements.total_time end_time = :opentelemetry.timestamp() start_time = end_time - total_time + measurements = Map.put(measurements, :total_time, total_time) database = repo.config()[:database] url = @@ -124,12 +127,11 @@ defmodule OpentelemetryEcto do # TODO: need connection information to complete the required attributes # net.peer.name or net.peer.ip and net.peer.port base_attributes = %{ - "db.type": db_type, - source: source, - "db.instance": database, - "db.name": database, - "db.url": url, - "total_time_#{time_unit}s": System.convert_time_unit(total_time, :native, time_unit) + :source => source, + :"db.instance" => database, + :"db.type" => db_type, + unquote(DBAttributes.db_name()) => database, + :"db.url" => url } db_statement_config = Keyword.get(config, :db_statement, :disabled) @@ -189,7 +191,7 @@ defmodule OpentelemetryEcto do measurements |> Enum.reduce(attributes, fn {k, v}, acc - when not is_nil(v) and k in [:decode_time, :query_time, :queue_time, :idle_time] -> + when not is_nil(v) and k in [:total_time, :decode_time, :query_time, :queue_time, :idle_time] -> Map.put( acc, String.to_atom("#{k}_#{time_unit}s"), @@ -202,7 +204,7 @@ defmodule OpentelemetryEcto do end defp maybe_add_db_statement(attributes, :enabled, query) do - Map.put(attributes, :"db.statement", query) + Map.put(attributes, unquote(DBAttributes.db_statement()), query) end defp maybe_add_db_statement(attributes, :disabled, _query) do @@ -210,7 +212,7 @@ defmodule OpentelemetryEcto do end defp maybe_add_db_statement(attributes, sanitizer, query) when is_function(sanitizer, 1) do - Map.put(attributes, :"db.statement", sanitizer.(query)) + Map.put(attributes, unquote(DBAttributes.db_statement()), sanitizer.(query)) end defp maybe_add_db_statement(attributes, _, _query) do @@ -218,19 +220,19 @@ defmodule OpentelemetryEcto do end defp maybe_add_db_system(attributes, Ecto.Adapters.Postgres) do - Map.put(attributes, :"db.system", :postgresql) + Map.put(attributes, unquote(DBAttributes.db_system()), :postgresql) end defp maybe_add_db_system(attributes, Ecto.Adapters.MyXQL) do - Map.put(attributes, :"db.system", :mysql) + Map.put(attributes, unquote(DBAttributes.db_system()), :mysql) end defp maybe_add_db_system(attributes, Ecto.Adapters.SQLite3) do - Map.put(attributes, :"db.system", :sqlite) + Map.put(attributes, unquote(DBAttributes.db_system()), :sqlite) end defp maybe_add_db_system(attributes, Ecto.Adapters.Tds) do - Map.put(attributes, :"db.system", :mssql) + Map.put(attributes, unquote(DBAttributes.db_system()), :mssql) end defp maybe_add_db_system(attributes, _) do diff --git a/instrumentation/opentelemetry_ecto/mix.exs b/instrumentation/opentelemetry_ecto/mix.exs index 1f2bbbd2..dd7f1ebc 100644 --- a/instrumentation/opentelemetry_ecto/mix.exs +++ b/instrumentation/opentelemetry_ecto/mix.exs @@ -57,14 +57,15 @@ defmodule OpentelemetryEcto.MixProject do defp deps do [ {:telemetry, "~> 0.4 or ~> 1.0"}, - {:opentelemetry_api, "~> 1.0"}, - {:opentelemetry, "~> 1.0", only: [:dev, :test]}, + {:opentelemetry_api, "~> 1.4"}, + {:opentelemetry_process_propagator, "~> 0.3"}, + {:opentelemetry_semantic_conventions, "~> 1.27"}, + {:opentelemetry, "~> 1.5", only: [:dev, :test]}, {:opentelemetry_exporter, "~> 1.0", only: [:dev, :test]}, {:ex_doc, "~> 0.36", only: [:dev], runtime: false}, {:ecto_sql, ">= 3.0.0", only: [:dev, :test]}, {:postgrex, ">= 0.15.0", only: [:dev, :test]}, - {:dialyxir, "~> 1.1", only: [:dev, :test], runtime: false}, - {:opentelemetry_process_propagator, "~> 0.3"} + {:dialyxir, "~> 1.1", only: [:dev, :test], runtime: false} ] end end diff --git a/instrumentation/opentelemetry_ecto/mix.lock b/instrumentation/opentelemetry_ecto/mix.lock index 1437f8b5..03b440a8 100644 --- a/instrumentation/opentelemetry_ecto/mix.lock +++ b/instrumentation/opentelemetry_ecto/mix.lock @@ -17,11 +17,12 @@ "makeup_elixir": {:hex, :makeup_elixir, "1.0.1", "e928a4f984e795e41e3abd27bfc09f51db16ab8ba1aebdba2b3a575437efafc2", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}, {:nimble_parsec, "~> 1.2.3 or ~> 1.3", [hex: :nimble_parsec, repo: "hexpm", optional: false]}], "hexpm", "7284900d412a3e5cfd97fdaed4f5ed389b8f2b4cb49efc0eb3bd10e2febf9507"}, "makeup_erlang": {:hex, :makeup_erlang, "1.0.1", "c7f58c120b2b5aa5fd80d540a89fdf866ed42f1f3994e4fe189abebeab610839", [:mix], [{:makeup, "~> 1.0", [hex: :makeup, repo: "hexpm", optional: false]}], "hexpm", "8a89a1eeccc2d798d6ea15496a6e4870b75e014d1af514b1b71fa33134f57814"}, "nimble_parsec": {:hex, :nimble_parsec, "1.4.0", "51f9b613ea62cfa97b25ccc2c1b4216e81df970acd8e16e8d1bdc58fef21370d", [:mix], [], "hexpm", "9c565862810fb383e9838c1dd2d7d2c437b3d13b267414ba6af33e50d2d1cf28"}, - "opentelemetry": {:hex, :opentelemetry, "1.3.1", "f0a342a74379e3540a634e7047967733da4bc8b873ec9026e224b2bd7369b1fc", [:rebar3], [{:opentelemetry_api, "~> 1.2.2", [hex: :opentelemetry_api, repo: "hexpm", optional: false]}, {:opentelemetry_semantic_conventions, "~> 0.2", [hex: :opentelemetry_semantic_conventions, repo: "hexpm", optional: false]}], "hexpm", "de476b2ac4faad3e3fe3d6e18b35dec9cb338c3b9910c2ce9317836dacad3483"}, - "opentelemetry_api": {:hex, :opentelemetry_api, "1.2.2", "693f47b0d8c76da2095fe858204cfd6350c27fe85d00e4b763deecc9588cf27a", [:mix, :rebar3], [{:opentelemetry_semantic_conventions, "~> 0.2", [hex: :opentelemetry_semantic_conventions, repo: "hexpm", optional: false]}], "hexpm", "dc77b9a00f137a858e60a852f14007bb66eda1ffbeb6c05d5fe6c9e678b05e9d"}, + "opentelemetry": {:hex, :opentelemetry, "1.5.0", "7dda6551edfc3050ea4b0b40c0d2570423d6372b97e9c60793263ef62c53c3c2", [:rebar3], [{:opentelemetry_api, "~> 1.4", [hex: :opentelemetry_api, repo: "hexpm", optional: false]}], "hexpm", "cdf4f51d17b592fc592b9a75f86a6f808c23044ba7cf7b9534debbcc5c23b0ee"}, + "opentelemetry_api": {:hex, :opentelemetry_api, "1.4.0", "63ca1742f92f00059298f478048dfb826f4b20d49534493d6919a0db39b6db04", [:mix, :rebar3], [], "hexpm", "3dfbbfaa2c2ed3121c5c483162836c4f9027def469c41578af5ef32589fcfc58"}, "opentelemetry_exporter": {:hex, :opentelemetry_exporter, "1.6.0", "f4fbf69aa9f1541b253813221b82b48a9863bc1570d8ecc517bc510c0d1d3d8c", [:rebar3], [{:grpcbox, ">= 0.0.0", [hex: :grpcbox, repo: "hexpm", optional: false]}, {:opentelemetry, "~> 1.3", [hex: :opentelemetry, repo: "hexpm", optional: false]}, {:opentelemetry_api, "~> 1.2", [hex: :opentelemetry_api, repo: "hexpm", optional: false]}, {:tls_certificate_check, "~> 1.18", [hex: :tls_certificate_check, repo: "hexpm", optional: false]}], "hexpm", "1802d1dca297e46f21e5832ecf843c451121e875f73f04db87355a6cb2ba1710"}, "opentelemetry_process_propagator": {:hex, :opentelemetry_process_propagator, "0.3.0", "ef5b2059403a1e2b2d2c65914e6962e56371570b8c3ab5323d7a8d3444fb7f84", [:mix, :rebar3], [{:opentelemetry_api, "~> 1.0", [hex: :opentelemetry_api, repo: "hexpm", optional: false]}], "hexpm", "7243cb6de1523c473cba5b1aefa3f85e1ff8cc75d08f367104c1e11919c8c029"}, - "opentelemetry_semantic_conventions": {:hex, :opentelemetry_semantic_conventions, "0.2.0", "b67fe459c2938fcab341cb0951c44860c62347c005ace1b50f8402576f241435", [:mix, :rebar3], [], "hexpm", "d61fa1f5639ee8668d74b527e6806e0503efc55a42db7b5f39939d84c07d6895"}, + "opentelemetry_semantic_conventions": {:hex, :opentelemetry_semantic_conventions, "1.27.0", "acd0194a94a1e57d63da982ee9f4a9f88834ae0b31b0bd850815fe9be4bbb45f", [:mix, :rebar3], [], "hexpm", "9681ccaa24fd3d810b4461581717661fd85ff7019b082c2dff89c7d5b1fc2864"}, + "opentelemetry_telemetry": {:hex, :opentelemetry_telemetry, "1.1.2", "410ab4d76b0921f42dbccbe5a7c831b8125282850be649ee1f70050d3961118a", [:mix, :rebar3], [{:opentelemetry_api, "~> 1.3", [hex: :opentelemetry_api, repo: "hexpm", optional: false]}, {:telemetry, "~> 1.1", [hex: :telemetry, repo: "hexpm", optional: false]}], "hexpm", "641ab469deb181957ac6d59bce6e1321d5fe2a56df444fc9c19afcad623ab253"}, "postgrex": {:hex, :postgrex, "0.17.4", "5777781f80f53b7c431a001c8dad83ee167bcebcf3a793e3906efff680ab62b3", [:mix], [{:db_connection, "~> 2.1", [hex: :db_connection, repo: "hexpm", optional: false]}, {:decimal, "~> 1.5 or ~> 2.0", [hex: :decimal, repo: "hexpm", optional: false]}, {:jason, "~> 1.0", [hex: :jason, repo: "hexpm", optional: true]}, {:table, "~> 0.1.0", [hex: :table, repo: "hexpm", optional: true]}], "hexpm", "6458f7d5b70652bc81c3ea759f91736c16a31be000f306d3c64bcdfe9a18b3cc"}, "ssl_verify_fun": {:hex, :ssl_verify_fun, "1.1.7", "354c321cf377240c7b8716899e182ce4890c5938111a1296add3ec74cf1715df", [:make, :mix, :rebar3], [], "hexpm", "fe4c190e8f37401d30167c8c405eda19469f34577987c76dde613e838bbc67f8"}, "telemetry": {:hex, :telemetry, "1.2.1", "68fdfe8d8f05a8428483a97d7aab2f268aaff24b49e0f599faa091f1d4e7f61c", [:rebar3], [], "hexpm", "dad9ce9d8effc621708f99eac538ef1cbe05d6a874dd741de2e689c47feafed5"},