Merge branch 'main' into dependabot/cargo/serde-1.0.128

pull/24376/head
kodiakhq[bot] 2021-08-23 11:24:56 +00:00 committed by GitHub
commit 045989e173
No known key found for this signature in database
GPG Key ID: 4AEE18F83AFDEB23
8 changed files with 121 additions and 12 deletions

4
.gitignore vendored
View File

@ -2,7 +2,9 @@
**/*.rs.bk
.idea/
.env
.gdb_history
*.tsm
**/.DS_Store
**/.vscode
query_tests/cases/**/*.out
query_tests/cases/**/*.out
valgrind-out.txt

4
Cargo.lock generated
View File

@ -191,9 +191,9 @@ dependencies = [
[[package]]
name = "assert_cmd"
version = "1.0.8"
version = "2.0.0"
source = "registry+https://github.com/rust-lang/crates.io-index"
checksum = "c98233c6673d8601ab23e77eb38f999c51100d46c5703b17288c57fddf3a1ffe"
checksum = "54f002ce7d0c5e809ebb02be78fd503aeed4a511fd0fcaff6e6914cbdabbfa33"
dependencies = [
"bstr",
"doc-comment",

View File

@ -142,7 +142,7 @@ parking_lot = "0.11.1"
write_buffer = { path = "write_buffer" }
# Crates.io dependencies, in alphabetical order
assert_cmd = "1.0.0"
assert_cmd = "2.0.0"
flate2 = "1.0"
hex = "0.4.2"
predicates = "2.0.2"

42
docs/valgrind.md Normal file
View File

@ -0,0 +1,42 @@
# Valgrind
This document explains how to use [Valgrind] to perform certain debug tasks.
## Build
Create a debug build that uses the system memory allocator (i.e. neither [heappy] nor [jemalloc]):
```console
$ cargo build --no-default-features
```
## Memory Leaks
There is a script that does most of the config setting. Just start the server with:
```console
$ ./scripts/valgrind_leak ./target/debug/influxdb_iox run ...
```
You can kill the server w/ `CTRL-C` when you're ready. The [Valgrind] output will be written to `valgrind-out.txt`.
## Suppression Rules
[Valgrind] allows you to suppress certain outputs. This can be used to ignore known "issues" like that [lazycell] leaks.
For IOx we provide a file that is used by the scripts (under `scripts/valgrind.supp`). If you plan to write your own
rules, here are some useful links:
- <https://valgrind.org/docs/manual/mc-manual.html#mc-manual.suppfiles>
- <https://www.valgrind.org/docs/manual/manual-core.html#manual-core.suppress>
- <https://wiki.wxwidgets.org/Valgrind_Suppression_File_Howto>
You may also use the `--gen-suppressions=all` to auto-generate supppression rules:
```console
$ ./scripts/valgrind_leak --gen-suppressions=all ./target/debug/influxdb_iox run ...
```
Note that Rust symbols like `influxdb_iox::main` are mangled in a way that [Valgrind] cannot parse them (e.g. to
`_ZN12influxdb_iox4main17h940b8bf02831a9d8E`). The easiest way is to replace `::` w/ `*` and prepand and append an
additional wildcard `*`, so `influxdb_iox::main` gets `*influxdb_iox*main*`.
[heappy]: https://github.com/mkmik/heappy
[jemalloc]: ttps://github.com/jemalloc/jemalloc
[lazycell]: https://crates.io/crates/lazycell
[Valgrind]: https://valgrind.org/

31
scripts/valgrind.supp Normal file
View File

@ -0,0 +1,31 @@
{
dlopen
Memcheck:Leak
...
fun:do_dlopen
...
}
{
lazystatic
Memcheck:Leak
...
fun:__static_ref_initialize
...
}
{
oncecell
Memcheck:Leak
...
fun:*once_cell*imp*initialize_inner*
...
}
{
init_logs_and_tracing
Memcheck:Leak
...
fun:*init_logs_and_tracing*
...
}

14
scripts/valigrind_leak Executable file
View File

@ -0,0 +1,14 @@
#!/bin/bash
set -eu -o pipefail
SCRIPT_DIR="$( cd "$( dirname "${BASH_SOURCE[0]}" )" >/dev/null 2>&1 && pwd )"
exec valgrind \
--leak-check=full \
--log-file=valgrind-out.txt \
--num-callers=50 \
--show-leak-kinds=all \
--suppressions="$SCRIPT_DIR/valgrind.supp" \
--track-origins=yes \
--verbose \
$@

View File

@ -130,18 +130,41 @@ fn make_server(
app_server
}
#[cfg(all(not(feature = "heappy"), not(feature = "jemalloc_replacing_malloc")))]
fn build_malloc_conf() -> String {
"system".to_string()
}
#[cfg(all(feature = "heappy", not(feature = "jemalloc_replacing_malloc")))]
fn build_malloc_conf() -> String {
"heappy".to_string()
}
#[cfg(all(not(feature = "heappy"), feature = "jemalloc_replacing_malloc"))]
fn build_malloc_conf() -> String {
tikv_jemalloc_ctl::config::malloc_conf::mib()
.unwrap()
.read()
.unwrap()
.to_string()
}
#[cfg(all(feature = "heappy", feature = "jemalloc_replacing_malloc"))]
fn build_malloc_conf() -> String {
compile_error!("must use exactly one memory allocator")
}
/// This is the entry point for the IOx server. `config` represents
/// command line arguments, if any.
pub async fn main(config: Config) -> Result<()> {
let git_hash = option_env!("GIT_HASH").unwrap_or("UNKNOWN");
let num_cpus = num_cpus::get();
let build_malloc_conf = tikv_jemalloc_ctl::config::malloc_conf::mib()
.unwrap()
.read()
.unwrap();
let build_malloc_conf = build_malloc_conf();
info!(
git_hash,
num_cpus, build_malloc_conf, "InfluxDB IOx server starting"
num_cpus,
%build_malloc_conf,
"InfluxDB IOx server starting",
);
// Install custom panic handler and forget about it.

View File

@ -46,9 +46,6 @@ static VERSION_STRING: Lazy<String> = Lazy::new(|| {
)
});
#[cfg(not(any(feature = "heappy", feature = "jemalloc_replacing_malloc")))]
compile_error!("you need to pick either heappy or jemalloc_replacing_malloc feature, cargo can't pick a default out of a mutually exclusive set");
#[cfg(all(feature = "heappy", feature = "jemalloc_replacing_malloc"))]
compile_error!("heappy and jemalloc_replacing_malloc features are mutually exclusive");