Merge pull request #21406 from deryrahman/tasks/access-application-cluster/create-external-load-balancer
ID translation for create external load balancerpull/21995/head
commit
e88b6ce811
|
@ -0,0 +1,196 @@
|
||||||
|
---
|
||||||
|
title: Membuat Load Balancer Eksternal
|
||||||
|
content_template: templates/task
|
||||||
|
weight: 80
|
||||||
|
---
|
||||||
|
|
||||||
|
|
||||||
|
{{% capture overview %}}
|
||||||
|
|
||||||
|
Laman ini menjelaskan bagaimana membuat _Load Balancer_ Eksternal.
|
||||||
|
|
||||||
|
{{< note >}}
|
||||||
|
Fitur ini hanya tersedia untuk penyedia cloud atau lingkungan yang mendukung _load balancer_ eksternal.
|
||||||
|
{{< /note >}}
|
||||||
|
|
||||||
|
Ketika membuat Service, kamu mempunyai opsi untuk tersambung dengan jaringan cloud _load balancer_ secara otomatis.
|
||||||
|
Hal ini menyediakan akses eksternal alamat IP yang dapat mengirim lalu lintas melalui porta yang tepat pada klaster Node kamu
|
||||||
|
_asalkan klaster kamu beroperasi pada lingkungan yang mendukung dan terkonfigurasi dengan paket penyedia cloud load balancer yang benar_.
|
||||||
|
|
||||||
|
Untuk informasi mengenai penyediaan dan penggunaan sumber daya Ingress yang dapat memberikan
|
||||||
|
servis URL yang dapat dijangkau secara eksternal, penyeimbang beban lalu lintas, terminasi SSL, dll.,
|
||||||
|
silahkan cek dokumentasi [Ingress](/docs/concepts/services-networking/ingress/)
|
||||||
|
|
||||||
|
{{% /capture %}}
|
||||||
|
|
||||||
|
{{% capture prerequisites %}}
|
||||||
|
|
||||||
|
* {{< include "task-tutorial-prereqs.md" >}} {{< version-check >}}
|
||||||
|
|
||||||
|
{{% /capture %}}
|
||||||
|
|
||||||
|
{{% capture steps %}}
|
||||||
|
|
||||||
|
## Berkas konfigurasi
|
||||||
|
|
||||||
|
Untuk membuat _load balancer_ eksternal, tambahkan baris di bawah ini ke
|
||||||
|
[berkas konfigurasi Service](/docs/concepts/services-networking/service/#loadbalancer) kamu:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
type: LoadBalancer
|
||||||
|
```
|
||||||
|
|
||||||
|
Berkas konfigurasi kamu mungkin terlihat seperti ini:
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: example-service
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: example
|
||||||
|
ports:
|
||||||
|
- port: 8765
|
||||||
|
targetPort: 9376
|
||||||
|
type: LoadBalancer
|
||||||
|
```
|
||||||
|
|
||||||
|
## Menggunakan kubectl
|
||||||
|
|
||||||
|
Kamu dapat membuat Service dengan perintah `kubectl expose` dan
|
||||||
|
_flag_ `--type=LoadBalancer`:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
kubectl expose rc example --port=8765 --target-port=9376 \
|
||||||
|
--name=example-service --type=LoadBalancer
|
||||||
|
```
|
||||||
|
|
||||||
|
Perintah ini membuat Service baru dengan menggunakan pemilih yang sama dengan
|
||||||
|
sumber daya yang dirujuk (dalam hal contoh di atas, ReplicationController bernama `example`).
|
||||||
|
|
||||||
|
Untuk informasi lebih lanjut, termasuk opsi _flag_, mengacu kepada
|
||||||
|
[referensi `kubectl expose`](/docs/reference/generated/kubectl/kubectl-commands/#expose).
|
||||||
|
|
||||||
|
## Menemukan alamat IP kamu
|
||||||
|
|
||||||
|
Kamu dapat menemukan alamat IP yang telah dibuat untuk Service kamu dengan mendapatkan
|
||||||
|
informasi Service melalui `kubectl`:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
kubectl describe services example-service
|
||||||
|
```
|
||||||
|
|
||||||
|
yang seharusnya menghasilkan keluaran seperti ini:
|
||||||
|
|
||||||
|
```bash
|
||||||
|
Name: example-service
|
||||||
|
Namespace: default
|
||||||
|
Labels: <none>
|
||||||
|
Annotations: <none>
|
||||||
|
Selector: app=example
|
||||||
|
Type: LoadBalancer
|
||||||
|
IP: 10.67.252.103
|
||||||
|
LoadBalancer Ingress: 192.0.2.89
|
||||||
|
Port: <unnamed> 80/TCP
|
||||||
|
NodePort: <unnamed> 32445/TCP
|
||||||
|
Endpoints: 10.64.0.4:80,10.64.1.5:80,10.64.2.4:80
|
||||||
|
Session Affinity: None
|
||||||
|
Events: <none>
|
||||||
|
```
|
||||||
|
|
||||||
|
Alamat IP tercantum di sebelah `LoadBalancer Ingress`.
|
||||||
|
|
||||||
|
{{< note >}}
|
||||||
|
Jika kamu menjalankan Service dari Minikube, kamu dapat menemukan alamat IP dan porta yang ditetapkan dengan:
|
||||||
|
{{< /note >}}
|
||||||
|
|
||||||
|
```bash
|
||||||
|
minikube service example-service --url
|
||||||
|
```
|
||||||
|
|
||||||
|
## Preservasi IP sumber klien
|
||||||
|
|
||||||
|
Implementasi dari fitur ini menyebabkan sumber IP yang terlihat pada Container
|
||||||
|
target *bukan sebagai sumber IP asli* dari klien. Untuk mengaktifkan
|
||||||
|
preservasi IP klien, bidang berikut dapat dikonfigurasikan di dalam
|
||||||
|
spek Service (mendukung lingkungan GCE/Google Kubernetes Engine):
|
||||||
|
|
||||||
|
* `service.spec.externalTrafficPolicy` - menunjukkan jika Service menginginkan rute lalu lintas
|
||||||
|
eksternal ke titik akhir _node-local_ atau _cluster-wide_. Terdapat dua opsi yang tersedia:
|
||||||
|
`Cluster` (bawaan) dan `Local`. `Cluster` mengaburkan sumber IP klien dan mungkin menyebabkan
|
||||||
|
hop kedua ke Node berbeda, namun harus mempunyai penyebaran beban (_load-spreading_) yang baik secara keseluruhan.
|
||||||
|
`Local` mempreservasi sumber IP client dan menghindari hop kedua `LoadBalancer` dan Service dengan tipe `NodePort`, namun
|
||||||
|
resiko berpotensi penyebaran lalu lintas yang tidak merata.
|
||||||
|
* `service.spec.healthCheckNodePort` - menentukan pemeriksaan kesehatan porta dari sebuah Node (angka porta numerik) untuk Service.
|
||||||
|
Jika `healthCheckNodePort` tidak ditentukan, pengendali Service mengalokasi
|
||||||
|
porta dari rentang `NodePort` dari klaster kamu. Kamu dapat mengonfigurasi
|
||||||
|
rentangan tersebut dari pengaturan opsi barisan perintah API server,
|
||||||
|
`--service-node-port-range`. Hal itu menggunakan nilai `healthCheckNodePort` pengguna spesifik
|
||||||
|
jika ditentukan oleh klien. Hal itu dapat berefek hanya ketika `type` diset ke `LoadBalancer` dan
|
||||||
|
`externalTrafficPolicy` diset ke `Local`.
|
||||||
|
|
||||||
|
Pengaturan `externalTrafficPolicy` ke `Local` pada berkas konfigurasi Service mengaktifkan
|
||||||
|
fitur ini.
|
||||||
|
|
||||||
|
```yaml
|
||||||
|
apiVersion: v1
|
||||||
|
kind: Service
|
||||||
|
metadata:
|
||||||
|
name: example-service
|
||||||
|
spec:
|
||||||
|
selector:
|
||||||
|
app: example
|
||||||
|
ports:
|
||||||
|
- port: 8765
|
||||||
|
targetPort: 9376
|
||||||
|
externalTrafficPolicy: Local
|
||||||
|
type: LoadBalancer
|
||||||
|
```
|
||||||
|
|
||||||
|
## Pengumpul Sampah (Garbage Collector) Load Balancer
|
||||||
|
|
||||||
|
{{< feature-state for_k8s_version="v1.17" state="stable" >}}
|
||||||
|
|
||||||
|
Pada kasus biasa, sumber daya _load balancer_ yang berkorelasi pada penyedia cloud perlu
|
||||||
|
dibersihkan segera setelah Service bertipe _LoadBalancer_ dihapus. Namun perlu diketahui
|
||||||
|
bahwa terdapat kasus tepi dimana sumber daya cloud yatim piatu (_orphaned_) setelah
|
||||||
|
Service yang berkaitan dihapus. _Finalizer Protection_ untuk Service _LoadBalancer_
|
||||||
|
diperkenalkan untuk mencegah hal ini terjadi. Dengan menggunakan _finalizers_, sebuah sumber daya Service
|
||||||
|
tidak akan pernah dihapus hingga sumber daya _load balancer_ yang berkorelasi juga dihapus.
|
||||||
|
|
||||||
|
Secara khusus, jika Service mempunyai `type LoadBalancer`, pengendali Service akan melekatkan
|
||||||
|
_finalizer_ bernama `service.kubernetes.io/load-balancer-cleanup`.
|
||||||
|
_Finalizer_ hanya akan dihapus setelah sumber daya _load balancer_ dibersihkan.
|
||||||
|
Hal ini mencegah sumber daya _load balancer_ yang teruntai bahkan setelah kasus tepi seperti
|
||||||
|
pengendali Service berhenti.
|
||||||
|
|
||||||
|
## Penyedia Load Balancer Eksternal
|
||||||
|
|
||||||
|
Penting untuk dicatat bahwa jalur data untuk fungsionalitas ini disediakan oleh _load balancer_ eksternal ke klaster Kubernetes.
|
||||||
|
|
||||||
|
Ketika Service `type` diset `LoadBalancer`, Kubernetes menyediakan fungsionalitas yang ekuivalen dengan `type` sebanding `ClusterIP`
|
||||||
|
ke berbagai Pod di dalam klaster dan mengekstensinya dengan pemrograman (eksternal dari Kubernetes) _load balancer_ dengan entri pada Pod
|
||||||
|
Kubernetes. Pengendali Service Kubernetes mengotomasi pembuatan _load balancer_ eksternal, cek kesehatan (jika dibutuhkan),
|
||||||
|
dinding api (_firewall_) (jika dibutuhkan), dan mengambil IP eksternal yang dialokasikan oleh penyedia cloud dan mengisinya pada objek Service.
|
||||||
|
|
||||||
|
## Peringatan dan and Limitasi ketika preservasi sumber IP
|
||||||
|
|
||||||
|
_Load balancers_ GCE/AWS tidak menyediakan bobot pada kolam targetnya (target pools). Hal ini bukan merupakan isu dengan aturan kube-proxy
|
||||||
|
_Load balancer_ lama yang akan menyeimbangkan semua titik akhir dengan benar.
|
||||||
|
|
||||||
|
Dengan fungsionalitas yang baru, lalu lintas eksternal tidak menyeimbangkan beban secara merata pada seluruh Pod, namun
|
||||||
|
sebaliknya menyeimbangkan secara merata pada level Node (karena GCE/AWS dan implementasi _load balancer_ eksternal lainnya tidak mempunyai
|
||||||
|
kemampuan untuk menentukan bobot setiap Node, mereka menyeimbangkan secara merata pada semua Node target, mengabaikan jumlah
|
||||||
|
Pod pada tiap Node).
|
||||||
|
|
||||||
|
|
||||||
|
Namun demikian, kita dapat menyatakan bahwa NumServicePods << NumNodes atau NumServicePods >> NumNodes, distribusi yang cukup mendekati
|
||||||
|
sama akan terlihat, meski tanpa bobot.
|
||||||
|
|
||||||
|
Sekali _load balancer_ eksternal menyediakan bobot, fungsionalitas ini dapat ditambahkan pada jalur pemrograman _load balancer_.
|
||||||
|
*Pekerjaan Masa Depan: Tidak adanya dukungan untuk bobot yang disediakan untuk rilis 1.4, namun dapat ditambahkan di masa mendatang*
|
||||||
|
|
||||||
|
Pod internal ke lalu lintas Pod harus berperilaku sama seperti Service ClusterIP, dengan probabilitas yang sama pada seluruh Pod.
|
||||||
|
|
||||||
|
{{% /capture %}}
|
Loading…
Reference in New Issue