adapter.go 3.5 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126
  1. /*
  2. Copyright 2017 The Kubernetes Authors.
  3. Licensed under the Apache License, Version 2.0 (the "License");
  4. you may not use this file except in compliance with the License.
  5. You may obtain a copy of the License at
  6. http://www.apache.org/licenses/LICENSE-2.0
  7. Unless required by applicable law or agreed to in writing, software
  8. distributed under the License is distributed on an "AS IS" BASIS,
  9. WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  10. See the License for the specific language governing permissions and
  11. limitations under the License.
  12. */
  13. package ipam
  14. import (
  15. "context"
  16. "encoding/json"
  17. "net"
  18. "k8s.io/klog"
  19. "k8s.io/api/core/v1"
  20. metav1 "k8s.io/apimachinery/pkg/apis/meta/v1"
  21. "k8s.io/apimachinery/pkg/types"
  22. clientset "k8s.io/client-go/kubernetes"
  23. v1core "k8s.io/client-go/kubernetes/typed/core/v1"
  24. "k8s.io/client-go/tools/record"
  25. nodeutil "k8s.io/kubernetes/pkg/util/node"
  26. "k8s.io/legacy-cloud-providers/gce"
  27. "k8s.io/metrics/pkg/client/clientset/versioned/scheme"
  28. )
  29. type adapter struct {
  30. k8s clientset.Interface
  31. cloud *gce.Cloud
  32. recorder record.EventRecorder
  33. }
  34. func newAdapter(k8s clientset.Interface, cloud *gce.Cloud) *adapter {
  35. ret := &adapter{
  36. k8s: k8s,
  37. cloud: cloud,
  38. }
  39. broadcaster := record.NewBroadcaster()
  40. broadcaster.StartLogging(klog.Infof)
  41. ret.recorder = broadcaster.NewRecorder(scheme.Scheme, v1.EventSource{Component: "cloudCIDRAllocator"})
  42. klog.V(0).Infof("Sending events to api server.")
  43. broadcaster.StartRecordingToSink(&v1core.EventSinkImpl{
  44. Interface: k8s.CoreV1().Events(""),
  45. })
  46. return ret
  47. }
  48. func (a *adapter) Alias(ctx context.Context, nodeName string) (*net.IPNet, error) {
  49. cidrs, err := a.cloud.AliasRanges(types.NodeName(nodeName))
  50. if err != nil {
  51. return nil, err
  52. }
  53. switch len(cidrs) {
  54. case 0:
  55. return nil, nil
  56. case 1:
  57. break
  58. default:
  59. klog.Warningf("Node %q has more than one alias assigned (%v), defaulting to the first", nodeName, cidrs)
  60. }
  61. _, cidrRange, err := net.ParseCIDR(cidrs[0])
  62. if err != nil {
  63. return nil, err
  64. }
  65. return cidrRange, nil
  66. }
  67. func (a *adapter) AddAlias(ctx context.Context, nodeName string, cidrRange *net.IPNet) error {
  68. return a.cloud.AddAliasToInstance(types.NodeName(nodeName), cidrRange)
  69. }
  70. func (a *adapter) Node(ctx context.Context, name string) (*v1.Node, error) {
  71. return a.k8s.CoreV1().Nodes().Get(name, metav1.GetOptions{})
  72. }
  73. func (a *adapter) UpdateNodePodCIDR(ctx context.Context, node *v1.Node, cidrRange *net.IPNet) error {
  74. patch := map[string]interface{}{
  75. "apiVersion": node.APIVersion,
  76. "kind": node.Kind,
  77. "metadata": map[string]interface{}{"name": node.Name},
  78. "spec": map[string]interface{}{"podCIDR": cidrRange.String()},
  79. }
  80. bytes, err := json.Marshal(patch)
  81. if err != nil {
  82. return err
  83. }
  84. _, err = a.k8s.CoreV1().Nodes().Patch(node.Name, types.StrategicMergePatchType, bytes)
  85. return err
  86. }
  87. func (a *adapter) UpdateNodeNetworkUnavailable(nodeName string, unavailable bool) error {
  88. condition := v1.ConditionFalse
  89. if unavailable {
  90. condition = v1.ConditionTrue
  91. }
  92. return nodeutil.SetNodeCondition(a.k8s, types.NodeName(nodeName), v1.NodeCondition{
  93. Type: v1.NodeNetworkUnavailable,
  94. Status: condition,
  95. Reason: "RouteCreated",
  96. Message: "NodeController created an implicit route",
  97. LastTransitionTime: metav1.Now(),
  98. })
  99. }
  100. func (a *adapter) EmitNodeWarningEvent(nodeName, reason, fmt string, args ...interface{}) {
  101. ref := &v1.ObjectReference{Kind: "Node", Name: nodeName}
  102. a.recorder.Eventf(ref, v1.EventTypeNormal, reason, fmt, args...)
  103. }