Langkau ke kandungan utama

Kompil Kernel Linux-3.2.2 dalam Slackware 13.37

Bismillahirrahmanirrahim.

  Segala puji-pujian hanyalah padaMu Ya Rahman Ya Rahim. Sesungguhnya segala kebaikan daripadaMu, segala keindahan daripadaMu, segala ketenangan, kesenangan, rezeki, ilmu, usaha, daya dan apa sahaja yang ada padaku ini adalah daripada Mu Ya Allah.
 Ampunilah dosa dan ketelanjuranku, sesungguhnya tiada Tuhan melainkanMu Ya Allah, segala puji hanyalah padaMu dan sesungguhnya aku adalah orang-orang yang zalim.

Assalamualaikum WBT

Jika diimbas kembali, bagaimana caranya daripada tujuan membina kelompok pelayan, timbul pula isu kompil kernel.


Imbas sejenak   


Mulanya instal corosync, setelah belajar sikit demi sedikit pasal corosync, timbul keperluan untuk instal drbd ( keseragaman data segerak ). Kemudian untuk menjadikan DRBD satu yang ampuh, perlu pula install OCFS2.

Dari situ, DRBD dapat berfungsi dengan baik dan percubaan untuk keseragaman data memang berjaya. Alhamdulillah. DRBD berfungsi dengan baik menggunakan OCFS2 sebagai sistem fail.

Setelah itu, timbul pula masalah ( tidak cukup ilmu sebenarnya ) dalam corosync & pacemaker, yang mana, pakej inilah yang akan memantau perkhidmatan yang dilarikan dalam kelompok pelayan ini.

Namun, setelah memastikan yang setiap fail pustaka (library) telah sempurna diinstal, masih ada lagi masalah dengan pemantauan ocfs2. Bila diamati fail di script ( /usr/lib/ocf/resource.d/ocfs2/o2cb) terdapat arahan yang menggunakan modprobe -s ocfs2_stackglue.

Bila dilarikan secara manual di konsol, sistem mengeluarkan error "Invalid module format". Ini menjelaskan kepada kita bahawa, module itu tidak serasi dengan kernel yang sedang dilarikan oleh sistem.

Maka pakcik google pun kenalkanla kepada beberapa forum yang aktif membincangkan pasal ini. Dan kebanyakkan penyelesaian mereka ialah dengan melakukan kompil semula kernel yang bertujuan untuk kompil modul ocfs2 bagi membolehkan kita melakukan modprobe ocfs2. Dan dengan itu, skrip o2cb boleh dilarikan dengan baik.

Sebab itulah tutorial [ Membina Komputer Pelayan Capaian Tinggi ] ini menjurus ke arah ini, kompil kernel..



Tutorial Kompil Semula Kernel linux-3.2.2 ke dalam slackware 13.37


-tukar ke direktori 
#:cd /usr/src

-download kernel ke direktori
#:wget http://www.kernel.org/pub/linux/kernel/v3.0/linux-3.2.2.tar.bz2

-bukak pakej 
#:tar jxvf linux-3.2.2.tar.bz2

-buang link linux dari direktori
#:rm linux

-bina link linux ~> linux-3.2.2
#:ln -s /usr/src/linux-3.2.2 /usr/src/linux

-pindah ke folder linux-3.2.2
#:cd /usr/src/linux-3.2.2/


-salin fail config
#:zcat /proc/config.gz > .config

-bina make oldnoconfig
#:make oldnoconfig

-bina make menuconfig
#:make menuconfig

 
   Di sini, satu tetingkap menu config akan kelihatan.

   Untuk keselamatan, adalah lebih baik kita sediakan 2 kernel semasa boot nanti. Dan jika sudah berjaya, bolehlah kita buang tetapan untuk kernel lama. Oleh itu, jika anda rasa nak namakan dengan nama pilihan sendiri bolehlah ke


General setup  ---> (tekan enter)
() Local Version (tekan enter )
Masukkan nama pilihan anda. Contoh : serverCluster1


 Pilih Exit untuk ke menu utama. Di sini, kita perlu pilih modul OCFS2 diinstal sebagai modul ( dengan simbol M) dan bukannya built-in ( tetapan lalai )


