OpenShift - Cluster
OpenShift menggunakan dua metode penginstalan untuk menyiapkan cluster OpenShift.
- Metode instalasi cepat
- Metode konfigurasi lanjutan
Menyiapkan Cluster
Metode Instalasi Cepat
Metode ini digunakan untuk menjalankan konfigurasi pengaturan cluster yang tidak terjangkau secara cepat. Untuk menggunakan metode ini, kita perlu menginstal penginstal terlebih dahulu. Ini dapat dilakukan dengan menjalankan perintah berikut.
Interactive method
$ atomic-openshift-installer install
Ini berguna ketika seseorang ingin menjalankan pengaturan interaktif.
Unattended installation method
Metode ini digunakan ketika seseorang ingin mengatur cara instalasi tanpa pengawasan, di mana pengguna dapat menentukan file konfigurasi yaml dan meletakkannya di bawah ~/.config/openshift/dengan nama installer.cfg.yml. Kemudian, perintah berikut dapat dijalankan untuk menginstal file–u tag.
$ atomic-openshift-installer –u install
Secara default menggunakan file konfigurasi yang terletak di bawah ~/.config/openshift/. Dimungkinkan di sisi lain digunakan sebagai cadangan instalasi.
version: v2
variant: openshift-enterprise
variant_version: 3.1
ansible_log_path: /tmp/ansible.log
deployment:
ansible_ssh_user: root
hosts:
- ip: 172.10.10.1
hostname: vklnld908.int.example.com
public_ip: 24.222.0.1
public_hostname: master.example.com
roles:
- master
- node
containerized: true
connect_to: 24.222.0.1
- ip: 172.10.10.2
hostname: vklnld1446.int.example.com
public_ip: 24.222.0.2
public_hostname: node1.example.com
roles:
- node
connect_to: 10.0.0.2
- ip: 172.10.10.3
hostname: vklnld1447.int.example.com
public_ip: 10..22.2.3
public_hostname: node2.example.com
roles:
- node
connect_to: 10.0.0.3
roles:
master:
<variable_name1>: "<value1>"
<variable_name2>: "<value2>"
node:
<variable_name1>: "<value1>"
Di sini, kami memiliki variabel khusus peran, yang dapat ditentukan jika seseorang ingin menyiapkan beberapa variabel tertentu.
Setelah selesai, kami dapat memverifikasi penginstalan menggunakan perintah berikut.
$ oc get nodes
NAME STATUS AGE
master.example.com Ready 10d
node1.example.com Ready 10d
node2.example.com Ready 10d
Instalasi Lanjutan
Instalasi lanjutan sepenuhnya didasarkan pada konfigurasi yang memungkinkan di mana konfigurasi host lengkap dan definisi variabel mengenai konfigurasi master dan node ada. Ini berisi semua detail tentang konfigurasi.
Setelah kita menyiapkan dan playbook siap, kita cukup menjalankan perintah berikut untuk mengatur cluster.
$ ansible-playbook -i inventry/hosts ~/openshift-ansible/playbooks/byo/config.yml
Menambahkan Host ke Cluster
Kita dapat menambahkan host ke cluster menggunakan -
- Alat penginstal cepat
- Metode konfigurasi lanjutan
Quick installation toolbekerja dalam mode interaktif dan non-interaktif. Gunakan perintah berikut.
$ atomic-openshift-installer -u -c </path/to/file> scaleup
Format penskalaan file konfigurasi aplikasi terlihat dapat digunakan untuk menambahkan master maupun node.
Metode Konfigurasi Lanjutan
Dalam metode ini, kami memperbarui file host dari Ansible dan kemudian menambahkan node baru atau detail server di file ini. File konfigurasi terlihat seperti berikut.
[OSEv3:children]
masters
nodes
new_nodes
new_master
Di file Host yang sama, tambahkan detail variabel terkait node baru seperti yang ditunjukkan di bawah ini.
[new_nodes]
vklnld1448.int.example.com openshift_node_labels = "{'region': 'primary', 'zone': 'east'}"
Terakhir, dengan menggunakan file host yang diperbarui, jalankan konfigurasi baru dan aktifkan file konfigurasi untuk menyelesaikan penyiapan menggunakan perintah berikut.
$ ansible-playbook -i /inventory/hosts /usr/share/ansible/openshift-ansible/playbooks/test/openshift-node/scaleup.yml
Mengelola Log Cluster
OpenShift cluster log tidak lain adalah log yang dihasilkan dari master dan mesin node cluster. Ini dapat mengelola segala jenis log, mulai dari log server, log master, log container, log pod, dll. Ada beberapa teknologi dan aplikasi yang ada untuk pengelolaan log container.
Beberapa alat seperti yang terdaftar, yang dapat diimplementasikan untuk manajemen log.
- Fluentd
- ELK
- Kabna
- Nagios
- Splunk
ELK stack- Tumpukan ini berguna saat mencoba mengumpulkan log dari semua node dan menyajikannya dalam format yang sistematis. Tumpukan ELK terutama dibagi dalam tiga kategori utama.
ElasticSearch - Terutama bertanggung jawab untuk mengumpulkan informasi dari semua wadah dan meletakkannya di lokasi pusat.
Fluentd - Digunakan untuk memberi makan log yang dikumpulkan ke mesin kontainer elasticsearch.
Kibana - Antarmuka grafis yang digunakan untuk menyajikan data yang dikumpulkan sebagai informasi yang berguna dalam antarmuka grafis.
Satu hal penting yang perlu diperhatikan adalah, saat sistem ini diterapkan di kluster, ia mulai mengumpulkan log dari semua node.
Log Diagnostik
OpenShift memiliki inbuilt oc adm dignosticsperintah dengan OC yang dapat digunakan untuk menganalisis beberapa situasi kesalahan. Alat ini dapat digunakan dari master sebagai administrator cluster. Utilitas ini sangat membantu dalam memecahkan masalah dan menggali masalah yang diketahui. Ini berjalan pada klien master dan node.
Jika dijalankan tanpa agruments atau flags, ia akan mencari file konfigurasi dari klien, server, dan mesin node, dan menggunakannya untuk diagnostik. Seseorang dapat menjalankan diagnostik satu per satu dengan melewatkan argumen berikut -
- AggregatedLogging
- AnalyzeLogs
- ClusterRegistry
- ClusterRoleBindings
- ClusterRoles
- ClusterRouter
- ConfigContexts
- DiagnosticPod
- MasterConfigCheck
- MasterNode
- MetricsApiProxy
- NetworkCheck
- NodeConfigCheck
- NodeDefinitions
- ServiceExternalIPs
- UnitStatus
Seseorang dapat menjalankannya dengan perintah berikut.
$ oc adm diagnostics <DiagnosticName>
Mengupgrade Cluster
Upgrade cluster melibatkan peningkatan beberapa hal di dalam cluster dan memperbarui cluster dengan komponen dan upgrade baru. Ini melibatkan -
- Peningkatan komponen master
- Peningkatan komponen node
- Peningkatan kebijakan
- Peningkatan rute
- Peningkatan aliran gambar
Untuk melakukan semua pemutakhiran ini, pertama-tama kita perlu memasang penginstal atau utilitas cepat. Untuk itu kita perlu memperbarui utilitas berikut -
- atomic-openshift-utils
- atomic-openshift-excluder
- atomic-openshift-docker-excluder
- paket etcd
Sebelum memulai peningkatan, kita perlu membuat cadangan etcd di mesin master, yang dapat dilakukan dengan menggunakan perintah berikut.
$ ETCD_DATA_DIR = /var/lib/origin/openshift.local.etcd
$ etcdctl backup \
--data-dir $ETCD_DATA_DIR \
--backup-dir $ETCD_DATA_DIR.bak.<date>
Peningkatan Komponen Induk
Di master OpenShift, kami memulai peningkatan dengan memperbarui file etcd dan kemudian pindah ke Docker. Terakhir, kami menjalankan eksekutor otomatis untuk menempatkan kluster ke posisi yang diperlukan. Namun, sebelum memulai peningkatan, kami harus mengaktifkan paket atomic openshift terlebih dahulu di masing-masing master. Ini dapat dilakukan dengan menggunakan perintah berikut.
Step 1 - Hapus paket atomic-openshift
$ atomic-openshift-excluder unexclude
Step 2 - Tingkatkan dlld di semua master.
$ yum update etcd
Step 3 - Restart layanan etcd dan periksa apakah sudah berhasil dimulai.
$ systemctl restart etcd
$ journalctl -r -u etcd
Step 4 - Tingkatkan paket Docker.
$ yum update docker
Step 5 - Mulai ulang layanan Docker dan periksa apakah sudah benar.
$ systemctl restart docker
$ journalctl -r -u docker
Step 6 - Setelah selesai, reboot sistem dengan perintah berikut.
$ systemctl reboot
$ journalctl -r -u docker
Step 7 - Terakhir, jalankan atomic-executer untuk mengembalikan paket ke daftar pengecualian yum.
$ atomic-openshift-excluder exclude
Tidak ada paksaan untuk memutakhirkan kebijakan, itu hanya perlu ditingkatkan jika disarankan, yang dapat diperiksa dengan perintah berikut.
$ oadm policy reconcile-cluster-roles
Dalam kebanyakan kasus, kami tidak perlu memperbarui definisi kebijakan.
Peningkatan Komponen Node
Setelah pembaruan master selesai, kita dapat mulai meningkatkan node. Satu hal yang perlu diingat adalah, periode pemutakhiran harus singkat untuk menghindari masalah apa pun di kluster.
Step 1 - Hapus semua paket OpenShift atom dari semua node tempat Anda ingin melakukan peningkatan.
$ atomic-openshift-excluder unexclude
Step 2 - Selanjutnya, nonaktifkan penjadwalan node sebelum peningkatan.
$ oadm manage-node <node name> --schedulable = false
Step 3 - Gandakan semua node dari host saat ini ke host lain.
$ oadm drain <node name> --force --delete-local-data --ignore-daemonsets
Step 4 - Tingkatkan pengaturan Docker pada host.
$ yum update docker
Step 5 - Mulai ulang layanan Docker dan kemudian mulai simpul layanan Docker.
$systemctl restart docker
$ systemctl restart atomic-openshift-node
Step 6 - Periksa apakah keduanya dimulai dengan benar.
$ journalctl -r -u atomic-openshift-node
Step 7 - Setelah upgrade selesai, reboot mesin node.
$ systemctl reboot
$ journalctl -r -u docker
Step 8 - Aktifkan kembali penjadwalan pada node.
$ oadm manage-node <node> --schedulable.
Step 9 - Jalankan execututer atomic-openshift untuk mendapatkan kembali paket OpenShift pada node.
$ atomic-openshift-excluder exclude
Step 10 - Terakhir, periksa apakah semua node tersedia.
$ oc get nodes
NAME STATUS AGE
master.example.com Ready 12d
node1.example.com Ready 12d
node2.example.com Ready 12d