Skip to content

Commit

Permalink
Default blue/green mode as deploy; docs
Browse files Browse the repository at this point in the history
  • Loading branch information
jcmoraisjr committed Sep 30, 2018
1 parent d2ad4c2 commit c26c9cf
Show file tree
Hide file tree
Showing 5 changed files with 19 additions and 7 deletions.
8 changes: 8 additions & 0 deletions CHANGELOG.md
Original file line number Diff line number Diff line change
Expand Up @@ -2,6 +2,10 @@

## Current snapshot tag (v0.7)

Breaking backward compatibility from `v0.6`

* Default blue/green deployment mode changed from `pod` to `deploy`. Use `ingress.kubernetes.io/blue-green-mode` annotation to change to the v0.6 behavior. See also the blue/green deployment [doc](/README.md#blue-green).

Fixes and improvements since `v0.6`

* Add SSL config on TCP services [#192](https://github.com/jcmoraisjr/haproxy-ingress/pull/192) - [doc](/README.md#tcp-services-configmap)
Expand Down Expand Up @@ -36,6 +40,10 @@ Fixes and improvements since `v0.6`
* Configmap options:
* `http-port`
* `https-port`
* Add blue/green balance mode [#201](https://github.com/jcmoraisjr/haproxy-ingress/pull/201) - [doc](/README.md#blue-green)
* Annotations:
* `ingress.kubernetes.io/blue-green-balance`
* `ingress.kubernetes.io/blue-green-mode`

## v0.6-beta.2

Expand Down
2 changes: 1 addition & 1 deletion README.md
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,7 @@ selector and another that matches the blue/green selector.

* `ingress.kubernetes.io/blue-green-balance`: comma separated list of labels and weights
* `ingress.kubernetes.io/blue-green-deploy`: deprecated on v0.7, this is an alias to `ingress.kubernetes.io/blue-green-balance`.
* `ingress.kubernetes.io/blue-green-mode`: how to apply the weights, might be `pod` or `deploy`
* `ingress.kubernetes.io/blue-green-mode`: defaults to `deploy` on v0.7, defines how to apply the weights, might be `pod` or `deploy`

The following configuration `group=blue=1,group=green=4` will redirect 20% of the load to the
`group=blue` group and 80% of the load to `group=green` group.
Expand Down
2 changes: 1 addition & 1 deletion examples/blue-green/README.md
Original file line number Diff line number Diff line change
Expand Up @@ -144,7 +144,7 @@ Running 100 requests...

---

Changing to deploy mode. This mode targets the balance config to the whole deployment
Changing to *deploy* mode. This mode targets the balance config to the whole deployment
instead of single pods.

**Note:** BG mode was added on v0.7. On v0.6, the only supported mode is `pod`.
Expand Down
4 changes: 2 additions & 2 deletions pkg/common/ingress/annotations/bluegreen/main.go
Original file line number Diff line number Diff line change
Expand Up @@ -99,9 +99,9 @@ func (bg bgdeploy) Parse(ing *extensions.Ingress) (interface{}, error) {
mode, _ := parser.GetStringAnnotation(blueGreenModeAnn, ing)
if !modeAnnRegex.MatchString(mode) {
if mode != "" {
glog.Warningf("unsupported blue/green mode '%v' on '%v/%v', falling back to 'pod'", mode, ing.Namespace, ing.Name)
glog.Warningf("unsupported blue/green mode '%v' on '%v/%v', falling back to 'deploy'", mode, ing.Namespace, ing.Name)
}
mode = "pod"
mode = "deploy"
}
return &Config{
DeployWeight: dw,
Expand Down
10 changes: 7 additions & 3 deletions pkg/common/ingress/controller/bluegreen_test.go
Original file line number Diff line number Diff line change
Expand Up @@ -59,11 +59,13 @@ func TestWeightBalance(t *testing.T) {
"b06-01": buildBackend("v=1=50,v=2=25", ",pod0102-01", "deploy"),
"b07-01": buildBackend("v=1=50,v=non=25", "pod0101-01,pod0102-01", "deploy"),
"b07-02": buildBackend("v=1=50,v=non=25", "pod0101-01,pod0102-01", "pod"),
"b07-03": buildBackend("v=1=50,v=2=25", "pod0101-01,pod0102-non", "deploy"),
"b07-04": buildBackend("v=1=50,v=2=25", "pod0101-01,pod0102-non", "pod"),
"b07-03": buildBackend("v=1=50,non=2=25", "pod0101-01,pod0102-01", "deploy"),
"b07-04": buildBackend("v=1=50,v=2=25", "pod0101-01,pod0102-non", "deploy"),
"b07-05": buildBackend("v=1=50,v=2=25", "pod0101-01,pod0102-non", "pod"),
"b08-01": buildBackend("v=1=50,v=2=25,v=3=25", "pod0101-01,pod0102-01,pod0102-02,pod0103-01", "deploy"),
"b08-02": buildBackend("v=1=50,v=2=0,v=3=25", "pod0101-01,pod0102-01,pod0102-02,pod0103-01", "deploy"),
"b09-01": buildBackend("v=1=50,v=2=0,v=3=25", "", "deploy"),
"b10-01": buildBackend("v=1=0,v=2=0", "pod0101-01,pod0102-01", "deploy"),
}
testExpectedWeight := map[string][]int{
"b01-01": {1, 1},
Expand All @@ -83,10 +85,12 @@ func TestWeightBalance(t *testing.T) {
"b07-01": {1, 0},
"b07-02": {50, 0},
"b07-03": {1, 0},
"b07-04": {50, 0},
"b07-04": {1, 0},
"b07-05": {50, 0},
"b08-01": {4, 1, 1, 2},
"b08-02": {2, 0, 0, 1},
"b09-01": {},
"b10-01": {0, 0},
}
weightBalance(&testUpstreams, podLister)
for name, upstream := range testUpstreams {
Expand Down

0 comments on commit c26c9cf

Please sign in to comment.