Skip to content

Commit 6421869

Browse files
authored
Merge pull request #20264 from adityaalifn/port-forward-id
ID translation for port-forward-access-application-cluster page
2 parents f4d76b8 + 587ffc6 commit 6421869

File tree

2 files changed

+206
-0
lines changed

2 files changed

+206
-0
lines changed
Lines changed: 5 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,5 @@
1+
---
2+
title: "Mengakes Aplikasi-aplikasi di sebuah Klaster"
3+
weight: 60
4+
---
5+
Lines changed: 201 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,201 @@
1+
---
2+
title: Menggunakan Port Forwarding untuk Mengakses Aplikasi di sebuah Klaster
3+
content_template: templates/task
4+
weight: 40
5+
min-kubernetes-server-version: v1.10
6+
---
7+
8+
{{% capture overview %}}
9+
10+
Halaman ini menunjukkan bagaimana menggunakan `kubectl port-forward` untuk menghubungkan sebuah server Redis yang sedang berjalan di sebuah klaster Kubernetes. Tipe dari koneksi ini dapat berguna untuk melakukan _debugging_ basis data.
11+
12+
{{% /capture %}}
13+
14+
15+
{{% capture prerequisites %}}
16+
17+
{{< include "task-tutorial-prereqs.md" >}} {{< version-check >}}
18+
19+
* Install [redis-cli](http://redis.io/topics/rediscli).
20+
21+
{{% /capture %}}
22+
23+
24+
{{% capture steps %}}
25+
26+
## Membuat Deployment dan Service Redis
27+
28+
1. Buat sebuah Deployment yang menjalankan Redis:
29+
30+
```shell
31+
kubectl apply -f https://k8s.io/examples/application/guestbook/redis-master-deployment.yaml
32+
```
33+
34+
Keluaran dari sebuah perintah yang sukses akan memverifikasi bahwa Deployment telah terbuat:
35+
36+
```
37+
deployment.apps/redis-master created
38+
```
39+
40+
Lihat status Pod untuk memeriksa apakah sudah siap:
41+
42+
```shell
43+
kubectl get pods
44+
```
45+
46+
Keluaran menampilkan Pod yang telah terbuat:
47+
48+
```
49+
NAME READY STATUS RESTARTS AGE
50+
redis-master-765d459796-258hz 1/1 Running 0 50s
51+
```
52+
53+
Lihat status Deployment:
54+
55+
```shell
56+
kubectl get deployment
57+
```
58+
59+
Keluaran menampilkan bahwa Deployment telah terbuat:
60+
61+
```
62+
NAME READY UP-TO-DATE AVAILABLE AGE
63+
redis-master 1/1 1 1 55s
64+
```
65+
66+
Deployment secara otomatis mengatur sebuah ReplicaSet.
67+
Lihat status ReplicaSet menggunakan:
68+
69+
```shell
70+
kubectl get replicaset
71+
```
72+
73+
Keluaran menampilkan bahwa ReplicaSet telah terbuat:
74+
75+
```
76+
NAME DESIRED CURRENT READY AGE
77+
redis-master-765d459796 1 1 1 1m
78+
```
79+
80+
81+
2. Buat sebuah Service untuk mengekspos Redis di jaringan:
82+
83+
```shell
84+
kubectl apply -f https://k8s.io/examples/application/guestbook/redis-master-service.yaml
85+
```
86+
87+
Keluaran dari perintah yang sukses akan memverifikasi bahwa Service telah terbuat:
88+
89+
```
90+
service/redis-master created
91+
```
92+
93+
Lihat Service yang telah terbuat menggunakan:
94+
95+
```shell
96+
kubectl get service redis-master
97+
```
98+
99+
Keluaran menampilkan service yang telah terbuat:
100+
101+
```
102+
NAME TYPE CLUSTER-IP EXTERNAL-IP PORT(S) AGE
103+
redis-master ClusterIP 10.0.0.213 <none> 6379/TCP 27s
104+
```
105+
106+
3. Periksa apakah server Redis berjalan di Pod, dan mendengarkan porta 6379:
107+
108+
```shell
109+
# Ubah redis-master-765d459796-258hz menjadi nama Pod
110+
kubectl get pod redis-master-765d459796-258hz --template='{{(index (index .spec.containers 0).ports 0).containerPort}}{{"\n"}}'
111+
```
112+
113+
Keluaran akan menampilkan porta dari Redis di Pod tersebut:
114+
115+
```
116+
6379
117+
```
118+
119+
(ini adalah porta TCP yang dialokasi untuk Redis di internet)
120+
121+
## Meneruskan sebuah porta lokal ke sebuah porta pada Pod
122+
123+
1. `kubectl port-forward` memungkinkan penggunaan nama sumber daya, seperti sebuah nama Pod, untuk memilih Pod yang sesuai untuk melakukan penerusan porta.
124+
125+
126+
```shell
127+
# Ubah redis-master-765d459796-258hz menjadi nama Pod
128+
kubectl port-forward redis-master-765d459796-258hz 7000:6379
129+
```
130+
131+
yang sama seperti
132+
133+
```shell
134+
kubectl port-forward pods/redis-master-765d459796-258hz 7000:6379
135+
```
136+
137+
atau
138+
139+
```shell
140+
kubectl port-forward deployment/redis-master 7000:6379
141+
```
142+
143+
atau
144+
145+
```shell
146+
kubectl port-forward replicaset/redis-master 7000:6379
147+
```
148+
149+
atau
150+
151+
```shell
152+
kubectl port-forward service/redis-master 7000:6379
153+
```
154+
155+
Semua perintah di atas berfungsi. Keluarannya mirip dengan ini:
156+
157+
```
158+
I0710 14:43:38.274550 3655 portforward.go:225] Forwarding from 127.0.0.1:7000 -> 6379
159+
I0710 14:43:38.274797 3655 portforward.go:225] Forwarding from [::1]:7000 -> 6379
160+
```
161+
162+
2. Memulai antarmuka baris perintah (*command line*) Redis:
163+
164+
```shell
165+
redis-cli -p 7000
166+
```
167+
168+
3. Pada baris perintah di Redis, masukkan perintah `ping`:
169+
170+
```
171+
ping
172+
```
173+
174+
Sebuah permintaan *ping* yang sukses akan mengembalikan:
175+
176+
```
177+
PONG
178+
```
179+
180+
{{% /capture %}}
181+
182+
183+
{{% capture discussion %}}
184+
185+
## Diskusi
186+
187+
Koneksi-koneksi yang dibuat ke porta lokal 7000 diteruskan ke porta 6379 dari Pod yang menjalankan server Redis.
188+
Dengan koneksi ini, kamu dapat menggunakan *workstation* lokal untuk melakukan *debug* basis data yang berjalan di Pod.
189+
190+
{{< note >}}
191+
`kubectl port-forward` hanya bisa diimplementasikan untuk porta TCP saja.
192+
Dukungan untuk protokol UDP bisa dilihat di
193+
[issue 47862](https://github.com/kubernetes/kubernetes/issues/47862).
194+
{{< /note >}}
195+
196+
{{% /capture %}}
197+
198+
199+
{{% capture whatsnext %}}
200+
Belajar lebih tentang [kubectl port-forward](/docs/reference/generated/kubectl/kubectl-commands/#port-forward).
201+
{{% /capture %}}

0 commit comments

Comments
 (0)