pilih File systems --->
Tekan bawah hingga ke OCFS2 file system support
Tekan huruf 'm' di papan kekunci
pilih exit
pilih exit sekali lagi.


Setup akan mengeluarkan dialog untuk kita simpan atau tidak tetapan yang baru sahaja kita lakukan.


---> Pilih yes.

Setelah tetingkap dialog tertutup, maka tetapan untuk kernel sudahpun siap. Sekarang kita akan bina modul dan kemudian lakukan instalasi kernel


#:make all
#:make modules_install
#:make install


Biasanya masa yang diambil untuk kompil setiap modul agak lama. Jom la kita minum kejap. Takpe, lambat lagi ni dalam 20-30 minit.


Alhamdulillah...

Bila dah siap, langkah seterusnya adalah untuk 'memberitahu' sistem kita supaya menggunakan kernel baru apabila reboot nanti.

Yang ni agak keliru sikit2 bagi aku.


- salin fail kernel baru ke /boot
#:cp arch/x86/boot/bzImage /boot/vmlinuz-custom-3.2.2

- salin System.map ke boot
#:cp System.map /boot/System.map-custom-3.2.2          

- salin fail tetapan
#:cp .config /boot/config-custom-3.2.2                

- buang link lama dalam /boot
#:cd /boot
#:rm System.map                                          

- bina link baru
#:ln -s System.map-custom-3.3.2 System.map              


Alhamdulillah...

Kita telahpun berjaya kompil kernel baru, letak di tempat yang sesuai untuk system boot. Dan yang terakhir, kita perlu tetapan untuk linux loader (lilo) atau dalam bahaha melayu gemilangnya pemuat linux.


#:nano /etc/lilo.conf

Baiklah, pada tahap ini, kita perlu putuskan samaada sistem ini perlu untuk terus load ke kernel baru atau tidak. Dalam tutorial ini aku letakkan dulu tetapan untuk pemuat linux supaya kita dapat memilih kernel mana yang nak kita boot.

beginilah rupa dalam fail lilo.conf di bahagian bawah sekali (lebih kurang)


image = /boot/vmlinuz
root = /dev/sda1
label = linux
read-only 


di bahagian bawah daripada tetapan di atas, kita masukkan pula tetapan tambahan


image = /boot/vmlinuz-custom-3.2.2
root = /dev/sda1
label = kernel-3.2.2
read-only 


Dengan ini, anda telahpun menambah satu lagi kernel untuk sistem ini.

Simpan fail /etc/lilo.conf di atas ( ctrl-o ) dan kemudian, larikan lilo.


#:lilo


*tambahan*

setelah anda larikan lilo, dan ada keluar warning message :


#:lilo

Warning: LBA32 addressing assumed
Added ......
Added ......
One warning was issued




Buka semula fail /etc/lilo.conf anda, tambah kod dibawah ini dalam satu baris.


#:lba32


simpan dan larikan semula lilo

Alhamdulillah, sampai peringkat ini, kita telahpun berjaya kompil kernel, letak kernel ditempat yang betul dalam /boot dan buat tetapan untuk sistem boot pada linux baru dalam pemuat linux.

Sekarang apa lagi, reboot PC anda.



Sistem anda boleh boot dengan kernel baru?


root@serverCluster1#:/usr/src/inux# uname -a
Linux serverCluster1 3.2.2-serverCluster1 #1 SMP Thu Jan 26 11:51:43 MYT 2012 x86_64 Pentium(R) Dual-Core  CPU      E5500  @ 2.80GHz GenuineIntel GNU/Linux


1. Jika boleh, edit fail /etc/lilo.conf dan tambah kod berikut dalam baris baru


default = kernel-3.2.2





2. Jika tidak, anda perlu pastikan apakah mesej ralat yang keluar dan perlu cari penyelesaian. Biasanya kita google je mesej ralat tu. InsyAllah adalah insan2 yang berbincang pasal ralat tersebut.

satu lagi, edit fail /etc/lilo.conf jadi gini jika anda mahu terus boot ke kernel asal/lama


default = linux


Berjaya Kompil? Tahniah dan syukur kepada Allah kerana telah memudahkan urusan kita dan memberi kita sedikit ilmu di dunia.


