datanodes-netpol.yaml 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. # Copyright 2020 Crown Copyright
  2. #
  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. #
  7. # http://www.apache.org/licenses/LICENSE-2.0
  8. #
  9. # Unless required by applicable law or agreed to in writing, software
  10. # distributed under the License is distributed on an "AS IS" BASIS,
  11. # WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
  12. # See the License for the specific language governing permissions and
  13. # limitations under the License.
  14. {{- if .Values.networkPolicy.enabled }}
  15. apiVersion: networking.k8s.io/v1
  16. kind: NetworkPolicy
  17. metadata:
  18. name: {{ template "hdfs.fullname" . }}-datanodes
  19. labels:
  20. {{ include "hdfs.labels" . | nindent 4 }}
  21. app.kubernetes.io/component: datanode
  22. spec:
  23. podSelector:
  24. matchLabels:
  25. {{- include "hdfs.selectorLabels" . | nindent 6 }}
  26. app.kubernetes.io/component: datanode
  27. policyTypes:
  28. - Ingress
  29. ingress:
  30. # Allow clients to access client RPC and HTTP servers
  31. - ports:
  32. - port: http
  33. - port: https
  34. - port: data-xfer
  35. # Allow NameNode and DataNodes to access IPC Server
  36. - from:
  37. - podSelector:
  38. matchLabels:
  39. {{- include "hdfs.selectorLabels" . | nindent 10 }}
  40. ports:
  41. - port: ipc
  42. {{- end }}