adapter.go 3.6 KB

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