3.2.23. 대규모 클러스터에 대한 ARP 캐시 튜닝
다수의 경로가 있는 OpenShift Container Platform 클러스터에서는 기본적으로 65536
인 net.ipv4.neigh.default.gc_thresh3
값보다 큰 경로가 있는 OpenShift Container Platform 클러스터에서 라우터 Pod를 실행하는 클러스터의 각 노드에서 sysctl 변수의 기본값을 늘려 ARP 캐시에 더 많은 항목을 허용해야 합니다.
문제가 발생하면 커널 메시지가 다음과 유사합니다.
[ 1738.811139] net_ratelimit: 1045 callbacks suppressed [ 1743.823136] net_ratelimit: 293 callbacks suppressed
이 문제가 발생하면 oc
명령이 다음 오류로 인해 실패할 수 있습니다.
Unable to connect to the server: dial tcp: lookup <hostname> on <ip>:<port>: write udp <ip>:<port>-><ip>:<port>: write: invalid argument
IPv4의 실제 ARP 항목을 확인하려면 다음을 실행합니다.
# ip -4 neigh show nud all | wc -l
숫자가 net.ipv4.neigh.default.gc_thresh3
임계값에 접근하기 시작하면 값을 늘립니다. 다음을 실행하여 현재 값을 가져옵니다.
# sysctl net.ipv4.neigh.default.gc_thresh1 net.ipv4.neigh.default.gc_thresh1 = 128 # sysctl net.ipv4.neigh.default.gc_thresh2 net.ipv4.neigh.default.gc_thresh2 = 512 # sysctl net.ipv4.neigh.default.gc_thresh3 net.ipv4.neigh.default.gc_thresh3 = 1024
다음 sysctl은 변수를 OpenShift Container Platform 현재 기본값으로 설정합니다.
# sysctl net.ipv4.neigh.default.gc_thresh1=8192 # sysctl net.ipv4.neigh.default.gc_thresh2=32768 # sysctl net.ipv4.neigh.default.gc_thresh3=65536
이러한 설정을 영구적으로 설정하려면 이 문서를 참조하십시오.