mirror of
https://github.com/prometheus/prometheus.git
synced 2025-01-11 13:57:36 -08:00
Merge pull request #5099 from prometheus/release-2.6
Merge release-2.6 to master
This commit is contained in:
commit
22a1def98d
|
@ -1,5 +1,12 @@
|
||||||
|
## 2.6.1 / 2019-01-15
|
||||||
|
|
||||||
|
* [BUGFIX] Azure SD: Fix discovery getting stuck sometimes. #5088
|
||||||
|
* [BUGFIX] Marathon SD: Use `Tasks.Ports` when `RequirePorts` is `false`. #5026
|
||||||
|
* [BUGFIX] Promtool: Fix "out-of-order sample" errors when testing rules. #5069
|
||||||
|
|
||||||
## 2.6.0 / 2018-12-17
|
## 2.6.0 / 2018-12-17
|
||||||
|
|
||||||
|
* [CHANGE] Remove default flags from the container's entrypoint, run Prometheus from `/etc/prometheus` and symlink the storage directory to `/etc/prometheus/data`. #4976
|
||||||
* [CHANGE] Promtool: Remove the `update` command. #3839
|
* [CHANGE] Promtool: Remove the `update` command. #3839
|
||||||
* [FEATURE] Add JSON log format via the `--log.format` flag. #4876
|
* [FEATURE] Add JSON log format via the `--log.format` flag. #4876
|
||||||
* [FEATURE] API: Add /api/v1/labels endpoint to get all label names. #4835
|
* [FEATURE] API: Add /api/v1/labels endpoint to get all label names. #4835
|
||||||
|
@ -7,7 +14,6 @@
|
||||||
* [ENHANCEMENT] Add `prometheus_tsdb_lowest_timestamp_seconds`, `prometheus_tsdb_head_min_time_seconds` and `prometheus_tsdb_head_max_time_seconds` metrics. #4888
|
* [ENHANCEMENT] Add `prometheus_tsdb_lowest_timestamp_seconds`, `prometheus_tsdb_head_min_time_seconds` and `prometheus_tsdb_head_max_time_seconds` metrics. #4888
|
||||||
* [ENHANCEMENT] Add `rule_group_last_evaluation_timestamp_seconds` metric. #4852
|
* [ENHANCEMENT] Add `rule_group_last_evaluation_timestamp_seconds` metric. #4852
|
||||||
* [ENHANCEMENT] Add `prometheus_template_text_expansion_failures_total` and `prometheus_template_text_expansions_total` metrics. #4747
|
* [ENHANCEMENT] Add `prometheus_template_text_expansion_failures_total` and `prometheus_template_text_expansions_total` metrics. #4747
|
||||||
* [ENHANCEMENT] Remove default flags from the container's entrypoint. #4976
|
|
||||||
* [ENHANCEMENT] Set consistent User-Agent header in outgoing requests. #4891
|
* [ENHANCEMENT] Set consistent User-Agent header in outgoing requests. #4891
|
||||||
* [ENHANCEMENT] Azure SD: Error out at load time when authentication parameters are missing. #4907
|
* [ENHANCEMENT] Azure SD: Error out at load time when authentication parameters are missing. #4907
|
||||||
* [ENHANCEMENT] EC2 SD: Add the machine's private DNS name to the discovery metadata. #4693
|
* [ENHANCEMENT] EC2 SD: Add the machine's private DNS name to the discovery metadata. #4693
|
||||||
|
|
|
@ -395,6 +395,10 @@ func (d *Discovery) refresh() (tg *targetgroup.Group, err error) {
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
|
// If we get here we haven't sent anything to the channel.
|
||||||
|
// We need to send it something to release it.
|
||||||
|
ch <- target{}
|
||||||
}(i, vm)
|
}(i, vm)
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|
|
@ -327,6 +327,7 @@ type App struct {
|
||||||
Container Container `json:"container"`
|
Container Container `json:"container"`
|
||||||
PortDefinitions []PortDefinition `json:"portDefinitions"`
|
PortDefinitions []PortDefinition `json:"portDefinitions"`
|
||||||
Networks []Network `json:"networks"`
|
Networks []Network `json:"networks"`
|
||||||
|
RequirePorts bool `json:"requirePorts"`
|
||||||
}
|
}
|
||||||
|
|
||||||
// isContainerNet checks if the app's first network is set to mode 'container'.
|
// isContainerNet checks if the app's first network is set to mode 'container'.
|
||||||
|
@ -435,7 +436,11 @@ func targetsForApp(app *App) []model.LabelSet {
|
||||||
|
|
||||||
for i := 0; i < len(app.PortDefinitions); i++ {
|
for i := 0; i < len(app.PortDefinitions); i++ {
|
||||||
labels[i] = app.PortDefinitions[i].Labels
|
labels[i] = app.PortDefinitions[i].Labels
|
||||||
ports[i] = app.PortDefinitions[i].Port
|
// When requirePorts is false, this port becomes the 'servicePort', not the listen port.
|
||||||
|
// In this case, the port needs to be taken from the task instead of the app.
|
||||||
|
if app.RequirePorts {
|
||||||
|
ports[i] = app.PortDefinitions[i].Port
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
prefix = portDefinitionLabelPrefix
|
prefix = portDefinitionLabelPrefix
|
||||||
|
@ -456,8 +461,9 @@ func targetsForApp(app *App) []model.LabelSet {
|
||||||
// Iterate over the ports we gathered using one of the methods above.
|
// Iterate over the ports we gathered using one of the methods above.
|
||||||
for i, port := range ports {
|
for i, port := range ports {
|
||||||
|
|
||||||
// A zero port can appear in a portMapping, which means it is auto-generated.
|
// A zero port here means that either the portMapping has a zero port defined,
|
||||||
// The allocated port appears at the corresponding index in the task's 'ports' array.
|
// or there is a portDefinition with requirePorts set to false. This means the port
|
||||||
|
// is auto-generated by Mesos and needs to be looked up in the task.
|
||||||
if port == 0 && len(t.Ports) == len(ports) {
|
if port == 0 && len(t.Ports) == len(ports) {
|
||||||
port = t.Ports[i]
|
port = t.Ports[i]
|
||||||
}
|
}
|
||||||
|
|
|
@ -343,6 +343,8 @@ func marathonTestAppListWithPortDefinitions(labels map[string]string, runningTas
|
||||||
task = Task{
|
task = Task{
|
||||||
ID: "test-task-1",
|
ID: "test-task-1",
|
||||||
Host: "mesos-slave1",
|
Host: "mesos-slave1",
|
||||||
|
// Auto-generated ports when requirePorts is false
|
||||||
|
Ports: []uint32{1234, 5678},
|
||||||
}
|
}
|
||||||
docker = DockerContainer{
|
docker = DockerContainer{
|
||||||
Image: "repo/image:tag",
|
Image: "repo/image:tag",
|
||||||
|
@ -358,6 +360,7 @@ func marathonTestAppListWithPortDefinitions(labels map[string]string, runningTas
|
||||||
{Labels: make(map[string]string), Port: 31000},
|
{Labels: make(map[string]string), Port: 31000},
|
||||||
{Labels: labels, Port: 32000},
|
{Labels: labels, Port: 32000},
|
||||||
},
|
},
|
||||||
|
RequirePorts: false, // default
|
||||||
}
|
}
|
||||||
)
|
)
|
||||||
return &AppList{
|
return &AppList{
|
||||||
|
@ -379,6 +382,80 @@ func TestMarathonSDSendGroupWithPortDefinitions(t *testing.T) {
|
||||||
case tgs := <-ch:
|
case tgs := <-ch:
|
||||||
tg := tgs[0]
|
tg := tgs[0]
|
||||||
|
|
||||||
|
if tg.Source != "test-service" {
|
||||||
|
t.Fatalf("Wrong target group name: %s", tg.Source)
|
||||||
|
}
|
||||||
|
if len(tg.Targets) != 2 {
|
||||||
|
t.Fatalf("Wrong number of targets: %v", tg.Targets)
|
||||||
|
}
|
||||||
|
tgt := tg.Targets[0]
|
||||||
|
if tgt[model.AddressLabel] != "mesos-slave1:1234" {
|
||||||
|
t.Fatalf("Wrong target address: %s", tgt[model.AddressLabel])
|
||||||
|
}
|
||||||
|
if tgt[model.LabelName(portMappingLabelPrefix+"prometheus")] != "" {
|
||||||
|
t.Fatalf("Wrong first portMappings label from the first port: %s", tgt[model.AddressLabel])
|
||||||
|
}
|
||||||
|
if tgt[model.LabelName(portDefinitionLabelPrefix+"prometheus")] != "" {
|
||||||
|
t.Fatalf("Wrong first portDefinitions label from the first port: %s", tgt[model.AddressLabel])
|
||||||
|
}
|
||||||
|
tgt = tg.Targets[1]
|
||||||
|
if tgt[model.AddressLabel] != "mesos-slave1:5678" {
|
||||||
|
t.Fatalf("Wrong target address: %s", tgt[model.AddressLabel])
|
||||||
|
}
|
||||||
|
if tgt[model.LabelName(portMappingLabelPrefix+"prometheus")] != "" {
|
||||||
|
t.Fatalf("Wrong portMappings label from the second port: %s", tgt[model.AddressLabel])
|
||||||
|
}
|
||||||
|
if tgt[model.LabelName(portDefinitionLabelPrefix+"prometheus")] != "yes" {
|
||||||
|
t.Fatalf("Wrong portDefinitions label from the second port: %s", tgt[model.AddressLabel])
|
||||||
|
}
|
||||||
|
default:
|
||||||
|
t.Fatal("Did not get a target group.")
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func marathonTestAppListWithPortDefinitionsRequirePorts(labels map[string]string, runningTasks int) *AppList {
|
||||||
|
var (
|
||||||
|
task = Task{
|
||||||
|
ID: "test-task-1",
|
||||||
|
Host: "mesos-slave1",
|
||||||
|
Ports: []uint32{31000, 32000},
|
||||||
|
}
|
||||||
|
docker = DockerContainer{
|
||||||
|
Image: "repo/image:tag",
|
||||||
|
}
|
||||||
|
container = Container{Docker: docker}
|
||||||
|
app = App{
|
||||||
|
ID: "test-service",
|
||||||
|
Tasks: []Task{task},
|
||||||
|
RunningTasks: runningTasks,
|
||||||
|
Labels: labels,
|
||||||
|
Container: container,
|
||||||
|
PortDefinitions: []PortDefinition{
|
||||||
|
{Labels: make(map[string]string), Port: 31000},
|
||||||
|
{Labels: labels, Port: 32000},
|
||||||
|
},
|
||||||
|
RequirePorts: true,
|
||||||
|
}
|
||||||
|
)
|
||||||
|
return &AppList{
|
||||||
|
Apps: []App{app},
|
||||||
|
}
|
||||||
|
}
|
||||||
|
|
||||||
|
func TestMarathonSDSendGroupWithPortDefinitionsRequirePorts(t *testing.T) {
|
||||||
|
var (
|
||||||
|
ch = make(chan []*targetgroup.Group, 1)
|
||||||
|
client = func(client *http.Client, url string) (*AppList, error) {
|
||||||
|
return marathonTestAppListWithPortDefinitionsRequirePorts(marathonValidLabel, 1), nil
|
||||||
|
}
|
||||||
|
)
|
||||||
|
if err := testUpdateServices(client, ch); err != nil {
|
||||||
|
t.Fatalf("Got error: %s", err)
|
||||||
|
}
|
||||||
|
select {
|
||||||
|
case tgs := <-ch:
|
||||||
|
tg := tgs[0]
|
||||||
|
|
||||||
if tg.Source != "test-service" {
|
if tg.Source != "test-service" {
|
||||||
t.Fatalf("Wrong target group name: %s", tg.Source)
|
t.Fatalf("Wrong target group name: %s", tg.Source)
|
||||||
}
|
}
|
||||||
|
@ -716,85 +793,3 @@ func TestMarathonSDSendGroupWithContainerNetworkAndPortMapping(t *testing.T) {
|
||||||
t.Fatal("Did not get a target group.")
|
t.Fatal("Did not get a target group.")
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
func marathonTestAppListWithContainerNetworkAndPortDefinition(labels map[string]string, runningTasks int) *AppList {
|
|
||||||
var (
|
|
||||||
task = Task{
|
|
||||||
ID: "test-task-1",
|
|
||||||
Host: "mesos-slave1",
|
|
||||||
IPAddresses: []IPAddress{
|
|
||||||
{Address: "1.2.3.4"},
|
|
||||||
},
|
|
||||||
}
|
|
||||||
docker = DockerContainer{
|
|
||||||
Image: "repo/image:tag",
|
|
||||||
}
|
|
||||||
portDefinitions = []PortDefinition{
|
|
||||||
{Labels: labels, Port: 8080},
|
|
||||||
{Labels: make(map[string]string), Port: 1234},
|
|
||||||
}
|
|
||||||
container = Container{
|
|
||||||
Docker: docker,
|
|
||||||
}
|
|
||||||
networks = []Network{
|
|
||||||
{Mode: "container", Name: "test-network"},
|
|
||||||
}
|
|
||||||
app = App{
|
|
||||||
ID: "test-service",
|
|
||||||
Tasks: []Task{task},
|
|
||||||
RunningTasks: runningTasks,
|
|
||||||
Labels: labels,
|
|
||||||
Container: container,
|
|
||||||
Networks: networks,
|
|
||||||
PortDefinitions: portDefinitions,
|
|
||||||
}
|
|
||||||
)
|
|
||||||
return &AppList{
|
|
||||||
Apps: []App{app},
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
func TestMarathonSDSendGroupWithContainerNetworkAndPortDefinition(t *testing.T) {
|
|
||||||
var (
|
|
||||||
ch = make(chan []*targetgroup.Group, 1)
|
|
||||||
client = func(client *http.Client, url string) (*AppList, error) {
|
|
||||||
return marathonTestAppListWithContainerNetworkAndPortDefinition(marathonValidLabel, 1), nil
|
|
||||||
}
|
|
||||||
)
|
|
||||||
if err := testUpdateServices(client, ch); err != nil {
|
|
||||||
t.Fatalf("Got error: %s", err)
|
|
||||||
}
|
|
||||||
select {
|
|
||||||
case tgs := <-ch:
|
|
||||||
tg := tgs[0]
|
|
||||||
|
|
||||||
if tg.Source != "test-service" {
|
|
||||||
t.Fatalf("Wrong target group name: %s", tg.Source)
|
|
||||||
}
|
|
||||||
if len(tg.Targets) != 2 {
|
|
||||||
t.Fatalf("Wrong number of targets: %v", tg.Targets)
|
|
||||||
}
|
|
||||||
tgt := tg.Targets[0]
|
|
||||||
if tgt[model.AddressLabel] != "1.2.3.4:8080" {
|
|
||||||
t.Fatalf("Wrong target address: %s", tgt[model.AddressLabel])
|
|
||||||
}
|
|
||||||
if tgt[model.LabelName(portMappingLabelPrefix+"prometheus")] != "" {
|
|
||||||
t.Fatalf("Wrong first portMappings label from the first port: %s", tgt[model.AddressLabel])
|
|
||||||
}
|
|
||||||
if tgt[model.LabelName(portDefinitionLabelPrefix+"prometheus")] != "yes" {
|
|
||||||
t.Fatalf("Wrong first portDefinitions label from the first port: %s", tgt[model.AddressLabel])
|
|
||||||
}
|
|
||||||
tgt = tg.Targets[1]
|
|
||||||
if tgt[model.AddressLabel] != "1.2.3.4:1234" {
|
|
||||||
t.Fatalf("Wrong target address: %s", tgt[model.AddressLabel])
|
|
||||||
}
|
|
||||||
if tgt[model.LabelName(portMappingLabelPrefix+"prometheus")] != "" {
|
|
||||||
t.Fatalf("Wrong portMappings label from the second port: %s", tgt[model.AddressLabel])
|
|
||||||
}
|
|
||||||
if tgt[model.LabelName(portDefinitionLabelPrefix+"prometheus")] != "" {
|
|
||||||
t.Fatalf("Wrong portDefinitions label from the second port: %s", tgt[model.AddressLabel])
|
|
||||||
}
|
|
||||||
default:
|
|
||||||
t.Fatal("Did not get a target group.")
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
Loading…
Reference in a new issue