mirror of
https://github.com/VictoriaMetrics/VictoriaMetrics.git
synced 2025-01-22 08:10:44 +01:00
app/vmctl: add insecure skip verify flags for source and destination addresses for native protocol (#5606)
https://github.com/VictoriaMetrics/VictoriaMetrics/issues/5595
This commit is contained in:
parent
178d64cc51
commit
b95d6f5f5e
@ -335,12 +335,14 @@ const (
|
|||||||
vmNativeSrcPassword = "vm-native-src-password"
|
vmNativeSrcPassword = "vm-native-src-password"
|
||||||
vmNativeSrcHeaders = "vm-native-src-headers"
|
vmNativeSrcHeaders = "vm-native-src-headers"
|
||||||
vmNativeSrcBearerToken = "vm-native-src-bearer-token"
|
vmNativeSrcBearerToken = "vm-native-src-bearer-token"
|
||||||
|
vmNativeSrcInsecureSkipVerify = "vm-native-src-insecure-skip-verify"
|
||||||
|
|
||||||
vmNativeDstAddr = "vm-native-dst-addr"
|
vmNativeDstAddr = "vm-native-dst-addr"
|
||||||
vmNativeDstUser = "vm-native-dst-user"
|
vmNativeDstUser = "vm-native-dst-user"
|
||||||
vmNativeDstPassword = "vm-native-dst-password"
|
vmNativeDstPassword = "vm-native-dst-password"
|
||||||
vmNativeDstHeaders = "vm-native-dst-headers"
|
vmNativeDstHeaders = "vm-native-dst-headers"
|
||||||
vmNativeDstBearerToken = "vm-native-dst-bearer-token"
|
vmNativeDstBearerToken = "vm-native-dst-bearer-token"
|
||||||
|
vmNativeDstInsecureSkipVerify = "vm-native-dst-insecure-skip-verify"
|
||||||
)
|
)
|
||||||
|
|
||||||
var (
|
var (
|
||||||
@ -466,6 +468,16 @@ var (
|
|||||||
"Non-binary export/import API is less efficient, but supports deduplication if it is configured on vm-native-src-addr side.",
|
"Non-binary export/import API is less efficient, but supports deduplication if it is configured on vm-native-src-addr side.",
|
||||||
Value: false,
|
Value: false,
|
||||||
},
|
},
|
||||||
|
&cli.BoolFlag{
|
||||||
|
Name: vmNativeSrcInsecureSkipVerify,
|
||||||
|
Usage: "Whether to skip TLS certificate verification when connecting to the source address",
|
||||||
|
Value: true,
|
||||||
|
},
|
||||||
|
&cli.BoolFlag{
|
||||||
|
Name: vmNativeDstInsecureSkipVerify,
|
||||||
|
Usage: "Whether to skip TLS certificate verification when connecting to the destination address",
|
||||||
|
Value: true,
|
||||||
|
},
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
|
|
||||||
|
@ -2,6 +2,7 @@ package main
|
|||||||
|
|
||||||
import (
|
import (
|
||||||
"context"
|
"context"
|
||||||
|
"crypto/tls"
|
||||||
"fmt"
|
"fmt"
|
||||||
"log"
|
"log"
|
||||||
"net/http"
|
"net/http"
|
||||||
@ -212,6 +213,7 @@ func main() {
|
|||||||
|
|
||||||
var srcExtraLabels []string
|
var srcExtraLabels []string
|
||||||
srcAddr := strings.Trim(c.String(vmNativeSrcAddr), "/")
|
srcAddr := strings.Trim(c.String(vmNativeSrcAddr), "/")
|
||||||
|
srcInsecureSkipVerify := c.Bool(vmNativeSrcInsecureSkipVerify)
|
||||||
srcAuthConfig, err := auth.Generate(
|
srcAuthConfig, err := auth.Generate(
|
||||||
auth.WithBasicAuth(c.String(vmNativeSrcUser), c.String(vmNativeSrcPassword)),
|
auth.WithBasicAuth(c.String(vmNativeSrcUser), c.String(vmNativeSrcPassword)),
|
||||||
auth.WithBearer(c.String(vmNativeSrcBearerToken)),
|
auth.WithBearer(c.String(vmNativeSrcBearerToken)),
|
||||||
@ -219,10 +221,14 @@ func main() {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("error initilize auth config for source: %s", srcAddr)
|
return fmt.Errorf("error initilize auth config for source: %s", srcAddr)
|
||||||
}
|
}
|
||||||
srcHTTPClient := &http.Client{Transport: &http.Transport{DisableKeepAlives: disableKeepAlive}}
|
srcHTTPClient := &http.Client{Transport: &http.Transport{
|
||||||
|
DisableKeepAlives: disableKeepAlive,
|
||||||
|
TLSClientConfig: &tls.Config{InsecureSkipVerify: srcInsecureSkipVerify},
|
||||||
|
}}
|
||||||
|
|
||||||
dstAddr := strings.Trim(c.String(vmNativeDstAddr), "/")
|
dstAddr := strings.Trim(c.String(vmNativeDstAddr), "/")
|
||||||
dstExtraLabels := c.StringSlice(vmExtraLabel)
|
dstExtraLabels := c.StringSlice(vmExtraLabel)
|
||||||
|
dstInsecureSkipVerify := c.Bool(vmNativeDstInsecureSkipVerify)
|
||||||
dstAuthConfig, err := auth.Generate(
|
dstAuthConfig, err := auth.Generate(
|
||||||
auth.WithBasicAuth(c.String(vmNativeDstUser), c.String(vmNativeDstPassword)),
|
auth.WithBasicAuth(c.String(vmNativeDstUser), c.String(vmNativeDstPassword)),
|
||||||
auth.WithBearer(c.String(vmNativeDstBearerToken)),
|
auth.WithBearer(c.String(vmNativeDstBearerToken)),
|
||||||
@ -230,7 +236,10 @@ func main() {
|
|||||||
if err != nil {
|
if err != nil {
|
||||||
return fmt.Errorf("error initilize auth config for destination: %s", dstAddr)
|
return fmt.Errorf("error initilize auth config for destination: %s", dstAddr)
|
||||||
}
|
}
|
||||||
dstHTTPClient := &http.Client{Transport: &http.Transport{DisableKeepAlives: disableKeepAlive}}
|
dstHTTPClient := &http.Client{Transport: &http.Transport{
|
||||||
|
DisableKeepAlives: disableKeepAlive,
|
||||||
|
TLSClientConfig: &tls.Config{InsecureSkipVerify: dstInsecureSkipVerify},
|
||||||
|
}}
|
||||||
|
|
||||||
p := vmNativeProcessor{
|
p := vmNativeProcessor{
|
||||||
rateLimit: c.Int64(vmRateLimit),
|
rateLimit: c.Int64(vmRateLimit),
|
||||||
|
@ -41,6 +41,7 @@ The sandbox cluster installation is running under the constant load generated by
|
|||||||
* FEATURE: all VictoriaMetrics components: add `-metrics.exposeMetadata` command-line flag, which allows displaying `TYPE` and `HELP` metadata at `/metrics` page exposed at `-httpListenAddr`. This may be needed when the `/metrics` page is scraped by collector, which requires the `TYPE` and `HELP` metadata such as [Google Cloud Managed Prometheus](https://cloud.google.com/stackdriver/docs/managed-prometheus/troubleshooting#missing-metric-type).
|
* FEATURE: all VictoriaMetrics components: add `-metrics.exposeMetadata` command-line flag, which allows displaying `TYPE` and `HELP` metadata at `/metrics` page exposed at `-httpListenAddr`. This may be needed when the `/metrics` page is scraped by collector, which requires the `TYPE` and `HELP` metadata such as [Google Cloud Managed Prometheus](https://cloud.google.com/stackdriver/docs/managed-prometheus/troubleshooting#missing-metric-type).
|
||||||
* FEATURE: dashboards/cluster: add panels for detailed visualization of traffic usage between vmstorage, vminsert, vmselect components and their clients. New panels are available in the rows dedicated to specific components.
|
* FEATURE: dashboards/cluster: add panels for detailed visualization of traffic usage between vmstorage, vminsert, vmselect components and their clients. New panels are available in the rows dedicated to specific components.
|
||||||
* FEATURE: dashboards/cluster: update "Slow Queries" panel to show percentage of the slow queries to the total number of read queries served by vmselect. The percentage value should make it more clear for users whether there is a service degradation.
|
* FEATURE: dashboards/cluster: update "Slow Queries" panel to show percentage of the slow queries to the total number of read queries served by vmselect. The percentage value should make it more clear for users whether there is a service degradation.
|
||||||
|
* FEATURE [vmctl](https://docs.victoriametrics.com/vmctl.html): add `-vm-native-src-insecure-skip-verify` and `-vm-native-dst-insecure-skip-verify` command-line flags for native protocol. It can be used for skipping TLS certificate verification when connecting to the source or destination addresses.
|
||||||
|
|
||||||
* BUGFIX: [VictoriaMetrics cluster](https://docs.victoriametrics.com/Cluster-VictoriaMetrics.html): properly return full results when `-search.skipSlowReplicas` command-line flag is passed to `vmselect` and when [vmstorage groups](https://docs.victoriametrics.com/Cluster-VictoriaMetrics.html#vmstorage-groups-at-vmselect) are in use. Previously partial results could be returned in this case.
|
* BUGFIX: [VictoriaMetrics cluster](https://docs.victoriametrics.com/Cluster-VictoriaMetrics.html): properly return full results when `-search.skipSlowReplicas` command-line flag is passed to `vmselect` and when [vmstorage groups](https://docs.victoriametrics.com/Cluster-VictoriaMetrics.html#vmstorage-groups-at-vmselect) are in use. Previously partial results could be returned in this case.
|
||||||
* BUGFIX: `vminsert`: properly accept samples via [OpenTelemetry data ingestion protocol](https://docs.victoriametrics.com/#sending-data-via-opentelemetry) when these samples have no [resource attributes](https://opentelemetry.io/docs/instrumentation/go/resources/). Previously such samples were silently skipped.
|
* BUGFIX: `vminsert`: properly accept samples via [OpenTelemetry data ingestion protocol](https://docs.victoriametrics.com/#sending-data-via-opentelemetry) when these samples have no [resource attributes](https://opentelemetry.io/docs/instrumentation/go/resources/). Previously such samples were silently skipped.
|
||||||
|
Loading…
Reference in New Issue
Block a user