praktik paling apik Kubernetes. Pemetaan layanan njaba

praktik paling apik Kubernetes. Nggawe wadhah cilik
praktik paling apik Kubernetes. Organisasi Kubernetes kanthi namespace
praktik paling apik Kubernetes. Validasi Kubernetes Liveness kanthi Tes Kesiapan lan Liveness
praktik paling apik Kubernetes. Nyetel panjalukan lan watesan sumber
praktik paling apik Kubernetes. Mati sing bener Mungkasi

Yen sampeyan kaya umume wong, sampeyan bisa uga nggunakake sumber daya sing ana ing njaba klompok sampeyan. Mbok menawa sampeyan nggunakake API Taleo kanggo ngirim pesen teks, utawa nganalisa gambar nggunakake API Google Cloud Vision.

Yen sampeyan nggunakake titik pungkasan panyuwunan sisih server sing padha ing kabeh lingkungan sampeyan lan ora ngrencanakake migrasi server menyang Kubernetes, mula ora ana titik pungkasan layanan ing kode sampeyan. Nanging, ana akeh skenario liyane kanggo pangembangan acara. Ing seri Kubernetes Best Practices iki, sampeyan bakal sinau carane nggunakake mekanisme internal Kubernetes kanggo nemokake layanan ing njero lan njaba kluster.

Conto layanan eksternal umum yaiku database sing mlaku ing njaba kluster Kubernetes. Ora kaya database maya kaya Google Cloud Data Store utawa Google Cloud Spanner, sing nggunakake titik pungkasan siji kanggo kabeh akses, umume database duwe titik pungkasan sing kapisah kanggo kahanan sing beda-beda.
Praktik paling apik kanggo nggunakake basis data tradisional kayata MySQL lan MongoDB biasane tegese sampeyan nyambungake menyang komponen sing beda kanggo lingkungan sing beda. Sampeyan bisa duwe mesin gedhe kanggo data produksi lan mesin cilik kanggo lingkungan test. Saben wong bakal duwe alamat IP utawa jeneng domain dhewe, nanging sampeyan mbokmenawa ora pengin ngganti kode nalika pindhah saka lingkungan siji menyang lingkungan liyane. Dadi, tinimbang ngode alamat kasebut, sampeyan bisa nggunakake panemuan layanan eksternal basis DNS sing dibangun ing Kubernetes kanthi cara sing padha karo layanan Kubernetes asli.

praktik paling apik Kubernetes. Pemetaan layanan njaba

Contone, sampeyan nggunakake basis data MongoDB ing Google Compute Engine. Sampeyan bakal macet ing jagad hibrida iki nganti sampeyan bisa nransfer menyang kluster.

Untunge, sampeyan bisa nggunakake layanan Kubernetes statis kanggo nggawe urip luwih gampang. Ing conto iki, aku nggawe server MongoDB nggunakake Google Cloud Launcher. Wiwit digawe ing jaringan sing padha (utawa Kubernetes cluster VPC), diakses nggunakake alamat IP internal kinerja dhuwur.

praktik paling apik Kubernetes. Pemetaan layanan njaba

Iki minangka setelan gawan ing Google Cloud, dadi sampeyan ora kudu ngatur apa-apa. Saiki sampeyan duwe alamat IP, langkah pisanan yaiku nggawe layanan. Sampeyan bisa uga sok dong mirsani sing ora ana pamilih pod kanggo layanan iki. Yaiku, kita nggawe layanan sing ora ngerti ngendi ngirim lalu lintas. Iki bakal ngidini sampeyan nggawe obyek endpoint kanthi manual sing bakal nampa lalu lintas saka layanan iki.

praktik paling apik Kubernetes. Pemetaan layanan njaba

Conto kode ing ngisor iki nuduhake yen titik pungkasan nemtokake alamat IP kanggo database nggunakake jeneng mongo sing padha karo layanan kasebut.

praktik paling apik Kubernetes. Pemetaan layanan njaba

Kubernetes bakal nggunakake kabeh alamat IP kanggo nemokake titik pungkasan kaya-kaya Pods Kubernetes biasa, mula saiki sampeyan bisa ngakses database kanthi string sambungan sing prasaja menyang jeneng ing ndhuwur mongodb: // mongo. Ora perlu nggunakake alamat IP ing kode sampeyan.

Yen alamat IP diganti ing mangsa ngarep, sampeyan mung bisa nganyari titik pungkasan nganggo alamat IP anyar lan aplikasi sampeyan ora perlu diowahi kanthi cara tambahan.