Sekiranya kita ikut turutan biasa untuk menyiapkan pelayan kadar capaian tinggi, mungkin tutorial ini adalah langkah terakhir. Akan tetapi, untuk memudahkan pengguna lain dan diri sendiri selepas ini, adalah lebih baik kita kompil dulu kernel sebelum kita membuat instalasi perisian kelompok pelayan yang lain-lain. Supaya nanti memudahkan dalam tetapan, skrip dan sebagainya.


Yang baik itu segalanya daripada Allah SWT. yang tidak baik dan lemah itu adalah di atas kelemahan dan kekurangan diri ini. Maafkan yang terkurang dan tercela.

Jazakallahu Khairun..

wassalam

Ulasan

Catatan popular daripada blog ini

Apa Maksud RON dalam pengkelasan Petrol?

RON dan Petrol Oleh yusdirman, Oktober 2014 RON adalah singkatan daripada Research Octane Number Ianya kaedah penarafan bahan api. Lebih tinggi nilai RON, lebih mahal harga PETROL. Adakah minyak RON 97 lebih berkuasa berbanding RON 95? RON merujuk kepada tahap bahan api menahan rintangan "ketukan" semasa proses pembakaran oleh palam pencucuh dalam enjin. Ianya merujuk kepada tahap ketahanan bahan api untuk tidak terbakar sebelum dinyalakan oleh palam pencucuh dalam enjin. "ketukan" dalam konteks RON ini adalah apabila campuran bahan api dan udara dalam enjin terbakar lebih awal sebelum api dari palam pencucuh menbakarnya. Pembakaran awal ini mungkin disebabkan enjin terlalu panas. Haba dari silinder enjin itu sendiri mungkin telah menyalakan bahan api sebelum palam pencucuh menyala. Ini boleh menurunkan prestasi dan mungkin boleh memudaratkan enjin! Jadi, RON bukannya bermaksud LEBIH KUASA! Ianya bermaksud bahan api itu dapat menahan tekanan dari

Load Balancing dengan Nginx dan Puma

Load Balancing dengan Nginx dan Puma Tutorial ini adalah sangat ringkas hanya untuk menunjukkan kebolehan nginx sebagai load balancer yang dapat menjadi 'orang tengah' antara banyak server di belakangnya Keperluan 1. Paling kurang 2 server aplikasi 2. Satu server diinstall nginx Contoh Persekitaran yang sekarang 1. server1: os: debian application: ruby on rails web server : puma dns : myaplication1.yusdirman.com 2. server2: myaplication2.yusdirman.com os:debian application: ruby on rails web server : puma dns : myaplication1.yusdirman.com 3. nginx diinstall di server1 /ets/nginx/nginx.conf setup (default): worker_processes  2; worker_processes  auto; worker_rlimit_nofile 65536; error_log  logs/error.log  notice; error_log  logs/error.log  info; events {   worker_connections  65536; } http {   include       mime.types;   default_type  application/octet-stream;   sendfile        on;   tcp_nopush on;   tcp_nodelay on;   keepalive_tim

Server Redundancy - Pertindanan Komputer Pelayan

alkisahnya tercari-cari untuk buat server redundancy ( pertindihan komputer pelayan ) atas sebab perlunya server yang sentiasa on-line tanpa ada downtime yang lama. Dan, cabarannya adalah memang kami tak pernah jalani apa-apa latihan, pengalaman dan apa jua pengetahuan berkenaan teknologi ini. Yang pastinya, perlu banyak mengoogle. Setakat ini, ada banyak kaedah untuk memastikan aplikasi masih terus boleh berfungsi walaupun server mati/rosak. 1. guna 2 server yang sama. Bila satu mati, satu lagi yang masih hidup dapat terus melayan pengguna. 2. guna 2 talian rangkaian yang berbeza. Bila satu talian rosak/putus, masih ada satu lagi talian rangkaian yang berfungsi. 3. storan di server guna raid ( redundant array of independent disk ) atau dalam bahasa melayu : barisan disk berlainan yang bertindan. Raid dapat menjadikan sebilangan hd menjadi 1 dengan semua data pada 1 hd adalah sama dengan data pada hd 2. (mirroring) 4. satu IP maya untuk sebilangan server. 2 server yang mena