Yen sampeyan nggunakake basis data sing di-host ing host pihak katelu, mesthine sing nduweni host wis menehi sampeyan Uniform Resource Identifier URI kanggo nyambungake. Dadi yen sampeyan wis diwenehi alamat IP, sampeyan mung bisa nggunakake cara sadurunge. Conto iki nuduhake yen aku duwe rong database MongoDB sing di-host ing host mLab.

praktik paling apik Kubernetes. Pemetaan layanan njaba

Salah sijine yaiku database pangembang lan liyane yaiku database produksi. Senar sambungan kanggo database iki katon kaya iki - mLab nyedhiyakake URI dinamis lan port dinamis. Nalika sampeyan bisa ndeleng, padha beda.

praktik paling apik Kubernetes. Pemetaan layanan njaba

Kanggo abstrak iki, ayo nggunakake Kubernetes lan nyambung menyang database pangembang. Sampeyan bisa nggawe jeneng layanan Kubernetes eksternal, sing bakal menehi layanan statis sing bakal nerusake lalu lintas menyang layanan eksternal.

praktik paling apik Kubernetes. Pemetaan layanan njaba

Layanan iki bakal nindakake penerusan CNAME sing prasaja ing tingkat kernel kanthi pengaruh kinerja minimal. Thanks kanggo iki sampeyan bisa nggunakake senar sambungan prasaja.

praktik paling apik Kubernetes. Pemetaan layanan njaba

Nanging amarga jeneng eksternal nggunakake CNAME forwarding, ora bisa nindakake port forwarding. Mulane, solusi iki mung ditrapake kanggo port statis lan ora bisa digunakake karo port dinamis. Nanging mLab Free Tier menehi pangguna nomer port dinamis kanthi standar lan sampeyan ora bisa ngganti. Iki tegese sampeyan butuh baris perintah sambungan sing beda kanggo dev lan prod. Sing ala yaiku iki mbutuhake hardcode nomer port kasebut. Dadi, kepiye carane nerusake port supaya bisa digunakake?

Langkah pisanan yaiku njupuk alamat IP saka URI. Yen sampeyan mbukak nslookup, hostname, utawa ping URI, sampeyan bisa entuk alamat IP database. Yen layanan ngasilake sawetara alamat IP kanggo sampeyan, kabeh alamat kasebut bisa digunakake ing titik pungkasan obyek kasebut.

praktik paling apik Kubernetes. Pemetaan layanan njaba

Siji bab sing kudu dielingake yaiku IP URI bisa diganti tanpa kabar, nggawe beboyo kanggo digunakake ing prod. Nggunakake alamat IP iki, sampeyan bisa nyambung menyang database remot tanpa nemtokake port. Dadi, layanan Kubernetes nindakake port forwarding kanthi cukup transparan.

praktik paling apik Kubernetes. Pemetaan layanan njaba

Pemetaan, utawa pemetaan sumber daya njaba kanggo internal, menehi sampeyan keluwesan kanggo nggunakake layanan iki ing kluster ing mangsa nalika minimalake refactoring efforts . Iku uga nggawe luwih gampang kanggo ngatur lan menehi wawasan babagan layanan eksternal sing digunakake perusahaan sampeyan.

Diterusake kanthi cepet ...

Sawetara iklan πŸ™‚

Matur nuwun kanggo tetep karo kita. Apa sampeyan seneng karo artikel kita? Pengin ndeleng konten sing luwih menarik? Ndhukung kita kanthi nggawe pesenan utawa menehi rekomendasi menyang kanca, cloud VPS kanggo pangembang saka $4.99, analog unik saka server level entri, sing diciptakake kanggo sampeyan: Bebener kabeh babagan VPS (KVM) E5-2697 v3 (6 Cores) 10GB DDR4 480GB SSD 1Gbps saka $ 19 utawa carane nuduhake server? (kasedhiya karo RAID1 lan RAID10, munggah 24 intine lan nganti 40GB DDR4).

Dell R730xd 2 kaping luwih murah ing pusat data Equinix Tier IV ing Amsterdam? Mung kene 2 x Intel TetraDeca-Core Xeon 2x E5-2697v3 2.6GHz 14C 64GB DDR4 4x960GB SSD 1Gbps 100 TV saka $199 ing Walanda! Dell R420 - 2x E5-2430 2.2Ghz 6C 128GB DDR3 2x960GB SSD 1Gbps 100TB - saka $99! Maca babagan Carane mbangun infrastruktur corp. kelas karo nggunakake Dell R730xd E5-2650 v4 server worth 9000 euro kanggo Penny?

Source: www.habr.com

Add a comment