Şimdi Ara

Eklediğim Bu Linux El Kitabını Beğendinizmi?

Daha Fazla
Bu Konudaki Kullanıcılar: Daha Az
2 Misafir - 2 Masaüstü
5 sn
24
Cevap
0
Favori
4.246
Tıklama
Daha Fazla
İstatistik
  • Konu İstatistikleri Yükleniyor
0 oy
Öne Çıkar
Sayfa: 12
Sayfaya Git
Git
sonraki

Eklediğim Bu Linux El Kitabını Beğendinizmi?


(En Son Oy Tarihi: 21.2.2017)
Giriş
Mesaj
  • Merhaba ile başlıyım, [BU TAMAMİ İLE ALINTIDIR].... Bu metini bana benim "LİNUX ABİ" dediğim çok sevidiğim bir insan verdi.Kaynağını bilmiyorum ama sizlerle paylaşmak istedim...Lütfen emeğe saygı duyalım burdan copy-paste yapıp sanki kendiniz hazırlamış gibi dağıtmayalım arkadaşlar....



    İÇİNDEKİLER

    Önsöz ve Teşekkür ....................................................................................................... 7

    3. Linux Nedir ? ............................................................................................................ 8

    3.1. Linux'un Desteklediği Donanımlar .............................................................. 9

    3.2. Linux'un Kullanım Amaçları ...................................................................... 10

    3.2.1. Kişisel Kullanım .......................................................................... 11

    3.2.2. İnternet Sunucusu ........................................................................ 11

    3.2.3. Ağ Elemanı .................................................................................. 12

    3.3. Linux'u Nereden Bulabilirim ? ................................................................... 12

    3.3.1. Döküman Temini ......................................................................... 13

    3.4. Yazılım Özellikleri ..................................................................................... 13

    3.4.1. Temel Komutlar ........................................................................... 14

    3.4.2. Uygulama Programları ................................................................. 15

    3.4.3. X Window Arabirimi ................................................................... 15

    3.5. Linux ve Diğer İşletim Sistemleri ............................................................... 16

    3.6. Türkiye'de ve Dünyada Linux .................................................................... 18

    3.7. Linux ve Donanım Desteği ......................................................................... 18

    3.7.1. Sabit Diskler ve Sabit Disk Denetleyicileri ................................. 21

    3.7.2 Ethernet Kartları ............................................................................ 22

    3.7.3 Ses Kartları .................................................................................... 23

    3.7.4. Fare ............................................................................................... 24

    3.7.5. Modem, Yazıcı ve Oyun Çubuğu ................................................ 24

    3.8. Linux Avantaj ve Dezavantajları ................................................................ 25

    3.8.1. Avantajları ................................................................................... 26

    3.8.2. Dezavantajları .............................................................................. 26

    4. Linux Kurulumu ve Başlangıç .............................................................................. 27

    4.1. Mevcut Dağıtımlar ..................................................................................... 29

    4.1.1. Slackware .................................................................................... 29

    4.1.2 Red-Hat ....................................................................................... 30

    4.1.3. Debian ........................................................................................ 30

    4.1.4. InfoMagic ................................................................................... 31

    4.2. Ne Şekilde Bulabilirim ? ........................................................................... 31

    4.2.1. CD-ROM ................................................................................... 31

    4.2.2. İnternet ....................................................................................... 32

    4.2.3. NFS ............................................................................................. 32

    4.2.4. Sabit Disk .................................................................................... 32

    4.3. Sabit Disk Üzerinde Linux İçin Yer Açmak ............................................... 33

    4.4. Bilgisayarın Linux ile Açılması .................................................................. 36

    4.4.1. Ön Hazırlıklar .............................................................................. 38

    4.4.2. Örnek FDISK Çalışması .............................................................. 40

    4.4.3. Setup Programı ............................................................................ 45

    4.4.4. Konfigürasyon ............................................................................. 53

    4.4.5. Makinayı Açmak ......................................................................... 55

    4.5. LILO Konfigürasyonu ................................................................................ 60

    4.6. Sorun Çıktığında ......................................................................................... 62

    4.7. Başlangıçta .................................................................................................. 64

    4.8. Linux Komut Yapısı ................................................................................... 66

    4.9. Dosya ve Dizin Yapısı ................................................................................ 68

    4.9.1. Dosya Listesi ve İçeriklerinin Görüntülenmesi .......................... 69

    4.9.2. Dosyaların Kopyalanması ........................................................... 71

    4.9.3. Dosyaların Silinmesi ................................................................... 72

    5. Kabuk İşlemleri ..................................................................................................... 73

    5.1. Yönlendirme .............................................................................................. 74

    5.2. Standart Girdi, Çıktı ve Hata ..................................................................... 74

    5.3. Boru (pipe) İşlemleri .................................................................................. 78

    5.4. Çokgörevlilik .............................................................................................. 79

    5.4.1. Arkaplanda Çalıştırma ................................................................. 79

    5.4.2. Klavye Üzerinden Kesinti ........................................................... 82

    5.4.3. Süreçlerin Sona Erdirilmesi ......................................................... 83

    6. Dosya ve Dizin İşlemleri ......................................................................................... 84

    6.1. Erişim Hakları ............................................................................................. 84

    6.1.1. Dosya İzinlerinin Değiştirilmesi .................................................. 85

    6.2. Dosyanın Sahibinin ve Grubunun Değiştirilmesi ....................................... 87

    6.3. Diğer Dosya Sistemlerinin Kullanılması .................................................... 88

    6.3.1. Mount İşlemi ............................................................................... 89

    6.3.2. Dosya Sistemi Bilgileri ................................................................ 91

    6.3.3. Dosya Sistemi Yaratılması ve Kontrolü ....................................... 93

    6.4. Sembolik Bağlantılar .................................................................................. 95

    6.5. Dosya Arşivleme ve Sıkıştırma .................................................................. 96

    6.5.1. Dosya Arşivleme ......................................................................... 96

    6.5.2. Dosya Sıkıştırma ve Açma .......................................................... 98

    6.5.3. Birlikte Kullanım ......................................................................... 99

    6.6. Dizin Tarama ............................................................................................ 100

    6.7. Mtools MSDOS Arabirimi ........................................................................ 101

    7. Linux Sistem Yönetimi ......................................................................................... 102

    7.1. Yetkili Kullanıcı ve Diğer Kullanıcılarla İlişkiler .................................... 103

    7.2. Sistem Kuralları ........................................................................................ 104

    7.3. Kullanıcı İşlemleri .................................................................................... 104

    7.3.1. Kullanıcı Hesabı Açmak (adduser) ............................................ 105

    7.3.2. Kullanıcı Grubu ......................................................................... 108

    7.3.3. Kullanıcının Hesabının Silinmesi .............................................. 109

    7.4. Sistemin Yedeklenmesi ............................................................................. 110

    7.5. Sistemin Güncellenmesi ........................................................................... 113

    7.6. Çekirdeğin Derlenmesi ............................................................................. 114

    7.6.1. Çekirdek Konfigürasyonu ......................................................... 119

    7.6.2. Temizlik ..................................................................................... 122

    7.6.3. Çekirdeğin Kurulması ................................................................ 123

    7.6.4. Çekirdeğin Yamanması (patch) ................................................. 125

    7.6.5. Çıkabilecek Sorunlar .................................................................. 126

    7.7. Modüller (Yüklenebilir Çekirdek Parçaları) ............................................. 127

    7.8. Yeni Yazılımların Yüklenmesi ................................................................. 128

    7.9. Sistem Açılış Dosyaları ............................................................................ 131

    7.9.1. Inetd ve /etc/inetd.conf ............................................................... 131

    7.9.2. Syslogd ve /etc/syslog.conf ........................................................ 133

    7.9.3. Init ve /etc/inittab ....................................................................... 135

    7.9.4. /etc/rc.d/* Dosyaları ................................................................... 136

    7.10. Çekirdek Mesajları .................................................................................. 138

    7.11. Linux Dosya Sistemi Yapısı ................................................................... 139

    7.12. Konsolda Türkçe Yazmak ...................................................................... 145

    7.13. Belirli Zamanlarda Komut İşletilmesi .................................................... 147

    8. Bash Kabuğu ......................................................................................................... 149

    8.1. Bash Özellikleri ........................................................................................ 150

    8.2. Takma Adlar (alias) .................................................................................. 151

    8.3. Özel Kabuk Tanımları .............................................................................. 151

    8.4. Özel Kabuk Değişkenleri ......................................................................... 152

    8.5. Sisteme Giriş Dosyaları ........................................................................... 156

    8.6. Kabuk Programlamaya Giriş ................................................................... 158

    8.6.1. Kabuk Programları .................................................................... 159

    8.6.2. Değişkenlerin Kullanımı ........................................................... 160

    8.6.3. Giriş/Çıkış İşlemleri .................................................................. 161

    8.6.4. Aritmetik İşlemler ..................................................................... 161

    8.6.5. If-else Kalıbı ve Kontrol İşlemleri ............................................ 162

    8.6.6. Case Kalıbı ................................................................................ 165

    8.7. Döngüler ........................................................................................ 167

    8.7.1. While-do Döngüsü .................................................................... 167

    8.7.2. For-do döngüsü ......................................................................... 168

    8.8. Örnek Kabuk Programı ............................................................................ 169

    9. TCP/IP ................................................................................................................... 171

    9.1. Temel TCP/IP .......................................................................................... 172

    9.2. İnternet Adresleri ..................................................................................... 173

    9.3. Protokoller .............................................................................................. 174

    9.4. İnternet'e Bağlanma ................................................................................. 176

    9.4.1. Ağ Konfigürasyonu .................................................................. 177

    9.4.2. Kontrol Dosyaları ..................................................................... 183

    9.5. Yönlendirme ............................................................................................ 185

    9.5.1. Birden Fazla Ethernet Kartının Tanıtılması ............................. 187
    İnternet Üzerinde Yeralan Linux Dökümanları ................................................... 189






    ÖNSÖZ

    Linux İşletim Sistemi, temel olarak sistem kaynakları yapılandırılmış bir işletim sistemidir. Bununla beraber ortam bağımsız bir işletim sistemi olması her sistemde minimum konfigürasyon ile kullanılabilmesini sağlamaktadır.

    Bu işletim sistemi temel olarak Unix’ e benzemekle birlikte ternel (yapı çekirdeği) bakımından açık ve lisans gereksinim duymamaktadır. Bu özelliği de yani kaynak kodlarının açıktan dolaşması Linux‘ un meraklıları tarafından geliştirilerek globalleşmesidir.

    Gün geçtikçe Linux İşletim Sistemi, önemi kavranmakta olan bir iletişim sistemi olmaktadır. İletişim kaynaklarını en iyi biçimde kullanılabildiği Linux, artık global iletişim protokollerini en iyi biçimde kullanan işletim sistemi ünvanı ile gelişerek diğer işletim sistemlerinin tahtlarını sallamaktadır.

    Hasan TANER ELAZIĞ – 2000


    TEŞEKKÜR
    Bir yıllık bu uzun çalışmamın hazırlanmasında benden yardımlarını esirgemeyen, beni yönlendiren ve yalnız bırakmayan, Fırat Üniversitesi Elektronik – Bilgisayar Bölüm hocası Arş. Gör. Murat KARABATAK’ a katkılarından dolayı teşekkürü bir borç bilirim.

    3. LINUX NEDİR?

    Linux , serbestçe dağıtılabilen, çokgörevli, çok kullanıcılı UNIX işletim sistemi türevidir. Linux, İnternet üzerinde ilgili ve meraklı birçok kişi tarafından ortak olarak geliştirilmekte olan ve başta IBM-PC uyumlu kişisel bilgisayarlar olmak üzere birçok platformda çalışabilen ve herhangi bir maliyeti olmayan bir işletim sistemidir.

    UNIX 70'li yılların ortalarında büyük bilgisayarlar üzerinde çok kullanıcılı bir işletim sistemi olarak geliştirilmiştir. Zaman içerisinde yayılmış ve birçok türevi ortaya çıkmıştır. UNIX ismi UNIX Research Laboratories INC şirketinin tescilli markası olduğundan dolayı birçok şirket, aynı temele dayanan işletim sistemleri için değişik isimler kullanagelmişlerdir. Örnek olarak

    • Hewlett-Packard; HP-UX
    • IBM; AIX
    • Sun Microsystems; SunOS

    kullanmaktadırlar. Bugün kişisel bilgisayarlardan süper bilgisayarlara kadar bir çok bilgisayar için yazılmış bulunan UNIX türevleri mevcuttur. Ne var ki bu türevlerin çoğu gelişimi belirli bir noktada durmuş ve yüksek fiyatla satılan ticari yazılımlardır.

    Linux, temel olarak Finlandiya Üniversitesinde öğrenci olan Linus Torvalds 'ın ve İnternet üzerinde meraklı bir çok yazılımcının katkıları ile geliştirilmiştir. Linux gelişimi açık bir şekilde yapılmaktadır. Bunun anlamı, işletim sisteminin her aşaması açık olarak İnternet üzerinde yayınlanmakta, dünyanın dört bir yanında kullanıcılar tarafından test edilmekte, hataları ve eksiklikleri tesbit edilerek düzeltilmekte ve geliştirilmektedir. Zaman zaman bu deneme aşamaları belirli bir noktada durdurulur ve güvenilir bir işletim sistemi sunulup, geliştirme için ayrı bir seriye devam edilir. Geliştirmede yer alan bu açıklık Linux'un en büyük avantajlarından biridir. Gelişimi evrimseldir, hatalar anında kullanıcılar tarafından tesbit edilip rapor edilmekte ve birçok kişinin katkısıyla düzeltilmektedir. Bazı işletim sistemi sürümleri saatler içerisinde güncellenebilmektedir.
    Linux, Andy Tannenbaum tarafından geliştirilmiş olan Minix işletim sisteminden esinlenilmiştir. Linus Torvalds boş zamanlarında Minix'ten daha iyi bir Minix işletim sistemi yaratmak düşüncesiyle 1991 Ağustos sonlarında ilk çalışan Linux çekirdeğini oluşturdu. 5 Ekim 1991 tarihinde 0.02 sürümü Linux ilk defa tanıtıldı. Linus, comp.os.minix haber grubuna gönderdiği yazıda yeni bir işletim sistemi geliştirmekte olduğunu ve ilgilenen herkesin yardımını beklediğini yazmıştı. İşletim sisteminin çekirdeği için verilen numaralar kısa sürede bir standart kazandı. a.x.y seklinde belirtilen çekirdek türevlerinde y bulunulan seviyeyi, x gelişim aşamasını göstermektedir. Tek sayılı x'ler geliştirme aşamalarını çift sayılı x'ler ise güvenilir Linux çekirdeklerini göstermektedirler. a ise değişik Linux sürümlerini belirtir. Bu yazının hazırlandığı Ocak 1998 içerisinde en son güvenilir (kararlı) Linux çekirdeği 2.0.33, en son gelişim aşamasındaki çekirdek ise 2.1.79'dur.

    Linux gerçekten son yıllarda hızlı bir gelişme göstermiş, çesitli ülkelerden birçok kullanıcıya erişmiş ve yazılım desteği günden güne artmıştır. Değişik kuruluşlar Linux sistemi ve uygulama yazılımlarını biraraya getirerek dağıtımlar oluşturmuşlar ve kullanımını yaygınlaştırmışlardır.

    3.1. Linux'un Desteklediği Donanımlar

    • Linux şu anda başta IBM-PC uyumlu kişisel bilgisayarlar olmak üzere Apple, Atari ve Amiga gibi 68000 tabanlı bilgisayarlar üzerinde, Sun Sparc işlemcili iş istasyonları, Alpha işlemcili kişisel bilgisayarlar, MIPS, PowerPC, HP PA-RISC ve ARM mimarilerinde çalışmaktadır.
    • IBM uyumlu kişisel bilgisayarlar üzerinde 80386 ve üzeri (80486 80586 Pentium PentiumPro ve türevleri) değişik üreticilerin işlemcileri ile sorunsuz olarak çalışmaktadır. 80286 ve 8086 işlemcili bilgisayarlar için sınırlı kabiliyette Linux uygulamaları mevcuttur.
    • PCI, VESA, ISA ve MCA mimarilerinde her türlü anakartı desteklemektedir.
    • Teorik olarak 4 Gbyte'a kadar RAM desteklenmektedir.
    • AT uyumlu diskler (IDE, EIDE ve 16 bitlik MFM,RLL veya ESDI) desteklenmektedir. Kontrol kartına uyumlu destek bulunduğu sürece SCSI diskler ve diğer cihazlar desteklenmektedir.
    • IDE-ATAPI CD-ROM sürücüleri, ve bazı özel CD-ROM kontrol kartları desteklenmektedir.
    • Metin ekranlarda CGA, EGA, VGA, Hercules veya uyumlu kartlar desteklenmektedir. X Window ortamında genel VGA ve SVGA uyumlu kartlar ve S3, ET4000, 8514/A, ATI MACH8, ATI MACH32 gibi birçok görüntü kartı desteklenmektedir.
    • Birçok 10 ve 100 Mbit ethernet kartı, ISDN, ATM, FDDI, SLIP, CSLIP, PPP desteği verilmektedir.
    • Başta SoundBlaster, Gravis Ultrasound olmak üzere birçok ses kartı desteklenmektedir.

    Linux altında hangi donanımların desteklendiği ile ilgili ayrıntılı bilgiyi Hardware-HOWTO'dan alabilirsiniz. HOWTO dokümanları hakkında daha geniş bilgi ve nereden temin edeceğiniz kitabın sonunda detaylıca anlatılmıştır.

    Makinanızda Linux çalıştırmak için kullanacağınız uygulamalara bağlı olarak en az bir 386SX işlemci ve 4 Mbayt RAM'a ihtiyaç duyacaksınız. Sabit disk üzerinde ise en az 40 Mbayt'lık bir alan ayırmanız gerekecektir. Rahat bir kullanım için en az 8 Mbayt RAM ile 200 Mbayt sabit disk ve bir 486 işlemci önerilmektedir.

    3.2. Linux'un Kullanım Amaçları

    Ücretsiz olarak dağıtılıyor ve gelişiminin hala devam ediyor olması biçcok kişinin Linux'un profesyonel alanlarda kullanılamayacağının düşünmesine yol açmaktadır. Oysa Linux işletim sistemini kullanan bilgisayarlar özel kullanım başta olmak üzere birçok alanda yaygın olarak kullanılmaktadırlar.



    3.2.1. Kişisel Kullanım

    Linux evinde veya işinde UNIX işletim sistemi altında çalışmak isteyenler için ideal bir platformdur. Özellikle işi veya eğitimi sırasında UNIX platformlar altında çalışmak, uygulamalar kullanmak veya yazılım geliştirmek isteyenler kendi kişisel bilgisayarlarında benzer ortamı yakalayabilmekte ve işlerini kendi kişisel bilgisayarlarında gerçekleştirebilmektedirler. Bunlara ek olarak Linux altında yer alan uygulamalar giderek sıradan bir kullanıcı için bile bu işletim sisteminin ilgi çekici hale gelmesini sağlamaktadır. Gelişimleri henüz tamamlanmamış olmasına rağmen, herhangi bir kişisel bilgisayardan beklenebilecek metin editörleri, hesap cetvelleri, çizim yazılımları, veri tabanları birçok ihtiyaca cevap verecek düzeye gelmiştir. Örneğin LaTeX kullanıcıları MS-DOS altında buldukları desteğin çok daha fazlasını Linux altında bulabilmektedirler. 3.2.2. İnternet Sunucusu

    Linux doğrudan TCP/IP desteği ile gelmektedir. Bu yönü ile TCP/IP temelli bilgisayar ağlarında hem istemci hem de sunucu olarak yaygın kullanım bulmuştur. Üzerinde hali hazırda bulunan servislerin çeşitliliği, yeni çıkan servislere hızlı ayak uydurması, kolay konfigüre edilebilmesi ve özellikle de düşük maliyeti sebebi ile yaygın olarak İnternet servislerinin verilmesi amacıyla kullanılmaktadır. Zamanla verdiği ağ servisleri başka protokollere destek verecek sekilde genişletilmiştir. Şu anda Linux

    • WWW sunucu
    • DNS sunucu
    • NFS sunucu
    • NIS sunucu
    • X Window sunucu
    • BOOTP sunucu
    • SMTP sunucu
    • FTP sunucu
    • LIST sunucu
    • NEWS sunucu
    gibi yaygın TCP/IP servislerinin yanısıra
    • NOVELL sunucu (Novell protokolü kullanarak disk ve yazıcı servisi)
    • SAMBA sunucu (Windows 3.1, Windows95, Windows NT ve WfW için disk ve yazıcı servisi)
    • APPLETALK sunucu (MacOS kullanan Apple makinalar için disk ve yazıcı servisi)

    3.2.3. Ağ Elemanı

    Linux yazılım desteği ile birçok ağ elemanının yerine geçebilecek bir alternatif olarak kullanılabilmektedir. Birden fazla ağın birbirine bağlanması amacıyla bir yönlendirici (router) olarak da kullanılabilmektedir. Özellikle farklı protokoller arası bir geçiş elemanı olarak yaygın şekilde Linux'tan yararlanılmaktadır. Ayrıca yönlendirici olarak kullanıldığında kolaylıkla güvenlik amacıyla firewall olarak konfigüre edilebilmektedir. Buna ek olarak bir ağ üzerinde bulunan iki segment trafiğini birbirinden ayıran bir köprü (bridge) olarak da hizmet verebilmektedir. Birçok kurumda bir veya daha çok modemin bağlanması amacıyla bir terminal sunucu (terminal server) olarak Linux kullanılmaktadır.

    3.3. Linux'u Nereden Bulabilirim ?

    Linux işletim sistemiminin temelini oluşturan çekirdek, bu çekirdeğin kullandığı destek kütüphaneleri ve uygulama yazılımları bir araya getirilerek, yükleme yazılımları da eklenerek Linux dağıtımları meydana getirilmektedir. Bu dağıtımlar temel olarak bir kullanıcının Linux kullanmak için ihtiyaç duyabileceği bir çok yazılımı bir araya getirirler. Bu dağıtımların çoğu İnternet üzerinde anonim FTP arşivlerinde bulunabilmektedirler. İnternet erişimi bulunmayan kişilerinde (veya İnternet'ten onlarca Mb kopyalamak istemeyen kişilerin) yararlanabilmesi için çesitli CD-ROM şirketleri tarafından CD-ROM üzerinde dağıtımlar meydana getirilmiştir.


    3.3.1. Döküman Temini

    Linux hakkında yazılan kitapların sayısı gün geçtikçe artmaktadır. Yine de en güncel bilgi İnternet üzerinde bulunmaktadır. Elektronik ortamda iki temel doküman çeşidi bulunmaktadır.
    Bunlar: 1. http://w3.metu.edu.tr/ldp Linux Documentation Project
    2. ftp://ftp.metu.edu.tr/pub/sunsite/docs/HOWTO /NASIL (HOWTO) dokümanları

    NASIL dokümanlarının bir kısmının Türkçeye çevrilmesi işlemi devam etmektedir. Şu ana kadar çevrilen dokümanlarıhttp://linux.org.tr Linux Kullanıcıları Grubu WWW sayfasından bulabilirsiniz.

    3.4. Yazılım Özellikleri

    Bir işletim sistemi, ne kadar mükemmel olursa olsun, uygulama yazılımlarının çokluğu ve kalitesi ile varolabilir. Herhangi bir Linux dağıtımı içerisinde, değişik amaçlara hizmet eden birçok yazılım bulunmaktadır. Ancak her geçen gün bu dağıtımlarda yer almayan yeni yeni yazılımlar çıkmaktadır.

    UNIX makinalar üzerinde yer alan uygulamaların çoğu, değişik platformlar altında bulunduğundan çalıştırılabilir (executable) olarak dağıtılmaz, kaynak kodu şeklinde sunulurlar. Sözkonusu yazılımı kullanmak isteyen bir kullanıcı bu kaynak kodunu kendi platformunda derleyerek çalıştırır. Bu yazılımların birçoğu Linux altında kolaylıkla çalıştırılabilmektedir. Bu tür yazılımları İnternet üzerinde çeşitli FTP arşivlerinde bulmak mümkündür.

    Linux'a özel veya Linux üzerinde geliştirilen yazılımlar için standart bazı FTP arşivleri vardır. Bunların en bilineniftp://sunsite.unc.edu/pub/LinuxSunsite FTP arşividir. Burada çeşitli dizinler altında konularına göre ayrılmış bir durumda elektronik devre tasarım yazılımlarından oyun programlarına kadar birçok değişik yazılım bulunmaktadır. Bu arşivin Türkiye'de yeralan bir kopyasıftp://sunsite.bilkent.edu.tr adresinde vardır.
    Linux'un bu denli sevilmesi ve yaygınlaşması çesitli şirketlerin (Macintosh, Sun, SSC gibi) Linux üzerinde çalışan ticari yazılımlar geliştirmesi sonucunu verdi. Bu konuda detaylı bilgi için Commercial-HOWTO dokümanından yararlanabilirsiniz.

    Linux üzerinde bulunan uygulamaların ve yazılımların listeleri için aşağıdaki adreslerden yararlanabilirsiniz:
    http://www.redhat.com/linux-info/linux-app-list Linux Applications
    http://sal.kachinatech.com Scientific Applications on Linux
    http://www.execps.com/lsm Linux Software Map

    3.4.1. Temel Komutlar

    Daha önce UNIX tabanlı bir işletim sisteminde çalışanlar için Linux, öğrenilmesi çok kolay bir sistem olacaktır. Standart bir UNIX sisteminde yeralan hemen hemen tüm komutlar, Linux'a taşınmıştır. Onlarca çeşit kabuğun yanı sıra, sed, awk gibi programcının işini kolaylaştıran diller, ls, less, finger gibi temel her türlü komut, Linux'ta vardır.

    Ağ ve İnternet uygulamaları için elm ve pine (Pine Is Not Elm) yanında metin editörleri olarak vi, vim (vi'ın daha gelişmiş sürümü), pico ve joe sayılabilir. Editörlerden, bizde fazla bilinmeyen Emacs da Linux altında denemeye değer programlardandır. Kelime işlem programlarından troff, groff (GNU troff) ve daha modern metin işleme yazılımlarından TeX ve LaTeX sayılabilir.

    Bazı program isimlerinin (GNU-tar, GNU-bash gibi) başında görebileceğiniz GNU (Gnu is Not UNIX!), Linux için de yazılım ve programlar üreten bir kuruluştur. GNU, lisansını ve yazarını korumak koşuluyla programları kaynak koduyla birlikte Linux kullanıcılarına dağıtır. Örnek olarak tcsh ve GNU bash, Linux altında en çok rağbet edilen iki kabuk ismidir. Diğer kabuklar arasında zsh, ash, ksh ve csh sayılabilir. Kabuklar hakkında daha geniş bilgiyi, Bash konu başlığı altında bulabilirsiniz.

    3.4.2. Uygulama Programları

    Linux üzerinde ver tabanı uygulamaları ortalama bir kullanıcının ihtiyacını karşılayabilir.http://www.postgresql.orgPostgres, Mbase, msql ve Ingres gibi profesyonel yazılımlar Linux ve diğer platformlarda istemci/sunucu bazda görev yapabilirler. Özellikle Postgres, uygulama kolaylığı ve C, perl, tcl gibi birçok dile yönelik arabirimiyle göze çarpar.

    Mühendislik yazılımları arasında gnuplot (grafiksel veri analiz yazılımı), xspread ve xfractint (fraktal yaratma programı) sayılabilir.

    Doğru seçilmiş bir donanım üzerinde kurulan bir Linux makinası, hemen her tür çokluortam (multimedia) uygulamalarını rahatlıkla çalıştırabilir. En az Pentium tabanlı, 32Mbayt RAM ve 2GB sabit diske sahip makina yardımıyla ticari olarak satılan çokluortam uygulamalarını kullanabilirsiniz. Linux, hemen her türlü ses kartını desteklediğinden ses dosyalarının, workman, Cdplayer gibi programlar yardımıyla kolayca çalınması mümkün olur. MIDI editörleri ve bir sentezleyici ile kendi müzik stüdyonuzu kurabilirsiniz.

    Biraz oyun oynamak mı istediniz ? Doom, Quake, Abuse, Xtetris, FreeCiv(ya da CivNet), Imaze ve benzeri onlarca oyun Linux'ta da var. ODTÜ'de yüzlerce öğrenciyi bilgisayar başına mıhlayan MUD (Multi User Dungeon) oyunlarını sunan makinaların birkısmı Linux idi.

    3.4.3. X Window Arabirimi

    Linux işletim sistemi altında X Window sistemi ile Windows altındaki gibi grafik arabirimiyle birlikte çalışabilirsiniz. Windows ile uğraşan herkes rahatlıkla X Window'a geçiş yapabilir. X ile ekranda aynı anda birden fazla pencere açılabilir, fare yardımıyla birden fazla uygulama aynı anda kontrol edilebilir.

    Pekçok uygulamanın (özellikle İnternet tabanlı) X üzerinde çalışan sürümleri vardır. Bu sayede metin tabanlı ekrana dönmeden her işinizi X yardımıyla tamamlayabilme şansınız olur. Bu sayede Linux, bir iş istasyonu görünümüne ve kullanışlılığına sahip olacaktır.

    X pencere denetleyici (window manager - wm) kullanıcı ile X arasında bekler ve klavye ile fareden aldığı emirleri ekranda yerine getirir. Bu emirler, pencerelerin açılması, kapatılması ve yerlerinin değiştirilmesi gibi komutlardır. Sıkça kullanılan pencere denetleyicilerinden fvwm, twm, Afterstep, KDE, Enlightenment ve olwm sayılabilir.

    3.5. Linux ve Diğer İşletim Sistemleri

    Linux ve diğer işletim sistemleri arasındaki ilişkiyi, benzerlikleri ve farklılıkları bilmek önemlidir. Linux işletim sistemi, diğer sistemler ile birlikte aynı sabit diski paylaşabilir. UNIX'i öğrenmek için kesinlikle en kolay ve ucuz yol olan Linux, diğer işletim sistemlerine karşı her zaman güçlü bir alternatif olmaktadır. İnternet servis sağlayıcılarının büyük çoğunluğu, Linux kullanmakta, İnternet bağlantılarını, e-posta ve haber grubu (öbeği) alış-verişini Linux sayesinde yapmaktadır.

    Bir kişisel bilgisayarı satın aldığınız zaman çok büyük ihtimalle üzerinde MS-DOS veya türevi bir işletim sistemi yüklenmiş olduğunu göreceksiniz. Her kullanıcı o veya bu şekilde MS-DOS ile tanışır. MS-DOS, üzerinde en fazla program yazılan işletim sistemi olmuş, bu yüzden modern işletim sistemleri çıkmadan önce her kullanıcının kurtarıcısı gözüyle bakılmıştır. Fakat MS-DOS arabirimi programlanırken ileriyi düşünemeyen programcılar, bu işletim sistemine Linux'ta olan bazı hayati özellikleri kazandıramamışlardır. MS-DOS, çok kullanıcılı bir sistem değildir ve aynı anda birden çok işi yapamaz. İsterseniz çalıştırılabilecek en geniş programın büyüklüğünü görmek için mem komutunu kullanmayı deneyin. Linux, sadece üzerindeki hafıza ile sınırlıdır. 80x86 tabanlı mikroişlemcinin her özelliğini sonuna kadar kullanır. Bunun sonucu olarak performanslı bir işletim sistemidir.

    Tüm bu olumsuzluklara rağmen yine de MS-DOS kullanmak istiyorsunuz. Onun da kolayını bulmuş Linux programcıları. Ücretsiz dağıtılan MS-DOS ve Windows emülatörü yardımıyla MS-DOS altında çalışan programların hemen hepsi Linux'la birlikte de çalışabilir. WinWord 2.0, sysinfo, Civilization ve Qbasic Linux altında sorunsuz çalışan MS-DOS/Windows programlarından sadece birkaçı.

    Profesyonel bir yatırım sayılabilecek Windows NT'nin çokgörevlilik ve hafızayı mükemmel kullanma gibi özellikleri vardır. Buna karşılık fiyatı oldukça yüksektir ve çalışmak için gayet yüksek standartlı bir makina ister.
    IBM firmasının geliştirdiği OS/2 de NT'ye benzer şekilde çokgörevli işletim sistemi olup fiyat/performans oranı açısından makul sayılabilecek bir işletim sistemi olarak göze çarpar.

    Linux, herkese göre bir işletim sistemi değildir. UNIX'i benimsemeyen bir kullanıcıdan Linux'u kullanmasını bekleyemezsiniz. İnternet UNIX ile doğduğu için Linux bu alanda yukarıda sözü geçen sistemlerden daha avantajlı bir duruma gelir. Dağıtımı tek firmayla sabit olmadığı için geliştirilme aşamasında dünyanın dört bir yanından katkı ve destek gelir. UNIX'e belirli bir standart getirilmesi için yapılan çalışmalara uyan Linux, POSIX standardını destekler.

    RedHat, Caldera gibi çeşitli Linux sürümleri da piyasada satılmakta, çok zengin bir doküman ve arşiv kaynağı ile kullanıcılara sunulmaktadır. 80386+ tabanlı işlemciler üzerinde kurulabilen ve İnternet üzerinde bedava dağıtılan diğer işletim sistemlerinden bir diğeri de FreeBSD'dir. FreeBSD, bir grup programcı tarafından BSD standartını 80x86 bilgisayarlara taşımak üzere geliştirilmiştir ve Linux ile büyük benzerlikleri bulunur.

    Linux işletim sisteminin güvenilir ve sağlam yapısından haberdar olmayan, hatta bu gerçeği bilerek ücretli sistemlerdem medet uman kişiler vardır. Sabit fikirli olmadan önce bu sistem hakkında daha fazla verinin dağıtılması, kullanıcıların bilinçlendirilmesi gereklidir. Bu da ancak, Linux'un yapabildiklerini göstermekle olabilir.

    3.6. Türkiye'de ve Dünyada Linux

    Eğer Linux'u sever ve bu sistemin yaygınlaşmasında, bihaber kullanıcılara tanıtımında öncülük etmek isterseniz, bu bölüm tam size göredir.

    Henüz tüzel kişiliği olmayanhttp://www.linux.org.trTürkiye Linux Kullanıcıları Grubu sayfası Türkiye'de Linux çalışmaları için iyi bir başlangıç noktasıdır. Türkçe ve İngilizce Türkiye'deki en geniş kapsamlı Linux sunucusunun genişlemesinde yeni fikirlere, çözüm önerilerine ihtiyaç vardır. Bu da ancak Linux seven bir kitlenin varlığıyla mümkündür.

    Dünyada ve Türkiye'de İnternet Servis Sağlayıcıları (İSS) Linux'u uzunca bir süredir ticari olarak kullanıyorlar. Uygulama yazılımları da bu yönde kullanıcıların hizmetine sunuluyor. Fakat güvenlik sorunları nedeniyle Linux kullanan servis sağlayıcıları, müşterilerini bu hizmetten yoksun tutuyorlar. Açık sistem kavramının ve kullanımının yaygınlaşması da bu sebepten dolayı sekteye uğruyor.

    SSC (Specialized Systems Consultants -http://www.scc.com), ``Linux Journal'' adında bir dergiyi başarıyla dağıtıyor. Tirajı onbinleri bulan bu aylık dergide bu işletim sistemini aktif kullanan herkes için, her konuda, her düzeyde makale bulmak mümkündür.

    3.7. Linux ve Donanım Desteği

    Bir işletim sisteminin tüm kartları tanıması, tüm sabit disklerle çalışabilmesi, tüm giriş/çıkış kartlarıyla uyum içinde çalışması mümkün değildir. Bu konuda çok iddalı olan tak-çalıştır sistemine sahip Windows95 bile bazen yetersiz kalabilmekte. Linux da piyasada yeralan hemen hemen bütün donanımlarla birlikte çalışabilir.

    Linux, üzerinde matematiksel işlemci olsun veya olmasın Intel 386SX/DX, 486SX/DX/SX2/DX2/DX4, Pentium, PentiumPro, Pentium II ve MMX işlemcilerde sorunsuz çalışır. Bunlarla beraber (Cyrix 486 tabanlı işlemcilerinde nadiren sorun çıkarsa da) AMD, Cyrix gibi firmaların işlemcileri de Linux tarafından desteklenir. Matematik işlemcisi olmayan bilgisayarlarda Linux'un beyni sayılan çekirdek, matematik işlemcisine gerek duyulan kod parçalarında bu işlemciyi emüle edebilir. Burada belirtilen IBM uyumlu PC'ler dışında ALPHA, PowerPC, MIPS, farklı Sparc modelleri, PA-RISC gibi birçok farklı işlemciye de başarılı bir şekilde taşınmıştır.

    Linux, kişisel bilgisayarlarda kullanılan ISA, VLB (Vesa Local Bus - yerel veri yolu), EISA, MCA (IBM Microchannel) veya PCI veriyolu mimarisi ile çalışabilirler.

    Linux, SMP (symmetric multi processor) olarak da bilinen birden fazla işlemcili bilgisayarlar üzerinde de çalışabilir ve birden fazla işlemciyi en verimli şekilde kullanır.

    Kişisel bilgisayarların kullandığı 80x86 tabanlı işlemciler dışında, taşınan ve sorunsuzca çalıştığı bilinen işlemciler ve bilgisayarlar ile konu hakkında daha fazla bilgi alınabilecek İnternet adresleri aşağıda verilmiştir.

    http://www-users.informatik.rwth-aachen.de/2#2hn/linux68k.htmlLinux/68000
    http://www.waldorf-gmbh.de/linux-mips-faq.htmlLinux/MIPS
    ftp://sunsite.unc.edu/pub/Linux/docs/ports/Linux-PowerPC-FAQ.gzPowerPC
    http://www.ph.kcl.ac.uk/2#2hamb/linux.htmlLinux for Acorn
    http://www.mklinux.apple.comMacLinux
    http://www-c724.uibk.ac.at/XL/Compaq Deskpro XL
    ftp://invaders.dcrl.nd.edu/pub/misc/IBM PS/2 MCA systems
    http://domen.uninett.no/2#2hta/linux/aero-faq.htmlCompaq Contura Aero
    http://peipa.essex.ac.uk/tp-linux/tp-linux.htmlIBM ThinkPad
    http://lena.fnet.fr/Linux/MIPS
    http://www.azstarnet.com/2#2haxplinux/Linux/Alpha
    http://www.osf.org/mall/os/pa-mklinux/index.htmlHP PA-RISC
    http://www.geog.ubc.ca/sparclinux.htmlSPARC/Linux

    Linux, metin modu kullanırken tüm ekran kartlarıyla (Hercules, CGA, EGA, CGA, IBM monokrom) sorunsuz çalışır. X Window çalıştırmak isterseniz hızlandırılmış bir SVGA kart önerilir. Sürekli yenileri eklense de aşağıda şu anda desteklenen kartların tam listesi vardır.

    • Hercules mono
    • VGA / VGA Mono
    • EGA
    • ARK Logic ARK1000PV/2000PV, ARK1000PV/VL
    • ATI VGA Wonder, ATI Mach32, ATI Mach8, ATI Mach64
    • Cirrus 542x, 543x, 62x5, 6420/6440
    • OAK OTI-037/67/77/87
    • Trident TVGA8900, TVGA8800, TVGA9xxx
    • Tseng ET3000/ET4000/W32, ET4000/W32/W32i/W32p, ET4000AX
    • IBM 8514/A, IBM XGA, XGA-II
    • IIT AGX-010/014/015/016 (16 bpp)
    • Oak OTI-087, OTI-067, OTI-077
    • S3 911, 924, 801, 805, 928, 864, 964, Trio32, Trio64, 868, 968
    • Weitek P9000 (16/32 bpp)
    • Diamond Viper VLB/PCI
    • Orchid P9000
    • Western Digital PVGA1, WD90C00/10/11/24/30/31/33
    • Avance Logic AL2101/2228/2301/2302/2308/2401
    • Chips & Technologies 65520/65530/65540/65545
    • Compaq AVGA
    • Genoa GVGA
    • MCGA (320x200)
    • MX MX68000/MX68010
    • NCR 77C22, 77C22E, 77C22E+
    • RealTek RTG3106
    • Video 7 / Headland Technologies HT216-32
    • Western Digital/Paradise PVGA1, WD90C00/10/11/24/30/31/33
    • Hyundai HGC-1280
    • Sigma LaserView PLUS

    3.7.1. Sabit Diskler ve Sabit Disk Denetleyicileri

    Linux, standart IDE, bazı ESDI, hemen hemen tüm SCSI ve nadiren kullanılsa da MFM ve RLL denetleyicilerini desteklerler. Aslında Linux çalıştırmak için sabit diske gerek yoktur. Ağ üzerinden, Bootp protokolü yardımıyla Linux yüklü başka bir bilgisayarın kaynaklarını kullanmak mümkündür. Sabit disk denetleyiciniz en az 16 bit olmalıdır. Genellikle MS-DOS altında sorunsuz çalışan her sabit diski Linux da görebilir.

    Sabit disk üzerinde Linux için bir miktar yer ayırmalısınız. Birden fazla disk de kullanabilirsiniz, Linux her diski ayrı bir dizin altından erişebilir. Bu konuda daha geniş bilgiyi Linux kurulumu bölümünde bulabilirsiniz.

    Sabit diskler, denetleyicileri desteklendiği sürece Linux altında kullanılabilirler. Artık neredeyse tüm CD-ROM'lar SCSI denetleyicilerle çalışıyorlar. Bir SCSI denetleyiciniz varsa makinanız CD-ROM'u da tanıyacaktır. Linux, CD-ROM'ların standart iso9660 dosya sistemini de tanır.
    Desteklenenen kartlar,

    • AMI Fast Disk VLB/EISA
    • Adaptec AVA-1505/1515, AHA-1510/152x, AHA-154x, AHA-174x, AHA-274x, AHA-2940/3940, ACB-40xx
    • Always IN2000
    • BusLogic (ISA/EISA/VLB/PCI)
    • DPT PM2001, PM2012A (EATA-PIO)
    • DTC 329x (EISA) (Adaptec 154x compatible)
    • Future Domain TMC-16x0, TMC-3260 (PCI), TMC-8xx, TMC-950
    • Media Vision Pro Audio Spectrum 16 SCSI (ISA)
    • NCR 5380 generic, 53c400, 53c406a, 53c7x0, 53c8x0 (PCI)
    • Qlogic / Control Concepts SCSI/IDE (FAS408) (ISA/VLB)
    • Seagate ST-01/ST-02 (ISA)
    • SoundBlaster 16 SCSI-2 (ISA)
    • Trantor T128/T128F/T228 (ISA)
    • UltraStor 14F (ISA), 24F (EISA), 34F (VLB)
    • Western Digital WD7000 SCSI
    • AMD AM53C974, AM79C974 (PCI)
    • Adaptec SCSI-MFM/RLL bridgeboard
    • Iomega PC2/2B
    • logic (ISP1020) (PCI)

    3.7.2. Ethernet Kartları

    Piyasada çok çeşitli ethernet kartları vardır. Genellikle yaygın olarak kullanılanlar 3Com veya NE2000 uyumlulardır. Aşağıda desteklenen ethernet kartların bir listesi yeralmaktadır. PCMCIA, Tokenring, ISDN, AX25 kartlarının uyumlu olanları, çok nadir kullanıldıkları için burada belirtilmeyecektir.

    • 3Com 3C501, 3Com 3C503, 3C505, 3C507, 3C509/3C509B (ISA) / 3C579 (EISA)
    • AMD LANCE (79C960) / PCnet-ISA/PCI (AT1500, HP J2405A,
    • NE1500, NE2100, NE2000, NE1000
    • AT&T GIS WaveLAN
    • Allied Telesis AT1700
    • Ansel Communications AC3200 EISA
    • Apricot Xen-II
    • Cabletron E21xx
    • DEC DE425 (EISA) / DE434/DE435 (PCI), DEC DEPCA
    • HP PCLAN 27245, 27247, 27252A, 10/100VG PCLAN
    • Intel EtherExpress, EtherExpress Pro
    • New Media Ethernet
    • Racal-Interlan NI5210, NI6510
    • PureData PDUC8028, PDI8023
    • SEEQ 8005
    • SMC Ultra
    • Schneider & Koch G16
    • Western Digital WD80x3
    • Zenith Z-Note / IBM ThinkPad 300 built-in adapter

    3.7.3. Ses Kartları

    Linux üzerinde hemen her türlü ses kartı desteği var. SoundBlaster16 ses kartlarının üzerinde ASP çipi veya 4.11 ve 4.12 DSP (digital signal processor - sayısal ses işleyici) bulunanları Linux üzerinde kullanamazsınız.

    Desteklenen ses kartları,

    • 6850 UART MIDI
    • Adlib (OPL2)
    • Audio Excell DSP16
    • Aztech Sound Galaxy NX Pro
    • Crystal CS4232
    • CHO-PSS (Orchid SoundWave32, Cardinal DSP16)
    • Ensoniq SoundScape
    • AWE 32
    • Gravis Ultrasound, Gravis Ultrasound MAX
    • Logitech SoundMan Games, Logitech SoundMan Wave
    • Logitech SoundMan 16 (PAS-16 uyumlu)
    • MPU-401 MIDI
    • MediaTriX AudioTriX Pro
    • Media Vision Premium 3D (Jazz16), Pro Sonic 16 (Jazz), Pro Audio Spectrum 16
    • Microsoft Sound System (AD1848)
    • OAK OTI-601D cards (Mozart)
    • OPTi 82C928/82C929 cards (MAD16/MAD16 Pro)
    • Sound Blaster, Sound Blaster Pro, Sound Blaster 16
    • Turtle Beach Wavefront cards (Maui, Tropez)
    • Wave Blaster

    3.7.4. Fare

    Linux, Microsoft serial mouse, Mouse Systems serial mouse, Logitech Mouseman serial mouse, Logitech serial mouse, ATI XL Inport busmouse, Microsoft busmouse, Logitech busmouse ve PS/2 mouse destekler.

    Genellikle kullanacağınız farenin türü Microsoft ya da Mouse Systems serial mouse olacaktır.

    3.7.5. Modem, Yazıcı ve Oyun Çubuğu

    Hem internal (kasa içine takılan) hem de external (kasanın dışında kalan) tüm modemler Linux tarafından desteklenir. Aynı şekilde paralel veya seri porta takılan her yazıcı ve çizici desteklenir. İsterseniz bunları yerel bir ağ üzerinden birden fazla makinaya paylaştırabilirsiniz. Linux altında lpr yazılımı, yazıcılara erişimi sağlamak için kullanılır.

    Oyun çubukları için sürücüler ister doğrudan çekirdeğe eklenebilir, istenirse de modül olarak derlenebilir.

    Aşağıda, Linux'un desteklediği giriş/çıkış kartlarının geniş bir listesi vardır.

    • AST FourPort and clones
    • Accent Async-4
    • Arnet Multiport-8
    • Bell Technologies HUB6
    • Boca BB-1004, 1008, BB-2016, IO/AT66, IO 2by4
    • Computone ValuePort
    • DigiBoard PC/X (4, 8, 16 port)
    • Comtrol Hostess 550 (4, 8 port)
    • PC-COMM 4-port (4 port)
    • SIIG I/O Expander 4S (4 port, uses 4 IRQ's)
    • STB 4-COM (4 port)
    • Twincom ACI/550
    • Usenet Serial Board II (4 port)
    • Cyclades Cyclom-8Y/16Y (8, 16 port) (ISA/PCI)
    • Stallion EasyIO, EasyConnection 8/32, 8/64

    3.8. Linux Avantaj ve Dezavantajları

    Pek çok okuyucu, ``Neden Linux?'' diye sorabilir. Belki de cevap önce kullanıcının kendini tanıması ile bulunabilir. Değişik yerlerde Linux kullanılması ve bunun sonuçları hakkında gözlemlediklerimizin ışığı altında çok kabaca:

    Eğer, bilgisayarla ilişkiniz belirli paket programlara dayanıyorsa, bilgisayar kullanmak için bilgisayar konusunda bilgi sahibi olmanız gerektiğine inanmıyorsanız, bilgisayar ile uğraşmak hoşunuza gitmiyorsa, sorunlarınızı kendi başınıza çözmeyi denemekten hoşlanmıyorsanız, bir sorun çıktığında para vererek de olsa bu sorununuzu birisi aracılığı ile çözmek istiyorsanız Linux kesinlikle size göre değil.

    Ama eğer, bilgisayarınızla ilgilenmekten hoşlanıyorsanız, bilgisayarda çıkan problemlerle uğraşmak hoşunuza gidiyorsa, diğer işletim sistemlerinin sizi sıktığına ve sınırladığına inanıyorsanız, donanımınızdan daha çok performans istiyorsanız, UNIX işletim sistemi ile çalışmayı seviyorsanız Linux size göre olabilir.


    3.8.1. Avantajları

    UNIX işletim sistemine sahip bir bilgisayar kullanmak istiyorsanız ve bu işletim sisteminde platforma bağımlı bir yazılım kullanmıyorsanız, Linux ideal bir çözümdür.
    Linux ücretsizdir. Sadece işletim sisteminin maliyeti açısından değil, verdiği performans için ihtiyaç duyduğu donanım açısından da çok ucuzdur. Üstüne üstlük çok kullanılan ve bol yedek parçası bulunan bir platform altında çalıştığı için belirli bir Linux sisteminin performansını artırmak için yapılması gereken yatırım başka bir UNIX iş istasyonunu aynı oranda geliştirmek için gereken yatırıma göre çok düşüktür. Fakat şirketler bazında Linux'un bedava bir işletim sistemi olması genelde gözardı edilir.

    Bir Linux makina bu sayede sadece işletim sistemi açısından değil donanım olarak da ucuza gelmektedir.
    Linux hızla geliştirilmektedir. Bu gelişimin en büyük yararı, eksikliklerin kullanıcıların talepleri ve çabaları sonucunda hızla giderilmesidir. Linux diğer tüm işletim sistemlerine göre belirli bir donanım için daha hızlı destek verebilmektedir.

    Linux çok değişik donanımlar ve servisler için özel olarak hazırlanır. İşletim sisteminin temelini oluşturan çekirdek kullanıcı tarafından da derlenebildiği için, bu derleme sırasında sadece kullanım amacına yönelik alt programlarla donatılır. Bu genel olarak daha sistemin performansını artırmaktadır. (Örnek olarak SCSI donanımınız yoksa çekirdeğinizde SCSI ile ilgili alt programlara yer vermezsiniz)

    3.8.2. Dezavantajları

    Linux'un serbestçe dağıtılıyor olması bir çok kişinin bu işletim sistemine güvenmemesine yol açmıştır. ``Ciddi bir şey olsa, bedava olmazdı !'' kanısı oldukça yaygındır.

    Linux'un sürekli gelişiyor olması en büyük dezavantajlarından biridir. Henüz tüm ihtiyaçlara cevap vermemesi (hala Windows95 programlarını çalıştıramıyor :) ), gelişimin bazı aşamalarında topyekün değişiklikler yapılması, gelişimi takip etmek için bazen sürekli yenileme yapılması, birçok kullanıcının bu işletim sistemine güvenmemesine yol açmıştır.

    Linux herhangi bir ticari destek altında gelişmemektedir. Bunun en büyük yararı işletim sisteminin ticari kaygılar taşımamasıdır. Ancak bunun yanısıra diğer işletim sistemlerinde olan teknik destek, dağıtım ve dokümantasyon alanlarında eksikleri vardır. Özellikle teknik destek eksikliği, anahtar teslim çözümlere alışmış kullanıcıların çokluğu Linux kullanıcılarının sayısını sınırlayan temel faktörler olmuşlardır.

    Bu konudaki eksikliği gidermek için çeşitli gönüllü kuruluşlar, kullanıcı grupları oluşmuştur. Zamanla Linux teknik desteği ticari bir konu olarak ortaya çıkmıştır. Şu anda tüm dünyada Linux çözümleri konusunda teknik destek veren danışmanlar bulunmaktadır. Bu kişiler ve kurumlar hakkında ayrıntılı bilgiyi Consultants-HOWTO dokümanında bulabilirsiniz.

    Linux işletim sistemini geliştirenlerin ticari kaygılar gütmemeleri bazı ticari yazılımların Linux üzerinde gelişmemesine sebep olmuştur. Linux üzerinde belirli konularda diğer işletim sistemlerinden aşağı kalmayan yazılımlar bulunmasına rağmen, belirli bazı konularda çok zayıf kalmıştır. ( Mesela oyunlar :) )

    Linux üzerinde yer alan çözümlerin hepsi, basit kullanıcıların rahatça kullanabileceği düzeyde değildir. Bazı çözümler kullanıcıların belirli bir yazılım ve işletim sistemi bilgisine sahip olmalarını gerektirmektedir.

    4. LINUX KURULUMU VE BAŞLANGIÇ

    Linux hakkında ilk dokümanlar yazıldığında, Linux çalıştırabilecek bilgisayarların özellikleri önemliydi. Linux 32 bitlik bir işletim olduğundan en az 80386SX işlemcilerle çalışmaktadır. 8086 ve 80286 işlemcili IBM-PC uyumlu kişisel bilgisayarlar Linux tarafından desteklenmemektedir. Hafıza olarak en az 4 Mb RAM (yoğun işlemler için 12 veya 16) tavsiye edilmektedir. Teknik olarak 2 Mb ile de çalışabilmesi gerekir. Pratik olarak bugün piyasada bulunan hemen hemen her IBM-PC uyumlu kişisel bilgisayarda Linux çalışabilmektedir.

    8 MB RAM'a sahip herhangi bir 486 üzerinde hemen hemen her türlü uygulama rahatlıkla çalıştırılabilmektedir. Tabii ki daha fazla RAM ve daha hızlı işlemciler sistemin genel olarak daha hızlı çalışmasını sağlayacaklardır.

    Linux tarafından desteklenen donanımlar her geçen gün değişiyor. Bilgisayarınızda bulunan herhangi bir donanımın desteklenip desteklenmediğini Hardware-HOWTO dosyasından öğrenebilirsiniz.

    Yine de daha önce yazılanları kısaca tekrar edersek,

    - Kişisel bilgisayarlarda INTEL, AMD, CYRIX şirketlerinin tüm 80386, 486, 586, 686, Pentium, PentiumPro, Pentium II işlemcileri
    - Tüm IDE, MFM, RLL sabit diskler
    - Çoğu SCSI sabit disk denetçileri
    - Çoğu ethernet ve G/Ç kartları
    - Birçok VGA, SVGA, EGA, HERCULES görüntü kartları
    Linux tarafından desteklenmektedir.

    Linux başka işletim sistemleri ile aynı sabit diskte bulunabilir. Makinanıza Linux yüklemek için mevcut işletim sisteminizi kaldırmak zorunda değilsiniz. Fakat yine de Linux yükleyebileceğiniz bir miktar alan ayırmak zorundasınız. Bir bilgisayara Linux yüklemek için bilgisayarınız üzerinde bir başka işletim sisteminin bulunmasına gerek yoktur, Linux tam anlamıyla kendi başına çalışabilen bir işletim sistemidir.

    ``Linux sabit disk üzerinde ne kadar yer kaplar?'' sorusuna kesin bir cevap vermek oldukça zor, zira bu hangi yazılımları yükleyeceğinize ve ne kadar kullanıcı alanı istediğinize çok bağlıdır. Yine de kaba rakamlar vermek gerekirse, 40 Mb'lık bir alana çalışılabilir durumda ve işinizin çoğunu görebilecek bir Linux kurulabilir. Tüm paketleri yüklemeye kalktığınızda ise kabaca 250 Mb kadar yer kaplayacaktır.

    Linux, çok çeşitli gruplar tarafından sürekli geliştirilen bir işletim sistemidir. Belirli kişiler ve topluluklar Linux için geliştirilen temel işletim sistemini ve uygulama yazılımlarını bir araya getirerek dağıtımlar oluştururlar. Bir Linux dağıtımı temel olarak bir makinaya Linux kurmak ve o bilgisayar üzerinde Linux'la çalışmak için gerekecek tüm yazılımları ve paketleri içerir, bu yazılımların yüklenmesi için bir yükleme yazılımı sağlar.

    Şu an mevcut çok çeşitli Linux dağıtımları mevcuttur. Bu dağıtımlar içerdikleri paketler ve yükleniş şekilleri açısından bazı ufak tefek farklılıklar gösterseler de temelde aynı işletim sistemini yüklerler. Bir Linux dağıtımı bir araya getirildiği zamandaki güncel işletim sistemini içermektedir. Örnek olarak Linux işletim sisteminin temeli olan çekirdek neredeyse her hafta yenilenerek geliştirilmektedir. Oysa dağıtımlar senede ancak birkaç kere oluşturulurlar.

    Linux dağıtımları geleneksel olarak 3.5" lik disketler halinde hazırlanır. (her biri bir 3.5" lik diskete sığabilecek seri dizinler şeklinde). Her konu ile ilgili bir seri disket bulunur (örnek olarak n serisi ağ uygulamaları için n1,n2,n3... şeklinde)

    4.1. Mevcut Dağıtımlar

    4.1.1. Slackware

    Belki de en yaygın olarak yer alan dağıtım Slackware dağıtımıdır. Bu doküman boyunca anlatılacak olan komutlar ve sistem özellikleri Slackware dağıtımına göre düzenlenmiştir. Diğer dağıtımlar için anlatılan işlemlerin karşılıkları için dağıtım hakkındaki açıklamalara başvurabilirsiniz. Slackware dağıtımlarının temin edilebileceği yerler,

    http://www.cdrom.com/titles/slackware.html Slackware dağıtıcısı Walnut Creek
    http://ftp.cdrom.com/pub/slackware Orjinal Slackware FTP arşivi

    Türkiye içerisinde Slackware Dağıtımı bulunduran bazı FTP arşivleri:

    ftp://ftp.metu.edu.tr/pub/sunsite/distributions/slackware ODTÜ
    ftp://ftp.ege.edu.tr/pub/Linux Ege Üniversitesi
    ftp://ftp.akdeniz.edu.tr/pub/linux Akdeniz Üniversitesi
    ftp://ftp.itu.edu.tr/pub/linux/slackware İstanbul Teknik Üniversitesi

    4.1.2. Red-Hat

    Genel dağıtım

    Red Hat Software
    3201 Yorktown Rd, Suite 123 DeKalb Center
    Durham, NC 27713
    İnternet adresi : redhat@redhat.com

    http://www.redhat.com RED-HAT Linux dağıtımı WWW sayfası
    ftp://ftp.redhat.com/pub Orjinal RED-HAT FTP arşivi

    Türkiye içerisinde Red Hat dağıtımı bulunduran FTP arşivleri

    ftp://ftp.ege.edu.tr/pub/linux/redhat Ege Üniversitesi
    ftp://ftp.metu.edu.tr/pub/redhat ODTÜ

    4.1.3. Debian

    Genel dağıtım

    The Debian Linux Association
    Software in the Public Interest
    P.O. Box 70152
    Pt. Richmond CA 94807-0152

    http://www.debian.org Debian Linux dağıtımı WWW sayfası
    ftp://ftp.debian.org/debian Orjinal Debian FTP arşivi

    Türkiye içerisinde Debian dağıtımı bulunduran FTP arşivleri

    ftp://ftp.metu.edu.tr/pub/debian ODTÜ

    4.1.4. InfoMagic

    Genel dağıtım

    InfoMagic, Inc.
    PO Box 30370. Flagstaff, AZ 86003-0370
    Tel: (800)-800-6613 (siparis)
    (520)-526-9852 (teknik destek)
    Fax: (520)-526-9573
    İnternet adresi : info@infomagic.com

    http://www.infomagic.com InfoMagic WWW sayfası

    4.2. Ne Şekilde Bulabilirim ?

    4.2.1. CD-ROM

    Çeşitli dağıtımlara ait CD-ROM'lar Türkiye'de çeşitli bilgisayar firmalarında satılmaktadırlar. Linux aslında ücretsiz bir işletim sistemidir. Alınan ücret CD'nin basımı dağıtımı, ambalajını karşılaması için alınmaktadır. fiyatları kabaca 10$-30$ mertebesinde (bazen birkaç yüz doları da bulabiliyor) değişmektedir. Bazı dağıtımlarda telif kitapların bulunması bu dağıtımları daha pahalı yapabilmektedir. Eğer herhangi bir şekilde bir İnternet erişiminiz yoksa ve bir akademik çevrede değilseniz en pratik Linux elde etme yöntemi CD-ROM'lardır.

    4.2.2. Internet

    Tüm Linux dağıtımları İnternet üzerinde anonim FTP hizmeti ile sunulmaktadır. Ancak bireysel olarak dağıtımın tüm disketlerini bu yolla almak çok pratik olmayacaktır. Örnek olarak son slackware dağıtımı 100 Mb'tan fazla yer kaplamaktadır. İnternet aracıyla dağıtım elde etmek, yerel kullanıcılarına yeni dağıtımlar sunmak isteyen sistem sorumluları için ilginç bir çözüm olmaktadır.

    4.2.3. NFS

    Bir yerel bilgisayar ağına sahip kurumlarda paylaşılan bir disk alanı üzerinden Linux yüklemek mümkündür. Bu sayede CD-ROM veya İnternet aracılığı ile elde edilen bir dağıtım kurumda ortak bir disk alanına yerleştirilir ve ağa bağlı makinalara yükleme yapılabilir.

    Birçok kurumda Linux yüklemek için, geçici olarak bir ethernet kartı takılır, bilgisayar ağ desteği veren bir şekilde açılır ve Linux disketleri bu şekilde ağ üzerinden yapılır.

    4.2.4. Sabit Disk

    Herhangi bir şekilde Linux dağıtımı disketleri bir sabit diske de kopyalanmış olabilir. Bu durumda mevcut sabit disk üzerindeki disketler kullanılarak da yükleme yapılabilir. Bu yöntem yine daha çok eğitim kurumlarında başka kaynaklardan elde edilmiş bir Linux dağıtımını kopyalamak için kullanılır.

    Bir kullanıcı makinasına Linux yüklerken tüm özelliklerini yüklemek istemeyebilir. Yüklediği yazılımların bazılarının gereksiz olduğunu düşünüyorsa ileride bazı uygulamaları kaldırabilir veya sonradan gerekli gördüğü yazılımları dağıtım disketlerinden rahatlıkla ekleyebilir.

    Linux sadece dağıtımlarda bulunan yazılımlarla sınırlı bir işletim sistemi değildir. Dağıtımlarda bulunan yazılımlara ek olarak çok çeşitli başka uygulamalar mevcuttur. (Örnek olarak Netscape çoğu Linux dağıtımında bulunmamaktadır). Bu ek yazılımların birçoğu İnternet üzerinde FTP arşivlerinde bulunmaktadırlar. Kitabın sonundaki ek, Linux uygulama yazılımlarının nerede bulunduğu hakkında geniş bilgi veriyor.

    CD-ROM üzerindeki dağıtımlarda, dağıtımların yanısıra bir çok tanınmış FTP arşivinde yer alan yazılımlar ve çeşitli dokümanlarda yer alır. İnternet bağlantısı olan bir kurumda çalışmayan (veya bu tür bir kuruma erişimi bulunmayan) birisi için CD-ROM çok iyi bir çözümdür.

    İnternet bağlantısı bulunan (özellikle akademik) kurumlarda güncel dağıtımların İnternet üzerinden aktarılması ve buradaki kullanıcılara NFS ve sabit disk üzerinde aktarılması daha pratik bir uygulamadır. Aynı kurumlar kendi çalışma alanları ile ilgili buldukları ek yazılımları da FTP arşivlerinden toparlayabilir ve kullanıcılarına bu ek yazılımları sunabilirler.

    4.3. Sabit Disk Üzerinde Linux İçin Yer Açmak

    Linux işletim sistemini yüklemek için sabit diskiniz üzerinde Linux için bir miktar yer ayırmak zorundasınız. Herhangi bir sabit disk bir işletim sisteminde kullanılabilmesi için ilk olarak bölümlere (partition ) ayrılır. Daha sonra bu bölümler işletim sistemine uygun şekilde formatlanır. Linux işletim sistemi kendi disk formatını (ext2) kullanır. En yüksek verimi sabit disk üzerinde, kendi bölümünde, kendi disk formatı altında çalıştığı zaman verebilir. Eğer ayrı bir bölümlendirme yapılamıyorsa, tavsiye edilmese bile MS-DOS formatlı bir disk üzerinde de Linux kurulabilir (UMSDOS ), ancak bu sistemin performansı diğerine göre oldukça düşük olacaktır. Bu dokümanın geriye kalan tüm kısımlarında bilgisayarınıza Linux yüklemek için sabit disk üzerinde Linux'a özgü bir bölüm ayrılacağı ve bu bölüme yükleneceği kabul edilecektir. MS-DOS formatlı bir disk hiyerarşisi altına Linux kurmak için UMSDOS-HOWTO dokümanından yararlanabilirsiniz. Eğer bilgisayarınızı uzunca bir süredir kullanıyorsanız, büyük bir ihtimalle sabit diskinizin tümünü kullandığınız işletim sistemi için ayrılmış durumdasınızdır. MS-DOS kullanıyorsanız diskiniz bir (sadece C:) veya birden fazla (C: D: ..) bölüme ayrılmış durumda olabilir. MS-DOS altında bir disk üzerinde en fazla 4 temel bölüm olabilir (primary partition). Eğer daha fazla bölüme ihtiyaç varsa temel bölümlerden biri genişletilmiş bölüm olarak ayrılır (extended partition) ve bu bölüm üzerinde mantıksal bölümler ayrılır (logical partitions).

    Bilgisayarınızda birden fazla bölüm varsa bir bölümü boşaltıp bu bölümü Linux için ayırabilirsiniz. Eğer tek bölümünüz varsa, veya mevcut bölümlerinizden birini tümüyle harcamak istemiyorsanız diskinizi yeniden bölümlemeniz gerekecektir. Klasik olarak bu durumda bölmek istediğiniz bölümdeki yazılımların yedeğini almanız, daha sonra MS-DOS altında fdisk yazılımı yardımı ile sözkonusu bölümü silmeniz, yeni boyutu ile yeniden yaratmanız, bu bölümü format komutu ile formatlamanız ve yedeğini aldığınız yazılımları yeniden yerleştirmeniz gerekecektir (Çok iş :) )

    Bazı yazılımlar mevcut bölümünüzü iki parçaya ayırabilirler. Örnek olarak fips bu amaçla kullanılan bir yazılımdır. (Diskiniz üzerinde işlem yapan her yazılım az da olsa disk üzerindeki bilgilere zarar verme riski taşır. Bu tür yazılımlar ile çalışmadan önce önemli olduğunu düşündüğünüz bilgilerin yedeğini almaya özen gösterin). fips , defrag programı kullanıldıktan sonra bölümünüzü sizin belirleyeceğiniz boyutlarda iki bölüme ayırabilir.

    Eğer bilgisayaranızı yeni alıyorsanız veya yeni bir disk alıyorsanız, bu diskin tamamını veya bir bölümünü Linux için kullanabilirsiniz. Bu amaçla diskinizde sadece Linux kullanmak istemediğiniz bölümleri ayırmanız (ve gerisini boş bırakmanız) yeterlidir. Linux bölümlerinin Linux altından formatlanması gerekecektir.
    Linux sabit disk üzerinde bir bölümden fazlasını kullanabilir. Özel olarak normal dosyaların yazılmadığı, hafıza gereken işler sırasında geçici bir alan olması amacıyla Linux bir takas alanına (swap space) ihtiyaç duyar. Bu takas alanı için en verimli çözüm sadece takas işlemi için ayrılmış küçük bir disk bölümü yaratmaktır.

    Yoğun olarak Linux kullanan yerler için standart olarak dağıtımdan gelen işletim sistemini ayrı bir bölüme yüklemeleri kullanıcı alanları (/home) ve sonradan yüklenen yazılımlar (/usr/local) için ayrı bir alan ayırmaları tavsiye edilebilir. Bu sayede, işletim sistemi güncellemek son derece kolaylaşır, yeni işletim sistemi yüklerken sadece işletim sisteminin bulunduğu bölüm üzerinde işlem yapılır ve bu sayede kullanıcı alanlarının veya sonradan (dağıtım dışı) yüklenen yazılımların zarar görmeleri engellenebilir.

    Her bir bölüm için ne kadar yer ayrılacağı hakkında çok şey yazılmıştır. Ne var ki yazılanların birçoğu sabit disklerin nadiren 200 Mb sınırını geçtiği günlerden kalmaktadır. Linux'un kaplayacağı alan, hangi paketleri kullanacağınıza çok bağlıdır. Kabaca her disketin 2-3 Mb arasında yer kaplayacağını düşünerek, yüklemek istediğiniz disketleri hesaplayarak kaba bir tablo çıkarabilirsiniz. Tecrübeli bir Linux kullanıcısı hangi yazılımları kullanıp hangilerini kullanmadığını daha iyi belirleyebilecek durumda olacaktır. Dolayısı ile yeni bir kullanıcı ortalama olarak 300 - 400 Mb kadar bir yer ayırmak isteyecektir. Bu, günümüzün disk kapasiteleri düşünülünce o kadar büyük bir alan değildir.

    Takas alanı konusunda da çok şey yazılmıştır. Birçok kaynak takas bölümü için ayrılması gereken alanının gerçek hafızanın 2 katının biraz fazlası olarak kabul etmektedir. Pratikte 10-60 Mb arasında bir alan fazlasıyla yeterli kalmaktadır. Ancak takas bölmeleri 128 megabaytdan daha büyük olamaz. Eğer 128 Mb'tan daha büyük takas alanı gerekiyorsa birden fazla takas bölmesi yaratmalısınız. Toplam 16 tane takas bölmeniz olabilir.

    Takas alanı kullanırken, bir seferde daha fazla uygulama çalışmanızı sağlayacak şekilde Linux kullanılmayan sayfaları hafızadan diske taşır. Ancak, takas işlemi genelde yavaş olduğundan gerçek fiziksel hafızanın yerini dolduramaz. Ama çok fazla hafıza isteyen uygulamalar (X Window System gibi) eğer yeteri kadar fiziksel hafızanız yoksa takas alanına bel bağlar.

    Tercih olarak, 1.2 Gbyte'lık bir disk üzerinde,

    Linux nedir denemek isteyen bir kişi için
    • Bölüm 1: DOS : 1000 Mb
    • Bölüm 2: Linux : 180-200 Mb
    • Bölüm 3: Linux takas (swap) bölümü : 10-20 Mb
    İşinde arada sırada Linux kullanan birisi için
    • Bölüm 1: DOS : 400 Mb
    • Bölüm 2: Linux : 400 Mb
    • Bölüm 3: Linux takas bölümü : 32 Mb
    • Bölüm 4: DOS (DOS altında D: olarak gözükecek) 400 Mb
    İnternet üzerinde sadece Linux kullanılan bir bilgisayar için
    • Bölüm 1: Linux : 100 Mb
    • Bölüm 2: Linux takas bölümü : 60 Mb
    • Bölüm 3: Linux /usr : 400 Mb
    • Bölüm 4: Linux /home : 600 Mb

    4.4. Bilgisayarın Linux ile Açılması

    Bilgisayarın sabit diski üzerinde yer ayırdıktan, bir Linux dağıtımı bulduktan sonra artık Linux yüklemek için yapılması gereken, yükleme yapmanıza yardımcı olmaya yetecek şekilde bilgisayarınızı Linux altında çalıştırmaktır. Bu amaçla boot ve root disketi adı verilen iki disket kullanılması yeterlidir.Bu disketlerden boot disketi bilgisayarınız üzerindeki donanıma uygun bir Linux çekirdeği (kernel) içerir ve bilgisayarın Linux ile açılmasını sağlar, root disketi adı verilen diğeri ise makinanız Linux olarak açıldığı zaman çalıştıracağı yazılımları içeren ve Linux'un çalışması için gereken sistem programlarını içerir. Bu iki disketi, MS-DOS altındaki sistem disketine benzetmek mümkündür.

    Boot ve root disketleri, Linux dağıtımı ile birlikte gelirler. Eğer bir CD-ROM dağıtımı kullanıyorsanız, büyük ihtimal disketler CD-ROM ile beraber geleceklerdir. Eğer dağıtımı İnternet'ten alıyorsanız bu disketler bir disket görüntüsü olarak bulunacaklardır. Yapmanız gereken bu disket görüntülerini normal disketlere bu amaç için yazılmış bir yazılımla aktarmak ve açılış disketlerini oluşturmaktır. Bunun için RAWRITE.EXE programını kullanabilirsiniz.
    Root disketi için genelde bir veya iki seçenek bulunmaktadır. Genelde kullanılan disket color.gz adını alır.

    Boot disketi için aynı şeyi söylemek mümkün değildir. Zira boot disketi Linux çekirdeğini içermektedir. Her işletim sistemi, o işletim sistemi altında çalışacak olan bilgisayar üzerindeki donanıma erişebilmek için bazı destekler içerir. Ne var ki her donanım kendisine göre bir takım farklılıklar gösterir. Linux bilgisayarınız üzerinde bulunan birçok donanım için destek verebilir, ne var ki tüm donanım desteğini tek bir çekirdekte toplamak çekirdeğin gereksiz yere büyümesine ve hantallaşmasına neden olacaktı (Bilgisayarınızda ses kartı donanımı yoksa çekirdeğin ses kartı desteğine ihtiyacınız olmayacaktır, yapılan sadece gereken destekleri ekleyerek çekirdeğin verimini artırmak demektir). Linux çekirdeği gerektiğinde destek verdiği donanımları destekleyecek şekilde güncellenebilir. Ancak Linux yükleyebilmek için, seçeceğiniz yükleme yöntemine göre bazı donanımlara destek vermesi gereklidir. Örnek vermek gerekirse, NFS üzerinden Linux yüklemek için çekirdek içerisinde mutlaka ağ (network) desteğinin olması gerekmektedir ama ses kartı desteğinin olmasına gerek yoktur. Linux yükledikten sonra derleyeceğiniz bir çekirdeğe ses kartı desteği vermesini sağlayabilirsiniz.

    Bir işletim sisteminin sabit diske yüklenme aşamasında kullanıcıya sağlayacağı en büyük kolaylık, deneyimli kullanıcılar için tüm paketleri kurmadan önce sormak, Linux'u bilmeyen ve sabit diskine Linux kurmak isteyen yeni kullanıcılar için ise kurulum aşamasını mümkün olan en az soru ile bitirip daha önceden belirlenmiş birtakım paketleri otomatik olarak yüklemektir.

    Çok farklı donanımların olması Linux yükleyebilmek için bir dizi boot disketinin oluşmasına neden olmuştur. Güncel bir Linux dağıtımında hangi boot disketlerinin hangi donanımlara destek verebildiğini görmek için ilgili dağıtımla gelen README dosyalarına bakmak gerekecektir. Şu anki Slackware dağıtımı ile gelen boot disketlerinden bazıları

    • bare.i IDE sabit disklere, sabit disk veya IDE/ATAPI CD-ROM'lardan yükleme yapmak için
    • net.i IDE sabit disklere, NFS üzerinden yükleme yapmak için
    • scsinet.s SCSI sabit disklere, NFS üzerinden yükleme yapmak için. Buna ek olarak değişik SCSI denetçileri için 25 kadar değişik boot disketi bulunmaktadır.
    • xt.i Bu açılış disketinde sadece IDE ve XT sabit disk sürücüleri vardır.

    Boot ve root disketlerinizi de elde ettikten sonra artık bilgisayar ilk defa Linux altında çalışmak için hazırdır. Boot disketini takarak sistemi açın (PC'nin açılma sırasının A:,C: olmasına dikkat edin). Disket açılır açılmaz yaklaşık bir sayfalık bir mesaj verecek ve kullanıcıdan ek bir parametre isteyip istemediğini soracaktır. Bu noktada çalışacak olan çekirdeğe birçok ek parametre verilebilir. Eğer herşey yolunda giderse bu noktada özel bir parametre belirtmeye gerek kalmayacaktır. Boot disketi parametreleri hakkında BootPrompt-HOWTO içerisinde detaylı bilgi bulabilirsiniz. Bu aşamayı geçtikten sonra çekirdek yüklenmeye başlayacak ve bir dizi mesaj geçecektir. Bu mesajlar çekirdeğinizin bilgisayar üzerindeki donanımları tanıması ve çeşitli hizmetleri çalıştırması ile ilgili mesajlardır. Çekirdeğin donanımınızı ne şekilde tanıdığı bu mesajlardan anlaşılır. Yükleme yapabilmek için çekirdeğin sabit diskinizi ve ağ bağlantısı kullanacaksanız ethernet kartınızı doğru olarak tanımış olması gerekecektir.

    Daha sonra kullanıcıdan root disketini yüklemesi için bir mesaj çıkacaktır. Bu aşamada boot disketi yerine root disketi takılmalıdır. Kısa bir yüklemeden sonra bir mesaj çıkacak ve ardından

    login:
    mesajı ile karşılaşılacaktır. Tebrikler ! Artık Linux altında çalışmaya başlayabilirsiniz. Bilgisayar şu anda sizden bir kullanıcı ismi beklemektedir. 'root' yazarak sisteme girin.

    4.4.1. Ön Hazırlıklar

    Slackware dağıtımında yükleme işi için

    Setup
    isimli bir yazılım bulunmaktadır. Yüklemenin her aşaması bu yazılım tarafından yürütülebilir. Ancak ilk olarak Linux için disk alanlarının tanımlanması gerekmektedir. Bu amaçla

    fdisk
    programı kullanılır. Linux altında bir bilgisayar bağlı her türlü cihaza bir dosya gibi erişmek mümkündür. Her cihaza karşılık gelen bir sistem dosyası mevcuttur. Cihazlarla ilgili dosyalar (düğümler) /dev dizini altında yer alırlar. Burada IDE sabit diskler "hd" SCSI sabit diskler "sd" olarak isimlendirilirler. Aynı anda bir bilgisayarda birden fazla disk bağlanmış olabilir. Diskler sırayla a b c d olarak isimlendirilirler. Her disk üzerinde birden fazla bölüm yer alabilir. bu bölümler ise 1 2 3 4 olarak numaralandırılırlar. Örnek olarak

    • /dev/hda, bir numaralı IDE (Primary Master) diski
    • /dev/hda1, bir numaralı IDE diskin ilk bölümü ( DOS altında C:)
    • /dev/hda2, bir numaralı IDE diskin ikinci bölümünü
    • /dev/hdb, iki numaralı IDE (Primary Slave) diski
    • /dev/hdc, üç numaralı IDE (Secondary Master) diski
    • /dev/hdd, dört numaralı IDE (Secondary Slave) diski
    • /dev/sdb3, ikinci SCSI sabit diskin üçüncü bölümünü

    göstermektedir. Birden fazla sabit diskiniz varsa hangi sabit diskle ilgileneceğinizi belirtmeniz gerekir. Eğer iki sabit diskiniz varsa fdisk'i kullanırken dikkat edin, her an yanlış bir diski formatlama şansınız var.

    # fdisk /dev/hda

    Bu noktadan sonra artık fdisk ile istediğiniz bölümleri tanımlamanız mümkündür.

    fdisk komutu sabit disk bölümlerinin düzenlenmesi için kullanılan bir yazılımdır. Komut satırından genelde tek harflik komutlarla kullanılır. Eğer komut satırında bir parametre verilmezse fdisk ilk bulduğu disk üzerinde işlem yapacaktır. Birden fazla disk mevcutsa komut satırında istenilen diskin belirtilmesi gerekecektir. Aşağıdaki örnekte fdisk herhangi bir parametre ile çağrılmamış ve sistemde bulunan öncelikli disk olarak bir numaralı SCSI disk (/dev/sda) seçilmiştir.

    fdisk, komutunun yanında bazı parameteler alır:

    • /fdisk -v : fdisk programının sürümü ekrana gelir.
    • fdisk -l : /dev/hda, /dev/hdb, /dev/sda, /dev/sdb, /dev/sdc, /dev/sdd, /dev/sde, /dev/sdf, /dev/sdg ve /dev/sdh disklerinin (varsa) bölümlendirme tablosunu ekrana yazar ve çıkar.
    • fdisk -s <disk-bölümü> : Eğer bir DOS bölümü değilse (bölüm numarası 10'dan büyük) , sözkonusu disk bölümünün büyüklüğü bayt cinsinden ekrana yazılır.

    4.4.2. Örnek FDISK Çalışması

    Bu örnek içerisinde 1 Gb'lık SCSI sabit diske sahip bir makina üzerinde LINUX için gerekli kısımların ayrılması adım adım incelenmiştir. Sözkonusu sabit disk üzerinde kullanıcı önceden 400 Mb'lık bir kullanıcı alanı tanımlamış ve geri kalan alanı LINUX için ayırmıştı. Düşünülen dağılım:
    • 400 Mb DOS
    • 250 Mb LINUX işletim sistemi
    • 60 Mb Takas alanı
    ve geri kalan alan LINUX altında kullanıcı alanı.

    fdisk programı çalışır çalışmaz ilk iş olarak mevcut bölümler hakkında bilgi almak için p komutunu ( Print Partition Info) kullanıyoruz.

    Command (m for help): p

    Disk /dev/sda: 34 heads, 61 sectors, 1017 cylinders
    Units = cylinders of 2074 * 512 bytes

    Device Boot Begin Start End Blocks Id System
    /dev/sda1 * 1 1 395 409584+ 6 DOS 16-bit >=32M

    Bu tablo bize sadece tek bölüm ayrıldığını, ayrılan alanın DOS formatında olduğunu, önyüklenecek bölüm olduğunu belirtiyor. Bölümün adı /dev/sda1, yani ilk SCSI sabit disk üzerinde tanımlanan ilk bölüm. İlk iş olarak LINUX işletim sistemi için yeni bir bölüm yaratmalıyız.

    Command (m for help): n
    Command action
    e extended
    p primary partition (1-4)
    p
    Partition number (1-4): 2
    First cylinder (396-1017): 396
    Last cylinder or +size or +sizeM or +sizeK ([396]-1017): +250M

    n komutu ile kendimize yeni bir bölüm yarattık. İlk seçenek temel bir disk bölümümü yoksa gelişmiş bir disk bölümü üzerinde mi işlem yapacağımızı sordu. Temel bir bölüm için p komutunu girdik. Daha sonra hangi bölümü yaratacağımızı sordu. Halen mevcut 1 bölüm var, bu bölüm ikinci bölüm olacak bu yüzden 2 yazdık.
    Bölümün başlangıç adresini giriyoruz. Bu değer otomatik olarak bir önceki bölümün bitiş değerinden hesaplanmaktadır. Sadece onaylıyoruz. Daha sonra istediğimiz boyutu belirtiyoruz. +250M tanımı 250 Mb'lık bir kısım istediğimizi belirtiyor. Yarattığımız bu bölümü p komutu ile inceliyoruz

    Command (m for help): p

    Disk /dev/sda: 34 heads, 61 sectors, 1017 cylinders
    Units = cylinders of 2074 * 512 bytes

    Device Boot Begin Start End Blocks Id System
    /dev/sda1 * 1 1 395 409584+ 6 DOS 16-bit >=32M
    /dev/sda2 396 396 642 256139 83 Linux native

    fdisk yaratılan her bölümü otomatik olarak (LINUX native) olarak yaratmaktadır. Şimdi takas alanı için 60 Mb'lık 3. temel bölümü tanımlayalım:


    Command (m for help): n
    Command action
    e extended
    p primary partition (1-4)
    p
    Partition number (1-4): 3
    First cylinder (643-1017): 643
    Last cylinder or +size or +sizeM or +sizeK ([643]-1017): +60M

    Command (m for help): p

    Disk /dev/sda: 34 heads, 61 sectors, 1017 cylinders
    Units = cylinders of 2074 * 512 bytes

    Device Boot Begin Start End Blocks Id System
    /dev/sda1 * 1 1 395 409584+ 6 DOS 16-bit >=32M
    /dev/sda2 396 396 642 256139 83 Linux native
    /dev/sda3 643 643 702 62220 83 Linux native

    Dikkat edilecek olursa bu bölüm de LINUX native olarak tanımlandı. LINUX tarafından takas bölümü olarak kullanılacak olan bölümler farklı bir yapıya sahiptirler ve ayrıca tanımlanmaları gerekmektedir. Bu amaçla t komutu ile herhangi bir bölümün tipini değiştirmek mümkündür. (Tip değiştirmekle o bölümün yapısı (formatı) değişmiş olmuyor, format sonradan yapılan bir işlemdir)

    Command (m for help): t
    Partition number (1-4): 3
    Hex code (type L to list codes): 82
    Changed system type of partition 3 to 82 (Linux swap)

    Command (m for help): p

    Disk /dev/sda: 34 heads, 61 sectors, 1017 cylinders
    Units = cylinders of 2074 * 512 bytes

    Device Boot Begin Start End Blocks Id System
    /dev/sda1 * 1 1 395 409584+ 6 DOS 16-bit >=32M
    /dev/sda2 396 396 642 256139 83 Linux native
    /dev/sda3 643 643 702 62220 82 Linux swap

    Yukarıda yapılan işlemle 3 numaralı bölümün tipini Linux swap olarak değiştirmiş olduk. Şu anda üç farklı türden alanımız mevcut. Son bölümü de yine n komutu ile ekleriz.

    Command (m for help): n
    Command action
    e extended
    p primary partition (1-4)
    p
    Partition number (1-4): 4
    First cylinder (703-1017): 703
    Last cylinder or +size or +sizeM or +sizeK ([703]-1017): 1017

    Command (m for help): p

    Disk /dev/sda: 34 heads, 61 sectors, 1017 cylinders
    Units = cylinders of 2074 * 512 bytes

    Device Boot Begin Start End Blocks Id System
    /dev/sda1 * 1 1 395 409584+ 6 DOS 16-bit >=32M
    /dev/sda2 396 396 642 256139 83 Linux native
    /dev/sda3 643 643 702 62220 82 Linux swap
    /dev/sda4 703 703 1017 326655 83 Linux native

    Bu örnekte boyut Mb cinsinden verilmedi. Zaten amaç kalan alanı tümüyle kullanıcı alanı olarak ayırmaktı. Bu nedenle son silindirin numarasının girilmesi yeterli oldu. Artık yapılması gereken bu bilginin diske yazılmasıdır. Şu ana kadar yapılan hiç bir değişiklik sistem üzerinde herhangi bir etki yapmamıştır. Yanlız her tür formatlama için geçerli bir kural burada da mevcuttur : Bölümleme bilgisi diske yazıldıktan sonra geri dönüş yoktur ve bölümleme yaptığınız disk bölümü üzerindeki bilgileri kaybedersiniz. Lütfen yaptığınız değişiklikleri bir kez daha gözden geçirin!

    Command (m for help): w
    The partition table has been altered!

    Calling ioctl() to re-read partition table.
    (Reboot to ensure the partition table has been updated.)
    Syncing disks.
    Reboot your system to ensure the partition table is updated.

    Sabit diski bölümleme esnasında karşılaşılan bazı sorunlar vardır. Bunların en önemlisi Linux'un nasıl çalıştırılacağı ile ilgilidir. Linux açmak için belli başlı üç yöntem vardır:

    • LILO ile bir boot menüsünden
    • DOS altından LOADLIN isimli bir yazılımla
    • Yüklemek için yapıldığı gibi bir boot diskiyle

    Son iki yöntem herhangi bir sınırlama getirmezken ilk yöntemin bir sınırlaması vardır. LILO isimli yazılım ile kullanıldığı zaman bilgisayar açıldığı zaman minik bir yazılım çalıştırır ve gerektiğinde Linux çekirdeğini yükler. Ancak çekirdek yüklenmesine kadar geçen süre içerisinde sistemin BIOS komutları çalışır. Bu komutların önemli bir sınırlaması bir disk üzerindeki bir yazılımı belirleyen üç parametreden (silindir sayısı , kafa numarası , sektör numarası ) silindir sayısının en fazla 1024 ile sınırlı olmasıdır. Bu bakımdan LILO kullanılacaksa Linux çekirdeğinin yer alacağı bölüm bu 1024 numaralı silindir sınırının altında kalmalıdır. Bu sınırlama tamamıyla DOS'un kullandığı BIOS'un bir sınırlamasıdır. Yeni BIOS'lar bu sınırlamadan kurtulmak için LBA adı verilen bir yöntem kullanırlar. Bu yöntemin temelinde BIOS'ta kafa sayısı için gereksiz yere ayrılan kısımların silindir sayısını belirtmek için kullanılmasıdır. (BIOS, bir sabit disk için 64'e kadar kafa kabul edebilmektedir. Pratik olarak 15 kafadan fazla sabit diskin üretilmesi çok zor olduğu için yapılan kafa sayısını iki veya dört ile çarparak, silindir sayısını iki veya dörde bölmektir.) Böylelikle 1654 silindirli 16 kafalı bir sabit disk, LBA olarak 827 silindirli ve 32 kafalı olarak tanımlanabilmektedir. İkinci durumda bu disk üzerinde tanımlanabilecek her bölümün yukarıda belirtilen sınırlama içerisinde kalacağına dikkat ediniz.

    4.4.3. Setup Programı

    Disk üzerindeki tanımlamaları da bitirdikten sonra artık setup yazılımı çalıştırılabilir. Setup Linux yüklemek için gereken temel birçok işlemi yapabilir. Ok tuşları yardımı ile menüler arasında gezerek işlemleri tamamlayabilirsiniz. Burada yukarıdan aşağıya doğru bir sıra izleyebilirsiniz.

    Şu anki güncel Slackware dağıtımının setup komutu çalıştırılınca ekrana gelen menüleri aşağıdadır.

    Welcome to Slackware Linux Setup.

    Hint: If you have trouble using the arrow keys on your keyboard,
    you can use ''+'', ''-'', and TAB instead. Which option would you like?

    HELP Read the Slackware Setup HELP file
    KEYMAP Remap your keyboard
    MAKE TAGS Tagfile customization program
    TARGET Select target directory [now: /]
    SOURCE Select source media
    DISK SETS Decide which disk sets you wish to install
    INSTALL Install selected disk sets
    CONFIGURE Reconfigure your Linux system
    PKGTOOL Install or remove packages with Pkgtool
    EXIT Exit Slackware Linux Setup

    < OK > <Cancel>

    • HELP Menüsü : Setup programı hakkında bazı ipuçları verecektir.

    • KEYMAP Menüsü : Bu menü ile Amerikan klavye dışında bir klavye tanımlamak mümkün olacaktır. Henüz türkçe q veya f klavye desteği bulunmamaktadır.

    • MAKE TAGS Menüsü : Bu menü yardımı ile dağıtım disketlerinde özel uzantılı dosyalar hazırlayarak hangi paketlerin yükleneceğini otomatik olarak belirlemek mümkündür. Bu sayede eğer benzer makinalar yüklenecekse yüklenecek paketler bir kere belirlenir ve bir daha menülerden ekstradan paketlerin seçilmesine gerek kalmaz. Büyük ihtimalle buraya kadar henüz bir takas alanı tanımlamamışsınızdır. Setup yazılımı bu durumu anlar ise bir takas bölmesi oluşturulması için aşağıdaki menüyü ekrana getirecektir.

    • ADDSWAP Menüsü : fdisk ile ayırdığınız takas bölümünü uygun şekilde formatlar ve bu bölümü kullanıma açar. Setup yazılımı hangi disk bölümünün takas bölümü olarak ayrıldığını otomatik olarak bulacaktır. Daha sonra sözkonusu alanları form atlayacak ve bu takas alanını sistem belleğine ekleyecektir. (Her adımda bir onay isteyecektir)

    • TARGET Menüsü : Linux'un hangi bölüme yükleneceğini belirler. Bu menüye girildiği zaman Linux'un disk formatına (ext2) sahip (sabit disk bölümü numarası 83 olan) tüm disk bölümleri gösterilecek ve içerlerinden hangisine Linux kurulması istenileceği sorulacaktır. Bu aşamadan sonra o disk bölümü kullanıcı isterse formatlanacaktır. Burada iki format seçeneği vardır. Bu seçeneklerin ikincisinde disk önce hatalar için taranacak daha sonra formatlanacaktır. Eğer Linux disk formatında başka bölümler varsa bu bölümlerin kullanılmasının istenip istenmediği sorulacaktır. Bu sayede disk hiyerarşisinin herhangi bir kısmını bu ek disk bölümleri üzerine kurmak mümkündür. Son olarak Linux tarafından desteklenen başka disk bölümleri varsa (Örneğin DOS) bu bölümlere Linux altından erişim yapılmasının istenip istenmediği sorulacak ve bu bölümler için hiyerarşi içerisinde bir dizin atanması istenecektir.

    • SOURCE Menüsü : Bu menü Linux dağıtımının nerede aranması gerektiğini belirler. Buradaki seçenekler


    SOURCE MEDIA SELECTION

    Where do you plan to install Slackware Linux from?


    1 Install from a hard drive partition
    2 Install from floppy disks
    3 Install via NFS
    4 Install from a pre-mounted directory
    5 Install from CD-ROM

    • 1 Numaralı seçenek, Linux dağıtımını bir sabit disk bölümünde aramak için kullanılacaktır. Bu seçenekle örnek olarak DOS kısmında bulunan dağıtım disketlerinden yükleme yapılabilir.
    • 2 Numaralı seçenek, disketlerden yükleme yapmaktır. Çalışır bir sistemi birkaç disketle oluşturmak mümkündür. Ancak günümüzde pek tercih edilen bir yöntem değildir.
    • 3 Numaralı seçenek, NFS üzerinden yükleme yapmak için kullanılmaktadır. Burada bilgisayarın bir yerel bilgisayar ağına bağlı olması, Bu bilgisayar ağı üzerindeki bir sunucu üzerinde erişim izni bulunan bir dizin altında dağıtım disketlerinin bulunması gerekmektedir. Bu seçenekle yükleme yapmak için boot disketi içerisinde yer alan diskette ağ desteğinin bulunması gerekmektedir. Bu seçeneğin ardından bilgisayarın (geçici) IP numarası varsa ağ üzerindeki yönlendiricinin (router-gateway) IP numarası, ağ maskesi (subnet mask), NFS sunucusu IP numarası ve sunucu üstünde dağıtım disketlerinin bulunduğu hiyerarşi gibi ağ ile ilgili parametreler sorulacaktır. Bu soruların cevabını sistem yetkilisinden öğrenmeniz ve onun onayını almanız gerekecektir.
    • 4 Numaralı seçenek, aslında 1 numaralı seçeneğe çok benzemektedir. Aradaki fark bu durumda sistem hiyerarşisine bağlanmış (mounted) bir dizin içerisinde dağıtım disketlerinin bulunmasıdır.
    • 5 Numaralı seçenek ise CD-ROM'dan yükleme yapmak içindir.

    Elimizde bir CD sürücü ve Slackware CD-ROM bulunduğunu farzedelim. Bu durumda 5. seçeneği girmemiz gerekir. CD'nin içindeki alt dizinlerin tamamı /cdrom dizini altına yerleşecektir. Linux sistemini oluşturan disket setleri de elinizdeki CD'nin en üst dizin hiyerarşisi içinde yeralması beklenen slakware dizini altında olmalıdır.

    Kurulum disketleri CD'nizi otomatik olarak tanıyacaktır.

    Eğer disket setlerini İnternet üzerinden (NFS) indiriyor iseniz, önce NFS sunucunuzun adresini (IP numarası olarak), ardından sunucu üzerinde yeralan Slackware dizinini yazmalısınız. Sistem yöneticiniz NFS ve İnternet üzerindeki Slackware NFS sunucuları hakkında daha geniş bilgi verecektir.

    • DISKSETS Menüsü Artık nereye ve nereden yükleyeceğiniz belirlenmiştir. Sıra yüklemek istediğiniz disket serilerini seçmeye gelmiştir. Disk serileri:

    CUS Also prompt for CUSTOM disk sets
    A Base Linux system
    AP Various Applications that do not need X
    D Program Development (C, C++, Lisp, Perl, etc.)
    E GNU Emacs
    F FAQ lists, HOWTO documentation
    K Linux kernel source
    N Networking (TCP/IP, UUCP, Mail, News)
    T TeX typesetting software
    TCL Tcl/Tk script languages
    X XFree86 X Window System
    XAP X Applications
    XD X Server development kit
    XV XView (OpenLook Window Manager, apps)
    Y Games (that do not require X)

    1. A Serisi (8 disket) : Temel işletim sistemi bu disketlerde yer alır. Temel disk hiyerarşisi yaratılır, sistemin çalışması için hayati olan yazılımlar, terminal yazılımları, kabuklar (shell), disk düzenleme yazılımları, kütüphaneler, Linux çalıştırmak için LILO ve LOADLIN bu disketlerdedir.

    2. AP Serisi (5 disket) : X Window ortamı gerektirmeyen uygulama yazılımlar. Metin editörleri, ghostscript, kılavuz sayfaları, midnight commander (Norton commander benzeri bir yazılım) bu disketlerde yer alır.

    3. D Serisi (13 disket) : Tüm programlama dilleri ve destek yazılımları bu disketlerde yer alır. Eğer kendinize yeni bir Linux çekirdeği derlemeyi düşünüyorsanız bu seriye ihtiyacınız var.
    4. E Serisi (8 disket) : EMACS editörü.
    5. F Serisi (2 disket) : Linux hakkında birçok doküman ve açıklama bu disketlerde yer almaktadır. Yeni başlayan birisinin bu disketleri mutlaka yüklemesi gerekir. Söz konusu dokümanlar sıkıştırılmış halde

    /usr/doc
    /usr/doc/faq
    /usr/doc/faq/HOWTO

    dizinlerine yüklenecektir. Birçok kullanıcı cevap aradığı soruların birçoğunun zaten makinalarında hazır bulunduğunu sonradan öğrenince çok şaşırmaktadır. Dökümanlar sıkıştırılmış olduklarından

    zless
    gibi sıkıştırılmış dosyaları destekleyen bir yazılımla okunmaları gerekir.

    6. K Serisi (6 disket) : Çekirdeğin kaynak kodu burada bulunur. Eğer kendi donanımınıza uygun bir çekirdek derlemek istiyorsanız bu seriye muhakkak ihtiyaç duyacaksınız. FTP arşivlerinden kaynak kodu olarak bulacağınız bazı yazılımlar da bu hiyerarşi altında yer alan bazı dosyalara ihtiyaç duyacaklardır.

    7. N Serisi (6 disket) : Ağ desteği bu disketler ile sağlanmaktadır. E-posta okuma yazılımları, lynx, www sunucusu, haber grubu (öbeği) okuma yazılımları bu disketlerin içerisinde yer alan yazılımlardır.

    8. T Serisi (9 disket) : TeX. TeX yüklerken üç temel seçenekle karşılaşacaksınız. İlk seri seçenek hangi TeX yardımcı paketlerini isteyeceğinizi sorar, ikinci seçenekler hangi dil için makro tanımları istediğinizi sorar, son seçenek ise yazı tipleri hakkında tercihlerinizi sorar. (Burada gerçekten çok fazla seçenek var)
    9. TCL Serisi (2 disket) : X Window altında kullanımı basit bir programlama dili ve bu dili ile yazılmış bazı uygulama yazılımları (tkdesk)

    10. X Serisi (16 disket) : X Window desteği. Bu disketlerin büyük kısmı değişik grafik kartları için X window sunucuları ve yazı karakterlerinden oluşmaktadır. Linux yüklediğiniz bilgisayar üzerindeki grafik kartını bilmeniz ve buna uygun bi r sunucu seçmeniz gerekmektedir.

    11. XAP Serisi (4 disket) : X window altında çeşitli uygulamalar: satranç, gnuplot, xv, xfileman, windows95 benzeri X Window arayüzü bu seriler içerisinde yer almaktadır.

    12. XD Serisi (3 disket) : Xserver geliştirmek için kütüphaneler ve uygulama yazılımları

    13. XV Serisi (3 disket) : OpenLook desteği veren yazılımlar. Bu sayede X Window altında Sun bilgisayarlarda yer alan OpenWindows benzeri bir ortam kullanılabilir.

    14. Y Serisi (1 disket) : Minik birkaç oyun. (özellikle bog) Seçtiğiniz disk serileri ilgi alanınızı genel olarak belirler. Her seri içerisinde birçok yazılım pakedi yer almaktadır. Bu paketlerden istediklerinizi yükleyebilirsiniz.

    • INSTALL Menüsü Seçtiğiniz disk serilerini belirlediğiniz kaynaktan, belirtilen hedef disk bölümüne aktarır. Disk serileri içerisinde yer alan paketleri ne şekilde yüklemek istediğiniz konusunda birtakım seçenekleriniz olacaktır. Bunlar:

    NORMAL Use the default tagfiles for verbose prompting
    MENU Choose package subsystems from interactive menus
    CUSTOM Use custom tagfiles in the package directories
    PATH Use tagfiles in the subdirectories of a custom path
    EXPERT Choose individual packages from interactive menus
    NONE Use no tagfiles - install everything

    NORMAL : Sistem her disk serisi içerisindeki paketleri 'gerekli (required)', 'tavsiye edilir (recommended)' ve 'seçime bağlı (optional)' olarak sınıflar. Bu seçenek ile gerekli paketler yüklenir, diğer paketler için kısa bir açıklama yazılır ve kullanıcının fikri sorulur. İlk yüklemeler için tavsiye edilen bir seçenektir. Ancak özellikle T serisi insanın sabrını taşıracak derecede çok ufak tefek paket yüklemekte ve her paketi sormaktadır (mesela klingon yazıtiplerini yüklemek isteyip istemediğinizi soruyor, bilmeyenler için klingonlar uzay yolu dizisindeki kötü uzaylı yaratıklardır!)

    MENU ve EXPERT : Bu seçeneklerde her disk serisi yüklenmeye başlanırken o seride yer alan tüm paketler bir menü içerisinde görülür. Kullanıcı istediği paketleri işaretler ve bunların yüklenmesini sağlar.

    CUSTOM ve PATH : Daha önce belirtilen TAGFILE dosyaları yardımıyla yükleme yapmak için kullanılır. Bu durumda belirli bir uzantıya sahip dosyalar içerisinde (TAGFILE) yüklenmesi gereken yazılımlar belirtilir. Bu seçenek ile TAGFILE'ların uzant ısı belirtilir ve o uzantılı dosyalarda bulunan paketler yüklenir.
    NONE : Tembellerin seçeneği. Her şeyi kuracaktır. Sadece belirli paketler için anlamlıdır. Zira birçok paket içerisinde içinden seçilmesi gereken seçenekler mevcuttur. (Mesela Xserver 10 seçenek arasından seçilecektir)
    Bu noktadan sonra artık yükleme başlayacaktır.

    4.4.4. Konfigürasyon

    Yükleme bittikten sonra yapılacak iş artık sisteminiz için tanıtımlarınızı yapmaktır. Bu işlemin ilk aşaması sistemi açacak bir çekirdek belirlemektir. Bu konuda üç seçeneğiniz var:

    Bootdisk Use the kernel from the installation bootdisk
    cdrom Use a kernel from the Slackware CD
    floppy Install a zimage or bzimage file from a DOS floppy

    Bootdisk : Bu seçenekte yüklemede kullandığınız çekirdek boot disketinden kopyalanacaktır. Sisteminizi yükleyebildiğinize göre bu çekirdek ile çalışabilirsiniz. Eğer bir değişiklik yapmamışsanız bu anda sürücü içerisinde boot disketi değil root disketi bulunuyor olmalı, değiştirmeyi unutmayın!

    CD-ROM : Slackware CD-ROM'unda bulunan önceden derlenmiş çekirdeklerden herhangi birini seçebilirsiniz.

    Floppy : herhangi bir DOS disketinde yer alan çekirdeği yüklemenizi sağlar.
    Daha sonra sisteminiz için bir boot disketi yaratmak isteyip istemediğiniz sorulacaktır. Ne olursa olsun, elinizin altında her zaman bir boot ve root disketi bulundurmak zorundasınız. Herhangi bir sorun olduğunda sisteminizi açmak için bir boot disketi bulmanız gerekecektir. Bunun için yükleme sırasında kullandığınız boot ve root disketlerini de kullanabilirsiniz.

    Ardından setup size modem, mouse, CD-ROM, bulunduğunuz zaman dilimini soracak ve

    Liloconfig

    yazılımı çalışacaktır. LILO, Linux Loader (Linux yükleyicisi) kelimelerinden meydana gelir. LILO Linux yüklemek için kullanılan çok pratik ve etkili bir yazılımdır. Bilgisayar açılır açılmaz, boot eden ilk sabit diskin üzerinde (boot partition) kendini yazar, bilgisayar açılır açılmaz, birden fazla işletim sistemi için seçenek sunabilir. Konfigürasyon sırasında LILO kendisinin nereye yazılacağını sorar, bu seçenekler arasında

    1. The Master Boot Record of your first hard drive
    2. The superblock of your root Linux partition
    3. A formatted floppy disk

    yeralır.

    1 numaralı seçenek, birçok uygulamada kullanılacak olan seçenektir. MBR bir bilgisayar açarken ilk bakılan yerdir.

    2 numaralı seçenek, MBR'yi kullanmamaktadır. Bunun sebebi, MBR üzerinde bir başka işletim sisteminin benzer bir yazılımının bulunması olabilir. (örneğin OS/2 Bootmanager)

    3 numaralı seçenek'te LILO kendisini bir diskete yükleyecektir. Bu disketten açıldığı zaman menü ortaya çıkacaktır.
    Daha sonra boot işlemi sırasında çekirdeğe gönderilecek ekstra parametreler belirtilebilir. Birçok sistem için bu tür bir parametre gereksizdir. Bu parametre boot diski ile açıldığı zaman sorulan parametrenin aynısıdır. Sonraki seçenek LILO'nun yükleme sırasındaki davranışını belirler. LILO konfigürasyonu sırasında birden fazla boot edebilecek sabit disk bölümü tanımlanabilir. Shift, control, veya alt tuşuna basıldığı zaman LILO mevcut bölümler için bir liste çıkaracaktır. LILO için tanımlı dört davranış vardır:


    1 -- None, don't wait at all - boot straight into the first OS
    2 -- 5 seconds
    3 -- 30 seconds
    4 -- Present a prompt and wait until a choice is made without timing out

    1 numaralı seçenek hiç beklemeden doğrudan listede belirtilen ilk işletim sistemini yükleyecektir. Sadece Linux bulunan bilgisayarlar için kullanılan seçenek budur.

    2 ve 3 numaralı seçenekler sırasıyla 5 ve 30 saniye beklerler, eğer bu süre içerisinde Shift tuşuna basılmazsa ilk sırada yer alan işletim sistemini yüklerler.

    4 numaralı seçenek bir işletim sistemi seçilene kadar bekler.
    Daha sonra sırasıyla yüklenmesini tercih ettiğiniz disk bölümlerini tanıtabilirsiniz. LILO her bölüm için sizden ayıredici bir kelime isteyecektir. LILO yükleme anında sizden komut beklerken bu kelimeye göre işletim sistemi yükleyecetir.

    4.4.5. Makinayı Açmak

    Linux yükleme işlemi sona erdi. Artık bundan sonra sıra makinanızı Linux çalışacak şekilde çalışmasını sağlamaktır. Bunun için temel olarak iki değişik yöntem mevcuttur:

    • LILO : en çok kullanılan en pratik açılış şekli. Burada bilgisayar açıldığı zaman isteğe göre bir süre bekler ve bu esnada shift,tab veya control tuşuna basılırsa birden fazla işletim sistemi ile çalıştırma seçeneği sunar.

    • LOADLIN : Dos altından çalışan bir yazılımdır. DOS altında çalışırken Linux yüklemenize yarar. Eğer kurulum aşamasında LOADLIN pakedini (A serisi disketler içinde ) seçmişseniz bu paket /root dizini altında LOADLIN.ZIP ismi ile kaydedilmiş olacaktır. Yapmanız gereken bu yazılımı ve mevcut çekirdeğinizi (/vmlinuz ) DOS kısmına aktarmaktır.


    Aşağıda yer alan örnekte,
    1. IDE bir sabit disk kullanıldığı
    2. /dev/hda1'in DOS olduğu
    3. /dev/hda3 üzerine Linux yüklendiği
    4. DOS kısmına (henüz) Linux altından erişilemediği
    5. Makinanın Linux olarak açılmış olduğu

    varsayılmıştır.

    # ls /root
    lodlin16.txt lodlin16.zip
    # mkdir /dos
    # mount -t msdos /dev/hda1 /dos
    # cd /dos
    # unzip /root/lodlin16.zip
    Archive: lodlin16.zip
    creating: loadlin/
    inflating: loadlin/readme.1st
    inflating: loadlin/loadlin.exe
    inflating: loadlin/copying
    inflating: loadlin/test.par
    inflating: loadlin/linux.bat
    extracting: loadlin/initrd.tgz
    inflating: loadlin/files
    creating: loadlin/doc/
    inflating: loadlin/doc/changes
    inflating: loadlin/doc/announce.txt
    inflating: loadlin/doc/lodlin16.lsm
    inflating: loadlin/doc/quicksta.rt
    inflating: loadlin/doc/initrd.txt
    inflating: loadlin/doc/manual.txt
    inflating: loadlin/doc/params.doc
    creating: loadlin/src/
    inflating: loadlin/src/loadlin.asm
    inflating: loadlin/src/loadlina.asm
    inflating: loadlin/src/loadlini.asm
    inflating: loadlin/src/loadlinj.asm
    inflating: loadlin/src/loadlinm.asm
    inflating: loadlin/src/makefile
    extracting: loadlin/src/srclinux.tgz
    inflating: loadlin/src/pgadjust.asm
    # cp /vmlinuz /dos/loadlin/zimage
    # cd loadlin
    # ls
    copying* files* linux.bat* readme.1st* test.par*
    doc/ initrd.tgz* loadlin.exe* src/ zimage
    # cat linux.bat

    rem First, ensure any unwritten disk buffers are flushed:
    smartdrv /C
    rem Start the LOADLIN process:
    c:\loadlin\loadlin c:\loadlin\zimage root=/dev/hda3 ro vga=3
    # cp linux.bat /dos

    Burada verilen örnekte yapılan sırasıyla

    • Sabit diskin DOS kısmını Linux altından ulaşılır yapmak
    • /root altında yer alan lodlin16.zip isimli dosyayı DOS diski altında açmak. Bu işlem C:\LOADLIN isimli bir dizin yaratıp içerisine gereken dosyaları yerleştirmektedir.
    • Çalışan çekirdeği (/vmlinuz) bu dizine kopyalamak ve LINUX.BAT dosyasını kendimize uygun hale getirmek. Bu dosya C:\LOADLIN\ZIMAGE isimli bir çekirdeği kullanarak /dev/hda3 bölümünde Linux çalıştırmak için kullanılır.
    • LINUX.BAT dosyasını PATH içinde tanımlı bir yere kopyalamak, mesela C:\DOS.

    Artık bilgisayar DOS açıldıktan sonra

    linux

    komutu ile tekrar Linux çalıştırmak mümkün olacaktır.

    Bilgisayarınıza Linux yüklediğiniz disketlerle her zaman bilgisayarınızı Linux olarak açıp çalışabilirsiniz.
    Tavsiye edilen mümkünse LILO kullanmaktır. LOADLIN ise bir ikinci alternatif olarak çokça kullanılır. Boot disketlerine ise genelde son çare olarak başvurulur.
    Bütün bu adımlardan sonra artık elinizde çalışmaya hazır bir Linux makina vardır. Makinayı kapatıp tekrar açın. Ekranda çekirdek mesajları geçtikten sonra

    login :

    belirecektir. Buraya root yazın ve sisteme girin. İlk denemeniz için

    # shutdown -rf now

    yazabilirsiniz. Linux bir makina çalıştığı sürece hafıza içerisinde birçok tampon bellek açar. Mümkün olduğu kadar makinayı kapama tuşuna basarak kapatmayın. Shutdown komutu işletim sisteminin tampon belleklerde tuttuğu bilgileri güncellemesini sağlayacaktır. -r parametresi sistemin reboot etmesini sağlayacaktır. Bilgisayarı kapatmak için

    # shutdown -hf now

    komutunu kullanabilirsiniz. Burada yer alan h parametresi sistemin "halt" edeceğini (tamamen kilitlenme) ve bir daha açılmayacağını belirtecektir.

    Eğer herşey yolunda giderse makinanızın başında oturup çalışmaya başlayabilirsiniz. Sistemde çalışmaya başlamak üzere ilk iş olarak kendinize çalışmak amacıyla bir kullanıcı tanımlayın. Sistemde başka kullanıcı olacaksa, onlar için de hesap açacaksınız. Kullanıcı hesabı açmak için

    # adduser

    komutu size bu konuda yardımcı olacaktır. adduser komutu , kullanıcı ismi, isim ve soyadı, GID (grup kimliği), UID (kullanıcı kimliği) gibi birtakım sorular soracaktır. Bu komut hakkında detaylı bilgiyi Sistem Yönetimi bölümü altında bulabilirsiniz. root kullanıcısı sistem üzerinde sınırsız yetkiye sahip olduğundan sistem dosyalarını kazara değiştirmenize veya silmenize sebep olabilir.

    Şimdi yeni hesabınızla sisteme girebilirsiniz. Alt F1 'den Alt F6 'ya kadar olan tuşlarla birden çok ekranda (sanal ekranlar ) aynı anda çalışabilirsiniz.

    Bu noktadan sonra bazı uygulamaların ayarlamalarını yapmanız gerekecektir. Artık Linux yüklemek ile ilgili bir sorunuzunun kalmamış olmasını umuyorum. DOS kullanıcılarına Linux hakkında bilgi veren kapsamlı bir doküman için DOS2Linux Mini-HOWTO iyi bir başlangıç olabilir.

    Açılış esnasında makinanızın ismi /etc/rc.d/rc.M dosyasında belirlenir. Bu dosyayı uygun şekilde değiştirerek makinanızın ismini de yeniden tanımlayabilirsiniz. Makinanızın ilk ismi darkstar olacaktır. Eğer TCP/IP ağ üzerinde çalışıyorsanız, /etc/HOSTNAME dosyasının içeriğini değiştirerek ve hostname komutu kullanılarak makina ismi de değiştirilebilir:

    # echo "denizati" > /etc/HOSTNAME
    # hostname denizati

    Yukarıda yeralan komutların ilkinde /etc/HOSTNAME dosyasının içine ``denizati'' satırını yazdırdık, ikincisinde ise makinanın kendi adını tanıması için hostname komutunu kullandık. /etc/rc.d/rc.M dosyası da makina adını belirlerken /etc/HOSTNAME dosyasını kullanacaktir.

    4.5. LILO Konfigürasyonu

    Eğer linux ve OS/2 ile birlikte aynı disk üzerinde çalışmayacaksanız, LILO'yu öncelikli yükleyici olarak diskinizdeki diğer işletim sistemlerinin açılışında rahatlıkla kullanabilirsiniz. Daha önce de belirttiğim gibi OS/2'nin kendine özgü önyükleyicisi olduğundan birincil önyükleyici olarak bunu kullanın.

    Slackware LILO kurulum işlemi, bazı özel durumlar için yetersiz kalmaktadır. Bu gibi durumlarda dosyanın el yardımıyla konfigürasyonu gereklidir.

    LILO'yu değiştirmek için /etc/lilo.conf dosyası üzerinde değişiklikler yapmalısınız. Aşağıda bir LILO konfigürasyon örneği görülüyor. Burada Linux bölümü /dev/hda2'de , MS-DOS bölümü ise /dev/hdb1'de (ikinci sabit diskin ilk bölümü) bulunuyor.

    /etc/lilo.conf dosyası üzerinde değişiklik yapabilmek için birkaç metin editörü kullanma şansınız var. Bu editörler arasında en kolayı pico 'dur. pico'yu açtığınız zaman ekranın en altında girebileceğiniz komutların bir listesi yer alır.

    Daha deneyimli ve klavyeye hakim kullanıcılar vi kullanabilirler. vi hakkında daha geniş bilgiyi Sed ve Vi konusunda bulabilirsiniz.

    # LILO, /dev/hda uzerinde kurulacak.
    boot = /dev/hda

    # Linux yuklemek icin
    image = /vmlinuz (Cekirdegin diskteki ismi /vmlinuz)
    label = linux (Buna "linux" ismini ver. Acilis aninda
    ekranda "linux" yazisi gorunur)
    root = /dev/hda2 (Kok dosya sistemi olarak /dev/hda2 kullan)
    vga = ask (VGA ekran modu icin kullanicidan komut bekle)

    # MS-DOS yuklemek icin
    other = /dev/hdb1 (MS-DOS bolumu)
    label = msdos ("msdos" ismini ver)
    table = /dev/hdb (ikinci surucu icin bolumlendirme tablosu)

    Yukarıda bir örneği görülen /etc/lilo.conf dosyasında gerekli değişiklik veya düzeltmeleri yaptıktan sonra /sbin/lilo programını root yetkisiyle çalıştırın. Bir komutu root yetkisiyle çalıştırmak için sisteme root kullanıcı adıyla ve şifresiyle girmelisiniz. Bu komut LILO önyükleyicisini sabit diske kuracaktır. Bundan sonra her yeni çekirdek derlemenin ardından dosyada uygun değişiklikleri yapıp aynı komutu çalıştırmalısınız.

    Şimdi sistemi sabit diskten tekrar açabilirsiniz. LILO, /etc/lilo.conf dosyasındaki ilk işletim sistemini yükleyecektir. Başka bir sistemle açmak için önyükleme menüsünü ekrana getirmelisiniz. Bunun için makina açılırken shift veya kontrol tuşlarına basılı tutun. Ekrana bir açılış istemcisi gelecektir:

    Boot :
    Burada ya açılmasını istediğiniz işletim sisteminin ismini yazın (ilk kurulum sırasında MS-DOS veya linux), ya da tab tuşuna basarak listeyi ekrana getirin.

    OS/2 kullanabilmek için Linux önyükleyicisini ikincil kullanmanız gerekecektir. Linux'u OS/2 önyükleyicisinden açmalısınız.

    Bundan sonra LILO'yu linux dosya sisteminin olduğu bölüme kurun. (yukarıdaki örnekte /dev/hda2). /etc/lilo.conf dosyasının linux için kullanılan satırlarının son durumu şu şekilde olacaktır:

    boot = /dev/hda2

    image = /vmlinuz
    label = linux
    root = /dev/hda2

    /sbin/lilo dosyasının çalıştırılmasının ardından OS/2 önyükleyicisine linux bölümünü tanıtın. Benzer yordamları, sorun çıkaran işletim sistemleri için de kullanabilirsiniz.

    4.6. Sorun Çıktığında

    Tabii ki temennimiz sorun çıkmaması, ama her nedense her zaman bu satırları okuyacak birkaç kişi olacaktır. Linux üzerinde kendi ihtiyacınıza göre ayarlanamayacak bir parametre yok gibidir. Bu özelliği sayesinde son derece esnek bir çalışma ortamı haline gelebilir. Aynı özellik kişilerin çoğu zaman kendi çözümlerini bulmalarını da beraberinde getirmektedir. Kendi bilgisayarınızda Linux çalışmak için bir miktar doküman karıştırmanız kaçınılmazdır.

    Çıkabilecek en önemli sorun bilgisayarın açılmamasıdır. Bunun birçok sebebi olabilir. Açılış esnasında
    1. İlk olarak LILO çalışır.
    2. Çekirdek yüklenir.
    3. Hizmet veren yazılımlar teker teker çalışmaya başlarlar.

    Her aşama birçok satırda durumunu belirtecektir. Çalışan yazılımlar veya yazılım parçalarının her biri birbirinden bağımsız olduğu için açılış sırasında geldiğiniz nokta çok önemlidir. LILO çalışmadığında veya çekirdek yüklenirken takılırsa boot disketi ile rahatlıkla sistemi açabilirsiniz. Örnek olarak Linux yüklü disk bölümünüzün /dev/hda2 olduğunu varsayalım. Boot disketi parametre istediğinde

    mount root=/dev/hda2

    yazmanız yeterli olacaktır. Bu durumda boot disketinde yer alan çekirdek ile belirttiğiniz bölümde yer alan Linux hiyerarşisi açılacaktır. Çalışan bu sisteminiz içerisinde artık hatanın kaynağını daha rahat bulabilirsiniz.

    Çekirdeğin yükleme esanasında takılması büyük ölçüde çekirdeğin donanımı doğru belirleyememesinden çıkar. Mesela ses kartınızı yanlış tanımış ya da tanımak isterken takılmış olabilir. Bunu çözmenin temel yöntemi çekirdek içerisinde kullanmayacağınız donanımlara ilişkin destekleri kaldırmak (Tüm ethernet kartlarını destekleyen bir çekirdek yerine sadece kullanmanızın muhtemel olduğu ethernet kartlarına destek veren bir çekirdek derlemek) veya çekirdeğe yardımcı olabilecek açılış parametreleri vermek.

    Çekirdek derlemek hakkında Kernel-HOWTO ve açılış (boot) parametreleri hakkında BootPromt-HOWTO yardımcı olabilirler. Çalışan sisteminizde bir arıza meydana gelip de makina aniden çalışmamaya başlarsa en son yaptığınız değişiklikleri gözden geçirin.

    Ve son olarak, sistemin çalışmaması her zaman Linux'tan kaynaklanmayabilir, donanım ile ilgili sorunlar da yaşayabilirsiniz. Rasgele davranışlar, durup dururken çakılmalar, panik mesajları altında, bozuk sabit diskler, normalden yüksek frekansta çalıştırılan işlemciler veya bozuk RAM'lar yatabilir.

    Linux kurduktan hemen sonra genellikle kullanıcıların yaptığı linux loader 'ı (LILO) MBA'ya (Master Boot Record) kaydetmektir. O veya bu sebeple Linux'un bulunduğu bölüme zarar vermiş olabilirsiniz ve elinizde sadece DOS kalmış olabilir. Bu gibi bir durumda bilgisayar açılırken ekranda yazan

    LILO :
    kelimesinden kurtulmak ve sistemi temiz bir şekilde açabilmek için DOS'un fdisk /mbr komutu işinizi görür.

    4.7. Başlangıçta

    Bu satırları okuduğunuza göre çalışır durumda bir Linux sisteminiz var demektir. Hala silmediniz mi yoksa? Şaka bir yana, büyük badireler atlattınız. Önünüze sayısız engeller çıkabilirdi. Kurarken elektrikler kesilebilirdi, sabit disk çizilebilirdi veya yanlış bölümü formatlayabilirdiniz. Özellikle Linux Slackware dağıtımını kurmak, belgeler olmadan veya hatırlı bir arkadaşın yardımı olmaksızın ilk bakışta zor gelebilir.

    Bu bölümde Linux'a küçük bir giriş yapılacak, daha sonra da UNIX kullanmayanlar sistemle tanıştıracaktır. Bölüm boyunca yapmanız gereken korkmadan sistem üzerinde kolaylıkla gezinti yapmak ve dosyaları kurcalamaktır.

    Önceki bölünde sisteme girebilmek için şifresi olmayan "root" kullanıcıyı kullanmıştınız. Bu kullanıcı sistemde en fazla yetkiye sahip kullanıcı olup sistem görevlisi (sorumlusu) adını alır. Eğer root dışında bir kullanıcı hesabı tanımlanmışsa onu kullanın. Şifre yazıldıktan sonra komut istemcisine, yani kısaca kabuk dediğimiz programa girilir. Şifre yazılırken, başkalarının görmemesi için ekrana basılmaz.

    Kullanıcı isimleri veya şifrelerde büyük ve küçük harfler arasında fark vardır. Root, root ve ROOT, farklı kullanıcılara işaret eder. Klavyenin en sağındaki Caps Lock tuşunun yanmadığına emin olun.

    Sisteme ilk girişte, aşağıdaki gibi bir görüntü ile karşılaşacaksınız.

    Welcome to Linux 1.2.13.

    linux login: root
    password:
    Last login: Thu Feb 13 12:46:35 on tty1
    Linux 1.2.13.
    You have mail.
    #

    Genellikle komut istemcisinin sonundaki karakter, root kullanıcısı için #, diğer kullanıcılar için $ olur. Bu karakterden önce de makina ismi yeralır. MS-DOS'ta olduğu gibi burada UNIX komutlarını girebileceğiniz kabuk (shell) üzerindesiniz.

    Şifreyi değiştirmek için kullanılan komut passwd 'dir. Bir kullanıcı sadece kendi şifresini değiştirirken root'a herkesin şifresini değiştirme yetkisi verilmiştir. Herhangi bir sistemde hesap şifrenizi unutursanız, bunu sadece root değiştirebilir. Root iken passwd yazın ve enter tuşuna basın.

    # passwd
    Changing password for root
    Enter new password: *******
    Re-type new password: ******
    Password changed.
    #

    Şifrenizi iyi saklayın. Root şifresini ele geçiren birisi sistemde istediği değişikliği yapabilir. Şifre seçimi için Linux İşletim Sisteminde Güvenlik konu başlığına göz gezdirin.

    Linux komutları hakkında bilgi almak için man komutu kullanılır. Eğer kurulum aşamasında kılavuz (man) dosyalarının kopyalanması sorusuna olumlu yanıt verilmişse bunlar /usr/man dizini altında bulunurlar. Örneğin passwd komutu hakkında daha detaylı bilgi almak için

    $ man passwd
    yazın. Tüm kılavuz sayfaları /usr/man dizini altında 8 (bazı dağıtımlarda) ayrı dizinde saklanır (man1 .. man8). Bazı komutların kılavuz dosyaları birden fazla dizin altında bulunur, bir dosya komut hakkında temel bilgi verirken diğeri sistem programcılarına yönelik olabilir. Örnek olarak mount komutu, hem 2, hem de 8 numaralı kılavuz dosyalarıyla birlikte arşivlenmiştir. C programlayıcısı, mount komutuna ulaşmak için

    $ man 2 mount
    yazarken normal kullanıcı,

    $ man 8 mount

    yazmalıdır. Bunun yanında başlığında belirli bir anahtar sözcüğü içeren tüm kılavuz dosyalarını araştırmak için apropos komutu kullanılır.

    Her komut, bir veya birden çok parametre alabilir. Örnek olarak,

    $ find . -name "*.txt" -print
    komutu, bulunduğunuz yerden itibaren tüm dosyaları araştıracak ve bunların arasından sonu .txt ile bitenleri ekrana basacaktır. Parametreler genel olarak "-" işaretleri ve bu işaretten sonra gelen parametre ismi ile belirtilirler.

    4.8. Linux Komut Yapısı

    UNIX ve benzeri işletim sitemlerinde kullanıcının komut yazmasını sağlayan, bu komutları yorumlayarak gerekli işlemleri yapan programlara kabuk (shell) adı verilir. UNIX'te bir kullanıcı bir dizi kabuktan istediğini seçebilir. Kabuklar ile ilgili ayrıntılı bilgi ileride verilecektir. Kullandığınız kabuk ne olursa olsun, gerek kabuktan kaynaklanan, gerekse UNIX komutlarının hepsinin uyduğu bazı standartlardan kaynaklanan bazı geleneksel yapılar vardır. Bunları bilmeniz ilk kez duyduğunuz bir komutun kullanımını bile kolayca çıkarabilmenizin yanı sıra, bir dizi genel hatadan kaçınmanızı da sağlayacaktır.

    • UNIX'te (ve Linux'ta) bütün komutlar ve dosya isimlerinde büyük/küçük harf ayrımı önemlidir. Sistem komutlarının ve dosyaların çoğu küçük harfle yazılır.
    • Komut ve dosya adlarında kullanacağınız bazı karakterlerin gerek dosya ve dizin yapısı, gerekse kabuk ve diğer komutlar nedeniyle bazı özel anlamları vardır. Bu karakterlerden yeri geldikçe söz edilecektir. Örneğin, `/' karakteri hiçbir dosya adında bulunamaz (dosya ve dizinler için ayraç olarak kullanıldığından). `-' ile başlayan bir dosya oluşturulabilir olsa da silmeye kalktığında yeni bir UNIX kullanıcısının başına dert açabilir.
    • UNIX'te komutlara seçenek verirken seçenekten önce `-' karakteri kullanılır. Örnek olarak ls -l
    • UNIX komutları tersi istenmedikçe girdilerini standart girdiden (klavye) alır, çıktılarını standart çıktıya (ekran) yazar. Bu özellik ileride anlatılacak olan yönlendirme ve boru (pipe) operatorleri ile birlikte komut satırından birçok işlemi kolayca yapmanızı sağlar.
    • UNIX kabukları komut satırından verilen komutu çalıştırmadan önce bir dizi karakteri yorumlayarak dosya ad(lar)ına çevirirler. Bu karakterler:

    • * Sıfır dahil herhangi bir sayıda karakter yerine geçer. Örneğin rm * komutu bütün dosyaları siler, ls -l a* komutu `a' ile başlayan dosyaların listesini verir.
    • ? tek bir karakter yerine geçer. Örneğin ?? adı iki karakterden oluşan bütün dosyalar anlamına gelir.
    • [] karakterleri arasında yazılan liste içindeki herhangi bir harfe dönüştürülür. Örneğin cp *[abc] /tmp komutu `a', `b' ya da `c' ile biten bütün dosyaları /tmp dizinine kopyalayacaktır. liste içinde aralarına `-' işareti koyarak aralıklar verebilirsiniz. Örneğin, [A-Z]* büyük harfle başlayan bütün dosyalar anlamına gelir.

    4.9. Dosya ve Dizin Yapısı

    UNIX altında bazı karakterlerin özel anlamları vardır. Dizin ve dosya isimlerinin başında nokta olması durumunda bu dosyalar gizli dosya haline gelir ve parametresiz yazılan ls komutuyla görünmez.

    Dosya ve dizin isimleri 255 karakteri aşamazlar.

    Sisteme girince önceden tanımlanmış bir dizin altında bulunursunuz. Bu dizin normal kullanıcılar için genellikle /home/ ve ardından gelen kullanıcı dizini ismidir. Bulunduğunuz dizinin ismini görmek için pwd (print working directory) yazın. Temel dosya ve dizin kavramları hakkında detaylı bilgi alabilmek için MS-DOS veya, en iyisi bir UNIX kitabı edinin.

    $ pwd
    /home/gorkem
    $

    UNIX komut yapısı DOS'a çok benzer. Dizin değiştirmek için cd, dizin yaratmak için mkdir komutlarını sistemde sıkça kullanılır.

    $ cd /
    $ pwd
    /

    Hiyerarşik bir sıraya sahip olan UNIX'te en üstte / dizini (kök dizin) yeralır. Sistemdeki tüm diğer dosya ve dizinler bunun altında toplanırlar :

    2#2 işareti, kullanıcının ev dizinini gösterir. Ev dizinine geçin ve mkdir komutu ile benim isimli bir dizin yaratın. Dizini patikasını, bir başka deyişle kök dizininden itibaren ismini vererek de yaratabilirsiniz.

    $ cd ~
    $ pwd
    /home/gorkem
    $ mkdir /home/gorkem/benim

    4.9.1. Dosya Listesi ve İçeriklerinin Görüntülenmesi

    Dosya ve dizinleri görebilmek için ls komutu kullanılır. Parametresiz yazarak bulunduğunuz dizin hakkında bilgi alın. Linux altında değişik uzantılı dosyalar okunabilirliği artırmak amacıyla farklı renkte görülecektir. /etc/DIR_COLORS dosyası, dosya renklerini ayarlar. Bu dosyayı içeriğini değiştirerek belirli dosyaların istenilen renkte görünmesini sağlayabilirsiniz.

    $ ls
    README yazi.txt mail typescript
    adres linux perl

    ls komutu -a parametresiyle birlikte kullanılırsa normalde görükmeyen ve nokta karakteriyle başlayan dosya ve dizinler de görükür.

    $ ls -a
    . .bashrc .term yazi.txt typescript
    .. .kermrc .xinitrc linux
    .Xdefaults .less README mail
    .bash_history .lessrc adres perl

    -l parametresi de dosyalar hakkında tüm bilgiyi verir. Bunlar, dosyanın sahibi, ne zaman yaratıldığı, sahibi ve grubu gibi bilgilerdir. Dosya izinleri hakkında daha geniş bilgi bir sonraki bölümde verilmiştir.

    $ ls -al
    total 91
    drwxr-xr-x 6 gorkem users 1024 Feb 13 12:56 .
    drwxr-xr-x 4 root root 1024 Jan 7 1980 ..
    -rw-r--r-- 1 gorkem users 390 Feb 13 12:56 .Xdefaults
    -rw-r--r-- 1 gorkem ftpadm 230 Feb 13 12:57 .bash_history
    -rw-r--r-- 1 gorkem users 1 Feb 13 12:57 .bashrc
    -rw-r--r-- 1 gorkem users 163 Nov 24 1993 .kermrc
    -rw-r--r-- 1 gorkem users 34 Nov 24 1993 .less
    -rw-r--r-- 1 gorkem users 114 Nov 24 1993 .lessrc
    drwxr-xr-x 2 gorkem users 1024 Jan 7 1980 .term
    -rw-r--r-- 1 gorkem users 87 Feb 13 12:56 .xinitrc
    -rw-r--r-- 1 gorkem users 26264 Feb 13 12:53 README
    -rw-r--r-- 1 gorkem users 2795 Feb 13 12:55 adres
    -rw-r--r-- 1 gorkem users 47970 Feb 13 12:53 yazi.txt
    drwxr-xr-x 2 gorkem users 1024 Feb 13 12:54 linux
    drwxr-xr-x 2 gorkem users 1024 Feb 13 12:54 mail
    drwxr-xr-x 2 gorkem users 1024 Feb 13 12:54 perl
    -rw-r--r-- 1 gorkem users 0 Feb 13 12:57 typescript

    Yukarıda her iki parametrenin de birleştirilerek birlikte kullanımı yeralmaktadır. Dosyaların içeriklerini görmek için kullanılan birkaç komuttan en pratiği less'tir. Ok tuşları ile dosya içinde hareket edebilir ve q karakteri ile dosyadan çıkarsınız. Dosyanın içeriği birden fazla sayfadan ibaretse dosya sayfalar halinde ekrana gelir. Tüm dosyayı ekrana basmak için cat kullanın.

    $ cat README

    Bir dosyanın başından veya sonundan itibaren belirli miktarda satırı ekrana getirmek de mümkündür. Bunun için head ve tail komutları kullanıcının hizmetine sunulmuştur.

    $ head -6 README (dosyanin ilk 6 satirini ekrana basar)
    This is the README file for the 28 August 1994 public release of the
    Info-ZIP group's portable UnZip zipfile-extraction program (and related
    utilities).

    unzip512.zip portable UnZip, version 5.12, source code distribution
    unzip512.tar.Z same as above, but compress'd tar format

    $ tail -3 README (dosyanin son 3 satirini ekrana getirir)

    -- Greg Roelofs (Cave Newt), UnZip maintainer/container/explainer and
    developer guy, with inspiration from David Kirschbaum

    4.9.2. Dosyaların Kopyalanması

    Dosyaları kopyalamak için cp ve bir yerden başka bir dizine almak için mv komutu kullanılır. mv komutu, aynı zamanda dosya isimlerini değiştirmek üzere de işletilebilir.

    $ cp yazi.txt /tmp
    (yazi.txt adlı dosyayi /tmp dizinine kopyala)
    $ mv yazi.txt /tmp/yazi
    (yazi.txt isimli dosyayi /tmp dizini altina ismini yazi olarak degistirerek koy

    Kopyalama işlemi sadece dosyalar üzerinde değil, dizinler üzerinde de yapılabilir. Farklı dosya sistemleri üzerinde olmamak kaydıyla bir dizin ve altındaki herşeyi, başka bir dizine kopyalayabilir veya hareket ettirebilirsiniz. Kopyalarken bu işlem için -R parametresi kullanılır, mv komutu için -r parametresine gerek yoktur.

    $ cp -R /home/gorkem/temp /tmp
    (/home/gorkem/temp dizinini ve icindeki her dosyayi /tmp altina kopyala)

    $ mv yazi.txt ~/benim
    (yazi.txt isimli dosyayi ev dizini altindaki benim dizinine kopyala)

    4.9.3. Dosyaların Silinmesi

    Bir daha kullanılmayacak olan dosyalar, rm komutuyla silinebilir. Dosyaları silerken iki kere düşünün, zira Linux altında silinen bir dosyanın geri dönüşü olmaz. Eğer bu tür hataları çok yapıyorsanız rm komutunu -i parametresi ile birlikte kullanın, bu sayede Linux, dosyayı silmeden önce kullanıcının da onayını alır.

    $ rm -i README
    rm: remove `README'? y (sileyim mi ?)
    $

    Eğer dosya ismi - karakteri ile başlıyor ise, rm komutunu kullandığınız zaman dosya ismi bir parametre olarak algılanacak ve hata verecektir. Bunun için dosya isminden önce - karakterlerini yerleştirin.

    $ rm -- -dosya

    Bir dizin, boş iken rmdir komutu ile silinebilir, eğer boş değilse bu komut işe yaramaz. Onun yerine rm komutunu -r parametresiyle kullanın.

    $ rm mail
    rm: mail: is a directory
    $ rm -rf linux/ (linux dizinini icindekilerle birlikte silinir)

    -f parametresi ile kullanıcının onayını almadan tüm dosyaları tek adımda silmek mümkündür. Bulunduğunuz dizindeki tüm dosyaları silmek için * karakterini kullanın.

    $ rm *



    5. KABUK İŞLEMLERİ

    Sisteme girdiğiniz anda kabuk programının çalıştırıldığından bahsetmiştik. Bu andan sonra yapacağınız tüm işlemler bu kabuk programı tarafından yönetilir ve denetlenir. Kabuk, klavyeden girilen komutları çalıştırarak bir arabirim görevi yapar. UNIX (ve Linux) altında geliştirilen sayısız kabuk çeşidi ve bunların herbirinin kendine ait özelliği vardır. Her programcı kendi zevkine hitap eden kabuğu seçebilir, sistemde yeralan kullanıcılar farklı kabuklar üzerinde çalışabilirler.

    O an hangi kabuk üzerinde yeraldığınızı öğrenmek için şunları yazın.

    $ echo $SHELL
    /bin/bash

    Sıkça kullanılan kabuklar,

    sh (Shell ya da Bourne Shell): İlk UNIX kabuğu.

    ksh (Korn Shell): sh uyumlu, birçok ek programlama özelliği içeren bir kabuk. Bu kabuk da yaygın bir kitle tarafından kullanılıyor.
    bash(Bourne Again Shell): Kullanım kolaylığı bakımından en çok rağbet gören bash, GNU tarafından kaynak koduyla birlikte olarak dağıtılıyor. bash sh ve ksh uyumluluğunu korurken, özellikle etkileşimli kullanıma yönelik (komut tamamlama, gibi) birçok yenilik de içerir. Bu yazının hazırlandığı 1997 Temmuz ayı başlarında bash 2.0.1 sürümü çıkmıştı.

    csh (C shell): Berkeley Üniversitesi'nde geliştirilen csh'in C diline benzer bir programlama yapısı vardır.

    tcsh: csh'ın biraz geliştirilmiş hali.

    Yukarıdaki kabuk programlarından sh, ksh ve bash birbirleriyle uyumludur ve yukarıda en ilkelden en gelişmişe göre sıralanmışlardır. Aynı durum csh ve tcsh için de geçerlidir. Kullanılan shell genellikle kişisel bir tercih nedeni olsa da, bütün sistem scriptleri sh ile yazıldığından, sistem yöneticilerine sh ailesinden bir kabuk kullanmaları önerilir.

    Kabuk programları genellikle /bin dizini altında yeralır. Kullanıcının sisteme girerken hangi kabuğu kullanacağı /etc/passwd dosyasında yeralır. Bunu değiştirmek için chsh (change shell) komutunu kullanabilirsiniz.

    $ chsh
    Password:
    Changing the login shell for cagri
    Enter the new value, or press return for the default

    Login Shell [/bin/sh]: /bin/bash
    $

    Sisteminizde NIS kullanılıyorsa chsh yerine yppasswd -s komutunu kullanmalısınız.

    5.1. Yönlendirme

    Kullanıcı, ekrana yazdığı bir komutun neler yaptığını en rahat şekilde komut tarafından ekrana yönlendirilen bilgilerden anlayabilir. Program, kullanıcıyı bilgilendirme amacıyla gerek ve yeter miktarda bilgiyi ekrana vermelidir.

    5.2. Standart Girdi, Çıktı ve Hata

    Linux'ta, programın ekrana yazılan bilgiyi iki sınıf altında toplayabiliriz. Birincisi, olağandışı bir durumu bildiren standart hata, diğeri de her türlü verinin yazıldığı standart çıktı. Program çalıştığı andan itibaren bu iki kanal üzerinden akan bilgiler, programın çalıştığı sanal terminale yazılırlar. Program girdilerini ise standart girdi aracı olan klavyeden alır.

    Eğer bu bilgiler bir ekran boyundan (normalde 25 satır) fazla tutuyorsa bazı satırlar programcının gözünden kaçabilir. Bunu önlemek amacıyla standart çıktı ve hata bir dosyaya yazılacak şekilde ayarlanabilir. Yönlendirme olarak da bilinen bu işlem UNIX altında (DOS'ta olduğu gibi) > karakteri ile gerçekleştirilir.

    Örnek olarak o an bulunduğunuz dizinde yeralan dosyaları ekrana getirin :

    $ ls -al

    Bu komut, standart çıktı olarak dosyaların bilgilerini ekrana getirecektir. Bu çıktıyı, bir dosyaya yönlendirelim ve dosyanın içeriğine göz atalım:

    $ ls -al > liste
    $ cat liste
    total 16
    drwxr-xr-x 5 gorkem users 1024 Feb 13 13:10 .
    drwxr-xr-x 4 root root 1024 Jan 7 1980 ..
    -rw-r--r-- 1 gorkem users 390 Feb 13 12:56 .Xdefaults
    -rw-r--r-- 1 gorkem ftpadm 2016 Feb 13 13:09 .bash_history
    -rw-r--r-- 1 gorkem users 1 Feb 13 12:57 .bashrc
    -rw-r--r-- 1 gorkem users 163 Nov 24 1993 .kermrc
    -rw-r--r-- 1 gorkem users 34 Nov 24 1993 .less
    -rw-r--r-- 1 gorkem users 114 Nov 24 1993 .lessrc
    drwxr-xr-x 2 gorkem users 1024 Jan 7 1980 .term
    -rw-r--r-- 1 gorkem users 87 Feb 13 12:56 .xinitrc
    -rw-r--r-- 1 gorkem users 2795 Feb 13 13:06 adres
    -rw-r--r-- 1 gorkem users 0 Feb 13 13:10 liste
    drwxr-xr-x 2 gorkem users 1024 Feb 13 12:54 mail
    drwxr-xr-x 2 gorkem users 1024 Feb 13 12:54 perl
    -rw-r--r-- 1 gorkem users 0 Feb 13 13:10 typescript
    $

    > karakteri standart hatayı dosyaya yönlendirmez. Bu işlem için 2> kullanılır. Ama hatayı görebilmek için, hata yaratan bir komut yazmalıyız, değil mi ?

    $ ls /deneme
    /deneme : No such file or directory
    $ ls /deneme 2> hata
    $ cat hata
    /deneme : No such file or directory

    Aşağıdaki komutun işletilmesinin ardından standart çıktı oku1 dosyasına, standart hata ise oku2 dosyasına yazılacaktır. Bu dosyaları komutu çalıştırdıktan sonra incelemek suretiyle neler olup bittiğini anlamak mümkün olur.

    $ mkdir ~/deneme (deneme isimli bir dizin yarat)
    $ touch ~/deneme/gecici (gecici isimli bir dosya yarat)
    $ cat ~/deneme 2>oku2 >oku1

    Kabuk, standart çıktı ve standart girdi için sırayla 1 ve 0 numaralarının kullanımına izin verir. Yukarıda yeralan son komutta, standart hata mesajları için 2 kullanılarak hataların oku2 dosyasına yazılmıştır. Aşağıda, çekirdek derlemek için sürekli kullandığım program yeralıyor. Yönlendirme sayesinde ekrana gelmesi gereken mesajlar kullanılmayan 9. sanal konsola yönlendiriliyor.

    # make config
    # make dep > /dev/tty9
    # make clean > /dev/tty9
    # time make zImage > /dev/tty9

    Son satırdaki time komutu, kendinden sonra gelen komutun ne kadar zaman içinde çalıştırıldığını gösterir. Çekirdek derlemede geçen zaman, makinanın gücü hakkında bir fikir verebilir. Peki ne hata, ne de çıktıyı ekranda görmek istemiyorsam ne yapmalıyım? Bunun için standart çıktı ve hatayı biraraya getirerek yönlendirilen her çıktının kaybolduğu ``kara deliğe'' atmak yeterlidir:

    $ ls /deneme > /dev/null 2>&1

    Yukarıdaki komutun yazılış sırasına dikkat edin.

    Standart çıktı ya da standart hatayı yönlendirirken, > işareti kullanırsanız; dosya yoksa, oluşturulur ve komutun çıktısı dosyaya yazılır. Dosya varsa, içeriği yok olur, ve komutun çıktısı dosyanın yeni içeriği olur. Var olan bir dosyayının eski içeriğini tamamen silmek değil de komutun çıktısını dosyaya eklemek istiyorsanız >> kullanmalısınız. Bu durumda dosya varsa komutun çıktısı dosyanın eski içeriği korunarak sonuna eklenir, dosya yoksa oluşturulur ve komutun çıktısı dosyaya yazılır. Örneğin:

    $ echo deneme1 >>deneme.txt
    $ cat deneme.txt
    deneme1
    $ echo deneme2 >>deneme.txt
    $ cat deneme.txt
    deneme1
    deneme2
    $

    Örnekte görüldüğü gibi ilk komut deneme.txt dosyasını oluşturdu. İkincisi ise oluşan dosyanın içeriğini koruyarak ikinci komutun çıktısını bu dosyanın sonuna ekliyor.

    Standart hata ve çıktıya ek olarak UNIX'in desteklediği bir yönlendirme daha vardır: Standart girdi sayesinde bir dosyayı oluşturan satırlar, bir komut veya programa yönlendirilebilir. Daha önce bir metin editor kullanarak hazırlamış olduğumuz raporu patrona kısa yoldan göndermek için,

    $ mail -s "rapor" patron < rapor.txt

    Dosyanın içeriği, mail komutuna girdi olmuş ve rapor.txt dosyası patron kullanıcısına ``rapor'' konu başlığıyla e-posta ile gönderilmiştir.

    5.3. Boru (pipe) İşlemleri

    Bazı durumlarda, bir komutun çıktısı diğer bir komuta yönlendirilebilir. Başka bir deyişle, komutun standart çıktısını bir dosyaya değil, bu çıktıyı işleyecek başka bir komuta yönlendirmek istiyorsunuz. Bu amaçla UNIX altında (yine DOS'ta olduğu gibi) boru () karakteri kullanılır. Bu karakter, kendinden önce gelen komut veya komut serisinin çıktısını, kendinden sonra gelen komuta gönderir. Örneğin bir dizinde yeralan tüm detaylı dosya bilgilerini yazıcıya aktarmak için,

    $ ls -al | lpr

    komutları kullanılabilir. Artık ls -al komutunun ekrana vermesi gereken tüm bilgiler, lpr komutu aracılığıyla yazıcıya gönderilmiştir. İlk komutun standart çıktısı, ikinci komuta standart girdi olarak atanır. Diğer bir örnekte, README dosyasında kaç satır olduğu bulunuyor. Bir dosyadaki veya komut çıktısındaki satır, karakter ve kelime sayılarını bulmak için wc komutunu kullanabilirsiniz.

    $ who | wc -l
    40

    Yönlendirme ve pipe işlemleri bazen insanın kafasını karıştırabilir. Yönlendirme, bir programdan bir dosyaya yapılabilir, fakat bir programdan başka bir programa yönlendirme yapamazsınız. Benzer şekilde, iki dosyanın arasında pipe işlemi uygulamak mümkün olmaz.

    Şimdi de biraz karışık bir örnek:

    # ps -aux | grep inetd | grep -v grep|awk '{print $2}' | xargs kill -1

    Yukarıdaki örnek zorlama bir örnek değil, bir Linux sistem yöneticisinin her an kullanması gerekebilecek türden. Bu örneği burada ayrıntılı olarak açıklamayacağız, sadece pipe kullanarak ne kadar fazla sayıda komutun birbirine bağlanabildiğini göstemek amacıyla verdik. Bu ve benzeri komutların ayrıntılı açıklamalarını kabuk programlamayla ilgili bölümde bulabilirsiniz.

    5.4. Çokgörevlilik

    UNIX'in en büyük silahlarından biri süreçlerdir. Her süreç sistemde bağımsız çalışan, birbirini etkilemeyen ve herbiri kendi kaynağını kullanan programdır. Süreçler arkaplanda veya kabuğun kontrolünde çalışabilir. Çekirdek, her sürecin kullandığı sistem kaynağından haberdar olur ve bu kaynakların süreçler arasında adilce paylaşılmasından sorumludur.

    Bir süreç, aksi belirtilmedikçe çalıştığı süre içinde klavyeden bilgi alır ve ekrana bilgi verir. Kullanıcıların haberi bile olmadan çalışan süreçler, Linux makinasındaki G/Ç işlemlerini gerçekleştirebilmek için sürekli faaliyet içinde bulunurlar. Onlarca süreçten bazıları kullanıcıların sisteme girmesini sağlarken (getty) bazıları da WWW ve FTP gibi İnternet tabanlı istekleri yerine getirir (httpd, ftpd).

    5.4.1. Arkaplanda Çalıştırma

    Bir komutu arkaplanda çalıştırmak için, komutun sonuna & karakteri getirin. Komutu girdikten sonra tekrar kabuk istemcisine düşecek ve kaldığınız yerden devam edebileceksiniz. Program, arkaplanda diğer süreçlerle çakışmadan bir süre çalışır ve işi bittiğinde durur.

    $ sort buyuk_dosya > buyuk_dosya.sirali &
    [1] 772

    Komutun arkaplana atılmasından sonra ekranda yeralan 1 , sürecin sıra numarasını, 772 sayısı ise süreç kimliğini (Process ID) gösterir. Her program, sistem kaynaklarını biraz daha azalttığından Linux'çuların deyimiyle makina yavaşlar.

    Çalışan programların listesini görmek için ps komutunu kullanın. Hiç parametre vermeden yazılırsa sadece üzerinde çalışılan kullanıcının süreçleri ekrana gelir. Sık kullanılan bir başka parametre dizisi de uax tir. Bu sayede sistemdeki o anda çalışan tüm programlar daha ayrıntılı bir şekilde ekrana listelenir.

    $ ps
    PID TTY STAT TIME COMMAND
    76 v02 S 0:00 -bash
    111 v02 R 0:00 ps

    $ ps -aux
    USER PID %CPU %MEM SIZE RSS TTY STAT START TIME COMMAND
    bin 63 0.0 5.5 64 364 ? S 11:12 0:00 /usr/sbin/rpc.portmap
    gorkem 76 0.0 9.7 101 644 v02 S 11:12 0:00 -bash
    gorkem 112 0.0 5.0 59 332 v02 R 11:16 0:00 ps -aux
    root 1 0.0 5.0 56 332 ? S 11:12 0:00 init [5]
    root 6 0.0 4.2 35 284 ? S 11:12 0:00 bdflush (daemon)
    root 7 0.0 4.2 35 284 ? S 11:12 0:00 update (bdflush)
    root 48 0.0 5.1 45 340 ? S 11:12 0:00 /usr/sbin/crond -l10
    root 59 0.0 5.5 53 364 ? S 11:12 0:00 /usr/sbin/syslogd
    root 61 0.0 5.0 44 336 ? S 11:12 0:00 /usr/sbin/klogd
    root 65 0.0 5.5 62 364 ? S 11:12 0:00 /usr/sbin/inetd
    root 67 0.0 5.8 79 388 ? S 11:12 0:00 /usr/sbin/rpc.mountd
    root 69 0.0 6.0 88 400 ? S 11:12 0:00 /usr/sbin/rpc.nfsd
    root 75 0.1 9.9 115 660 v01 S 11:12 0:00 -bash
    root 77 0.0 4.6 52 304 v03 S 11:12 0:00 /sbin/agetty 38400 tty3
    root 78 0.0 4.6 52 304 v04 S 11:12 0:00 /sbin/agetty 38400 tty4
    root 79 0.0 4.6 52 304 v05 S 11:12 0:00 /sbin/agetty 38400 tty5
    root 80 0.0 4.6 52 304 v06 S 11:12 0:00 /sbin/agetty 38400 tty6
    root 81 0.0 5.5 42 368 ? S 11:12 0:00 gpm -t ms

    Burada yeralan bilgiler sırasıyla :
    • PID: Süreç numarası. Her sürecin farklı bir numara alması sistem tarafından düzenlenir.
    • %CPU: İşlemcinin % olarak ne kadarı süreç tarafından kullanılıyor ?
    • %MEM: % olarak hafızada kapladığı yer
    • SIZE: Programın toplam kullandığı bellek alanı (kilobyte)
    • RSS: Programın bellekte kapladığı gerçek alan. Bu değer paylaşılan sistem kütüphaneleri (shared library) nedeniyle genellikle SIZE değerinden büyüktür.
    • TTY: Sürecin çalıştırıldığı (sanal) terminal
    • STAT: Süreç o sırada ne yapıyor ?
    • S: Uyumakta, bu durum genellikle sürecin bir G/Ç işlemi (örneğin farenin hareketi ya da ağdan gelecek veriler) beklemesi sırasında olur.
    • R: Çalışabilir. Çalışabilir süreçler, gereksinim duydukları bütün sistem kaynaklarına sahip olan süreçlerdir. Çekirdek (tek işlemcili bir makinada) belirli aralıklarla bu süreçlerden sadece birini çalıştırır.
    • T: Durmuş. Bu durum sürecin kullanıcı tarafından (örneğin Control-Z tuşlarına basılarak) durdurulmasında görülür.
    • Z: Zombie. Bu tür süreçler, kendisini çalıştıran sürece (parent process) mesaj bırakamadıklarından takılmış süreçlerdir. Öldürülemezler ancak sitem kaynaklarını da kullanamazlar.
    • D: Kesilemez uykuda. Bazı G/Ç işlemleri o sırada bu işlemi yapan sürecin kesilmemesini gerektirir. Böyle durumdaki süreçleri de ilgili G/Ç işlemi bitinceye kadar öldüremezsiniz.
    • START: Sürecin çalıştığı zaman
    • COMMAND: Komut satırından girilen programın ismi

    ps komutuna bilgisayar üzerinde çalıştığınız her an ihtiyaç duymanız mümkündür, bu yüzden çeşitli parametrelerle kullanmayı öğrenmelisiniz.

    5.4.2. Klavye Üzerinden Kesinti

    Linux (ve UNIX) altında, klavyeden bazı tuş kombinasyonları yardımıyla çalışmakta olan program kesintiye uğratılabilir.

    Klavyeden kabuk komut satırına yazılan bir programın uzun sürmesi halinde, eğer daha önceden komutun arkasına & işareti koyup arkaplanda çalışır halde bırakılmamışsa, klavyeden yapılan bir müdahele ile durdurulup arkaplanda çalışır hale getirilebilir. Örnek vermek gerekirse, uzun sürmesi beklenen bir komutu klavyeden yazalım ve ardından Control-Z tuşlarına basalım:

    # find /usr -name "o*" -print
    /usr/bin/od
    /usr/lib/lilo/doc/other.fig
    /usr/lib/lilo/doc/other.tex
    /usr/man/man1/od.1.gz

    [1]+ Stopped find /usr -name "o*" -print
    #
    Bu esnada sürecin çalışmasına ara verilmiş, fakat program tamamen durmamıştır. Programın çalışmasını arkaplanda sürdürmek için bg komutunu kullanın.

    $ bg

    Bu komutu tekrar komut satırında çalışacak ve klavyeden müdahele edilecek şekilde terminale bağlamak için fg yazın:

    $ fg

    Bir programı çalıştırmaya başlattıktan sonra tamamen durdurmaya karar vermişseniz klavyeden Control-C tuşlarına basın. Durdurulup arkaplanda çalışmaya yönlendirilen süreçlere kısaca görev ismi verilir. Tüm görevleri görebilmek için

    $ jobs

    yazın. Görevler, birden fazla oldukları zaman sıra numarası ile belirtilirler.

    5.4.3. Süreçlerin Sona Erdirilmesi

    Her an çalışan süreçlerden biri veya birkaçı, beklenmedik döngüye girebilir. Bunun sonucu olarak sistemin kaynaklarını, özellikle hafızayı tüketici bir duruma gelebilir. Bu tür kısır döngüye giren süreçleri bulup, eğer hayati önem taşımıyorlarsa `öldürmek' gerekir. Süreci öldürmekten kasıt, programı tamamen durdurarak sistemle ilişkisini kesmektir. Bu sayede programın hafızada kapladığı bölge serbest kalacak, çekirdek de hafıza düzenlemesini tekrar yaparak başka süreçlere daha fazla yer ayıracaktır. Bir süreci öldürmek için kill komutu kullanılır. Yukarıdaki 67 numaralı sürece ait /usr/sbin/rpc.mountd programını öldürmek için şunları yazın :

    $ kill 67

    Birçok süreç sizden bu mesajı aldıktan sonra, dosya sistemi üzerinde yarattığı geçici dosyaları, dosyalar üzerine koyduğu kilitleri temizlemek gibi yapması gereken işlemleri yaptıktan sonra çalışmasına son verecektir. Eğer öldürmeye çalıştığınız süreç herhangi bir nedenle takılmışsa ve bu komuta tepki vermiyorsa aşağıdakini deneyin:

    $ kill -9 67

    Artık programın sistemle ilişkisi tamamen kesilmiştir. Kill komutu, -9 seçeneğiyle sürece 9 numaralı sinyali gönderir. Bu sinyali alan sürecin yukarıda sözü edilen iki özel durum dışında çalışmayı sürdürmesi olanaksızdır. -9 seçeneğini özellikle sistem süreçleri üzerinde gerekmedikçe kullanmamalısınız.

    6. DOSYA VE DİZİN İŞLEMLERİ

    Tıpkı MS-DOS'ta olduğu gibi Linux dosya yapısının da hiyerarşik bir yapıya sahip olduğunu söylemiştik. Temel dosya bilgisi önceki konularda anlatıldığından burada sadece dosya ve dizinlerle ilgili özelliklere değinilecektir.

    6.1. Erişim Hakları

    Erişim hakları, Linux dosya sistemi güvenliğinin belkemiğini oluşturur. Her dosyaya ayrı verilebilen erişim izinleri sayesinde çok daha rahat bir sistem yönetimi gerçekleştirilebilir. Bu, konuya sadece sistem görevlisi tarafından yaklaşıldığı zaman çıkartılabilecek bir sonuçtur. Kullanıcı bazında erişim hakları bazen daha da anlamlı olabilir. Yanlış kullanıldığında hoş olmayan süprizlere yol açabilir. Linux altında üç çeşit erişim hakkı vardır :

    • Okuma izni : Dosyanın okuma izni varsa içeriği görülebilir, dizinin okuma izni varsa içerdiği dosyaların listesi alınabilir.
    • Yazma izni : Dosyanın yazma izni varsa dosyayı değiştirebilir veya silebilirsiniz. Dizine yazma izni verildiğinde dizin altındaki dosyalar yazılabilir veya silinebilir.
    • Çalıştırma izni : Dosyayı çalıştırma hakkını verir.

    Bir dosya veya dizin ilk yaratıldığı anda Linux tarafından öntanımlı bazı izinler verilir. Genellikle bu izin çalıştırma ve okumadır. Dosyanın oluşma anında verilen izini değiştirmek için erişim yetki kalıbı olarak da bilinen umask komutu kullanılır. Daha fazla bilgi için komuta ait kılavuz dosyasına bakın.

    Erişim haklarının dışında bir dosyanın üç izin düzeyi daha vardır. Bunlar, dosyanın sahibi, dosyanın grubu ve diğer kullanıcılardır. Dosyanın sahibi, o dosyayı oluşturan kişidir. Her kullanıcının bir grubu da olduğu için, dosya oluşturulurken kullanıcı hangi grupta ise dosya da o gruba ait olacaktır. Dosyanın sahibi olmayan ve grubu da dosyanın grubuyla uyuşmayan sistemdeki kullanıcılar ``diğer'' sınıfına girerler. Gruplar hakkında daha fazla bilgi için Linux Sistem Yönetimi konusuna bakın.

    6.1.1. Dosya İzinlerinin Değiştirilmesi

    Dosya izin bilgilerini görebilmek için ls komutu, -l parametresiyle kullanılır. Aşağıdaki dosya üzerindeki erişim haklarına göz atalım :

    -rwxr-xr-x 2 gorkem users 182 Feb 12 03:58 deneme

    Dosya bilgisinin en sol kısmında izin hakları yeralır. En baştaki ``-'' işareti bunun düz dosya olduğunu belirtir. ``gorkem'', dosyanın sahibi; ``users'' ise grubudur. Ardından sırayla uzunluk, son değiştirilme tarihi ve dosya ismi gibi bilgiler gelir. Son harf kümesine dosyanın modu da denir.

    Solda yeralan r,w ve x karakterleri sırayla okuma, yazma ve çalıştırma haklarını belirtir. En soldaki ``-'' işaretini ayırdığımız zaman geri kalan harfleri üç adet üçlü grup haline getirelim:


    Sırayla birinci harf kümesi dosya sahibinin izinlerini, ikinci harf kümesi grup izinleri ve son küme de diğer kullanıcıların izinlerini belirtir. Buna göre yukarıdaki dosyada

    • rwx : kullanıcı okuyabilir, yazabilir, çalıştırabilir
    • r-x : grup okuyabilir, çalıştırabilir fakat yazamaz.
    • r-x : diğerleri okuyabilir, çalıştırabilir fakat yazamaz.

    Sol baştaki karakter ``d'' olsaydı, bir dizini inceliyor olacaktık.

    Dosyanın izinlerini değiştirmek için chmod komutu kullanılır. Bu komutu kullanırken hangi izin düzeyine (kullanıcı, grup veya diğerleri) hangi izinlerin verileceği veya kaldırılacağı yazılır.
    Örnek olarak yukarıdaki dosyanın okuma iznini kaldırmak için

    $ chmod -r deneme

    kullanılabilir. "-" işareti, iznin kaldırılacağını belirtir. İzin vermek için ise "+" yazın. Dosyanın yeni görüntüsü şöyle olur :

    --wx--x--x 2 gorkem users 182 Feb 12 03:58 deneme

    Sadece grubun, sadece kullanıcının veya sadece diğerlerinin erişim hakkını değiştirebilmek için her izin düzeyi için bir harf tanımlanmıştır. Kullanıcı için "u", grup için "g" ve diğerleri için "o" yazarak belirli bir izin düzeyi için erişim hakkını değiş tirmek mümkün olur. Bu üç harf, izinden hemen önce yazılır.

    $ chmod u+x deneme (dosyanin sahibi calistirabilir)
    $ chmod o+r t2sac (digerleri okuyabilir)
    $ chmod g-w deneme (dosyanin grubu yazamaz)

    Her izin için aynı zamanda sayılar da tanımlanmıştır. Dosyanın erişim izinlerinideğiştirmek için her izne ait sayıları kullanabilirsiniz. Aşağıdaki tabloda, her izin düzeyi (dosyanın sahibi, grubu ve diğerleri) için üçer tane olmak üzere toplam 9 sayıdan oluşan izin numaralarını görebilirsiniz. Bir izni vermek için sırayla numaraları toplayın. Örneğin sahibinin okuması (400), yazması (200), çalıştırması (100), grubun okuması (40), çalıştırması (10) ve diğerlerinin okuması (4) ve çalıştırması (1) için kullanılan rakamların toplamı 755'tir.

    $ chmod 755 deneme

    400
    sahibi okur
    200 sahibi yazar
    100 sahibi çalıştırır
    040 grubu okur
    020 grubu yazar
    010 grubu çalıştırır
    004 diğerleri okur
    002 diğerleri yazar
    001 diğerleri çalıştırır

    Başka bir değişiklikle konuyu pekiştirelim. Sahibinin okuması (400), yazması (100), grubun okuması (40), diğerlerinin okuması (4) için izin numarasını bulmak için bu cümlede parantez içinde yeralan sayıları toplarsak 644 yapacaktır.

    $ chmod 644 deneme

    Aynen dosyalarda olduğu gibi, bir dizinin de sahibi ve grubu vardır.

    6.2. Dosyanın Sahibinin ve Grubunun Değiştirilmesi

    Bir dosyanın sahibini sadece sistemdeki root kullanıcı değiştirebilme yetkisine sahiptir. Dosya sahibinin değiştirilmesi için chown komutu kullanılabilir. Yukarıdaki dosyanın sahibini ozgur isimli kullanıcı yapalım.

    # chown ozgur deneme

    Dosyanın yeni hali şöyle olur :

    -rwxr-xr-x 2 ozgur users 182 Feb 12 03:58 deneme

    chgrp komutu yardımıyla da dosyanın grubunu değiştirilebilir. Yukarıdaki dosyanın grubunu www yapmak için,

    # chgrp www deneme

    komutu kullanılabilir. chown komutu, dosyanın hem kullanıcısını, hem de grubunu değiştirme özelliğine sahiptir. chown komutundan sonra kullanıcı ve grup isimlerini aralarında bir nokta kalacak şekilde yazın.

    $ chown ozgur.www deneme
    $ ls -l deneme
    -rwxr-xr-x 2 ozgur www 182 Feb 12 03:58 deneme

    6.3. Diğer Dosya Sistemlerinin Kullanılması

    Bir Linux işletim sisteminde dosyaların ve dizinlerin her birisi sabit disk, CD-ROM veya diğer bilgi saklamaya yarayan cihazların birer parçası olan "dosya sistemlerinde" tutulur. Linux'un desteklediği pek çok dosya sistemi vardır ve bunların her birisinin veri depolarken kullandıkları yöntem birbirinden farklıdır.

    Linux'ta her dosya sistemi farklı bir dizinde tutulur ve bu dizinlerin bilgisi /etc/fstab dosyasında yeralır. Açılış anında bu dosyada hangi dosya sistemlerinin hangi dizinler altına yerleştirileceği okunur ve buna göre makina açılır. Linux, kendisi için özel olarak geliştirilen ext2 dosya sistemini kullanır.

    Bir sistem görevlisi olarak çeşitli dosya sistemlerini (FAT, VFAT, FAT32, minix, ext2, HPFS, vb) tanımalı, bu dosya sistemleri üzerinde hata oluşması durumunda zararı en aza indirecek yolu bilmelisiniz. Bilgisayar başında geçireceğiniz zamanınızın büyük bir bölümünü dosya sistemleri üzerinde harcayacaksınız.



    6.3.1. mount İşlemi

    Bir dosya sisteminin kullanılabilmesi için boş bir dizin altına yerleştirilmesi (bağlanması) gerekir. Ancak bu gerçekleştirilirse sözkonusu dosya sistemini oluşturan dosyalar üzerinde işlem yapılabilir. Bu işlem mount komutu yardımıyla yapılır.

    mount komutu şu şekilde kullanılır :

    mount -t [tip] [aygit] [nereye-baglanacak]

    tip : Dosya sistemi çeşidi. Örnek dosya sistem çeşitleri arasında ext2, minix , msdos sayılabilir. Dosya sistemleri hakkında daha geniş bilgi için Çekirdek Konfigürasyonu konusuna bakın. Genellikle mount programı ne tür bir diske eriştiğini otomatik olarak anlayacaktır.

    nereye : Bağlanacak dosya sistemi hangi dizin altına yerleştirileceğini belirtir.

    aygıt : Üzerinde dosya sisteminin bulunduğu sabit disk, CD-ROM benzeri aygıt.

    Linux'a bağlı olan tüm donanımlara ait bir giriş, /dev dizini altında bulunur. Bu dizin altındaki dosyalar özel olarak tanımlanmıştır ve bunlara kısaca "düğüm " adı verilir. Örneğin /dev/hda2, birinci IDE sabit diskin ikinci bölümünü; /dev/tty1 ise birinci sanal konsolu gösterir.

    Çeşitli sabit disklere ait /dev düğümleri, Linux Kurulumu bölümünde detaylı olarak anlatılmıştı. mount programı bu düğümlere ihtiyaç duyacaktır. Bu yüzden bir dosya sistemini erişilebilir hale getirebilmek için hangi düğüm ismine sahip olduğunu bilmelisiniz. Örnek olarak CD-ROM için /dev/cdrom, birinci disket sürücü için /dev/fd0 gibi.

    CD-ROM sürücüsünü /mnt altına bağlamak için

    # mount -t iso9660 /dev/cdrom /mnt

    yazın. Eğer çekirdekte CD-ROM dosya sistemi desteği varsa ve sistem açılırken çekirdek CD-ROM'u tanımışsa /mnt dizini altına CD'deki dosya sistemi yerleştirilir. Buna benzer şekilde MS-DOS disket içeren disket sürücüyü ve üzerinde ext2 dosya sistemi bulunan ikinci IDE sabit diskin birinci bölümünü sırasıyla /mnt/disket ve /mnt/disk dizinlerine bağlamak için

    # mount -t msdos /dev/fd0 /mnt/disket

    ve

    # mount -t ext2 /dev/hdb1 /mnt/disk

    yazılabilir. Bir bağlama işleminin tersini yapmak ve dosya sistemini erişilemez kılmak için umount komutu kullanılır. /disk altındaki /dev/hdb1 sabit disk bölümünü ayırmak (umount) için

    # umount /disk

    veya

    # umount /dev/hdb1

    kullanılır. Her iki yazım şekli de kabul edilir. Son olarak o an sistemde bindirilmiş halde bulunan tüm dosya sistemlerini görmek için mount komutunu parametresiz yazın. Bu komut hakkında daha detaylı bilgi ve aldığı diğer parametreler için mount(8) kılavuz sayfasına bakın.

    mount ve umount komutları ile bir dizin yapısını disk üzerinde konumlandırırken veya ayırırken üzerinde işlem yapılan dizinde bulunmamanız, ya da o dizinde başka bir süreç çalışıyor olmaması gereklidir. Aksi takdirde aşağıdaki hata mesajını alırsınız:

    # pwd
    /disk
    # umount /disk
    umount: /dev/hdb1: device is busy

    Yapmanız gereken, ayıracağınız dizinden dışarı çıkıp tekrar denemek. Diğer bir seçenek de fuser komutunu kullanmak. Bu komut, ayırmak istediğiniz dizini kullanan tüm süreçleri ekranda gösterir. Böylelikle rahatlıkla yukarıdaki örnekteki gibi umount işlemini gerçekleştirebilirsiniz. fuser komutunun -km seçeneğiyle o dizini kullanan süreçleri öldürülebilir.

    # cd /
    # fuser /disk
    /disk: 78c
    # fuser -km /disk
    # umount /disk


    fuser komutunu kullanırken dikkatli olun, zira sistemi kilitlenme noktasına getirebilirsiniz.

    6.3.2. Dosya Sistemi Bilgileri

    Linux açılırken mount komutu yardımıyla root dosya sistemine ekleyeceği her değişik dosya sistemini /etc/fstab dosyasından okur ve işleme koyar. Aşağıda örnek bir fstab dosyası yeralıyor.

    /dev/hda2 / ext2 defaults 1 1
    /swap none swap defaults 1 1
    /dev/cdrom /cdrom iso9660 defaults 1 1
    none /proc proc defaults 1 1
    /dev/hda1 /dos msdos defaults 1 1

    Çekirdek açılış mesajları içinde

    VFS: Mounted root (ext2 filesystem) readonly.

    gibi bir satır göreceksiniz. Sistem açılırken en önce / dosya sistemini bağlar. Bu sayede bu dosya sistemi altında yeralan ve hayati önem taşıyan yazılımlara (fsck, ifconfig gibi) ulaşır. Daha sonra yerel dosya sistemleri ve en son da ağ üzerinden erişilen dosya sistemlerine (NFS) bağlanır. fstab dosyasında kullanıcının kendi dosyalarını yerleştiremediği, fakat sistem tarafından kullanılan swap ve proc dosya sistemleri için de mount bilgileri bulunur.

    Yukarıdaki fstab dosyasında ext2 dosya sistemine sahip /dev/hda2 sabit disk bölümü, / dizinini oluşturuyor. MS-DOS formatlı /dev/hda1 bölümü de /dos dizinine erişilebilir olarak açılış anında eklenecektir.

    Sistemdeki CD-ROM sürücü /cdrom dizini altına yerleştirilmiş olup root kullanıcı bunu istediği dizine koyabilir. Bu dosyaya, mount komutundaki gibi parametreler de eklenebilir. Dördüncü sırada yeralan defaults parametresinin yanına eklemek istediğiniz seçenekleri yazın. Bu parametrelerden sıkça kullanılan bir tanesi de "user" olup root dışındaki kullanıcılara bağlama (mount) hakkını verir. CD-ROM sürücüyü normal sistem kullanıcılarının bir veri depolama cihazını bağlaması veya ayırması için fstab dosyasındaki ilgili satırı

    /dev/cdrom /cdrom iso9660 defaults,user 1 1

    satırıyla değiştirin. defaults parametresi ise , halihazırdaki dosya sistemini okunup yazılabildiğini, üzerindeki bilgileri bloklar halinde alıp verdiğini (buna diğer örnekler CD-ROM ve disket sürücülerdir), içerdiği programların çalıştırılabilir olduğunu ve normal kullanıcıların bağlama/ayırma işlemlerini yapamadığını gösterir. user parametresiyle kullanıcılara mount ve umount hakkı yukarıda verilmiştir.

    6.3.3. Dosya Sistemi Yaratılması ve Kontrolü

    Bazen MS-DOS altından oluşturulamayan dosya sistemlerini (ext2 gibi) oluşturmak gerekebilir. Linux altında bir dosya sistemini oluştururken aynı zamanda bunu kontrol eden programlar vardır. Bunların en çok kullanılanı, Slackware sürümünde gelen mkfs'tir.

    mkfs ile Linux native (ext2) dosya sistemi oluşturmak için mkfs.ext2 programı kullanılır.

    mkfs.ext2 <aygit> <blok-sayisi>

    "aygıt" yerine üzerine dosya sistemi kurulacak olan cihazın /dev dizini altındaki düğüm dosyasının ismi yazılır. Blok sayısı yerine, fdisk yazılımından o bölümün kaç blok olduğunu öğrenip bu sayıyı girmelisiniz. Bir blok 1024 bayttan oluşur. Örneğin

    # mke2fs /dev/hda3 163829

    komutu, /dev/hda3 disk bölümünde ext2 dosya sistemi kurar. Bu komutu kullanmadan önce iyi düşünün, zira burada yeralan tüm dosyalar silinir ve bu hatanın geri dönüşü olmaz. fdisk'in yeni sürümleri blok sayısını kendisi buluyor ve kullanıcının girmesine gerek kalmıyor. Aşağıdaki komut ile bir disket üzerinde ext2 dosya sistemi kuruluyor.

    # mke2fs /dev/fd0 1440

    mke2fs ile mkfs.ext2 komutları aynıdır. Benzer şekilde, MS-DOS dosya sistemi yaratmak için mkfs.msdos, minix dosya sistemi yaratmak için mkfs.minix kullanılabilir. Blok sayısı girilmez ise mke2fs bunu otomatik olarak bulacaktır.

    Herhangi bir sebepten dolayı diskte bozulma ve veri kaybını en aza indirmek için de yazılımlar vardır. fsck ile dosya sistemi kontrolü yapılabilir. fsck ile ext2, dosfsck (veya fsck.msdos) ile MS-DOS formatlı alanlar kontrol edilir.

    # fsck /dev/hda2
    Parallelizing fsck version 0.5b (14-Feb-95)
    e2fsck 0.5b, 14-Feb-95 for EXT2 FS 0.5a, 95/03/19
    /dev/hda2 is mounted. Do you really want to continue (y/n)? yes

    Pass 1: Checking inodes, blocks, and sizes
    Pass 2: Checking directory structure
    Pass 3: Checking directory connectivity
    Pass 4: Checking reference counts
    Pass 5: Checking group summary information
    Fix summary information<y>? yes

    Block bitmap differences: -46486 -46487 -46488 -46489 -46490. FIXED
    Free blocks count wrong for group 5 (2803, counted=2808). FIXED
    Free blocks count wrong (16326, counted=16331). FIXED

    /dev/hda2: ***** FILE SYSTEM WAS MODIFIED *****
    /dev/hda2: ***** REBOOT LINUX *****
    /dev/hda2: 3494/29632 files, 42904/59235 blocks

    Bir dosya sistemini kontrol etmeden önce okunan bölümü root dosya sisteminden ayırın ve kontrol işleminden sonra bilgisayarı kapatıp tekrar açın.

    debugfs programı, dosya sistemi parametrelerini incelemek için kullanılır. Disk üzerine doğrudan erişim yaptığı için dikkatli kullanmalısınız. ext2fs yardımıyla kurtarılamayan bazı dosyalar (özellikle silinmiş dosyalar) debugfs yardımıyla kurtarılabilir.

    6.4. Sembolik Bağlantılar

    Bazı durumlarda, bir dosyayı oluşturup bu dosyanın başka bir dosyayı işaret etmesi istenebilir. Genellikle sistem yöneticileri tarafından kullanılan sembolik bağlantı yardımıyla bir dosya veya dizin, bunlara karşılık gelen başka bir dosya veya dizin olarak gösterilir.

    Aşağıda bir sembolik bağlantı örneği yeralıyor. Sistem görevlisi, /root dizini altındayken /usr/src/linux dizinine geçmek istiyor. /usr/src/linux dizinine işaret eden bir bağlantı kurmak için ln komutu kullanılır. -s parametresi, bu bağlantının sembolik olacağına işaret eder.

    # ls -l
    total 116
    drwxr-xr-x 2 root root 1024 Feb 14 08:13 kernel
    -rw-r--r-- 1 root root 115695 Sep 15 1994 lodlin15.zip
    drwx------ 2 root root 1024 Jan 7 1980 mail
    -rw-r--r-- 1 root root 0 Feb 15 08:14 typescript
    # ln -s /usr/src/linux linux
    # ls -l
    total 116
    drwxr-xr-x 2 root root 1024 Feb 14 08:13 kernel
    -rw-r--r-- 1 root root 115695 Sep 15 1994 lodlin15.zip
    drwx------ 2 root root 1024 Jan 7 1980 mail
    lrwxrwxrwx 1 root root 9 Feb 15 08:14 linux -> /usr/src/linux
    -rw-r--r-- 1 root root 0 Feb 15 08:14 typescript

    Bu işlemden sonra kullanıcının /usr/src/linux dizinine geçmesi için cd linux yazması yetecektir. Sembolik bağlantı dosyasını diğerlerinden ayıran, satırın en solundaki l karakteridir.


    6.5. Dosya Arşivleme ve Sıkıştırma

    Linux altında dosya arşivlenmesi ve sıkıştırılması neredeyse belirli ve standartlaşmış birkaç komut ile gerçekleştiriliyor. tar komutu yardımıyla istenilen dosyaları arşivleyebilir, bunların üzerine yenilerini ekleyebilir, istediğiniz zaman da tekrar açıp eski haline getirebilirsiniz. GNU gzip komutu ise dosyaların sıkıştırılması (zip) ve sıkıştırılmış dosyaların açılması (unzip) işlemlerini yapabiliyor. Yeterli disk alanınız yoksa bu iki komut her zaman yardımınıza koşacaktır.

    6.5.1. Dosya Arşivleme

    tar (Tape ARchive) programı, bir veya birden fazla dosyayı tek bir arşiv haline sokar. Genellikle bir dizin ve bu dizinin altında yer alan tüm alt dizinleri biraraya getirmek için kullanılır. tar, dosyaların üzerinde sıkıştırma işlemini normalde uygulamaz. Fakat tar'ın GNU sürümü (Linux'ta da kullanılan) bu işlemi bir parametre yardımıyla yapabilir.

    tar komutuna bir örnek verelim :

    $ tar -cf arsiv.tar tmp/

    Bu komut, -c (create archive) parametresi yardımıyla tmp dizini altındaki herşeyi paketleyip arsiv.tar isimli dosyaya yollar. -f parametresi, hangi dosyaya yazılacağını belirtir. İstediğiniz zaman dosyayı tekrar açmak isterseniz :

    $ tar -xf arsiv.tar

    komutunu kullanın. -x (extract) parametresi, -f ile belirtilen dosyayı açacaktır.
    -r opsiyonu ile daha önce yaratılmış bir arşive dosya eklenebilir. Böylece dosyayı açma ve tekrar arşiv oluşturma işleminden kurtulmuş olursunuz.

    $ tar -rf arsiv.tar ekleme.txt
    Dosyanın içeriğini önceden görebilmek için -t parametresini kullanın ve bu işlemi de alışkanlık haline getirin. Bazı durumlarda arşivlenmiş yazılım, kendine ait bir dizin açmak yerine içerdiği dosyaları bulunduğu yere yazabilir.

    $ tar -tf arsiv.tar

    Hangi dosyaların açıldığını ekranda görebilmek için -v parametresini ekleyin:

    # tar -zcvf tmp.tgz /tmp
    tar: Removing leading / from absolute path names in the archive.
    tmp/
    tmp/tar-error
    tmp/.X11-unix/
    tmp/rc.inet1.OLD
    tmp/networks.OLD
    tmp/linux/
    tmp/linux/fss.txt
    tmp/lilo.conf
    tmp/PKGTOOL.REMOVED

    Aşağıdaki komut, arşivlenen dosyaları diskete kaydetmeye yarıyor. Bunun için temiz bir disketi yuvasına yerleştirin ve aşağıdaki satırı yazın.

    # tar -cf /dev/fd0 tmp/

    tmp dizini altındaki herşeyi diskete kaydetmiş olduk. Açmak için bilinen yöntemi kullanırız :

    # tar -xf /dev/fd0



    6.5.2. Dosya Sıkıştırma ve Açma

    Dosya sıkıştırma amacıyla sıkça kullanan iki yazılım vardır : gzip ve compress. Her iki yazılım da Slackware Linux dağıtımında bulunuyor. GNU'nun dağıtımı olan gzip, tar ile birlikte kullanılan ve dosya sıkıştırma ve arşivlemede neredeyse standart haline gelmiş bir program. Bir dosyayı sıkıştırmak için parametre girmeden gzip komutunun ardından dosya ismini yazın.

    $ gzip elvis
    $ ls -al
    elvis.gz

    gzip ile sıkıştırılmış dosyaların sonu .gz ile biter. Bunları açmak için gunzip komutunu kullanın:

    $ gunzip elvis.gz

    compress ve uncompress de sırayla bir dosyayı sıkıştırmak ve açmak için kullanılır. Aslında Linux'ta uncompress adında bir yazılım yoktur, bu dosya ismi compress dosyasına sembolik bağlantılıdır. compress ile sıkıştırılan dosyaların sonu .Z ile biter.

    $ ls -al web.html
    -rw-r--r-- 1 gorkem users 41450 Jan 27 13:40 web.html
    $ compress web.html
    $ ls -al web.html.Z
    -rw-r--r-- 1 gorkem users 18906 Jan 27 13:40 web.html.Z

    Yukarıdaki web.html dosyasını sıkıştırdığımızda dosyanın boyutu 41450 bayttan 18906 bayta indi. Açmak için:

    $ uncompress web.html.Z
    kullanabilirsiniz. Bir dosyanın uzantısından ne tür bir dosya olduğunu anlayamazsanız file komutu imdadınıza koşar. Linux'ta belirli uzantılı dosyaların başı bilinen bir harf veya harf grubu ile başlar. file komutu dosyanın başındaki karakterleri kontrol ederek ve bunları bir listeyle (/etc/magic) karşılaştırarak dosyanın ne tür olduğunu söyler.

    # file tmp.gz
    tmp.tgz: gzip compressed data - deflate method, last modified: ... os: Unix
    # file tmp.tar.Z
    tmp.tar.Z: compressed data 16 bits

    6.5.3. Birlikte Kullanım

    ftp adreslerinde Linux için yeralan yazılımlar genellikle tar ve gzip, nadiren de tar ve compress ile sıkıştırılıp arşivelenerek saklanırlar. Çünkü tar komutu tek başına arşivi sıkıştırmaz, bu işlem için gzip veya compress kullanılır. Bunların açılabilmesi için tar komutu ve birkaç parametre yeterli olur.

    $ ls
    netscape-4.0.linux-elf.tar.gz

    Yukarıdaki dosya önce tar ile arşivlenmiş, ardından gzip ile sıkıştırılmış. Tek adımda bu iki dosyayı açmak için tar dosyasına x ve f parametrelerinin dışında z parametresini de ekleyin :

    $ tar -zxf netscape-4.0.linux-elf.tar.gz
    $ ls
    netscape-4.0.linux-elf

    Eğer dosya sıkıştırılırken compress komutu kullanılmışsa z yerine Z parametresini yazın.

    $ ls
    folder.tar.Z
    $ tar -Zxf folder.tar.Z
    $ ls
    folder

    Benzer şekile, bir dosyayı aynı anda hem tar ile arşivlemek, hem de sıkıştırmak istersek c ve f parametreleri dışında compress ile Z, gzip ile z parametrelerini girmek yeterlidir. Aşağıda sırayla gn-gopher dizisinin önce tar ve gzip ile, ardından tar ve compress ile arşivlenmesi görülüyor.

    $ ls
    gn-gopher/
    $ tar -zcf gopher.tgz gn-gopher/
    $ tar -Zcf gopher.tar.Z gn-gopher/

    6.6. Dizin Tarama

    Linux işletim sistemini ilk kurduğunuz anda, yüzlerce dizin altında binlerce dosyanız olacaktır. find komutu, bu dosyaların arasında tarama yapabilmek için geliştirilmiştir. Bu komutla sadece dosya isimlerine değil, dosyanın sahibi, erişim hakları, son erişim tarihi gibi verilere de ulaşmak mümkündür. find komutunun en sık kullanış şekli şudur :

    find <dizin-ismi> -name <ne-aratiliyor>

    dizin-ismi yerine taranacak olan dosyanın bulunduğu dizin ismi yazılır. -name parametresinden sonra ise aranan dosyanın ismini girin. Burada "*" ve "?" gibi joker karakterlerini de kullanabilirsiniz. (Bu gibi özel karakterler hakkında daha geniş bilgi Bash Kabuğu konusu altında bulunabilir)
    Aşağıda, find komutunun kullanımına ilişkin birkaç örnek yeralıyor.

    $ find . -name "*.html"
    (bulundugunuz dizinden itibaren sonu .html ile biten dosyalari arar)
    $ find /home/halil -name "screen"
    (/home/halil dizininden itibaren screen isimli dosyalari arar)

    Bu komut, -type d parametresi yardımıyla sadece dizin isimleri arasında arama yapar.

    $ find /usr/ -name "linux" -type d

    find komutuna bir alternatif olan locate komutu ile dosyalar çok kısa bir sürede taranabilir. update komutu, her sabah belirli bir saatte sistemdeki tüm dosya ve dizin isimlerini bir veri tabanına yükler. Daha sonra bu dosyada yeralan belirli bir dosya veya dizin ismini locate ile arayabilirsiniz:

    # locate pico
    /usr/bin/pico
    /usr/man/man1/pico.1.gz

    Yukarıdaki komut ile içinde pico kelimesi geçen dosyaları bulduk.

    6.7. mtools MSDOS Arabirimi

    Linux altından, MS-DOS formatlı disketlere ulaşmayı kolaylaştıran paketin ismi mtools olarak bilinir. Paketle birlikte gelen çeşitli yardımcı programlar sayesinde MS-DOS formatlı diskette yeralan dosyalar listelenebilir, silinebilir, disket formatlanabilir, hatta disketin kimliği değiştirilebilir.

    Son çıkan mtools paketi, 2MB formatlı disketleri de tanıyabiliyor. Aşağıda, mtools paketinden çıkan bazı komutlar ve örnek kullanımları gösteriliyor.

    mdir : disketin içeriğini görüntüler.
    5#5

    mcopy : Bir dosyayı Linux'tan diskete, disketten Linux'a aktarır.

    # mcopy a:/autoexec.bat .
    Copying AUTOEXEC.BAT

    mdel : DOS dosyasını siler

    mformat : Disketi formatlar.

    mmd : Disket üzerinde dizin oluşturur.

    MSDOS mtools yazılımı aynı zamanda VFAT tipi uzun dosya isimlerini de ekranda gösterebilir. Eğer dosya ismi, tek bir DOS ismi içine sığmıyorsa ve 8+3 kuralını bozuyorsa uygun bir kısa isim yaratılır.

    Bunun yanında mtools'un 2 Mb'lık disketleri okuyabilme özelliği de vardır. mtools paketinin konfigürasyon dosyası /etc/mtools.conf'tur. Bu dosyanın kullanımı için mtools(1) kılavuz dosyasından yararlanabilirsiniz.

    7. LINUX SİSTEM YÖNETİMİ

    Bir işletim sistemi, marka ve modeli ne olursa olsun bakım isteyen bir araçtır. Yapılacak küçük bir hata, veya hatayı gösteren bir işaretin gözardı edilmesi, zaten değerli olan zamanın boşa gitmesine neden olabilir. Linux'a, sorumluluk sahibi sistem yöneticisi tarafından açık tutulduğu süre içinde verimli ve düzgün çalışması için gerekli özen gösterilmelidir. İnternet üzerinde üzerinde 500 kullanıcı olan , veya ftp.linux.org adresi gibi her hafta onbinlerce ziyaretçisi olup ağır sorumluluklar yüklenen Linux makinaları vardır. Bunların birkaç dakika boyunca bile kapalı kalması, o anda bağlanmayı bekleyen pek çok kullanıcıyı mağdur durumda bırakacaktır.

    Performansı etkileyen unsurların başında, önlemek pek de elinizde olmasa da elektrik kesintileri ve makinanın kapalı olduğu zamana denk gelen çekirdek değişimleridir. Bu tür donanımsal etkileri bir tarafa bırakırsak sistem yöneticisinin uyması gereken ve İnternet etikleri dediğimiz davranış kuralları vardır. Bu kurallara öncelikle sistem sorumlusu uymalı ve kullanıcıları da uymaya zorlamalıdır. Açık işletim sistemlerinin en büyük sorunlarından biri olan güvenlik konusuna sistem yöneticisi belirli günler zamanının bir bölümünü ayırmalıdır. Kullanıcılardan gelebilecek her türlü saldırı, sisteme onarılması zor zararlar verebilir. Bunun için düzenli olarak sistemi kontrol edin ve şüpheli durumlarda araştırma yapmaktan çekinmeyin. Bu konuda daha fazla bilgiyi Linux İşletim Sisteminde Güvenlik başlığı altında bulabilirsiniz.

    Yukarıdaki tabloya bakarak işinizin zor olduğu kanısına kapılmayın, zira tüm bu denetleme mekanizmasını basitleştirebilirsiniz. Yapılacak tüm rutin işleri bir program haline getirin. Günün veya haftanın belirli saatlerinde bu programı çalıştırın ve olabilecek tüm hata mesajlarını bir dosyaya yazın. Bu dosyayı boş bir vakitte inceleyerek programın ne kadar düzgün çalıştığını gözlemleyebilirsiniz. Bunun yanında sistem yönetimini zevkli kılacak uygulama programları da vardır. Bu uygulama yazılımlarından bazıları o kadar gelişmiştir ki neredeyse yapamadıkları tek iş yemek pişirmektir.

    Yabancı kaynaklı yayınlardan Essential System Management (Frisch) ve Essential System Administration (O'Reilly) bu yönde tavsiye edilebilecek kitaplar. Piyasada bulunan Türkçe kitapların hiçbirisinde sistem yönetimine ciddi olarak değinilmediği için Türkçe yayın bulmak gayet zor.

    7.1. Yetkili Kullanıcı ve Diğer Kullanıcılarla İlişkiler

    Sistemin en büyük sorumlusu root şifresini bilen kullanıcıdır. Yukarıda da belirtildiği gibi bu şifrenin sorumluluğu büyüktür. Sistem yöneticisi, makinadaki kullanıcıların isteklerini ve şikayetlerini yönelttikleri tek merci durumundadır. Burada karşılıklı güven sözkonusudur, bunu da sistem görevlisi herkese hissettirmelidir. root kullanıcısının, başkalarından gözünüz gibi sakladığınız e-posta ve dosyaları sizden habersiz okuduğunu öğrenseydiniz tepkiniz ne olurdu?

    root kullanıcısının sahibinin haberi olmaksızın sistem kullanıcılarına ait dosyaların yerini ve izinlerini değiştirmesi de uygun değildir. Zorda kalsanız bile, başkalarına ait hiçbir dosyayı silmeyin veya içeriğini değiştirmeyin. Belki de çözümsüz gibi görünen bir durumdan kurtulmanın başka bir yolu olabilir.

    Temel olarak zaman zaman kullanıcıları bilgilendirmek hoş bir davranış olarak karşılanır ve onların Linux'a olan ilgilerini perçinleyebilir. Örneğin /etc/motd ve /etc/issue dosyalarına periyodik olarak çekirdek değişimlerini ve eklenen uygulama programlarını haber veren birkaç satır iliştirebilirsiniz. Sistemde açılan her kullanıcı hesabınahttp://www.linux.org.tr/linuxtrfaq.htmlLinux Çokça Sorulan Sorular (Linux ÇSS), çeşitli UNIX belgeleri ve İnternet hakkında bilgilendirici dokümanlarının yeraldığı bir dizi e-posta da yollanabilir. Bu konuda yaratıcılığınızı konuşturun.

    7.2. Sistem Kuralları

    Kullanıcı hesabı açmadan önce birkaç basit kuralı tanımlayıp kullanıcılardan bunlara uymalarını istemelisiniz. En basitinden birkaç kural, bir hesabın birden fazla kişi ile kullanılmaması, sistemin güvenliğini zedeleyecek crack , COPS , SATAN gibi programların diğer kullanıcıların zararına çalıştırılmaması ve sistem kaynaklarının sorumsuzca tüketilmemesi olarak sayılabilir.

    Siz, en iyisi yukarıda yeralan kuralları birkaç madde halinde yazın ve sistemdeki herkesin bu maddelere uyacağını taahhüt eden imzasını alın. Tatsız durumların çıkmaması için de önlem almayı ihmal etmeyin.

    7.3. Kullanıcı İşlemleri

    Aşağıda yeralan konularda, kullanıcı hesaplarının açılması ve kapatılması anlatılıyor.




    7.3.1. Kullanıcı Hesabı Açmak (adduser)

    Kullanıcı hesabı açmak iki yoldan yapılabilir. Birincisi, adduser komutu yardımıyla, diğeri de bu komutun yaptığı işlemleri sırasıyla elle yapmak. root olarak sisteme girin ve komutu çalıştırın. Bu aşamadan sonra bir komutu 'root' olarak çalıştırın dediğimiz zaman 'root' kullanıcısına geçiş yaptıktan sonra bu komutu çalıştırmanız gerektiğini biliyor olmalısınız.

    # adduser

    Login name for new user (8 characters or less) []: mehmet

    User id for mehmet [ defaults to next available]:

    Initial group for mehmet [users]:

    Additional groups for mehmet []:

    mehmet's home directory [/home/mehmet]:

    mehmet's shell [/bin/bash]:

    mehmet's account expiry date (MM/DD/YY) []:

    OK, I'm about to make a new account. Here's what you entered so far:

    New login name: mehmet
    New UID: [Next available]
    Initial group: users
    Additional groups: [none]
    Home directory: /home/mehmet
    Shell: /bin/bash
    Expiry date: [no expiration]

    This is it... if you want to bail out, hit Control-C. Otherwise, press
    ENTER to go ahead and make the account.


    Making new account...

    Changing the user information for mehmet
    Enter the new value, or press return for the default

    Full Name []: linux kullanicisi
    Room Number []:
    Work Phone []:
    Home Phone []:
    Other []:

    Changing password for mehmet
    Enter the new password (minimum of 6, maximum of 8 characters)
    Please use a combination of upper and lower case letters and numbers.
    New password:
    Bad password: too simple.
    Warning: weak password (enter it again to use it anyway).
    New password:
    Re-enter new password:
    Password changed.
    Done...

    Kullanıcının isminin 3 karakterden az, 8 karakterden fazla olmamasına özen gösterin. Sistem sizden kullanıcının gerçek ismini, ev dizinini, (genellikle /home içinde olur), grubunu isteyecektir. adduser komutu, eğer özel olarak değiştirmek istemezseniz her kullanıcının grup kimliğini (GID) kendisi tanımlayacaktır. Bu gruba karşılık gelen grup ismi (Group Name) users dır. Kullanıcı kimliği (UID = User ID) ise genellikle 500'den sonra gelen ve kullanılmayan ilk sayı olarak atanır. Eğer UID olarak 0 girerseniz sistemde sizinle beraber bir süper-kullanıcı daha yaratmış olursunuz :)

    Sisteme girişte çalıştırılacak olan kabuk için seçimi ister kullanıcıya bırakın, isterseniz öntanımlı olarak bash verin. Bash'in sistemdeki tam patikasını (/bin/bash) yazmalısınız. Bu alana sadece kabuk ismi girmek şart değildir.

    Yukarıda sistem bizi güçlü bir şifre seçmediğimiz için uyardı. Şifre olarak, herkesin kolayca tahmin edemeyeceği zorlukta, fakat kullanıcının bir yere yazmasını önleyici kolaylıkta bir kelime bulun. Kullanıcı, hesabının açılmasından hemen sonra sisteme girecekse ve şifresini değiştirecekse kısa ve kolay bir şifre yeterli olacaktır.

    Her şeyin doğru olduğuna eminseniz, sorulan soruya ``y'' ile, değilseniz ``n'' ile cevap verin. Hemen ardından /etc/skel dizini altında yeralan tüm dosyalar bu kullanıcının dizinine kopyalanacaktır. Buraya, her kullanıcının ev dizinine önceden yüklenmesini istediğiniz sistem dosyalarını yerleştirebilirsiniz. Bu andan itibaren yeni kullanıcı sisteme girebilir.

    Sisteme kullanıcı ekleme işlemini el yordamıyla yapmak isterseniz, /etc/passwd ve /etc/shadow dosyalarına birer satır eklemelisiniz. /etc/passwd'de aralarında birer ':' karakteri olmak kaydıyla sırayla hesap ismi, "x", grup kimliği, kullanıcı kimliği, kullanıcı isim ve soyadı, ev dizini ve kabuk programı yeralır. /etc/passwd içine bu satırı ekleyin:

    ozgur:x:100:502:Misafir Sanatci:/home/ozgur:/bin/bash

    /etc/shadow içine ise aşağıdaki satırı yerleştirin, tabi diğer satırlara dokunmadan.

    ozgur::9990:0:99999:7::::

    Bu satırda yeralan ikinci girdi mirkelam kullanıcısının şifresini belirtiyor. /etc/shadow dosyasına yazılacak olan şifreyi önce boş bırakıp, ardından passwd ozgur komutuyla bir şifre atayın.
    /etc/shadow dosyasında kullanılabilecek parametreler için shadow(5) man dosyasına göz gezdirin.
    Ardından /home/ozgur dizinini oluşturun. Dizinin grubunu da ayarlayın. Çok gerekli olmasa da gelen e-postalar için /var/spool/mail dizininde bir dosya tanımlayın ve /etc/skel içinde yeralan dosyaları kullanıcının dizinine kopyalayın.

    # cp -R /etc/skel/* /home/ozgur
    # mkdir /home/ozgur
    # chown -R ozgur.users /home/ozgur
    # touch /var/spool/mail/ozgur
    # chown ozgur.mail /var/spool/mail/ozgur

    7.3.2. Kullanıcı Grubu

    Eğer Linux makinanız birkaç yoğun görev üstlenmişse (örneğin www veya ftp sunucusu olarak kullanılıyorsa) her bir işlem için birden fazla grup tanımlanabilir. users grubuna bağlı kalmadan wwwadm veya ftpadm gibi grup isimleri belirtebilir, bu grupları da bir veya birkaç kullanıcıya ait olacak şekilde değiştirebilirsiniz.

    users grubunun dışında birden fazla grup tanımlanması, sistemin denetlenmesini bir miktar güçleştirse de sistem güvenliğini artırır. Bazı kullanıcıların birden fazla grubunun olmasıyla bu kullanıcılar rahatlıkla sistemde root kullanıcısının üstlenmesi gereken işleri yapabilirler.

    Grup kimliğinin değiştirilmesi veya yeni grubun eklenmesi için /etc/group dosyası kullanılır. Bu dosyaya grubun ismi, numarası, grup şifresi ve gruba ait kullanıcılar yazılır. Her kullanıcının en az bir grubu vardır.

    /etc/group dosyasının iki satırında yeralan parametreler,

    root::0:root
    sys::3:root,bin,sys,adm

    gibidir. Sırayla ":" karakteri ile ayrılmış her kolon,
    1. Grup ismi
    2. Grup şifresi
    3. Grup numarası
    4. Gruba ait kullanıcılar

    şeklinde özetlenebilir. İlk sütun grup ismini belirtir. Grup ismi, ls -l komutunu işletince kullanıcı isminin hemen sağında görülen kelimedir. Grup şifresi, gruba ait olmayan kullanıcıların dosyalarına erişim sağlamak için kullanılır.

    Grup şifresi nadiren kullanılır. Grup numarası, kullanıcının ait olduğu grubun karşılığıdır. Son sütunda ise gruba ait kullanıcılar, her biri birer virgülle ayrılmış olarak yazılır. Kullanıcı sisteme girdiği zaman otomatik olarak /etc/passwd dosyasında yeralan grup ismi aktif olur, bu yüzden her kullanıcının ismi /etc/group dosyasına yazılmaz. Sistem ilk kurulduğu anda birkaç grup halihazırda zaten vardır. Örneğin root grubunun grup numarası 0'dır ve pekçok sistem dosyasının sahibidir, bin grubunun numarası is 2 olup /usr/bin ve /bin dizinlerindeki çoğu dosyanın grubudur.

    Hangi grubun (veya tanımlanmışsa grupların) içinde olduğunuzu öğrenmek için groups komutunu kullanabilirsiniz.

    $ groups gorkem
    users

    7.3.3. Kullanıcının Hesabının Silinmesi

    Bir kullanıcıya ait hesabı silmek için /etc/passwd dosyasında bu kullanıcıya ait olan satırdaki şifre kolonunun başına * işareti koyun. Bir şifrelenmiş bir parolanın içinde * karakteri olamayacağından bu kullanıcı bir daha sisteme giremez.

    Hesabı tamamen silmek için, kullanıcının ev dizinini ve e-postalarını yedekledikten sonra sistemde kullanıcıya ait olan dosyaları (/tmp altında) ve ev dizinini silin.

    /etc/passwd ve /etc/group dosyasından kullanıcının isminin geçtiği satırları kaldırın. Sistemde kullanıcıya ait olabilecek tüm dosyaları da silmeniz gerekebilir. Bunun için find kullanabilirsiniz.

    $ find / -user gorkem -ls -exec rm {} \;

    Bu komutu /etc/passwd dosyasından kullanıcı ismine ait olan satırı kaldırmadan önce yapmalısınız.

    7.4. Sistemin Yedeklenmesi

    Makinanızın belirli aralıklarla yedeklenmesi, sistem güvenliğinin bir parçası sayılabilir. Donanımdan meydana gelen bir hata sonucu veya yanlışlıkla girilen bir komut, sistemi açılamaz hale getirebilir. Ancak yedekleme ile bu tür kullanıcı hatalarının önüne geçebilirsiniz. Yedekleme genellikle tüm sistem üzerinde yapılmaz. Sadece önemli sistem bilgilerini içeren dizinler yedekleme aşamasına girmelidir.

    Yedekleme üniteleri olarak teyp, disket veya başka diskler kullanılabilir. Teypler, büyük miktarda yedekleme işlemleri için ön plana çıksa da birkaç dosyadan oluşan paketlerin korunması söz konusu olacaksa disketler daha pratiktir. İnternet üzerinde ise bağımsız bir makina, kendi rutin görevi dışında yerel ağda bulunan makinaların yedeklerini belirli gün ve saatlerde almak üzere programlanabilir.

    Sistemde fazla miktarda kullanıcı varsa yedekleme işlemi ciddi bir düzene oturtulmalıdır. Sistemdeki hayati dosyalar örneğin her hafta, üzerinde kullanıcıların bulunmadığı akşam saatlerinde yedeklemeye sokulabilir.

    Yedekleme için birkaç yol önerilebilir. Kullanışlı olması için yedeklemeyi yapan program, yedeklenen dosyalar arasındaki belirli bir dosyayı kolayca açabilmelidir. Bunun yanında, yedek bilginin de bozulması ihtimali vardır. Yedeğin içindeki tek baytın bozulması, bazı durumlarda tüm yedeğin çöp yığını haline gelmesine yol açabilir. Doğru yedekleme programının kullanılması bu anda önem kazanır.

    Yedeklenecek olan dizinlerden en önemlileri, sistem konfigürasyon dosyalarının yeraldığı /etc, kullanıcı dizinlerinin yeraldığı /home, bazı X Window dosyalarının bulunduğu /usr/X11/lib/X11 dizini altındaki bazı dosya ve dizinler, /usr ve /usr/local dizinde yeralan bazı dizin ve dosyalar ile /root dizinidir. Şart olmasa da yedekleme için yeriniz bolsa /tmp dizinini de koyabilirsiniz.

    Elektronik postaları (/var/spool/mail) da unutmamak gerekir.

    Aşağıdaki komut, /usr ve /home dizinlerini diskete yedekler.

    $ tar cvMf /dev/fd0 /usr /home

    tar komutununa verilen M parametresi yardımıyla bir disket dolduğu zaman başka bir diskete devam etmenizi sağlar. Dizinleri sıkıştırarak atmak için z seçeneğini vermek yeterli olur. Sıkıştırarak yedekleme disket ya da teypte yer kazandıracaktır, ancak hata olduğunda verilerin kurtarılması daha zor olacaktır. Açmak için

    $ tar xf /dev/fd0

    komutu yeterlidir. Sıkıştırılarak diskete atılan yedekler için açarken de "z" kullanın. Disketleri sıra ile numaralandırmayı ihmal etmeyin, yoksa bir disketten fazla yer kaplayan arşivleri açamazsınız.

    Linux'ta gerek SCSI, gerek floppy teyp desteği vardır. Özellikle çok veri yedekleyecekseniz teypler kaçınılmaz olur. Teyplere yedek alırken de yukarıdaki floppy orneklerindeki gibi tar kullanabilirsiniz. tar'ın yanı sıra sıkça kullanılan yedekleme komutları arasında dump ve restore , cpio ve dd gösterilebilir. Linux'ta ilk SCSI teyp sürücüye /dev/st0, ikinciye /dev/st1 ... kullanarak, PC'lerde sıkça kullanılan ``floppy teyp''lere de /dev/ftape üzerinden erişebilirsiniz. Piyasada bulacağınız ortalama floppy teyplerin kapasiteleri 120M, 4mm SCSI teyplerin 4G, 8mm SCSI teyplerin ise 7G kadar olacaktır. Teybin kapasitesi kullandığınız sürücünün yeteneğine ve teybinizin uzunluğuna göre değişir. Örnek olarak, bütün sistemin tar kullanarak ilk SCSI teybe yedeklemek için,

    # tar cvf /dev/st0 /
    Bir TCP/IP ağınız varsa, ve birden fazla Linux ya da UNIX makinası kullanıyorsanız, tek bir teyp sürücü ile bütün makinalarınızın, hatta Windows makinalarınızın bile (Linux'un yardımıyla) yedeğini alabilirsiniz. Bu iş için amanda gibi daha özelleşmiş ve yedekleme işlemini otomatikleştiren bir program kullanabileceğiniz gibi, GNU tar'dan da yararlanabilirsiniz. Örneğin tar ile, cclub.metu.edu.tr makinasından, linux.org.tr makinasındaki floppy teybe yedek almak için,

    # tar cvf linux.org.tr:/dev/ftape /home

    komutundan yararlanabilir. Bu komutun çalışması için linux.org.tr makinasının root'unun .rhosts dosyasında cclub makinasının root'una izin verilmiş olması gerekir. Bu işlem güvenlik için sakıncalı olduğundan, bu iş için özel bir kullanıcı açmak gibi bir yönteme başvurulabilir. Örneğin linux.org.tr'da yedek adlı bir kullanıcı açtığımızı düşünelim. Bu durumda yukarıdaki komutu,

    # tar cvf yedek@linux.org.tr:/dev/ftape /home
    şeklinde yazabiliriz.


    7.5. Sistemin Güncellenmesi

    Tekrar Linux yüklenecek olan makina üzerinde halihazırda Linux bulunmasının yararları olduğu gibi bazı sakıncaları vardır. İlk olarak yararlarına değinmek gerekirse, yapılacak aslında sadece işletim sisteminin bulunduğu bölümü değiştirmektir. Takas alanının ayrılması, kullanıcı alanının ayrılması gibi işlemler bu durumda önceden yapılmış oluyorlar. Ancak yeni işletim sisteminin yüklenmesinin bazı zararları da var.

    Herşeyden önce çalıştığı bilinen bir işletim sistemi yenisi ile değiştiriliyor. Gerçekten bunu gerektirecek bir sebep olmadıkça bu tür güncellemelerden kaçınılması veya en aza indirilmesi gerekir. Yeni bir sistem, yeni bilinmeyenler ve az olsa bile çalışmama riski getirecektir.

    Eğer sistem üzerinde belirli hizmetler veriliyorsa o hizmetlere ilişkin verilerin bu güncelleme esnasında yok olmamasına dikkat edilmeli. Mesela makina bir web sunucu olarak kullanılıyorsa web dosyalarının bir şekilde yeni sisteme aktarılması gerekecektir .

    Benzer şekilde güvenlik amacıyla makinaya ait tanımların (/etc) ve standart dağıtım dışında yüklenmiş paketlerin önceden yedeklenmesi gerekir.

    Güncelleme için iki yöntem akla gelebilir, doğrudan yeni sistemi eskisinin üzerine bindirmek veya eskisini silerek yeniden yüklemek. Slackware sürümü için en sağlıklısı eski sistemi silmektir. Çünkü değişik dağıtımlarda dosya dağılımı farklılıklar gösterebilmektedir. Bunun sonucunda bazı dosyalar birden fazla yerde gözükebilmektedirler. Bir diğer sakınca ise setup yazılımının bazen bu durumda şaşırabilmesi ve hata vermesi. Bazı ticari Linux sürümleri (Red-Hat, Debian, Caldera gibi) eski sürümü silmeye gerek bırakmadan sistemi güncelleme özelliğine sahipler.

    Güncellemeniz gerekebilecek dizinler, /var/spool/mail, kullanıcı dizinleri (root dahil), /usr altında gerekli dizinler, /var/adm/ ve /etc olarak sayılabilir. Bazen /etc içinde yer alan dosyaların yeri veya şekli değişmiş olabilir. Onun için en güvenlisi teker teker dosyaları inceleyip kopyalamaktır. Belirli dosyaları yeni sistemi kurduktan sonra hemen kopyalayabilirsiniz :

    /etc/group
    /etc/printcap
    /etc/hosts
    ...
    Daha önce shadow kullanmayan bir sistemden shadow sistemine geçiyorsanız, /etc/passwd ve /etc/shadow dosyalarında gerekli değişiklikleri yapmadan yeni yerine kopyalamayın. Ayrıca ne olur ne olmaz diye çalıştığını bildiğiniz bir çekirdeği de yedeğe almayı ihmal etmeyin.

    7.6. Çekirdeğin Derlenmesi

    Bu bölümde, çekirdeğin konfigürasyonu ve derlenmesi için gerekli bilgiler vardır. Çekirdek derleme uzun ve zahmetli bir işlemdir. Derleme aşamasını en kısa zamanda ve en uygun yoldan gerçekleştirmek gerekir. Derleme işlemi, kullanıcının önüne kafasını karıştıracak kadar çok seçenek sunar.

    Genel anlamda çekirdek, yazılımın ve donanımın arasında bekleyerek iletişimi sağlayan bir arabirimdir. Çalışan tüm programların ve süreçlerin hafıza ile olan ilişkilerini düzenler. İşlemcinin gücünün tüm bu programlar arasında adil bir şekilde dağıtımını üzerine alır. Bu işlemleri kullanıcının haberi olmadan her an durmaksızın yapar.

    Çekirdek kaynak dosyaları diskte hatırı sayılır bir alan tutar. Örneğin sürüm 2.0.20 yaklaşık 6Mb disk alanı kaplar. Açıldığı zaman ise toplam kapladığı alan 24 Mb olur. Derleme aşamasından sonra bu rakam 30 Mb'yi geçer. Her eklenen aygıt sürücü desteği çekirdekten bir miktar daha yer alır.

    Kullandığınız sisteme göre çekirdeğin derlenme süresi değişkenlik gösterir. 32 Mb Pentium 200MMX makinasında, 5 dosya sistemi desteği, ağ desteği ve ses kartı sürücüsü ile yaklaşık 5 dakika sürer. Aynı konfigürasyonu içeren çekirdeğin derlenmesi ise daha güçsüz bir makina olan 8Mb 386DX/40 altında 1.5 saati bulur. Derlerken gidip çayınızı için, biraz televizyon seyredin. Makinaniz 386 ise bir banyo alıp dışarı çıkın, alışveriş yapın. Çok ümitsiz bir durumdaysanız, yapılacak en iyi şey en yakın bilgisayar satıcısına uğrayarak yeni fiyatları sormak.

    Çekirdek kaynak kodu ,ftp://ftp.metu.edu.tr/pub/tsx/sources/systemODTÜ'deki adresinden veya tsx-11.mit.edu adresinin yansısını tutan herhangi bir adresten alınabilir. Bu dizin altındaki Linux sürümlerinin bir tanesini (v2.0, v2.1 gibi) seçtikten sonra altındaki dosyayı alabilirsiniz. Dosyanın ismi linux-x.y.z.tar.gz yapısındadır.

    Aşağıdaki örnekte ODTÜ ftp arşivinden 2.0.20 sürümünün alınışı gösterilmektedir:

    $ ftp ftp.metu.edu.tr
    Connected to ephesus.cc.metu.edu.tr.
    220-
    220-Welcome to METU Ftp Site !
    220-
    220-All logins and transfers are logged with your hostname.
    220-If you do not agree with this policy, please cancel now.
    220-
    220 ephesus FTP server (Version wu-2.4(5) Wed Jan 10 18:06:56 EET 1996) ready.
    Name (ftp.metu.edu.tr:gorkem): ftp
    331 Guest login ok, send your complete e-mail address as password.
    Password:
    230-##########################################################################
    230-## Welcome to the Middle East Technical University Ftp Archive ##
    230-##########################################################################
    230-
    230-
    230-Hello ftp@compclup.ceng.metu.edu.tr !
    230-You are the 19. anonymous user.
    230-Maximum number of users allowed is 100.
    230-Local Time is Tue Nov 5 12:19:41 1996.
    230-
    230-Mirrored sites are placed under the directory /pub
    230-This archive is maintained by ftpload@ftp.metu.edu.tr
    230-You can reach this archive via FSP at port 21.
    230-
    230-You can reach public directories via "cd dirname"
    230-command independent of your current location;
    230-e.g. "cd linux" instead of "cd /pub/linux"
    230-
    230 Guest login ok, access restrictions apply.
    ftp> cd /pub/linux/tsx/sources/system/
    250-Please read the file README
    250- it was last modified on Mon Sep 16 11:36:00 1996 - 50 days ago
    250 CWD command successful.
    ftp> dir
    200 PORT command successful.
    150 Opening ASCII mode data connection for /bin/ls.
    total 66
    -rw-r--r-- 1 ftpload ftp-adm 36981 Sep 16 12:36 CREDITS
    drwxr-xr-x 3 ftpload ftp-adm 512 Oct 13 15:59 Historic
    -rw-r--r-- 1 ftpload ftp-adm 12056 Sep 16 12:36 README
    drwxr-xr-x 2 ftpload ftp-adm 512 Oct 14 11:47 SillySounds
    drwxr-xr-x 2 ftpload ftp-adm 512 Oct 13 18:17 testing
    drwxr-xr-x 2 ftpload ftp-adm 512 Oct 14 11:47 v1.0
    drwxr-xr-x 2 ftpload ftp-adm 2048 Oct 31 21:55 v1.1
    drwxr-xr-x 2 ftpload ftp-adm 1024 Jun 25 11:34 v1.2
    drwxr-xr-x 2 ftpload ftp-adm 6656 Sep 27 04:24 v1.3
    drwxr-xr-x 2 ftpload ftp-adm 1536 Nov 2 00:05 v2.0
    drwxr-xr-x 2 ftpload ftp-adm 512 Nov 2 21:33 v2.1
    226 Transfer complete.
    ftp> cd v2.0
    250 CWD command successful.
    ftp> bin
    200 Type set to I.
    ftp> dir linux*
    200 PORT command successful.
    150 Opening ASCII mode data connection for /bin/ls.
    total 141009
    -rw-r--r-- 1 ftpload ftp-adm 5859566 Jul 3 11:22 linux-2.0.1.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5940281 Jul 27 06:39 linux-2.0.10.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5952403 Aug 5 03:01 linux-2.0.11.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5954278 Aug 9 12:53 linux-2.0.12.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5981780 Aug 16 06:19 linux-2.0.13.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5984960 Aug 20 11:52 linux-2.0.14.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5986368 Aug 25 06:20 linux-2.0.15.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5990228 Aug 31 14:03 linux-2.0.16.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5991606 Sep 2 06:37 linux-2.0.17.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5993351 Sep 5 10:38 linux-2.0.18.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5997342 Sep 11 10:21 linux-2.0.19.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5861789 Jul 5 12:09 linux-2.0.2.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5997693 Sep 13 08:53 linux-2.0.20.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5999162 Sep 20 09:51 linux-2.0.21.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 6009488 Oct 8 13:02 linux-2.0.22.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 6010694 Oct 18 08:20 linux-2.0.23.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5931967 Jul 6 07:53 linux-2.0.3.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5926911 Jul 8 08:48 linux-2.0.4.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5927899 Jul 10 08:23 linux-2.0.5.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5929807 Jul 12 07:22 linux-2.0.6.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5931378 Jul 15 07:38 linux-2.0.7.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5936467 Jul 20 02:52 linux-2.0.8.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5939510 Jul 26 04:09 linux-2.0.9.tar.gz
    -rw-r--r-- 1 ftpload ftp-adm 5843677 Jun 9 23:36 linux-2.0.tar.gz
    226 Transfer complete.
    ftp> get linux-2.0.20.tar.gz
    200 PORT command successful.
    150 Opening BINARY mode data connection for linux-2.0.20.tar.gz (5997693 bytes).
    226 Transfer complete.
    5997693 bytes received in 136 secs (43 Kbytes/sec)
    ftp> quit
    221 Goodbye.

    Sisteme root olarak giriş yapın ve /usr/src dizinine geçin. Linux'un kurulması aşamasında çekirdekleri de kurmuş iseniz bu dizinde 'linux' isminde ve eski çekirdeğin kaynak kodlarını kapsayan bir alt dizin göreceksiniz. Genellikle her kullanıcının yaptığı, bu dizinin ismini o an çalışan çekirdeğin sürümüne göre değiştirmektir. Çekirdek sürümünü bulmak için ise uname -r komutunu kullanabilirsiniz.

    $ uname -r
    2.0.23

    Bu komuttan çekirdeğin 2.0.23 sürümü olduğunu anlayabiliriz.

    Çekirdek kodunu içeren paketi açmadan önce /usr/src dizinine kopyalayın, ve açmadan önce bu dizinde 'linux' isimli bir dizinin olmadığına emin olun. Şimdi /usr/src içinde iken sıkıştırılmış çekirdek kodunu 'tar' komutu yardımıyla açın.

    # tar -zxf linux-x.y.z.tar.gz

    Komutun işletimi bitince ``linux'' dizini oluşur. Bir sonraki aşamaya geçebiliriz.

    7.6.1. Çekirdek Konfigürasyonu

    /usr/src/linux dizini altinda iken make config yazın. Bu komut, bir konfigürasyon dosyası yaratmak amacıyla sorular sorar.

    Karşınıza çıkan sorulara 'y' (evet) veya 'n' (hayır) ile cevap vermeniz gerekir. Bazı aygıt sürücülerde ya da sistem desteklerinde 'm' seçeneği de olabilir. Bunun anlamı, sistem o programı modül olarak derleyecek ve çekirdeğe dahil etmeyecek demektir. Kullanıcı derleme aşamasından sonra istediği zaman bu modülü çekirdeğe dahil edebilir, işini bitirdikten sonra da çıkarabilir. Eğer kerneld çalışıyorsa bu işlemleri otomatik olarak halleder. Örnek olarak, disket sürücü modülü hazırladınız. Ne zaman disketi okumak isterseniz, kerneld bunu farkeder ve gerekli modülleri hafızaya yükler.

    2.0.x ve daha yukarı sürümlerde '?' tuşuna basmakla daha ayrıntılı bilgi alabilirsiniz. Aşağıda bazı konfigürasyon parametreleri verilmiştir. Bu parametreler çekirdekten çekirdeğe farklılık gösterebilir.

    Matematik işlemci emülasyonu (Kernel math emulation)
    Kullandığınız makinanın işlemcisi yardımcı matematik işlemcisine sahip değilse (486SX, 386SX veya daha düşük makinalar) bu seçeneğe evet cevabını vermelisiniz.

    Normal disk ve IDE disk/cdrom desteği (Normal disk and IDE disk/cdrom sup.)
    Hemen herkesin kullandığı PC sabit disklerinin standart olması sebebiyle bu seçeneğe 'y' cevabı verilebilir. Daha ileride SCSI sabit disk ve cdrom desteği de sorulacaktır. Ardından gelecek olan 'old disks-only' ve 'new IDE' sürücülerinden birini seçerken, aralarındaki farkın ilkinde tek arabirim üzerinden iki adet diski desteklemesi, diğerinde ise ikinci arabirim ile birlikte IDE/ATAPI cdrom'ları desteklemesidir.

    Ağ desteği (Networking support)
    Makinanız herhangi bir ağ üzerinde ise (İnternet gibi), veya İnternet'e bağlanmak için SLIP, PPP gibi programları kullanmak istiyorsanız bu bölüme 'y' cevabı vermelisiniz. Fakat, ağ üzerinde olmasanız bile her geçen gün yeni yeni uygulama programlarının ve paketlerin ağ desteğine ihtiyacı olduğunu düşünürsek (X Window gibi) bu bölüme 'y' cevabı vermeniz şart görünüyor.

    En fazla 16Mb hafıza (Limit memory to low 16Mb)
    Bazı hatalı 386 DMA denetleyicileri hafızanın 16Mb'tan yüksek bölümlerine ulaşamazlar. Çok nadir görülen bu durum makinanızda varsa bu seçeneği 'y' ile geçin.

    System V IPC (System V IPC):
    IPC (Interprocess Communication) desteği verir. Bazı Perl programları ve oyunlar (DOOM gibi) bu seçenek olmadan çalışamazlar. Bu durumda ne yaptığınızı iyi bilmiyorsanız bu seçeneğe 'y' -evet- cevabı verin.

    İşlemci tipi (386, 486, Pentium, PPro):
    Burada, çekirdeğinizi hangi tür makina için derliyorsanız, o makinanın tipini giriniz.

    SCSI desteği (SCSI Support):
    SCSI aygıtlarınız var ise bu seçenek için 'evet' deyin. Daha sonra da karşınıza gelecek SCSI aygıtlar arasından size uygun olanları alın.


    Ağ kartı desteği (Network Device Support):
    Ağa bağlanmak için bir kart kullanacaksanız veya SLIP, PPP bağlantıları, ya da paralel port üzerinden yapacağınız her türlü işlemler için bu seçeneği işaretleyin. Ardından ekrana gelen kart tiplerinden uygun olanlarını seçin.

    Dosya sistemleri (Filesystems):
    Burada, aşağıdaki dosya sistemlerinden kullanmak istediklerinizi seçebilirsiniz.
    • minix: Yeni dağıtımlar , artık tarih olmaya başlayan bu dosya sistemini desteklememekte. Bazı kurtarma disketleri yaratmak için daha yaygın, fakat daha az kararlı olan ext2 dosya sistemine tercih edilirler.
    • Extended file system (ext): Bu da artık kullanımı olmayan bir dosya sistemi. Desteğini ekleyip eklememek size kalmış. 2.1.x sürümü çekirdeklerde artık bu destek yok.
    • Second extended file system (ext2): Linux'un kullandığı en önemli dosya sistemi. Alınması şart.
    • xiafs: Artık kullanılmıyor.
    • msdos: Sabit diskinizde DOS bölümü varsa, ya da DOS disketi kullanmak istiyorsanız, alın.
    • umsdos: MS-DOS dosya sistemine bazı yenilikler (uzun dosya isimleri gibi) getirilerek oluşturulan bir teknoloji. MS-DOS desteği almadıysanız buna da gerek yok.
    • proc: Bu aslında gerçek bir dosya sistemi değil, çekirdek görüntüsüdür. `y' cevabını vermezseniz ileride başınız çok ağrır.
    • NFS: Linux makinanız bir ağ üzerinde kurulu iken ağ üzerindeki diğer makinaların dosya sistemlerini kullanabilmenizi sağlar.
    • ISO9660: CD-ROM sürücünüzü Linux altında kullanabilmek için 'y' cevabı verin.
    • OS/2 HPFS : OS/2 dosya sistemlerini okuyabilmek için 'y' cevabı verin.
    • System V: Bir UN*X sürümü olan System V makinalarının dosya sistemleri üzerinde çalışabilmeyi sağlar.

    Karakter aygıtlar (Character devices):
    Bu bölümde yazıcı, fare ve bazı teyp yedekleme sürücüleri gibi karakter aygıtları (iletişimini karakter bazlı sağlayan aygıtlar) için sürücüleri ekleyebilirsiniz.

    Ses kartı (Sound Card Support):
    Linux'un ses kapasitesini "duyabilmek" için bu desteği ekleyin.

    Çekirdek işlemleri (Kernel Hacking):
    Çekirdekten doğan hataların bulunmasını kolaylaştıran bu seçenek, programcılara yönelik.

    Tüm bu işlemlerin ardından make config komutunun görevi bitmiş olur.

    7.6.2. Temizlik

    Fazla dosyaları temizlemek, gerekli olan dosyaların da yerinde olup olmadığını kontrol etmek için , sırasıyla

    # make dep
    # make clean

    yazın. Ardından tüm nesne dosyaları ve eski sürümden arta kalan dosyalar silinecektir. Bu adımı es geçmemelisiniz.

    Temizlik işleminden sonra,

    # make zImage , veya
    # make zdisk

    yazın. Eğer bir kişisel bilgisayarda çalışıyorsanız, ilk seçenekte çekirdek derlenip /usr/src/linux/arch/i386/boot dizini altına zImage adıyla yerleştirilecektir. Buraya yerleştirilmeden önce yerden kazanmak için çekirdek sıkıştırılır. Diğer durumda ise yeni çekirdek sabit disk yerine A: disket sürücüsüne yazılır. Disket üzerine yazmanın bir avantajı, kararlı olmayan ve sistemi açmayan çekirdek ile karşılaşılması halinde, sistemi sabit disket üzerindeki eski çekirdekten açabilme imkanı bırakmasıdır.


    7.6.3. Çekirdeğin Kurulması

    LILO, bilgisayarın açılışı anında çekirdek ile ilgili düzenlemeleri okur, buna göre hangi çekirdekten açması gerektiğini anlar. Konfigürasyon dosyası biraz karmaşık olmasına rağmen kullanım aşamasında büyük yararlar sağlar. /etc/lilo.conf dosyasının içinde gerekli olan kurulum bilgileri vardır. Bu dosyanın bir bölüm aşağıda görülüyor.

    image = /vmlinuz
    label = linux
    root = /dev/hda1

    other = /dev/hda1
    label = dos
    table = /dev/hda

    image = ibaresi kurulu olan çekirdeğin adına işaret eder. label = bölümünde hangi işletim sistemi veya çekirdek sürümünün açılışta kullanılacağı yazılır. Hemen altındaki root bölümünde ise label = kısmında seçilen işletim sisteminin hiyerarşik sırada en üst dizin yapısı yazılır. Eski çekirdeğin bir yedeğini alın ve yeni derlediğiniz çekirdeği image = satırında belirtilen yere kopyalayın.

    # cp zImage /vmlinuz

    Şimdi LILO programını çalıştırın. Komut satırında lilo yazmak yeterlidir. `*' karakteri, kullanıcı müdahalede bulunmaz ise çalıştırılacak ilk çekirdeği veya işletim sistemini gösterir.

    # lilo
    Added linux *
    Added dos

    Yeni bir çekirdeği derledikten sonra LILO üzerinden ekleme yapmak ve açılış anında kullanmak için /etc/lilo.conf dosyasındaki

    image = /vmlinuz
    label = Linux
    root = /dev/hda1

    satırlarının kopyasını çıkarın, image , label ve root yerine sırasıyla yeni derlenen çekirdeğin sabit disk üzerindeki yerini, ismini ve Linux işletim sisteminizin kök dizinini içeren sabit disk bölümünü yazın. Bunlara ek olarak, açılış anında bekleme sağlamak ve seçim yapabilmek için konfigürasyon dosyasının başına delay = xxx ekleyebilirsiniz. xxx sayısı, gecikme zamanı saniyenin onda biri olarak verilir. Bu sayede açılış anında , örneğin shift tuşuna basılarak istenen çekirdeğin ismi (label = satırında yazılan isim) seçilir ve çalıştırılır.


    7.6.4. Çekirdeğin Yamanması (patch)

    Çekirdeğin her yeni sürümüyle birlikte bir önceki sürümünun yaması da gelir. Yamayı uygulamak, tüm çekirdeğin tekrar derlenmesinden daha kolaydır. Örnek olarak, elinizde 2.0.10 çekirdeği var ve ftp adresinde 2.0.11 sürümü bekliyor. Halihazırdaki çekirdeği 2.0.11 sürümüne yükseltelim:

    Yamayı önce /usr/src dizinine kopyalayın. Bu dizin altında iken

    # zcat patch-2.0.11.gz | patch -p0

    veya eğer sıkıştırılmış değilse

    # patch -p0 < patch-2.0.11

    yazın. Bu komutun ardından satırlar ekrandan kaymaya başlayacak ve yama işlemi tamamlanacaktır. Satırlar bazen o kadar hızlı kayar ki neler yazdığını bile göremeyebilirsiniz. Yamanın başarılı bir şekilde tamamlandığından emin olmak amacıyla, /usr/src/linux dizini altında .rej uzantılı dosyalara bakın.

    # find . -name '*.rej' -print

    Komut, .rej uzantılı dosyalar bulursa yama işlemi tamamlanamamış demektir. Eğer yama işlemi tamamlanırsa, sırasıyla

    # make clean
    # make config
    # make dep

    komutlarını yazın. Bu komutlarla ilgili detaylı bilgi önceki konuda anlatılmıştır.

    patch komutunun alabildiği bazı seçenekler vardır. patch -s komutu oluşabilecek tüm hata mesajlarını ekrana yazar. Diğer yama seçenekleri man patch yazarak görülebilir.

    Birkaç yamanın ardından, .orig uzantılı dosyalar etrafta dolaşmaya başlar. Bu dosyalar gereksizdir, büyük yer kapladıkları için silinmeleri gerekir. Aşağıdaki komut yardımıyla /usr/src/linux dizini altında .orig uzantılı dosyaları silebilirsiniz.

    # find /usr/src/linux -name '*.orig' -exec rm -f {} ';'

    7.6.5. Çıkabilecek Sorunlar

    Eger rutin bir çekirdek güncellemesinden sonra yeni çekirdeğiniz gerçekten garip şeyler yapıyorsa, büyük ihtimalle yeni çekirdeğinizi derlemeden önce "make clean" komutunu kullanmayı unutmuşsunuzdur.

    Eğer çekirdek çok fazla hafıza harcıyorsa, çok büyükse, veya yeni 786DX6/440 makinanızda bile derlenmesi sonsuza kadar sürüyorsa, büyük ihtimalle ayarlanmış bir çok gereksiz parça (aygıt sürücüleri, dosya sistemleri, vb.) vardır. Büyük çekirdeklerin en belirgin özelliği sürekli hafızadan diske ve diskten hafızaya takas yapmalarıdır.

    Çekirdeğinizin ne kadar hafıza kullandığını öğrenmek için dmesg komutunu kullanabilir veya çekirdek kayıt dosyasına bakabiliriz.

    Memory: 15124k/16384k available (552k kernel code, 384k reserved, 324k data)

    LILO'yu çalışıtırmayı unuttunuz, veya sistem hiç açılmıyorsa bu durumda yapacağınız en iyi şey disketten açılış yapmak ve daha sonra açılış yapabilen başka bir disket hazırlamaktır.

    Eğer eski çekirdek 1.2.x ve daha düşükse ve bunu 2.0.x sürümüne yükseltmek istiyorsanız, 2.0.x çekirdek kurulumunda getirilen bazı değişiklikler sorun çıkartabilir.

    /usr/src/linux/Documentation/Changes dosyasında yapmanız gereken değişklik listesi vardır. gcc, libc gibi birkaç paketi yeniden kurmanız gerekebilir.

    Aynı anda birkaç çekirdek kaynak kodunu sistemde bulundurmayı düşünüyorsanız, izlenecek en güvenilir yol, her birine /usr/src/linux-x.y.z ismini vermektir (x.y.z halihazırdaki çekirdek sürümünü gösterir). Ardından sembolik bir bağlantı yardımıyla istediğiniz kaynak dizinini seçebilirsiniz, örneğin

    # ln -sf /usr/src/linux-2.0.2 /usr/src/linux

    komutu, linux-2.0.2 dizinini aktif hale getirir. Artık kaynak dosyalarının bulunduğu yer linux-2.0.2 dizinidir.

    7.7. Modüller (Yüklenebilir Çekirdek Parçaları)

    Linux işletim sistemi çekirdeğinin boyu genellikle 400-600Kb arasındadır. Hantal çekirdeklerde bu sayı 800Kb'lara kadar çıkabilir. Çekirdeğin boyunun büyümesi, sistemin performansını olumsuz yönde etkiler. Özellikle bilgisiz kullanıcıların gerekli gereksiz tüm desteği çekirdeğe yüklemesi sıkça görülür. Bunun önüne geçmek de deneyim ister.

    Linux'a özgü özelliklerden birisi modüllerdir (yüklenebilir çekirdek parçaları). Modüller sayesinde nadiren gerekli duyulan bir çekirdek parçası sadece gerektiği zaman çekirdeğe eklenir. Örneğin Java programlarını her zaman çalıştırmak istemiyorsanız, bu desteği modül olarak derleyip bir kenara koyarsınız. Ne zaman bir Java programı çalıştırılacaksa bu modül hafızaya yüklenecektir.

    Bir modül, çekirdeğin derleme aşamasında `M' parametresiyle tanımlanır. Her desteğin modülü henüz geliştirilmemiş olmasına rağmen bu sayı gün geçtikçe artmaktadır. İlginizi çekebilecek modüller arasında disket desteği, yazıcı desteği, minix dosya sistemi desteği veya SCSI aygıt sürücü desteği sayılabilir.

    Çekirdeği derledikten sonra modülleri önceden tanımlı yerlerine yerleştirmek için iki komut daha girmelisiniz:

    # make modules
    # make modules_install

    Bir modülü derledikten ve kurduktan sonra modüle ait dosya /lib/modules dizini altında yeralır. Burada istenilen bir modül

    # insmod modul-ismi

    komutuyla çekirdeğe eklenir. Modülü hafızadan çıkarmak için

    # rmmod modul-ismi

    yazın. Hafızadaki modüllerin bir listesini görebilmek için de lsmod komutu kullanılabilir.
    kerneld komutu, arka planda çalışarak gerekli olan modülleri anında yükler. Bu sayede çekirdeğe eklemek için insmod komutuna gerek kalmaz. Ayrıca belirli bir süre içinde kullanılmayan modülleri de çekirdekten atar.

    7.8. Yeni Yazılımların Yüklenmesi

    Linux işletim sistemi, benzerlerine nazaran çok büyük bir hızla genişliyor. Her an yeni bir program, yeni bir yazılım piyasaya çıkıyor ve bunları takip etmek de gittikçe zorlaşıyor. Bir ftp adresini kontrol ettikten iki gün sonra tekrar bakıyorsunuz ki üç-beş yeni yazılım gelivermiş.

    Tabi ki her an her programı makinanıza indirip açmak zorunda değilsiniz. Buna ne zamanınız, ne de sabit diskiniz yeter (Linux'un sunsite arşivi 20GB'tan fazla yer kaplıyor!). Öyleyse tespih çeker gibi program indirmek veya varolan yazılımları güncellemek komik olur. Sadece gereken zamanda gereken dosyaları makinanıza kurmalı veya güncellemelisiniz.

    Bu işlem çekirdek için de geçerlidir. Bazı çekirdek fanatikleri yeni çekirdek sürümü çıktığı anda makinalarına indirir ve derlerler. Sisteminize çok önemli bir fonksiyon kazandırmayacaksa her an çekirdek derlemek hem zaman kaybı olur, hem de derleme esnasında sistemi yavaşlatarak diğer kullanıcıları kızdırır. Burada küçük bir sır vereyim. Daha önce DOS altında çalışan eski kullanıcılara yönelik olarak nc'nin çok benzeri olan mc (midnight commander), sisteminizde kurulu olarak durmaktadır, ondan faydalanabilirsiniz.

    Kurmak istediğiniz ve ftp adresinden bulup getirilen dosya çok büyük ihtimalle tar ve gzip ile arşivlenip sıkıştırılmıştır. Bu dosyanın sonu genellikle tar.gz, tgz veya tar.Z ile biter. Dosya kaynak koduyla veya çalıştırılabilir program olarak dağıtılıyor olabilir. Her iki durumda da yapılacak işlemler birbirine benzer.

    Öncelikle yazılımın açıldığı zaman hangi dizine kendini yerleştireceğine bakmak gerekir. Bunu tar komutunun -t seçeneği ile kontrol edin. compress ve gzip ile sıkıştırılmış dosyalar için,

    # tar -ztvf dosya.tar.gz

    komutu kullanılabilir. Çok nadir durumlarda dosya, kendine ait bir dizin yaratmaz, onlarca programı ve konfigürasyon dosyasını bulunduğunuz dizine yazar. Karmaşıklık yaratan bu durumdan ancak arşivi ayrı bir dizin altında açmakla kurtulabilirsiniz.

    Linux'çular yeni bir yazılımı denemek istediklerinde arşivi genellikle /usr/src veya /usr/local/src dizini altına kopyalarlar ve burada açarak biraz sonra anlatılacak konfigürasyon işlemini uygularlar. Derleme gerektirmeyen bazı programların ise doğrudan kök dizinde açılmaları gerekebilir. Bu programlar açıldıkları anda çalışmaya hazırdırlar.

    /usr/src veya /usr/local/src dizini altına arşivi açtıktan sonra bol miktarda dosya ve dizinle karşılaşabilirsiniz. Buna en iyi örnek Linux çekirdeğidir. Burada yeralan bazı anahtar dosyalar yazılımın kurulması için hayati önem arzeder.

    Öncelikle README, README.linux ve varsa INSTALL dosyalarının gözden geçirilmesi gerekir. Bunlar sırayla bir kullanıcı olarak dosyaları nasıl kuracağınızı ayrıntılarıyla söyler. Kurma aşamasında dikkat edilecek dosyalardan ilki Makefile veya makefile dosyasıdır. Bu dosyanın içinde (nadiren) küçük birkaç değişiklik yapmak gerekebilir. Diğer kontol edilmesi gereken dosya ise varsa config.h dosyasıdır. Bunu da sistem gereksinimize göre değiştirmelisiniz.

    Bazen başta derleyici olmak üzere sistemdeki yazılımı baştan aşağı kontrol eden programlar olabilir (configure gibi). Bunların da komut satırından çalıştırılmaları gerekir.

    # ./configure

    Varsa Makefile dosyasına göre yazılımı kurmak için make komutunu kullanın. make komutu make all, make install gibi bazı parametreler alabilir. make all, halihazırda yeralan tüm yazılımları kurarken make install, bu yazılımı konfigürasyon dosyalarının gösterdiği dizinlere yerleştirirler.

    Çoğu büyük paketler, kılavuz dosyalarıyla birlikte gelirler. Bunları da diğer man dosyalarının yanına (/usr/man) koymak için ayrı bir make install.man türü komut kullanmak gerekebilir.

    Her durumda, mutlaka README dosyasını okuyun. Biraz sıkıcı gelse de sizi zaman kaybından kurtaracaktır.

    Slackware dağıtımını kullanıyorsanız, yüklenmiş yazılımları silmek için 2 yolunuz var. Birincisi, root olarak sisteme girip, istemediğiniz programları tek tek komut satırından silebilirsiniz. Ama bu size önerebileceğimiz bir yol değil ve çok fazla sakıncası var. Örneğin, programı silip, ona olan bağlantıları unutabilirsiniz. Ya da tam tersi olabilir. İkinci ve en geçerli yol, Slackware dağıtımı ile gelen pkgtool programı kullanmanız. pkgtool seçenekleri arasındaki remove package işinize yarayacaktır.

    7.9. Sistem Açılış Dosyaları

    Linux makinası açılırken onlarca dosyayı okur. Birkaç dakika içinde çekirdeği hafızaya yükler, belirli dizinlerin altındaki programları arkaplanda çalıştırır. Sistem uyanırken hatırı sayılır nicelikte konfigürasyon dosyası elden geçer. Açık bir işletim sistemini diğerlerinden ayıran bir özellik de kullanıcının büyük bir kolaylıkla bu konfigürasyon dosyalarını değiştirebilmesidir. Sistem açılış dosyalarında, özellikle ağ temelli dosyalarda değişiklik yapabilmek için TCP/IP konusunda basit temelleri anlayabilmiş olmanız gerekir.

    Açılış dosyalarında, tek bir kullanıcı için veya sistemde hesabı olan herkese yönelik olarak değişiklik yapmak mümkündür. Pek çok kullanıcı bu açılış dosyalarıyla oynayarak Linux'u daha yakından öğrenme imkanına sahip olur.

    Internet servisi veren bir makina bu servisini daemon'lar aracılığıyla yapar. Bir daemon, her makina tarafından bilinen bir port numarasını açar ve dinlemeye koyulur. Eğer sorumlu olduğu port adresine istek gelirse bu isteğe cevap vererek servise başlar.

    Bash kabuğunun anlatıldığı konu içinde sisteme girerken okunan dosyaları anlatmıştım. Sistemde yeralan önemli dizinler de dosya sistemi yapısı konusunda detaylı olarak belirtilmişti. Bu bölümde daemonlardan kısaca bahsedip açılış anında çalıştırılan programlara ve bunların konfigürasyon dosyalarına kısa bir giriş yapılacaktır.

    7.9.1. inetd ve /etc/inetd.conf

    inetd, en ağır görevleri üstlenen ve en önemli İnternet servislerindendir. Bu program sistem açılırken arkaplanda çalışmaya bırakılır. inetd'nin görevi belirli portları dinleyerek bu portlara yapılan bağlantıları denetlemektir. Bir bağlantı yapıldığı anda inetd bu portla ilgilenecek olan programı çalıştırır. Örnek olarak Linux'a ftp isteği geldiği anda inetd, ftp isteğine cevap verecek olan wu.ftpd programını uyandırır ve geri kalanını bu programa bırakır.

    inetd olmasaydı her standart port numarası için bu portu dinleyecek olan bir program arkaplanda çalışıyor olacaktı. Bu da sisteme normalden daha fazla yükün binmesi demektir. inetd'nin kullandığı konfigürasyon dosyası /etc/inetd.conf 'tur. Bu dosyadan bir bölüm aşağıda yeralmaktadır :

    # "kill -HUP <pid of inetd>".
    # The inetd will re-read this file whenever it gets that signal.
    #
    # <service_name> <sock_type> <proto> <flags> <user> <server_path> <args>
    #
    time stream tcp nowait root internal
    time dgram udp wait root internal
    ftp stream tcp nowait root /usr/sbin/tcpd wu.ftpd
    telnet stream tcp nowait root /usr/sbin/tcpd in.telnetd
    #nntp stream tcp nowait root /usr/sbin/tcpd in.nntpd
    shell stream tcp nowait root /usr/sbin/tcpd in.rshd -L
    login stream tcp nowait root /usr/sbin/tcpd in.rlogind
    ntalk dgram udp wait root /usr/sbin/tcpd in.talkd
    pop3 stream tcp nowait root /usr/sbin/tcpd in.pop3d
    imap2 stream tcp nowait root /usr/sbin/tcpd imapd
    finger stream tcp nowait nobody /usr/sbin/tcpd in.fingerd -w
    systat stream tcp nowait nobody /usr/sbin/tcpd /bin/ps -auwwx
    netstat stream tcp nowait root /usr/sbin/tcpd /bin/netstat -a
    # End of inetd.conf.

    /etc altında bir konfigürasyon dosyasını değiştirmek isterseniz, o dosyayı okuyan ve arkaplanda çalışıyor durumda bulunan süreçleri bundan haberdar etmelisiniz. Çünkü bu dizindeki bazı dosyalar sadece açılışta okunur. inetd, yukarıdaki inetd.conf dosyasını sistem açılırken okuyacaktır. Değişiklik yaptıktan sonra inetd'nin bu değişiklikten tekrar haberinin olması için bu sürecin PID numarasını ps -aux komutu ile bir kenara not edin ve şunları yazın.

    # kill -HUP <PID-inetd>

    PID-inetd yerine not ettiğiniz süreç numarasını girmelisiniz. Bu sayede inetd kendisine ait olan inetd.conf dosyasını tekrar okuyacak ve değişiklikler işleme konacaktır.
    Her bilgisayar tarafından bilinen servislerin isimleri ve hangi portları kullandıkları /etc/services dosyasında tutulur.

    7.9.2. syslogd ve /etc/syslog.conf

    syslogd programı Linux'taki çeşitli olayların kayıtlarını tutar. Bunlar genellikle hata mesajları veya çekirdek mesajları gibi kayıtlardır. syslogd sistem açılırken arkaplanda işlemeye bırakılır.

    /etc/syslog.conf, syslogd programının konfigürasyonu için kullanılır. Normal olarak sistem kayıtları /usr/adm/messages dosyasının sonuna eklenir. Bu dosyanın yapısı biraz karışık olmasına rağmen eğer sistem yöneticiyseniz syslogd sizin en büyük yardımcınız olabilir.

    Örnek bir syslog.conf dosyası aşağıda yeralıyor.

    *.info;*.notice /usr/adm/messages
    *.debug /usr/adm/debug
    *.warn /usr/adm/syslog
    *.emerg;*.alert;*.crit /dev/tty8
    mail.* /dev/tty9
    kern.* /dev/tty10

    Bu dosyanın en solunda yeralan ve nokta ile ayrılmış olan iki kelimeden ilki, kaydı yapılan program grubudur. Bu kısma kern (çekirdek mesajları), mail (sendmail mesajları), login (sisteme giriş veya sistemden çıkış mesajları), auth, authpriv veya security (güvenlik mesajları), cron (cron mesajları), daemon (deamon'lardan gelen mesajlar), lpr (yazıcı mesajları), news (haber grubu mesajları), user (kullanıcı mesajları) veya uucp (uucp mesajları) yazılabilir. Noktanın sağındaki kelime ise kaydı yapılan program grubunun mesaj önem sırasını belirler. Bu kısımda önem sırasına göre debug, info, notice, warning, err, crit, alert ve emerg bulunur.

    Dosyanın sağında yeralan kısımda ise bu mesajların hangi dosyaya yazılacağı vardır. Yukarıda verilen örnekte, syslogd'den gelen mesajlar sanal konsollardan kullanılmayanlara yönlendirilmiştir. Böylece sistem yöneticisi F8, F9 ve F10 tuşlarını kullanarak sistem kayıtlarına anında ulaşabilir.

    Başka bir makinaya kayıt tutturmak da mümkündür. Uzak makinanın ismi syslog.conf dosyasının sağ bölümüne yazılır. Böylece diğer makina yerel olarak sistem kayıtlarını tutacaktır.

    mail.err @hun.linux.org.tr.tr

    Bazı kritik ve sistemin düzgün çalışmadığını haber verebilecek mesajların konsola yönlendirilmesinde fayda vardır.

    kern.crit /dev/console

    Sisteme bağlanmış olan kullanıcılar hakkında bilgiyi ise

    /var/adm/wtmp

    dosyası tutar. Bu dosya ASCII olmadığından doğrudan okunamaz, last komutu ile içeriği incelenebilir. Buna ek olarak çeşitli paketler çalıştırılıyorsa onların yarattığı kayıt dosyaları da incelenmelidir. Örneğin ftp çalışıyorsa /var/adm/xferlog kimin ftp ile hangi dosyaları aktardığını gösterir. Bu tür dosyalar içerisinde elde edilebilecek ipuçları ile sistemin çalışma performansı artırılabilir, kendisini pek belli etmeyen hatalar bulunabilir.

    7.9.3. init ve /etc/inittab

    syslogd programı Linux'taki çeşitli olayların kayıtlarını tutar. Bunlar genellikle hata mesajları veya çekirdek mesajları gibi kayıtlardır. syslogd sistem açılırken arkaplanda işlemeye bırakılır.

    /etc/syslog.conf, syslogd programının konfigürasyonu için kullanılır. Normal olarak sistem kayıtları /usr/adm/messages dosyasının sonuna eklenir. Bu dosyanın yapısı biraz karışık olmasına rağmen eğer sistem yöneticiyseniz syslogd sizin en büyük yardımcınız olabilir.

    Örnek bir syslog.conf dosyası aşağıda yeralıyor.

    *.info;*.notice /usr/adm/messages
    *.debug /usr/adm/debug
    *.warn /usr/adm/syslog
    *.emerg;*.alert;*.crit /dev/tty8
    mail.* /dev/tty9
    kern.* /dev/tty10

    Bu dosyanın en solunda yeralan ve nokta ile ayrılmış olan iki kelimeden ilki, kaydı yapılan program grubudur. Bu kısma kern (çekirdek mesajları), mail (sendmail mesajları), login (sisteme giriş veya sistemden çıkış mesajları), auth, authpriv veya security (güvenlik mesajları), cron (cron mesajları), daemon (deamon'lardan gelen mesajlar), lpr (yazıcı mesajları), news (haber grubu mesajları), user (kullanıcı mesajları) veya uucp (uucp mesajları) yazılabilir. Noktanın sağındaki kelime ise kaydı yapılan program grubunun mesaj önem sırasını belirler. Bu kısımda önem sırasına göre debug, info, notice, warning, err, crit, alert ve emerg bulunur.
    Dosyanın sağında yeralan kısımda ise bu mesajların hangi dosyaya yazılacağı vardır. Yukarıda verilen örnekte, syslogd'den gelen mesajlar sanal konsollardan kullanılmayanlara yönlendirilmiştir. Böylece sistem yöneticisi F8, F9 ve F10 tuşlarını kullanarak sistem kayıtlarına anında ulaşabilir.

    Başka bir makinaya kayıt tutturmak da mümkündür. Uzak makinanın ismi syslog.conf dosyasının sağ bölümüne yazılır. Böylece diğer makina yerel olarak sistem kayıtlarını tutacaktır.

    mail.err @hun.linux.org.tr.tr

    Bazı kritik ve sistemin düzgün çalışmadığını haber verebilecek mesajların konsola yönlendirilmesinde fayda vardır.

    kern.crit /dev/console

    Sisteme bağlanmış olan kullanıcılar hakkında bilgiyi ise

    /var/adm/wtmp

    dosyası tutar. Bu dosya ASCII olmadığından doğrudan okunamaz, last komutu ile içeriği incelenebilir. Buna ek olarak çeşitli paketler çalıştırılıyorsa onların yarattığı kayıt dosyaları da incelenmelidir. Örneğin ftp çalışıyorsa /var/adm/xferlog kimin ftp ile hangi dosyaları aktardığını gösterir. Bu tür dosyalar içerisinde elde edilebilecek ipuçları ile sistemin çalışma performansı artırılabilir, kendisini pek belli etmeyen hatalar bulunabilir.

    7.9.4. /etc/rc.d/* Dosyaları

    İşte sistemin kalbinin attığı yer. Ne yaparsanız yapın ama bu dosyaları gözünüz gibi koruyun. Sistem açılırken arkaplanda çalışmaya başlayan programlar burada yazılıdır. Tüm bu dosyalar Slackware dağıtımına özgüdür.
    rc.0
    Bu dosya, 0 (halt) çalışma düzenine geçerken okunur. Sistemin shutdown veya halt komutları ile kapatılmak istenirse bu program çalıştırılır. Önce sistemdeki tüm süreçler öldürülür, ardından sistemin kapandığını belirten bazı satırları kayıt dosyalarına atar. Tüm dosya sistemlerini umount işleminden geçirdikten sonra da sistemi dondurur.
    rc.K
    Bu dosya, init tarafından 1 numaralı çalışma düzenine (tek kullanıcılı konum) geçilirken çalıştırılır. Tüm süreçler öldürülür ve sistem sadece konsoldan giriş yapılacak şekilde tekrar açılır.
    rc.cdrom
    Bu dosya, bulduğu CDROM sürücüsünü /cdrom dizini altına mount yardımıyla bağlar.
    rc.local
    Çok kullanıcılı açılış anında çalıştırılan bu dosyaya istediğiniz programları ekleyebilirsiniz.
    rc.4
    4 numaralı çalışma düzenine geçilirken bu dosya çağırılır. Tüm sanal konsollara vt100 terminalleri yerine grafik tabanlı bir program kullanılarak girilir.
    rc.M
    init tarafından çok kullanıcılı konuma geçmek için kullanılır.
    rc.S
    Sistem açılırken bu dosya mutlaka çalıştırılır. Takas alanı açılır, dosya sisteminde hata olması halinde bunu gidermeye çalışır. Bazı kontrollerden sonra kontrolü diğer rc programlarına bırakır.

    7.10. Çekirdek Mesajları

    Çekirdek, hafızaya yüklenip çalıştırıldıktan sonra kendisi ve sistemdeki donanım hakkındaki her türlü bilgiyi ekrana yazar. Her türlü bilginin içine hata mesajları da girer. Çekirdeğin hata verip vermemesi açılış anında ekrana bakmakla anlaşılabilir. Bu nedenle sistem açılırken gözünüzü monitörden ayırmamalısınız. Aşağıda bir çekirdeğin açılış kaydı yeralıyor :

    Console: colour EGA+ 80x25, 1 virtual console (max 63)
    bios32_init : BIOS32 Service Directory structure at 0x000faf10
    bios32_init : BIOS32 Service Directory entry at 0xfb390
    pcibios_init : PCI BIOS revision 2.10 entry at 0xfb3c0
    Calibrating delay loop.. ok - 30.22 BogoMips
    Serial driver version 4.11 with no serial options enabled
    tty00 at 0x03f8 (irq = 4) is a 16550A
    tty01 at 0x02f8 (irq = 3) is a 16550A
    lp1 at 0x0378, using polling driver
    ftape: allocated 3 buffers aligned at: 00210000
    hda: QUANTUM ELS170A, 162MB w/32KB Cache, CHS=1011/15/22, MaxMult=8
    ide0: primary interface on irq 14
    Floppy drive(s): fd0 is 1.44M
    FDC 0 is a post-1991 82077
    lance.c: PCI bios is present, checking for devices...
    Memory: 6612k/8192k available (760k kernel code, 384k reserved, 436k data)
    This processor honours the WP bit even when in supervisor mode. Good.
    Swansea University Computer Society NET3.019
    Swansea University Computer Society TCP/IP for NET3.019
    IP Protocols: ICMP, UDP, TCP
    PPP: version 0.2.7 (4 channels) NEW_TTY_DRIVERS OPTIMIZE_FLAGS
    TCP compression code copyright 1989 Regents of the University of California
    PPP line discipline registered.
    SLIP: version 0.8.3-NET3.019-NEWTTY (4 channels) (6 bit encapsulation enabled)
    CSLIP: code copyright 1989 Regents of the University of California
    eth0: D-Link DE-600 pocket adapter: at I/O 0x378.
    Checking 386/387 coupling... Ok, fpu using exception 16 error reporting.
    Checking 'hlt' instruction... Ok.
    Linux version 1.2.13 (root@bigkitty) (gcc version 2.7.0)
    Partition check:
    hda: multiple mode turned off
    hda: hda1 hda2
    VFS: Mounted root (ext2 filesystem) readonly.
    Adding Swap: 8188k swap-space

    Yukarıdaki mesajda takas alanı belirlenmesi, sabit diskin tanınması, disketin tanınması, aygıt sürücülerinin, ethernet kartını tanıması ve ekranın özelliklerinin yazılması gibi bilgiler vardır. Bu bilgilere sistem açıldıktan sonra /var/adm/messages dosyasıından da erişilebilir.

    7.11. Linux Dosya Sistemi Yapısı

    Bu bölümde Linux'un kullandığı dosya sistemi hakkında bilgi verilecektir. Dosya sistemini oluşturan dizinler, kapsadıkları dosyalar ve bunların Linux işletim sistemindeki görevleri de kısaca belirtilecektir.

    Bir işletim sisteminin dosya sisteminin performansı, hızı ve buna benzer çeşitli özellikleri sistemin verimli ve kararlı çalışması üzerinde doğrudan etkisi vardır. Linux dizin yapısının geliştirilmesinde FSSTND (file system standard) grubunun çalışmalarının payı çok büyük oldu. Programcılardan oluşan grup, standartların belirlenmesinde ve uygulama aşamasında Linux ile ilgilenenlere yardım etti. 1993 yılında Olaf Kirsh, Linux haber grubuna yazdığı bir e-postasında Linux dosya sistemi üzerindeki çalışmaların tamamlandığını haber verdi. O yıldan bu yana linux dosya sistemi standardı üzerinde kayda değer değişiklik olmamıştır.
    Linux dizin yapısında bazı dizinlerin işlevi birbiriyle aynıdır. Bu durum, özellikle birbirini takip eden iki Linux sürümünde belirginleşir. Örnek olarak bir dağıtımda /usr/bin dizini altında yeralan dosya, diğer sürümde /bin altına yerleştirilebiliyor.

    Dosya sistemleri ve dizinler paylaşımlı olarak da kullanılabilir. Birden fazla kişisel bilgisayarın bağlandığı ağda, disk alanından yer kazanmak için bir makina sunucu (ana makina) olarak tayin edilir. Ağ üzerindeki diğer makinalar da sunucu üzerindeki diski paylaşır. Buna örnek olarak kullanıcı ev dizinlerinin yeraldığı /home, çalıştırılabilir dosyaların bulunduğu /usr, e-posta ve haber grubu bilgilerinin bulunduğu /var/spool/mail ve /var/spool/news dizinleri verilebilir.

    Kök dizini, kendisine bağlı diğer tüm dizinleri de içerdiğinden, Linux dosya sisteminde önemli bir yere sahiptir. Linux açılırken önce kök dizini /etc/fstab dosyasına uygun şekilde bağlanır. Diğer dosya sistemlerinin onarımı ve kontrolü için gerekli olan fsck programları bu dizinde bulunmalıdır. Benzer şekilde yedekleme için gerekli olan tar, zip, compress gibi arşiv programlarına da kök dizin altından erişilebilmeli, açılış esnasında hafızaya yüklenen çekirdek de kök dizininde yeralmalıdır.

    Bir programı yerine koymadan önce bazı "dengelerin" gözönünde tutulmasında yarar vardır. Programlanan her yazılımı kök dizinine koyarsanız, bir süre sonra bu dosya sisteminin şiştiğini görürsünüz. Kök dizinini başlangıçta küçük (20-30Mb kadar) tutmak, geliştirilen programları daha önceden belirlenen başka bir dosya sistemi altına koymak akıllıca olur. Bu yol, ağ üzerinden genellikle paylaşımı mümkün olmayan kök dizininin her makinadaki sabit diskte mümkün olan en az yer işgal etmesini sağlar.

    Sistemdeki önemli dizinlere göz atarsak,
    /bin :
    Sistemin açılışı ve kontrolü için gerekli komutlar. Hem kullanıcıların, hem de sistem görevlisinin kullanabileceği dosyalar (kök dizinde ise fazla şişmemesi koşuluyla) buraya atılabilir. Sadece root kullanıcının ihtiyaç duyacağı init, getty, updatedb gibi programlar /sbin veya /usr/sbin'de durabilir. Bu dizinde bulunan dosyalara örnek olarak cat, chgrp, chown, date, dd, df, ln , mkdir, mount, ps, rm, sh, su, sync ve umount'u sayabiliriz.
    /dev :
    G/Ç dosyaları. Linux çekirdeğinde desteklenen her aygıta ait dosya /dev dizini altında bulunur. Kurulum anında bu dosyalar yerine yerleştirilir, bu dosyaların silinmesi durumunda /dev/MAKEDEV ile tekrar yaratılabilirler.
    /etc :
    Sistem konfigürasyon dosyaları. Bu dizinde çalıştırılabilir dosyalar bulunmamalıdır.
    • skel : Buradaki dosyalar, kullanıcı hesabı açıldığında kullanıcının ev dizinine kopyalanır.
    • rc.d : Bu dizinin içinde, init sürecinin başvurduğu konfigürasyon dosyaları vardır.
    • passwd : Kullanıcı şifre veritabanı
    • fstab : Linux'un açılışı esnasında bindirilecek dosya sistemleri burada listelenir.
    • group : passwd'e benzer şekilde kullanıcıların gruplarını tutar.
    • inittab : init daemon için konfigürasyon dosyası
    • motd : Kullanıcı sisteme girdikten sonra ekranına basılması istenen mesaj burada tutulur.
    • profile : Kullanıcı sisteme girdiği zaman çalıştırılan dosya (csh ve sh türevi kabuklar için)
    • shells : Sistemde kullanılabilecek kabuk isimleri burada tutulur.
    • login.access : login komutu için konfigürasyon dosyası. Sisteme girişi kullanıcı bazında sınırlamak için kullanılır.
    • limits : İşlemci performansının kullanıcı bazında kısıtlanmasını sağlar

    /home :
    Kullanıcılara ayrılmış dizin. Başka şekilde ayarlanmamış ise, açılan her hesaba ait kullanıcı, burayı kullanacaktır. Büyük sistemlerde, bu kısım alt parçalara ayrılabilir (/home/ftpadm , /home/ogrenci gibi)
    /lib :
    Kütüphane dosyaları.
    /mnt :
    Geçici bağlanan dosya sistemleri. Sadece bu iş için kullanıldığından sistem görevlisine zaman kazandırır.
    /proc :
    Süreç kontrollerini ve diğer sistem bilgilerini tutan dosya sistemi. Bu dosya sistemi aslında disk üzerinde yer kaplamaz, tüm dosyalar çekirdeğin bir uzantısı sayılabilir.
    • cpuinfo : işlemci modeli, tipi ve performansını bildirir.
    • devices : Halihazırda çalışan çekirdek içinde desteği bulunan aygıt sürücülerini listeler.
    • dma : Hangi dma kanallarının kullanıldığını belirtir.
    • filesystems : Halihazırda çalışan çekirdek içinde desteği bulunan dosya sistemlerini listeler.
    • interrupts : Hangi kesintilerin kullanımda olduğunu söyler.
    • iports : Halen hangi giriş/çıkış iskelelerinin kullanıldığını belirtir.
    • kcore : Sistem hafızasının görüntüsü
    /root :
    Sistem görevlisinin ev dizini. Mümkünse bu dizini sistemdeki diğer kullanıcıların görmeyeceği şekilde ayarlayın.
    /sbin :
    Hayati sistem komutları. Bir zamanlar bu dosyalar /etc dizini altında yeralıyorlardı. Sadece sistem görevlisinin ihtiyacı olan komutlar, /sbin veya /usr/sbin içinde bulunur.
    /tmp :
    Geçici dosyaların koyulduğu dizin. Belirli zaman aralıklarında temizlenmelidir.
    /usr :
    Diğer önemli sistem dosyalarını tutar. Bu bölüm genelde en kalabalık dizindir, zira yeni kurulan tüm programlar buraya konulur.
    • X11R6: X Window sistemi bilgileri tutulur.
    • doc: Belge ve dokümanlar, genellikle HOWTO ve FAQ dosyaları.
    • lib: Bazı kütüphaneler
    • man: Man dosyaları
    • src: Bazı kaynak dosyaları ve linux çekirdeğini oluşturan kodları (/usr/src/linux) içeren dizin.
    • sbin : Kök dosya sisteminde yeralması gerekmeyen çalıştırılabilir sistem görevlisi dosyaları
    /var :
    Sürekli değişen sistem bilgileri burada tutulur. İstisnalar dışında diğer makinalarla paylaştırılmaz.
    • adm: Sistem yönetimini ilgilendiren kayıtlar
    • preserve : Sistemin göçmesinden sonra zarar görmesi mümkün dosyaların kaydedildiği yer.
    • spool : Sonra işlenecek olan veriler buraya atılır (e-posta gibi)
    Eğer sistem yöneticisi iseniz düzenli olarak dosya ve dizin yapısını kontrol etmelisiniz. Örneğinn /tmp dizini normal kullanıcıların kullanımına açık olduğu için çok kısa bir sürede dolabilir. Burayı periyodik olarak silmek için find komutu işe yarayabilir:

    # find /tmp -atime +7 -exec rm -rf {} \;

    Yukarıdaki komut, tmp dizini altında yeralan tüm dosyaları kontrol edecek ve 7 günden daha eski dosyaları silecektir. Benzer şekilde, kullanıcıların dosyalarının yer aldığı /home dizini de çok kısa bir sürede dolmaya mahkumdur. Sistemde ne kadar büyük sabit disk olursa olsun bir gün gelecek burası dolacaktır. Periyodik olarak buraya da göz gezdirmek gerekir. Aşağıda yeralan kısa program, /home dizininde yeralan kullanıcı dizinlerideki disk kullanımını büyükten küçüğe doğru disk isimli dosyaya yollayacaktır. Bu dosyanın incelenmesiyle hangi kullanıcıları "cezalandıracağınızı" görebilirsiniz :)

    # du -skx /home/* | sort -rn > disk

    du (disk usage), sistem kullanıcılarının sıkça başvurduğu bir komuttur. Kullanılabilecek parametreler için du(1) kılavuz sayfasına bakın.

    UNIX, (ve dolayısıyla Linux) iki tip aygıt tanır. Bunlardan ilki karakter aygıtları, başka bir deyişle veri alışverişini bayt bazında yapan cihazlar, diğeri de blok aygıtları, yani veri alışverişini blok cinsinden yapan cihazlardır. Karakter aygıtlarına örnek olarak seri bağlanan cihazlar ve teypler, disk aygıtlarına örnek olarak da diskler verilebilir. Bu cihazlardan bir bilgi yazılıp okunduğunda dosya sistemi altında bunları tanımlayan dosyalar (/dev/*) kullanılmış olur. Örnek olarak bir yazıcıya bilgi göndermek için,

    $ cat dosya > /dev/lp1

    komutunu kullanabilirsiniz. Dosya, düz metin gibi, yazıcının anlayabileceği bir yapıda olmalıdır.
    Her aygıt, bir dosya olarak dosya sisteminde kendine yer bulduğuna göre hangi aygıt dosyalarının (düğüm ) bulunduğunu görmek mümkün olabilir.

    $ ls -l /dev/cua0
    crw-rw-rw- 1 root uucp 5, 64 Nov 30 1993 /dev/cua0

    İlk kolondaki ilk karakter (c), bu dosyanın bir karakter aygıtına ait olduğunu belirtiyor. Normal dosyalar için buradaki karakter '-' olmalıydı. Benzer şekilde blok aygıtlar için ise 'b' kullanılr.

    Aygıt sürücü desteği çekirdekte olmasa bile /dev dizini altında genellikle tüm aygıt dosyaları (düğümler) bulunur. Bu demektir ki /dev/sda dosyasına sahip olduğunuz halde bir SCSI sabit diski sistemde takılı olmayabilir. Tüm aygıt sürücülerinin bulunması, programların kurulumunu ve yeni donanımın eklenmesini kolaylaştırır.

    7.12. Konsolda Türkçe Yazmak

    Linux sanal terminallerinde bir tuşa basıldığı zaman bilgisayarın ekranda herhangi bir dildeki alfabeye ait harfi göstermesi kolayca sağlanabilir. Bunun yanında 12 fonksiyon tuşunun herbirine belirli bir dizesel değer atanabilir ve bu sayede bu tuşlara basıldığında bir komutun veya programın çalışması mümkün olur.

    Aslında bunları yapabilmek için önümüzdeki iki temel sorunu aşmamız gerekiyor. Birincisi standart olmayan karakterlerin (örneğin Türkçe) ekranda görüntülenebilmesi, ikincisi de bilgisayara standart dışı bir klavye olduğunun belirtilmesidir.

    Dünya üzerindeki belli başlı dillerin hepsi yıllar önce bir standart geliştirilmesi amacıyla sınıflandırıldı. Avrupa'da Slav dilleri hariç hemen tüm dillerin karakterleri ISO (Uluslararası Standartlar Organizasyonu) tarafından tek bir sınıfa yerleştirildi ve buna ISO8859-1 (latin 1) dendi. Ne yazık ki Türkçe bu sınıfa dahil edilmedi ve sadece Türkçe için ISO8859-9 (latin 5) isminde ayrı bir sınıf açıldı.
    Türkçe yazabilme sorununu hemen her işletim sisteminde hissediyor olmalısınız. Linux altında Türkçe desteğini sağlamak için birkaç işlem yapılmalıdır. Bu işlemlerin başında Linux'a Türkçe destekli klavye ve yazıtipi tanıtmak geliyor.

    /usr/lib/kbd/keytables dizini altında yeralan dosyalar, çeşitli ülke dillerine ait klavye dağılımını içeriyor. Buradaki bilgileri kullanarak klavye üzerinde yeralan tuşlara basılması halinde yazılı tuş dışında bir karakterin ekranda gösterimi sağlanabilir.

    Sistem açıldığı zaman -eğer kurulum aşamasında bir yazıtipi beğenip sürekli onu kullanmıyorsanız- defkeymap.map dosyasında yeralan klavye dağılımını kullanacaktır. /usr/lib/kbd/keytables dizini altındaki herhangi bir dosyada 300'den fazla satır ve üç ana tanımlamayla karşılaşacaksınız. Birinci grup, "keycode", "alt", "control" gibi bir satırla, ikinci grup "string" ile, üçüncü grup ise "compose" kelimesiyle başlar.

    Türkçe yazabilmek için standart dışı klavyeden gelen bir Türkçe karakteri ekranda gösterebilmek amacıyla bir yazıtipi dosyası oluşturmamız gerekecek. Linux altında bu dosyalar /usr/lib/kbd/consolefonts dizini altında yeralıyor.

    Linux'ta standart dışı bir yazıtipi yüklemek için setfont komutu kullanılır. Türkçe yazıtiplerini,ftp://ftp.linux.org.trLinux Kullanıcıları Grubu ftp arşivinden temin edebilir veya iso09 ön adlı herhangi bir yazıtipi kullanabilirsiniz. Aşağıdaki komut, 8 piksel eni, 16 piksel boyu olan Türkçe yazıtipi yükleyecektir.

    $ setfont tr8x16.map

    Türkce klavye düzenlerini içeren dosyaları ftp yardımıyla yine aynı adresten alabilirsiniz. Burada tr.map, trq.map ve trf.map adlı üç dosya bulacaksınız. Bunlardan tr.map, normal klavye düzeninin yanında `alt' tuşları ile "c, g, i, s, o, u" tuşlarına basıldığında karşılık gelen özel Türkçe karakterler (ç, ğ, i, ş, o, u) görüntülenir. trq.map yaygın olarak kullanılmakta olan Q-Türkçe klavye düzenini içerir.

    trf.map ise klavye düzeninizi f klavyeye çevirecektir.
    Bash kabuğu altında Türkçe yazabilmek için aşağıdaki üç komutu .inputrc dosyanıza eklemeniz gerekir.

    set meta-flag on
    set output-meta on
    set convert-meta off

    less komutununu Türkçe karakterleri göstermesi için de aşağıdaki gibi LESSCHARSET değişkenini latin5 yapmak gerekiyor.

    LESSCHARSET=latin5

    loadkeys ve setfont komutlarını sistem açılırken aktif olmaları için bunları /etc/rc.d/rc.local dosyasına yerleştirebilirsiniz. Fontu ve klavye düzenini ayarladıktan sonra sistemden çıkın ve tekrar girin.

    Artık Türkçe yazabilirsiniz.

    7.13. Belirli Zamanlarda Komut İşletilmesi

    crontab dosyası yardımıyla sistem üzerinde olmadığınız zamanlarda Linux'tan bazı belirli işleri yapmasını istemek mümkündür. Örneğin gereksiz trafik sıkışıklığı yaratamak için akşam geç saatlerde sistemi yedeklemek için evden İnternet'e bağlanmak yerine crontab ile bu işlemi otomatikleştirmek mümkün olur.

    Bir crontab dosyasında toplam 6 alan bulunur. Bunlardan ilk beşi komutun ne zaman işleneceğini gösterirken son kısımda bu saatler içinde çalıştırılacak olan komutu gösterir. Zamanı belirten sütunlardan ilki dakikayı (0 ile 59 arası), ikincisi saati (0 ile 23 arası), üçüncüsü günü (1-31 arası), dördüncüsü ayı (1-12 arası), son kısım ise haftanın gününü (0 pazarı göstermek üzere 0-6 arası) verir. Yine crontab'ın güzel özelliklerinden birisi de bu alanların her birisinde zaman aralıklarını yazmaya izin vermesidir. Mesela haftanın üçüncü ve beşinci günleri arası, saat 4 ve 9 arası gibi. Eğer bir zaman alanına * girilirse, bunun anlamı "her zaman" olur. Örneğin saat yerine * konulması "her saat", ay yerine * konulması "her ay" anlamına gelecektir.

    Önce aşağıda yeralan küçük bir crontab dosyası incelenecek, ardından crontab işlemine nasıl başlanılacağı kısaca anlatılacaktır.

    40 06 * * * updatedb

    Yukarıdaki örnekte birinci ve ikinci sayılar 06:40 saatini gösteriyor. Diğer zaman kısımları * ile doldurulmuş olduklarından her gün 06:40'ta updatedb isimli program çalışacaktır.

    Komut yerine kullanılacak olan program ismi parametre alabilir. Bu örnekteki crontab dosyası pazartesi günleri saat 1'de, /tmp dizinindeki üç günden daha eski dosyaları siler.

    0 1 * * mon find /tmp -atime 3 -exec rm -f {} \;

    Bu örnekte kullanılan virgül, her ayın 9, 19 ve 29'unu gösterir. Aynı alanda birden fazla sayı kullanacaksanız arada boşluk bırakmamaya dikkat edin.

    0 1 9,19,29 * * find /tmp -atime 3 -exec rm -rf {} \;

    Ay isimlerinde ocak, şubat, mart, nisan, mayıs, haziran, temmuz, ağustos, eylül, ekim, kasım, aralık için sırasıyla january, february, march, april, may, june, july, august, september, october, november, december kullanabilirsiniz. Benzer şekilde pazar, pazartesi, salı, çarşamba, perşembe, cuma, cumartesi ve pazar yerine sunday, monday, tuesday, wednesday, thursday, friday ve saturday kullanın. Aşağıdaki crontab girdisi yardımıyla iki ayda bir çalıştırılan komutla önce teyp başa alınıyor, ardından /home dizini bu teybe yedekleniyor:

    0 2 1 */2 * mt -f /dev/rft0 rewind; tar -cf /dev/rft0 /home
    */2 ile belirtilen zaman dilimini ikiye bölebilirsiniz. 2 yerine uygun herhangi bir tamsayı yazılabilir.

    Bu girdileri bir crontab dosyasına nasıl yazacağız? Bunun için root kullanıcısı olarak girin ve aşağıdaki satırları yazın :

    # crontab -e

    Ekrana bilgisayar ilk kurulduğu anda ön tanımlı olarak girilen crontab satırları gelecektir. Buraya yukarıda belirtilen yapıda istediğiniz kadar crontab girdisi ekleyebilirsiniz. Eğer daha önceden VISUAL çevresel değişkenini uygun bir editöre ayarlamamışsanız, vi altında çalışmanız gerekecektir. Başka bir editörle çalışabilmek için bu değişkeni, editörün patikasını gösterecek şe kilde değiştirin. İleride de kısaca bahsedilecek olan tin (haber grubu okuyucu yazılımı) de VISUAL değişkenine göre metin editörünün patikasını ayarlayacaktır.

    # export VISUAL=/usr/bin/pico

    Crontab dosyasının normal olarak işletilmesinden crond sorumludur. Sistem açılırken /etc/rc.d dizini içindeki dosyalardan bir tanesi crond programını çalıştırır ve bu andan itibaren crontab -e komutuyla yarattığınız dosyadaki emirler zamanı geldikçe yerine getirilir.

    8. BASH KABUĞU

    UNIX için geliştirilen en önemli ve en çok kullanılan kabukların başında tcsh, bash (Bourne Again Shell) ve ksh (Korn Shell) gelir. Bash, Bourne Shell'in biraz daha geliştirilmiş sürümüdür. Tcsh ise C-shell üzerine eklenen yeniliklerle genişletilmiştir. Unix altında, bash kabuğu diğer benzerlerine nazaran daha fazla özelliğe ve işleve sahiptir. Linux işletim sistemi için de derlenen bash ise hem tcsh, hem de ksh'dan özellikler taşır.
    Bir Slackware dağıtımında tüm bu kabuklar kullanıcının hizmetine sunulmuş olup bash kabuğu sistem ilk açıldığında tanımlıdır. Kullanıcı sisteme girdiği zaman bu kabuk aktif olur, bundan sonra kullanıcı herhangi bir kabuk altında çalışmalarına devam edebilir. Bunun için sadece ismini komut satırında yazması yeterlidir.

    8.1. Bash Özellikleri

    Bash'in kullanıcıya zaman kazandıran en önemli özelliklerinden birisi de dosya isimlerini tamamlamasıdır. Komut satırında tamamlanmamış bir komut veya dosya ismi yazdıktan sonra TAB tuşuna basılırsa satır tamamlanacaktır. Eğer komut satırındaki karakter kümesiyle başlayan birden fazla komut varsa bir sinyal sesi duyulacak ve sizden yeteri kadar karakteri yazmanızı bekleyecektir.

    $ ls
    postgres mandel.doc lilo-howto
    $ vi post <TAB>
    $ vi postgres

    Komut satırındaki karakterler dosyayı veya komutu tanıtmaya yetmiyorsa, <TAB> tuşunun iki kez ard arda basılmasıyla ekrana mümkün olan tüm dosya isimleri getirilebilir.

    $ ta <TAB> <TAB>
    tac tail talk tar
    $ talk

    Bash, komut satırında iken satırın kolayca değiştirilebilmesini sağlar. Böylece komut çalıştırılmadan önce birkaç tuş darbesiyle üzerinde değişiklik yapılabilir. Klavye üzerindeki alt ve üst yön tuşları, daha önce yazdığınız komutları görmenizi ve arasında seçim yapmanızı sağlar. Sağ ve sol yön tuşları ile seçtiğiniz komutun üzerinde değişiklikleri uygulabilirsiniz.

    8.2. Takma Adlar (alias)

    alias komutu ile bir komut veya komut kümesinin yerine bir isim tahsis edilebilir. İşleyişi bir makroya benzeyen bu komut yardımıyla uzun komutlar, daha kısa komutlarla tanımlanabilir. Bir alias komutu , anahtar kelimeyle başlar, ardından bir eşittir (=) işareti ve yerine kullanılacağı komut yazılır. Arada boşluk bırakılmaz.

    $ alias dir='ls -al'
    $ dir
    total 668
    -rw-r--r-- 1 gorkem users 1016 Dec 7 13:51 .profile
    -rw-r--r-- 1 gorkem users 277 Nov 26 13:02 .signature
    drwxr-xr-x 4 gorkem users 1024 Dec 3 18:24 .tin/
    drwxr-xr-x 2 gorkem users 1024 Nov 12 10:58 .wine/
    -rw-r--r-- 1 gorkem users 231 Nov 23 17:40 .xinitrc
    drwxr-xr-x 2 gorkem users 1024 Oct 3 16:17 Mail/
    -rw-r--r-- 1 gorkem users 26721 Dec 3 14:55 NIS-HOWTO
    drwxr-xr-x 2 gorkem users 1024 Nov 17 14:09 News/

    Daha karmaşık takma adlar da tanımlanabilir:

    $ alias yedek="cd /var/log; tar -zcvf yedek.tgz cron debug lastlog; cd -"

    8.3. Özel Kabuk Tanımları

    Bazı özellikleriyle bash, benzeri kabuklar arasından kolayca sıyrılır. Bunlardan birisi de tanımlardır. Tanımlamalar set komutu yardımıyla yapılır, tüm tanımlar küçük harflerle yazılırlar, bu özellikleri yardımıyla değişkenlerden ayrılırlar.

    $ set -o tanim # tanimi isletir
    $ set +o tanim # tanimi kaldirir

    Aşağıda en çok kullanılan iki tanım yeralmaktadır:

    noclobber : Bu tanımın seçilir kılınmasından sonra bir komutun çıktısı bir dosyaya gönderildiğinde, dosyanın eski içeriği aynı kalır. Bu tanım sayesinde kazara bir dosyanın üzerine başka bilgilerin yazılması önlenebilir.

    $ ls -al dosya
    -rw-r--r-- 1 gorkem users 1409 Nov 29 13:58 dosya
    $ set -o noclobber
    $ ls > dosya
    bash: dosya: Cannot clobber existing file

    ignoreeof : ignoreeof, kabuktan control-d tuş takımı ile çıkılmasını engeller. Yanlışlıkla basılan control-d ile sistemden anından çıkmak mümkün olduğu için kullanışlı bir tanımdır.

    $ set -o ignoreeof
    $ <control-d>
    Use "logout" to leave the shell.
    $ set +o ignoreeof
    $ (control-d tusuna basarsaniz, sistemden hemen cikarsiniz)
    $ ignoreeof=4

    Yukarıdaki son örnekte 5 kere control-d tuşuna basılırsa kabuktan çıkılır.

    8.4. Özel Kabuk Değişkenleri

    Sisteme girdiğiniz zaman Linux size bir kabuk tahsis eder ve kabuk üzerinde değişkenler tanımlayabilmenize izin verir. Kabuk içinde bir kabuk programı (script) çalıştırılınca sistem tarafından bir alt kabuk daha yaratılır. Bu andan itibaren iki kabuk çalışır, birisi sisteme girdiğiniz anda tahsis edilen, diğeri de programın çalıştırılabilmesi için sistem tarafından çağırılan. Program bittiği anda alt kabuğun işlevi sona erer ve sistem tarafından öldürülür.

    Bir kabuk altında tanımlanan değişken o kabuğa özgüdür. Bir kabuk altında erişilebilen değişkene diğer bir kabuk erişemez. Fakat bash kabuğu altında bir çevre değişkeni yaratılırsa, sistem tarafından her alt kabuğa bu çevre değişkeni kopyalanır. Böylece bir değişken yaratılır, ama her alt kabuk tarafından kullanılabilir. bash kabuğunda yaratılan çevre değişkenlerinin normal değişkenlerden tek farkı, bu değişkenin diğer alt kabuklar tarafından tanınmasıdır. Bir çevre değişkeni belirtmek için export komutu kullanılır. Aşağıdaki örnekte dosyam isimli çevre değişkeni tanımlanıyor.

    $ export dosyam="internet.98.txt"
    $ echo $dosyam
    internet.98.txt

    Bu esnadan sonra tüm alt kabuklar altında bu değişken tanımlı olacaktır.
    env komutu yardımıyla sistemde öntanımı yapılan veya sonradan tanımlanan tüm değişkenler ekrana listelenir.

    $ env
    HOME=/home/gorkem
    SHELL=/bin/bash
    LS_OPTIONS=--8bit --color=tty -F -b -T 0
    PS1=\h:\w\$
    PS2=>
    LOGNAME=gorkem
    OSTYPE=Linux

    Sisteme girdiğiniz anda tanımlanan bazı komutlar ve açıklamaları aşağıda verilmiştir:

    HISTFILE : Tüm yazdığınız komutlar .bash_history adlı bir dosya içinde tutulur. Her kullanıcının kendi ev dizinleri içinde kullanıcıya özgü bu dosyadan vardır. $HISTFILE değişkeni ile dosyanın ismi değiştirilebilir.

    $ echo $HISTFILE
    /home/gorkem/.bash_history
    $ HISTFILE="komutlar"
    $ echo $HISTFILE
    komutlar

    PATH : PATH değişkeninde bir komut yazıldığı anda sistem tarafından aranacak olan patika listesi görüntülenir. Örnek olarak who komutu /usr/bin/ dizini altındadır ve bu bilgi PATH değişkeninde saklı tutulur. Kullanıcının yaptığı programları çalıştırabilmesi için PATH değişkeninde bulunduğu dizini de tanımlaması gerekir.
    PATH değişkeninde her dizin ':' işareti ile birbirinden ayrılır. Örnek olarak /usr/local/bin:/usr/bin dizisi sırasıyla /usr/local/bin ve /usr/bin patikalarına karşılık gelir.
    Kullanıcı PATH değişkenine yeni girdiler ekleyebilir. Aşağıdaki örnekte bunun nasıl uygulandığı görülüyor. Kullanıcı kısaca PATH değişkeninin sonuna kendisinin istediği patikayı veya patikaları ekler.

    $ echo $PATH # PATH degiskenini ekrana bas
    $ export PATH=$PATH:~/net # buna /usr/net patikasini ekle

    SHELL : O an kullanılan kabuğun patika ismini verir. Kabuk programları genellikle /bin dizini altında tutulurlar. Her kabuğun patika ismi sistemdeki /etc/shells dosyasında bulunmalıdır.

    $ echo $SHELL
    /bin/bash

    HOME : Kullanıcının ev dizinini gösteren patikayı ekrana basar. Her kullanıcının ev dizini, sistemde hesap açılırken sistem görevlisi tarafından belirlenir. Linux Slackware dağıtımı altında bu dizin öntanımlı olarak /home 'dur. Aşağıdaki örnek kullanıcının ev dizinine ait patikayı ekrana basıyor.

    $ echo $HOME
    /home/gorkem

    LOGNAME : Sistemdeki kullanıcı hesabınının ismini tutar. Her kullanıcı için farklı bir değerde olur.

    $ echo $LOGNAME
    gorkem

    TERM : Kullanıcının halen üzerinde çalıştığı terminal tipini görüntüler. vi ve pico gibi editörler çalıştırıldıkları anda TERM çevresel değişkenine bakarlar. Bu sayede ekran ile ilgili bilgileri önceden düzenleyebilirler. Aşağıdaki komut önce halihazırdaki TERM değişkenini görüntülüyor, ardından değişkene başka bir değer atıyor.

    $ echo $TERM
    linux
    $ export TERM=vt100
    $ echo $TERM
    vt100

    PS1 ve PS2 : Ekranda komut satırının başına gelecek olan karakterleri belirlerler. Komut isteminin en başındaki yazı bu iki değişken yardımıyla değiştirilebilir. PS1, birinci satırın karakterlerini tutarken satıra sığmayan komutlar bir satır aşağı geçeceklerinden ikinci satırın karakterlerini de PS2 belirler. Aşağıdaki satır, bu iki değişkenin öntanımlı olan "$" işaretini bir kelimeyle değiştiriyorlar.

    $ export PS1='-> '
    -> export PS2='>'
    ->
    Önceden tanımlanan kodlar yardımıyla komut satırı başlangıcı değiştirilebilir. Her kodun başında \ karakteri vardır. Bu kodların herbiri örneğin o anki saati, makinanın ismini veya bulunduğunuz dizini ekrana yazabilirler. Örneğin \h ve \w kodları sırasıyla çalışılan makinanın ismini ve çalışma dizinini gösterirler. Bu örnekte PS1 değişkeni bu iki kod yardımıyla değiştiriliyor.

    $ export PS1='\h:\w\$ '
    $ # yeni komut satiri goruntusu
    $ cd /tmp
    $ # calisma dizinini de gosteriyor
    Aşağıda, sıkça kullanılan kodların bir listesi görülüyor.
    • \t , saat
    • \d , tarih
    • \s , kabuk ismi
    • \w , çalışma dizini
    • \u , kullanıcı ismi
    • \h , makina ismi

    8.5. Sisteme Giriş Dosyaları

    Sisteme girerken her giriş anında çalıştırılan birtakım dosyalar bulunur. Bash kabuğu ile doğrudan ilgili olan giriş dosyaları arasında

    /etc/profile
    ~/.bash_profile
    ~/.bash_login
    ~/.profile
    ~/.bashrc

    sayılabilir. Kullanıcı bu dosyaların kendine ait olanlarını dilediği gibi değiştirebilir. Sisteme girerken tanımlamak istediği değişkenleri tanımlar, çalıştıracaği programları yazar. /etc/profile dosyasını ise tüm kullanıcılar ortak kullanır. Her kullanıcı sisteme girdiğinde sistem tarafından bu dosya çalıştırılır. Bu dosyada kullanıcıların ihtiyacına yönelik özel sistem değişkenleri bulunur, ek olarak birtakım kontrol ve kayıt işlemleri yapılır.

    Örnek bir /etc/profile dosyası şekildeki gibidir.

    if [ "$TERM" = "" -o "$TERM" = "unknown" ]; then
    TERM=linux
    fi
    #PS1='`hostname`:`pwd`# '
    if [ "$SHELL" = "/bin/pdksh" -o "$SHELL" = "/bin/ksh" ]; then
    PS1="! $ "
    elif [ "$SHELL" = "/bin/zsh" ]; then
    PS1="%m:%~%# "
    elif [ "$SHELL" = "/bin/ash" ]; then
    PS1="$ "
    else
    PS1='\h:\w\$ '
    fi
    PS2='> '
    ignoreeof=2
    export PATH DISPLAY LESS TERM PS1 PS2 ignoreeof
    umask 022
    # set up the color-ls environment variables:
    if [ "$SHELL" = "/bin/zsh" ]; then
    eval `dircolors -z`
    elif [ "$SHELL" = "/bin/ash" ]; then
    eval `dircolors -s`
    else
    eval `dircolors -b`
    fi
    .bashrc dosyası, her bash kabuğu veya alt kabuk çalıştırıldığı anda okunur. Her kabuk programı çalıştırılınca bir alt kabuğa ihtiyaç olduğundan bu durumda .bashrc dosyası da okunacak ve içerdiği değişkenler proram çalışmadan önce tanımlanacaktır.

    Sistemden çıkarken varsa çalıştırılan dosyanın ismi .bash_logout'tur. Bu dosya ile kullanıcı sistemi terkederken fazladan işlemler yapabilir. Aşağıdaki örnekteki .bash_logout dosyasında kullanıcı sistemden her çıktığında ekran temizlenecek ve en üste 'Hoscakal' yazacaktır.

    clear
    echo "Hoscakal!"

    8.6. Kabuk Programlamaya Giriş

    Her kabuğun kendine özgü programlama dili yapısı vardır. Bash kabuğu ise güçlü programlama özellikleriyle karmaşık programların rahatça yazılmasına izin verir. Mantıksal operatörler, döngüler , değişkenler ve modern programlama dillerinde bulunan pek çok özellik bash kabuğunda da vardır ve işleyiş tarzları da hemen hemen aynıdır.

    Genellikle, bir programı oluşturacak olan komutlar bir dosyaya yazılırlar ve ardından bu dosya çalıştırılır. Herhangi bir editör yardımıyla yazılan program, daha sonra kabuk altında çalıştırılır. Bir kabuk programı diğerlerini çalıştırabilir. Bu düzende kabuk programlarını daha karmaşık komutların biraraya gelmiş ve yapısallaşmış haline benzetebiliriz.

    Bash'in en büyük dezavantajı, gayet yavaş, hantal olması ve sistem kaynaklarını kolayca tüketmesidir.




    8.6.1. Kabuk Programları

    Kabuk programları, bir veya birden fazla Linux komutunu tutan dosyalardır. Bu dosya yaratıldıktan sonra doğrudan dosyanın ismi girilerek veya dosya isminden önce '.' karakteri getirerek çalıştırılabilir. Bir kabuk programı, çalıştırma bitini 1 yapmak suretiyle "çalıştırılabilir" hale getirilir. chmod komutu yardımıyla bir programı çalıştırılabilir yapmak için ,

    $ chmod +x komut-ismi

    yazılabilir. Bundan sonra programın ismi yazılıp enter tuşuna basıldığı zaman bir program Linux komutuymuş gibi çalışacaktır.

    $ cat calistir
    echo -n "Tarih : "
    date
    $ chmod +x calistir
    $ calistir
    Tarih : Sun Dec 8 07:11:51 EET 1996

    Yukarıdaki örnekte "calistir" isimli iki satırlık bir kabuk programının önce içeriği ekrana yazıldı, ardından çalıştırılacak duruma getirildi ve çalıştırıldı.

    Kabuk programları yazarken dosyanın işlevini ve her satırdaki komutun veya komut kümesinin ne amaçla kullanıldığını gösteren açıklama satırları kullanmak işe yarar. Bir açıklama eklemek için satır başına (veya boş satıra) # işareti eklenir ve ardından istenilen cümle girilir. # işaretinden sonraki tüm satır kabuk tarafından gözardı edilir. Aşağıdaki programda komut öncesinde yeralan açıklama satırı, komut hakkında bilgi veriyor.

    # gunzip komutu dosya acmak icin kullanilir.
    gunzip sistem.gz
    Yorum satırı, komutun sonuna da eklenebilir.

    ps -aux # sistem surecleri hakkinda ayrintili bilgi..

    Bir kabuk altında çalışırken başka bir kabuk için yazılmış bir programı çalıştırmak mümkündür. Örneğin tcsh altındasınız ve daha evvel bash kullanarak yazdığınız bir programı çalıştırmak istiyorsunuz. Önce bash yazarak kabuk değiştirmeli, ardından programı çalıştırmalı, ve tekrar tcsh'a dönmelisiniz. Tüm bunları otomatik olarak yaptırabilirsiniz. Programın en başına #! karakterini, ardından programın çalışacağı kabuğun patikasını yazın. Örneğin #!/bin/bash komutunu programın en üstüne eklerseniz bu program bash kabuğu altında çalışacaktır.

    8.6.2. Değişkenlerin Kullanımı

    Bir değişkene değer atandığı anda sistem tarafından tanınır. Değişkenler alfabetik veya nümerik karakterlerden oluşabilirler fakat bir değişken sayısal bir değer ile başlayamaz. Bunların dışında değişken isminin içinde "_" karakteri de bulunabilir. Bir değişkene değer ataması "=" işareti yardımıyla yapılır.

    $ mesaj="aksama yemege geliyorum"

    İçeriği olan bir değişkene başına "$" işareti konularak ulaşılır. Aşağıda, echo komutu yardımıyla bir değişkenin içeriği ekrana basılıyor.

    $ echo $mesaj
    aksama yemege geliyorum
    $ echo yarin $mesaj
    yarin aksama yemege geliyorum

    Aynı mesajı değişken kullanmadan da görüntüleyebiliriz.

    $ echo "Aksama yemege geliyorum"
    Aksama yemege geliyorum

    8.6.3. Giriş/Çıkış İşlemleri

    Bir kabuk programı çalışırken kullanıcıdan klavye yardımıyla bilgi girmesi sağlanabilir. Bu tür işlemler için tanımlanan read komutu klavyeyi okur ve aldığı bilgiyi bir değişkene atar. Aşağıdaki komutları içeren program yardımıyla klavyeden okunan değer ekrana yazılıyor. echo komutundan sonra birden fazla değişken grubu veya hem değişken, hem de dizi kullanılabilir.

    echo Bir sayi giriniz..
    read sayi
    echo Girilen sayi : $sayi

    Bazı durumlarda girilen değer özel karakterleri içerebilir. Bu durumda istenmeyen bazı sonuçların doğması kaçınılmaz olur. Aşağıdaki örneği bir dosya içine yazın ve dosyayı çalıştırdıktan sonra "*" tuşuna basın.

    echo Bir karakter giriniz
    read a
    echo Girdiginiz karakter : $a

    8.6.4. Aritmetik İşlemler

    bash kabuğunda matematiksel işlemlere büyük sınırlamalar getirilmiştir. Tamsayı değişkeni dışında matematiksel değişken kullanmak için bu işlemler için geliştirilmiş ve kolaylıklar sağlayan awk veya bc kullanabilirsiniz.

    Aritmetik işlemler için eval komutunu veya bash kabuğu altında yerleşik (builtin) komut olan let komutunu kullanabilirsiniz. Aşağıda let komutunun kullanımı görülüyor.

    $ let "degisken=aritmetik islem"
    Bu örnekte iki sayı çarpılıp çıkan sonuç başka bir değişkene yazılıyor.

    $ let "carpim=2*7"
    $ echo $carpim

    Aritmetik değişken tanımlamanın diğer bir yolu da typeset komutu kullanmaktır.

    $ typeset -i sonuc (sonuc degiskeni bir dogal sayi icerecek)
    $ a=100 ; b=56 (iki komutu ayirmak icin ; kullanilabilir)
    $ sonuc=a*b
    $ echo $sonuc
    5600

    8.6.5. if-else Kalıbı ve Kontrol İşlemleri

    Hemen her programlama dilinde olan if kalıbı bir Linux komutunun çalışmasını kontrol (test) eder. if komutu yerleşik bir komuttur. if komutunun ardından gelen Linux komutu çalıştırılır ve komutun çıkış durumu (exit status) gözönüne alınarak ardından gelen then deyimiyle birlikte devamı işletilir. Genellikle komutun iki türlü çıkış durumu olacağından else komutunun ardından gelen komut zinciri, diğer çıkış durumunda çalıştırılır. Her if, bir fi komutuyla bitmelidir. Aşağıda if-then-else komutunun örnek sözdizimi görülüyor.

    if linux komutu
    then
    komut1
    komut2
    ...
    else
    komut1
    komut2
    ...
    fi

    if komutu genellikle kendine test komutu ile birlikte kullanım bulur. Bu komut yardımıyla mantıksal işlemler yapılabilir, sayılar ve hatta diziler karşılaştırılabilir. Anahtar sözcük olan test'ten sonra opsiyonlar ve/veya karşılaştırılacak olan değerler yazılır. Her opsiyon bir mantıksal işleme karşılık gelir. Örneğin -lt opsiyonu ilk girilen aritmetik değişkenin ikinci değerden küçük olup olmadığını denetler. Benzer şekilde = opsiyonu da iki karakter kümesinin eşitliğini kontrol eder. Aşağıda test komutunun örnek kullanımı yeralıyor.

    $ test 5 -eq 3
    $ a="linux"
    $ test $a="linux"

    komutun işletilmesinin ardından kabuğa bir değer döndürülür. Bu değer komut başarılı olarak işletilmişse 0, değilse 1'dir. Son çalıştırılan tüm Linux komutlarının çıkış değeri $? değişkeninde tutulur. test komutunun çıkış değeri de bu yolla öğrenilebilir.

    $ sayi=4
    $ test $sayi -eq 4
    $ echo $?
    0
    $ test $sayi -lt 2
    $ echo $?
    1

    test komutu yerine parantezler de kullanılabilir. Yukarıdaki iki örnek, parantez kullanılarak şu şekilde yazılabilir:

    $ [ $sayi -eq 4 ]
    $ [ $sayi -lt 12 ]
    Dikkat edilmesi gereken bir nokta, köşeli parantez kullanırken araya boşlukların eklenmesidir. Parantezler başlı başına bir komut olarak görüldüklerinden sağında ve solunda en az bir boşluk bırakılmalıdır. test komutunda sıkça kullanılan diğer seçenekler şunlardır:
    Aritmetik karşılaştırma

    -gt büyük
    -lt küçük
    -ge büyük eşit
    -le küçük eşit
    -eq eşit
    -ne eşit değil
    Dizisel karşılaştırma
    -z boş dizi
    -n tanımlı dizi
    = eşit diziler
    != farklı diziler
    Dosya karşılaştırması
    -f dosya var
    -s dosya boş değil
    -r dosya okunabilir
    -w dosyaya yazılabilir
    -x çalıştırılabilir dosya
    -h sembolik bağlantı
    -c karakter aygıt
    -b blok aygıt
    Mantıksal karşılaştırma
    -a VE
    -o VEYA
    ! DEĞİL

    if komutunun test ile birlikte kullanılabildiğini daha önce belirtmiştik. Aşağıda bununla ilgili küçük bir örnek yeralıyor.

    #!/bin/bash
    echo "0 ile 20 arasinda bir sayi secin"
    read sec
    if [ $sec -lt 10 ]
    then
    echo "Secilen sayi tek basamakli"
    else
    echo "Secilen sayi cift basamakli"
    fi

    Her if komutu bir fi ile son bulmalıdır.

    8.6.6. case Kalıbı

    Birkaç alternatif arasından seçim yapmak için kullanılan bir komut olan case, bir eşleştirme gördüğü anda belirli bir komut kümesini işleme sokar. case yapısı case komutu ile başlar, eşleştirilecek olan anahtar sözcük yazılır ve seçenekler alt alta, her seçeneğe ait olan komutlarla birlikte belirtilir. Tüm yapı esac komutu ile son bulur.

    case anahtar-sozcuk in
    secenek1)
    komutlar
    ;;
    secenek2)
    komutlar
    ;;
    *)
    komutlar
    ;;
    esac

    Seçenekler arasında özel karakterler (*, [, ], ? gibi) kullanılabilir. Hiçbir eşleme yapılmadığı zaman *) seçeneği değerlendirilecek ve buna bağlı olan komutlar işletilecektir. * kullanımı isteğe bağlıdır. Aşağıda case komutuna ilişkin kısa bir örnek veriliyor.

    #!/bin/bash

    clear
    echo "1. ekrani temizle"
    echo "2. sistemdekileri goruntule"
    echo "3. dizindeki dosyalari goster"

    echo -n "Secenegi giriniz : "
    read secenek

    case $secenek in
    1)
    clear
    ;;
    2)
    w
    ;;
    3)
    ls -al
    ;;
    *)
    echo Hatali secenek
    esac

    8.7. Döngüler

    Diğer hemen tüm programlama dillerinin en büyük gücü olan döngü işlemlerine kabuk altında da izin veriliyor. Burada programcı tarafından en çok kullanılan 2 döngü tipi anlatılacaktır: while ve for. while komutu her döngüde bir denetleme mekanizmasını harekete geçirirken for döngüsü bir listenin elemanlarını sırayla seçer.

    8.7.1. while-do Döngüsü

    Döngü bloğu while anahtar kelimesiyle başlar, ardından gelen koşul sağlandığı sürece döngü işletilir. Önce koşulun sağlanıp sağlanmadığına bakılır. Döngüden çıkabilmek için mutlaka döngü içindeki koşul ifadesinin değerini yanlış yapacak bir durum oluşmalıdır, aksi halde sonsuz döngü oluşur.

    while kosul ifadesi
    do
    komutlar
    done

    if komutuyla birlikte kullanılan test komutu, while döngüsünde koşul ifadesi olarak da yer alabilir. Aşağıda 1'den 100'e kadar sayan ve ekrana basan bir döngü görülüyor.

    #!/bin/bash
    deger=0
    while [ $deger -lt 100 ]
    do
    deger=$((deger+1))
    echo $deger
    done
    Yukarıda kullanılan (( ve )) karakterleri arasına matematiksel bir işlem getirilebilir. Bu özellik bash kabuğuna özgüdür.

    8.7.2. for-do döngüsü

    Bir liste dahilindeki tüm değerlere sırayla erişimi sağlar. for komutundan sonra yeralan liste sırayla kullanılır ve herbirisi için döngü çalıştırılır. Listenin sonuna gelindiğinde ise döngüden çıkılır.

    for degisken1 in deger1 deger2 ... degerX
    do
    komutlar
    done

    Aşağıdaki örnek bu döngüyü kullanarak ekrana bir dizi kelime yazıyor. Döngü boyunca akasya, elma ve visne kelimeleri "agac" değişkenine kopyalanıyor ve her döngüde bu değişkenin içerdiği bilgiler ekrana yazılıyor.

    for agac in akasya elma visne
    do
    echo $agac
    done

    for-do döngüsü, dosya isimleri üzerinde yapılan işlemlerde de büyük kolaylıklar sağlar. Bunun için özel karakterlerden yararlanmak da olasıdır. Örnek olarak * karakteri o anki çalışma dizini içindeki tüm dosyaları seçer.

    for a in * ; do
    file $a
    done




    8.8. Örnek Kabuk Programı

    Sistem görevlisinin en çok kullandığım komutlardan birisi ps -aux grep -i xxx komutudur. Bu satır yardımıyla çalışan xxx isimli program hakkında daha detaylı bilgi elde edilebilir. ps komutu detaylı bir süreç listesini ekrana verirken çıktı doğrudan grep komutuna yönlendirilir ve sadece istediğimiz bilgi ekranda görünür. Fakat her zaman aynı uzun satırı tekrar tekrar yazmaktansa bu satırı bir dosyaya gönderip, dosya adını komut satırından çalıştırmak zamandan tasarruf sağlayacaktır. Biz de öyle yapalım ve aşağıdaki satırları ``goster'' isimli dosyaya yazalım.

    #!/bin/bash
    if [ $# = 1 ]
    then
    ps -ax | grep -i $1
    else
    ps -ax
    fi

    Ardından dosyayı PATH değişkeninin işaret ettiği dizinlerden /usr/local/bin altına yerleştirip çalıştırılabilir olması için chmod +x /usr/local/bin/goster komutunu uygulayın. Kendi yazdığınız dosyaları /usr/local veya 2#2/bin dizini altına kopyalamanız bunların derli toplu olarak tek bir dizinde her an erişilebilir şekilde durmaları açısından önem taşır.

    grep komutu, bir dosyadaki veya standart girişteki satırlar içinden belirli bir kelime, harf veya harf grubunu bulmaya yarar. Aşağıdaki birkaç örnek grep'i özetlemeye yeter.

    $ grep while sort.c

    sort.c dosyasinda while kelimesini iceren tum satirlari ekrana yazar.

    $ w | grep demir

    sistemde demir isimli kullanici var mi?

    $ ls -al | grep "^d"

    Son örnek, ls -al çıktısında satır başında ``d'' varsa ekrana getirir. Sadece dizin isimlerinin başında ``d'' harfi bulunur. Şapka isareti, satır başlangıcını gösterir.

    Dosyaya biraz daha yakından bakalım. İlk satır, bu dosyanın /bin/bash programı tarafından çalıştırılacağını gösterir. İkinci satır yardımıyla komut satırı üzerinde kaç tane opsiyon olduğu bulunur. $# çevresel değişkeni her biri TAB veya boşluk karakteri ile ayrılmış komut satırı opsiyonları sayısını verir. Aşağıdaki komutta toplam 3 opsiyon vardır.

    $ ls --8bit -F -b

    $# komutuna benzer şekilde $1, $2, $3 ... değişkenleri de opsiyonları verir. Yukarıdaki komutta $1, $2, $2 değişkenleri sırasıyla

    --8bit
    -F
    -b

    değerlerini alırlar. Komut satırından çalıştırılan komut ise $0 değişkenine atılır. Yukarıdaki örnekte $0 değişkeni ls değerini tutacaktır.

    goster dosyasına tek opsiyon yollayacağız. Bu opsiyon da hakkında detaylı bilgi alacağımız süreç olacaktır. Dosya içinde $1 değişkenini ps komutuna yerleştirmek için :

    ps -ax | grep -i $1;
    yazılır. Bundan sonra komut satırında, örneğin:

    $ goster bash

    girilirse $1 değişkeni bash e eşit olacak ve bu da ps -ax grep -i bash eşdeğer komutunu çalıştıracaktır. Komut olarak sadece goster girilirse $# değişkeni 0'a eşit olacağından dosyada yeralan ve hiç bir filtreleme yapmayan ps -ax komutu çalışır.

    Linux'u yüklerken HOWTO dokümanlarını da eklemeyi ihmal etmediniz, değil mi ? Aşağıdaki kısa program, bu dosyalara en hızlı şekilde ulaşmanıza yarıyor. Tüm HOWTO'lar kurulum aşamasında /usr/doc/faq/howto dizini altına kopyalanır ve sıkıştırılır.

    Bu programı herhangi bir isimle kaydedin. Ardından komut satırından programın ismi ile birlikte ekranda görüntülemek istediğiniz HOWTO dokümanının ismini yazın (örneğin PPP). Bir parametre girilmez ise /usr/doc/faq/howto dizinindeki dosyalar ekrana gelir.

    #!/bin/bash
    if [ "$1" = "" ]; then
    ls /usr/doc/faq/howto | less
    else
    gunzip -c /usr/doc/faq/howto/$1-HOWTO.gz | less
    fi

    9. TCP/IP

    Diğer açık sistemler gibi Linux'un da en büyük özelliklerinden biri ağ protokolleri ve uygulamalarının sistemin en doğal parçalarından biri olmasıdır. Dolayısıyla ağ yapısını bilmeyen bir yöneticinin, açık sistemler üzerindeki bilgisini daha da geliştirebilmesi mümkün değildir. Bu bölümde anlatılacaklar Linux üzerinde TCP/IP'ye bir giriş yapılmasını sağlayacaktır. Ayrıntılı bilgi TCP/IP servislerinin ve uygulamalarının anlatıldığı diğer bölümlerden ve aşağıda sözü edilen kitap ve dokümanlardan edinilebilir.

    TCP/IP üzerine önerebileceğimiz bir kitap, ilk baskıları TÜBİTAK tarafından bastırılan, ve büyük bir okuyucu kitlesi bulmuş Herkes İçin İnternet (Kürşat Çağıltay) 'tir. Bunun dışında İngilizce Prentice Hall tarafından yayınlanan Internetworking with TCP/IP Volume I (D.E. Comer), O'Reilly & Associates tarafından yayınlanan, TCP/IP Network Administration (Craig Hunt) ve Linux Network Administrator's Guide (NAG - Olaf Kirsh). NAG, Linux Documentation Project'in bir parçası olduğundan elektronik kopyası İnternet üzerinden ücretsiz olarak edinilebilir.

    Linux Documentation Project grubunun hazırladığı NET-3-HOWTO, TCP/IP temelleri ve ağ uygulamalarını örnekleriyle işlemiş. Bu dokümanı nasıl temin edebileceğinizi kitabın sonunda bulabilirsiniz. NET-3, TCP/IP ve buna bağlı protokollerin Linux için geliştirilen bölümüne verilen isimdir.

    9.1. Temel TCP/IP

    TCP/IP, ilk defa ABD'de ARPANet (Advanced Research Projects Agency Network) adı altında, askeri bir proje olarak geliştirildi. Önceleri askeri amaçlı düşünülen proje önce ünivesiteler tarafından kullanılmaya başlandı. Ardından ABD'nin dört bir yanında birbirinden bağımsız geliştirilen ağlar, tek bir omurga altında NSFNet olarak adlandırıldı ve ulusal boyutu aşarak dünyaya yayıldı. İnternet'in doğuşu da bu tarihe denk gelir.

    Bir sokak üzerinde yeralan evlerin adresleri gibi, İnternet'e bağlı olan her makinanın da bir adresi vardır. Bu adres sayesinde bir bilgisayardan diğerine ulaşmak mümkün olur. İnternet adresi 4 bayttan (32 bit) ibaret olup yazılırken her bayt arasına bir nokta konulur. En çok kullanılan bu gösterim şekline örnek olarak, ODTÜ'deki bir sunucunun adresi olan 144.122.199.20'yi verebiliriz.

    Bununla beraber, 4 baytlık numaraların kolayca hatırlanmasının mümkün olmadığından, İnternet üzerindeki makinalara alfanümerik adlar da verilebilir. Yukarıda örneğini verdiğim adresin ismi, knidos.cc.metu.edu.tr'dır. ilk noktaya kadar olan kelime, makina adıdır(yukarıdaki örnekte knidos), bundan sonraki noktayla ayrılmış bölümler özelden genele doğru makinanın ait olduğu kurum, kurumun tipi ve ülke gibi bilgiler içerir. Bu adlandırma yöntemiyle ilgili ayrıntılı bilgiyi Alan İsimlendirme Sisteminin (Domain Name System - DNS) anlatıldığı bölümde bulabilirsiniz.

    9.2. İnternet Adresleri

    İnternet üzerinde 3 sınıf adres vardır. Avrupa'da RIPE (Réseaux IP Européens) tarafından dağıtılan bu adresler daha sonra o yerin ağ yöneticisi tarafından uygun şekilde bölünebilir. Bu bölümlendirmeye ``subnetting '' işlemi adı verilir. Bu sayede ağlar gruplanarak herbirisinin yönetimi bağımsız hale getirilmiş, aynı zamanda da kısıtlı olan IP adresleri daha verimli bir şekilde kullanılmış olur.

    Üç çeşit İnternet adresi şunlardır :
    • A sınıfı İnternet adresi: Adresin ilk baytı 1 ile 126 arasında bir sayıdır. Bu adrese verilen yetkiyle toplam 2^24 makina adreslenebilir. Dünya üzerinde 126 tane A sınıfı adres vardır.
    • B sınıfı İnternet adresi: Adresin ilk baytı 128 ile 192 arasında bir sayıdan oluşur. Bu adresin subnetlere bölünmesiyle 65534 farklı makina adreslenebilir.
    • C sınıfı İnternet adresi: Adresin ilk baytı 192 ile 223 arasındadır. C sınıfı bir adresi blokuyla bağlı 254 bilgisayar adreslenebilir.

    A ve B sınıfı adreslerin hepsi dağıtılmış ve şu anda intenet C sınıfı adreslerde de sıkıntı çekilmektedir. Adres yetersizliğine çözüm getirmek amacıyla IPv6 ya da IPNG adlarıyla daha uzun İnternet adresleri kullanan protokoller geliştirilme ve test aşamasındadır.

    Bir İnternet adresi iki kısımdan meydana gelir: ağ adresi ve düğüm adresi . Her makina, bir ağ üzerinde bulunur ve bu adres ``ağ adresi'' olarak adlandırılır. Üç sınıf (A, B ve C) İnternet adresinin ağ ve düğüm adresleri farklı farklıdır. A sınıfı İnternet adreslerinde ağ adresini 1 bayt tayin eder. Örnek olarak hayali yazılan 74.198.59.33 makinasını tanımlayan ağ adresi 74'tür. Ağ adresi uzun halde yazıldığı zaman kalan 3 baytın yerine 0 konur. Bu durumda yukarıda adı geçen makinaya ait ağ adresi 74.0.0.0 olacaktır.

    Ağ adresinden geriye kalan düğüm adresi , bir makinanın İnternet sınıfına göre 1,2 veya 3 bayttan ibaret olabilir. Örnek olarak,

    195.12.288.3 makinasının (C sınıfı) ağ adresi 195.12.288.0, düğüm adresi 3'tür.
    130.11.195.62 makinasının (B sınıfı) ağ adresi 130.11.0.0, düğüm adresi 195.62'dir.

    Düğüm adresleri yerine 4 baytı da kullanmak da olası. Yukarıdaki iki örnek için düğüm adreslerini sırasıyla 195.12.288.3 ve 130.11.195.62 olarak kabul edebiliriz.

    Yukarıda sözedilen subnetting (alt ağlara ayırma ), çok sıkça kullanılan bir yöntem olup getirdiği birtakım kolaylıklar vardır. Büyük bir iletişim ağı alt ağlara ayrılırsa, kontrol edilmesi daha kolaylaşır.

    Bir kuruluş, kendine ait olan B sınıfı adresi subnetlere bölmek isteyebilir. Gerekli düzenlemeleri yaparak bir B sınıfı adresi (örneğin) 255 adet alt adrese ayırabilir. ODTÜ'nün NIC'den aldığı 144.122.0.0 ağı, 254 parçaya bölünmüş, bu parçalardan 144.122.71.0 alt ağı Bilgisayar Mühendisliği bölümüne, 144.122.34.0 alt ağı Kimya Mühendisliği bölümüne verilmiştir. Bundan sonra her bölüm kendi ağı ve üzerindeki makinalardan sorumlu olur.

    9.3. Protokoller

    İnternet protokollerinin yaygınlaşmasındaki en önemli etkenlerden biri herhangi bir ağ donanımına ya da firmaya özel olmamalarıdır. Bilgisayarınız, işletim sistemiz ya da ağ bağlanma yönteminiz ne olursa olsun intenete bağlamanız mümkündür. İnternet protokolleri RFC adı verilen dokümanlarda açıklanır, bu dokümanlar herkese açıktır ve ücretsizdir. RFC'lereftp://nic.ddn.mil/rfc/NIC ya daftp://ftp.metu.edu.tr/pub/documents/rfc/ODTÜ'deki yansısından erişebilirsiniz.

    İnternet protokollerinin temeli Internet Protocol (IP)'dir. İnternet üzerinde yönlendirme(routing) gibi temel ağ işlemlerinin gerçekleştirildiği protokol katmanıdır. IP paketlerinin her biri kendi başlarına aradaki ağ cihazları tarafından yönlendirilen paket içinde belirtilen adrese ulaştırılır. Bu sırada fiziksel ağ farklılıklarından kaynaklanan paket parçalanmaları(fragmentation) ve bunların yeniden birleştirilmeleri aradaki ağ cihazlarının aşırı yüklenmelerini önlemek gibi görevler de IP katmanı tarafından gerçekleştirilir.IP bağlantı temelli(connection oriented) bir ağ protokolü değildir. Bunun yanı sıra IP paketlerin içeriklerinin doğruluğunu da garanti etmez. IP katmanı sadece başlık kısmında oluşan hataları bulur ve düzeltir. İnternet üzerinde yönlendirme, yukarıda sözü edilen adreslerden yararlanılarak yapılır.

    Kullanıcı uygulamalarının IP katmanına doğrudan ulaşımları yoktur. IP ve uygulama programları arasındaki bağlantıyı sağlayan iki protokol vardır: Transmission Control Protocol (TCP ) ve User Datagram Protocol (UDP ). TCP, İnternet protokolleri arasındaki en önemli protokollerden biridir (İnternet protokol ailesi bu nedenle TCP/IP diye adlandırılır.). TCP, IP katmanının sağlamadığı bağlantı temelli, güvenilir servisi sağlar. TCP kullanarak ağ üzerinden veri aktaran programlar, bir dosyadan okuyormuş ya da yazıyormuş gibi güvenle ağ bağlantısını kullanabilirler. Arada oluşan hatalar TCP tarafından onarılır. IP protokol katmanına uygulama programları doğrudan erişemediklerinden, hata kontrolü ve bağlantı gerektirmeyen ya da bu işlemleri kendileri gerçekleştirmek isteyen uygulamalar UDP kullanarak ağ üzerinden iletişim sağlarlar.

    Yukarıdaki protokollerin yanı sıra İnternet standardı olmuş birçok uygulama protokolü de vardır. Bunlar arasında, TELNET, FTP, SMTP ve HTTP gösterilebilir.

    İnternet üzerinde paketler son makinaya ulaştıktan sonra, ilgili uygulama programına ulaşabilmesi için port adı verilen sanal numaralar kullanılır. Servis veren uygulamalar, önceden belirlenmiş standart port numraları kullanırlar. Örnek olarak SMTP 25 numaralı TCP portunu, talk ise 518 numaralı UDP portunu kullanır. Sisteminizin kullandığı port numaraları ve bunların isimlerini /etc/services dosyasından görebilirsiniz.

    9.4. İnternet'e Bağlanma

    Linux'u İnternet'e bağlamak ilk aşamada biraz zor görünse de biraz teori, biraz pratik yardımıyla mantık kolayca anlaşılabiliyor. Ağlar, bilgisayar sistemlerinde hata olma olasılığı en yüksek, en çok sorunun çıktığı alandır. Bu bölüm, özelde bir ethernet kartı ile bağlantı yapıldığı varsayılarak anlatılmıştır. Ancak anlatılan birçok kavram herhangi bir yapıdaki İnternet bağlantısı için geçerli olacaktır.

    Öncelikle çekirdeği -daha önce yapmamışsanız- ağ bağlantısına destek verecek şekilde tekrar derleyin. Bunun için gerekli birkaç soruya "y" cevabı vermek yeterli olacaktır :

    CONFIG NET ? [Y/n] y
    ...
    TCP/IP networking (CONFIG_INET) [Y/n/?] y
    ...
    Network device support (CONFIG_NETDEVICES) [Y/n/?]
    ...
    Ethernet (10 or 100Mbit) (CONFIG_NET_ETHERNET) [N/y/?] y
    ...
    Other ISA cards (CONFIG_NET_ISA) [N/y/?] y
    ...
    NE2000/NE1000 support (CONFIG_NE2000) [N/y/m/?] y

    Yukarıdaki örnekte ethernet kartınızın ne2000/ne1000 ya da uyumlu bir kart olduğu var sayılıyor. Kartınızın marka/modeline uygun seçeneneğe `y' cevabı vermelisiniz. Ethernet kartlarının dışında bağlanma yönteminize bağlı olarak çekirdeği PPP, SLIP, Token Ring gibi bir destekle derlemeniz gerekebilir. Bunları modül olarak derlemeniz de mümkün. Çekirdek derlemek konusunda daha ayrıntılı bilgiyi bu kitabın ilgili bölümünde bulabilirsiniz.

    Tabi ki çekirdeği derlemek yetmiyor, derleme aşamasından sonra ağ desteğine sahip olan çekirdek ile makinanın açılması gerekir.

    Bağlantıyı gerçekleştirmek için ağ sorumlusundan bazı önemli bilgileri almalısınız. Makinanızın IP adresi bunların başında gelir. Diğer gerekli bilgiler de subnet mask ve broadcast adresidir.

    DNS adres çözümleyici olarak çalışan DNS makinası ve makinanızı İnternet'e bağlayacak olan yönlendiricinin IP adreslerini de biliyor olmalısınız.

    Bu aşamadan sonra konfigürasyon işlemlerine geçilebilir.

    9.4.1. Ağ Konfigürasyonu

    Bu bölümde anlatılan rc.* konfigürasyon dosyaları Slackware dağıtımına özeldir. Diğer dağıtımlarda da açılışta çalışan benzeri rc dosyaları değiştirilerek, ya da sistemle birlikte gelen sistem yönetim araçları kullanılarak istediğiniz konfigürasyonu yapabilirsiniz.

    Linux, açılırken bazı dosyalara bakarak düzgün çalışması için gerekli konfigürasyonu yapar ve bazı yazılımları çalıştırır. Bu dosyalar /etc/rc.d dizini altında yeralır. İnternet bağlantısı için sadece iki dosyaya gerek duyulur. Slackware dağıtımı içinde bunlar, konfigürasyonu yapan /etc/rc.d/rc.inet1 ve temel ağ programlarını çalıştıran /etc/rc.d/rc.inet2 dosyalarıdır.

    Bu dosyadaki değerleri gerektiği şekilde düzenleyerek İnternet'e bağlanacağız. Öncelikle rc.inet1 dosyasının içeriğine göz atalım:

    HOSTNAME=`cat /etc/HOSTNAME`

    /sbin/ifconfig lo 127.0.0.1
    /sbin/route add -net 127.0.0.0

    IPADDR="144.122.71.55"
    NETMASK="255.255.255.0"
    NETWORK="144.122.71.0"
    BROADCAST="144.122.71.255"
    GATEWAY="144.122.71.1"

    /sbin/ifconfig eth0 $IPADDR broadcast $BROADCAST netmask $NETMASK
    /sbin/route add -net $NETWORK netmask $NETMASK
    /sbin/route add default gw $GATEWAY metric 1

    ifconfig komutu, ağ bağlantısı yapan kartın belirli parametreler ile konfigürasyonunun sağlar. Kart kimliğini bilgisayara tanıtmak için bu komut kullanılır.

    İlk satırdaki ifconfig programı, makinanın kendisiyle haberleşmesini sağlamak amacıyla kendi ağ adresini (loopback device ) 127.0.0.1 olarak tanıtmıştır. İnternet üzerindeki her makinanın loopback adresi 127.0.0.1 'dir. 127 ile başlayan hiç bir adres, İnternet üzerinde gerçek bir adres olarak kullanılamaz.

    Her paket, gönderileceği adrese gitmeden önce bir tabloya bakar. Bu tablo, paketin muhtemel rotasını içerir. route komutu yardımıyla bu tablo oluşturulur veya kontrol edilir. Genellikle bir kart için bir ifconfig kullanılırken, paketin yollanacağı birden fazla rotanın olması durumunda rc.inet1 dosyasında birden fazla route komut girdisi yapılacaktır.

    Kullanılan her ağ kartının bir veya birden fazla internet adresi olabilir. Linux'a takılan birinci kart eth0 ismini alırken ikinci karta eth1, üçüncüye eth2 ... denir. Loopback cihazının ismi lo dur. ifconfig komutunu parametre vermeden kullanırsanız, Linux'a tanıtılan çevresel birimlerin listesi ekrana gelir.
    $ ifconfig
    lo Link encap:Local Loopback
    inet addr:127.0.0.1 Bcast:127.255.255.255 Mask:255.0.0.0
    UP BROADCAST LOOPBACK RUNNING MTU:3584 Metric:1
    RX packets:493 errors:0 dropped:0 overruns:0
    TX packets:493 errors:0 dropped:0 overruns:0

    eth0 Link encap:10Mbps Ethernet HWaddr 48:54:33:00:E8:3A
    inet addr:144.122.71.55 Bcast:144.122.71.255 Mask:255.255.255.0
    UP BROADCAST RUNNING MULTICAST MTU:1500 Metric:1
    RX packets:171956 errors:0 dropped:0 overruns:0
    TX packets:113212 errors:3 dropped:0 overruns:0
    Interrupt:3 Base address:0x300

    ODTÜ'deki bir Linux makinasının makinasının ifconfig bilgisi yukarıdaki şekildedir. Bu makina üzerinde tek ethernet kartı olup, ifconfig bilgisinde ikinci sırada yeralıyor. Kartla ilgili detaylı bilgi (her kart özgü donanım numarası, alınan ve verilen paket sayısı gibi) ifconfig çıktısında var.

    route komutunun genel kullanımı şu şekildedir:

    route [add | del] [-net | -host] varis_adresi [gw yonlendirici] secenekler...
    host: paketin gideceği yer başka bir makina
    net: paketin gideceği yer başka bir ağ
    varış_adresi: paketin gideceği yer
    yönlendirici: bu paketin gidebilmesi için geçmesi gereken yönlendirici
    add: tabloya ekle
    del: tablodan sil
    Tablonun genel durumunu kontrol etmek için route komutuna parametre vermeden komut satırından yazın:
    $ route
    Kernel IP routing table
    Destination Gateway Genmask Flags Metric Ref Use Iface
    localnet * 255.255.255.0 U 0 0 67 eth0
    loopback * 255.0.0.0 U 0 0 3 lo
    default router71.ceng.m 0.0.0.0 UG 1 0 404 eth0

    Örnek tabloda üç ayrı yönlendirme girişi vardır. Birincisi, makinanın kendisi ile haberleşmesini sağlayacak olan loopback. İkinci satırda, yerel ağa gidecek olan tüm paketlerin yönlendiriciye verilmeden ağa yönlendirilmesi söylenmiş. Son sırada ise (default) paket ilk iki satırda yeralan varış adresinden farklı bir adrese gidecekse, önce yönlendiriciden geçip sonra dış dünyaya açılacağından yönlendiricinin IP adresi yazılmıştır.

    ifconfig, biraz karmaşık bir komuttur. Sistem yöneticisinden öğrenmeniz gereken subnet maskesi, broadcast adresi ve IP adresini kullanıp kartların konfigüre eder.

    ifconfig eth0 144.122.71.55 netmask 255.255.255.0 broadcast 144.122.71.255
    Yukarıda ifconfig yardımıyla eth0 kartına hem bir IP adresi verilmiş, hem de bilgisayarın bulunduğu ağın özellikleri tanıtılmıştır.

    Bu andan sonra istendiği kadar route komutu ile makinadan çıkacak paketler için yeni yollar tanımlanabilir.

    route add -net ...
    route add -host ...

    Dosyanın içeriğini sistem görevlisinin verdiği bilgiler doğrultusunda değiştirdikten sonra komut satırından çalıştırmanız, İnternet'e bağlantı için yeterli olacaktır.



    # /etc/rc.d/rc.inet1

    Bağlantıyı kontrol etmek İnternet adresini bilip çalıştığından emin olduğunuz bir makinaya telnet ile bağlantı yapmaya çalışın :

    $ telnet orca.cc.metu.edu.tr
    Connected to orca.cc.metu.edu.tr
    Escape character is ^]

    Ethernet kartının bağlantısını yazılım yoluyla kesmenin yolu ifconfig 'in down seçeneğidir. Örneğin tek ethernet kartı üzerinden İnternet bağlantınız var ve bunu hemen kesmek için aşağıdaki satırı yazın.

    # ifconfig eth0 down
    ethernet bağlantısını yeniden açmak için
    # ifconfig eth0 up

    komutunu girmelisiniz. Bu işlem sonrasında yönlendirme bilgilerini yeniden girmeniz gerekebilir.

    ping komutu, bağlantıları ve aynı zamanda bağlantı hızını ölçmek için kullanılan bir komuttur. Ping, ICMP protokolü yardımıyla hedef makinaya belirli uzunlukta paketler gönderir. Karşıdaki makina bunları aldığı anda bekletmeden geri yollar. Arada geçen zaman farklı, iki makina arasındaki bağlantı hızı hakkında fikir verir.

    # ping knidos.cc.metu.edu.tr
    PING knidos.cc.metu.edu.tr (144.122.199.20): 56 data bytes
    64 bytes from 144.122.199.20: icmp_seq=0 ttl=253 time=34.0 ms
    64 bytes from 144.122.199.20: icmp_seq=1 ttl=253 time=487.7 ms
    64 bytes from 144.122.199.20: icmp_seq=2 ttl=253 time=3.6 ms


    --- knidos.cc.metu.edu.tr ping statistics ---
    3 packets transmitted, 3 packets received, 0% packet loss
    round-trip min/avg/max = 3.6/175.1/487.7 ms
    netstat komutu, makinanın ağ kartı üzerinden yapılan bağlantıların dökümünü çıkarır.
    # netstat
    Active Internet connections (w/o servers)
    Proto Recv-Q Send-Q Local Address Foreign Address State
    tcp 0 0 cclub.metu.edu.tr:1947 ftp02.quicktime.appl:20 ESTABLISHED
    tcp 0 0 cclub.metu.edu.tr:1943 despair.thebandit.c:ftp ESTABLISHED
    tcp 0 0 cclub.metu.edu.tr:1424 despair.thebandit.co:20 ESTABLISHED
    tcp 0 0 cclub.metu.edu.tr:1932 ftp02.quicktime.app:ftp ESTABLISHED
    tcp 0 0 cclub.metu.edu.tr:1407 165.113.58.253:20 ESTABLISHED
    tcp 0 0 cclub.metu.edu.tr:1392 165.113.58.253:ftp ESTABLISHED
    tcp 0 0 cclub.metu.edu.tr:1377 ppp23.cc.metu.ed:telnet ESTABLISHED
    tcp 0 0 cclub.metu.edu.t:telnet pclabI_23.feas.met:7075 ESTABLISHED
    tcp 1 0 cclub.metu.edu.t:telnet ppp23.cc.metu.edu.:1054 TIME_WAIT
    tcp 0 0 cclub.metu.edu.t:telnet labmonitor.feas.m:10345 ESTABLISHED
    tcp 0 9495 cclub.metu.edu.t:telnet a5-03-asy27.bil-ro:1026 ESTABLISHED
    tcp 0 0 cclub.metu.edu.t:telnet pclabI_14.feas.me:15694 ESTABLISHED
    tcp 0 0 cclub.metu.edu.t:telnet stu21.math.metu.e:16158 ESTABLISHED
    Active UNIX domain sockets (w/o servers)
    Proto RefCnt Flags Type State I-Node Path
    unix 1 [ ] STREAM CONNECTED 232
    unix 1 [ ] STREAM CONNECTED 299
    unix 1 [ ] STREAM CONNECTED 327
    unix 1 [ ] STREAM 591

    İkinci önemli dosya olan /etc/rc.d/rc.inet2, belli başlı tüm İnternet sunucularını çalıştırır.

    Aşağıda bu dosyanın bir kısmı görülüyor.
    #!/bin/sh

    NET="/usr/sbin"
    IN_SERV="lpd"
    LPSPOOL="/var/spool/lpd"

    echo -n "Starting daemons:"

    # inetd calistiriliyor.
    if [ -f ${NET}/inetd ]; then
    echo -n " inetd"
    ${NET}/inetd
    else
    echo "no INETD found. INET cancelled!"
    exit 1
    fi

    # degisik internet servisleri sirasiyla calistiriliyor.
    for server in ${IN_SERV} ; do
    if [ -f ${NET}/${server} ]; then
    echo -n " ${server}"
    ${NET}/${server}
    fi
    done

    Bu açılış dosyası, ağ üzerinden servs veren bir dizi sunucu programı çalıştırıyor ve hataları engellemek için programların yerinde olup olmadığına da bakıyor.

    9.4.2. Kontrol Dosyaları

    Konfigürasyonu tamamlamak için /etc dizini altında yeralan bazı dosyaların elden geçirilmesi gerekir. Bu dosyalar sistemin daha güvenli ve verimli çalışmasına yardım eder. Bu dosyaların belli başlı olanları ve ne işe yaradıklarını görelim.

    /etc/hosts dosyasında makinaların IP numaraları ve İnternet adresleri yazılır. Buraya sürekli kullanılan belli başlı önemli makinaların girişi yapılabilir. Her makinanın uzun isimleri yerine kısa bir kelime yazılarak sözkonusu makinaya ulaşılabilir. Örnek bir /etc/hosts dosyası :

    127.0.0.1 localhost
    144.122.199.20 knidos.cc.metu.edu.tr knidos

    İlk satırda loopback IP numarası ve buna karşılık gelen makina ismi vardır. Bu satırı silmemelisiniz. İkinci satırda ise knidos.cc.metu.edu.tr makinasının IP numarasını 144.122.199.20 olarak belirtilmiş ve bu bilgisayara "knidos" ismi ile de ulaşılabilmesi sağlanmıştır.

    /etc/hosts.allow ve /etc/hosts.deny konfigürasyon dosyaları, başka bir makinadan Linux'unuza yapılan bağlantıları denetler. /etc/hosts.deny içine, sınırlandırılma getirmek istediğiniz İnternet servislerini ve hangi makinalar için sınırlandırma istediğinizi yazabilirsiniz.

    $ cat /etc/hosts.deny
    #

    in.fingerd: ALL except localhost, localhost : \
    echo "request from %d@%h" >> /tmp/req;
    in.telnetd : .net.tr

    Yukarıdaki hosts.deny dosyasında dışarıdan gelebilecek finger istekleri filtreleniyor ve bu istekler hakkında detaylı bilgi (hangi kullanıcı, hangi makinadan) /tmp/req dosyasına ekleniyor.

    Sonraki satır in.telnetd yazılımını çalıştıran isteklerin *.net.tr adreslerinden gelmesi halinde bunların gözardı edileceğini belirtir.
    hosts.allow dosyasında, genellikle hosts.deny dosyasına gruplanan makina isimlerinin sınırlandırma istenmeyen bir veya birkaç tanesi yazılır. Eğer bir makina ismi ve karşılık gelen İnternet adresi her iki dosyada da varsa, sözkonusu servise izin verilir.

    Daha fazla bilgiyi hosts_access(5) kılavuz sayfalarından bulabilirsiniz.

    /etc/resolv.conf dosyasında alan adı ve alan adı sunucusunun IP numarası yazılır.
    $ cat /etc/resolv.conf
    domain linux.org.tr
    nameserver 144.122.199.20

    Yukarıdaki satırlardan üzerinde bulunduğum makinanın alan adının (domain name) linux.org.tr, alan adı sunucusunun ise 144.122.199.20 IP numaralı knidos makinası olduğu anlaşılıyor.

    9.5. Yönlendirme

    Daha önce de belirtildiği gibi birden fazla ağa fiziksel bağlantısı bulunan ve ağlar arası bilgi paketlerinin geçişine olanak tanıyan araçlara yönlendirici (router ) adı verilir.

    İki ayrı ağda yeralan makinaların haberleşmesine imkan tanıyan yönlendiriciler, kendilerine gönderilen paketleri bir ağdan diğerine iletirler.

    Herhangi bir ağ içerisinde yer alan makinalar aynı IP ağ içerisinde bulunan makinalarla (ağ konfigürasyonları doğru olduğu sürece) haberleşebilirler. Başka adreslere ulaşabilmek için bulunulan ağ dışındaki ağlarla bağlantısı olan ve o ağ üzerinde bulunan bir makina ile haberleşmeleri gereklidir. Bu makina bilgisayar tanımlarında gateway (yönlendirici, arabirim, arayol) olarak verilir.

    Minimum yönlendirme, bir ağa bağlı olmayan makinalarda, ifconfig yardımıyla yapılan yönlendirmedir. En çok kullanılan statik yönlendirme çeşidinde, az sayıda arayol ile dışarıya bağlı olan bir makinada, route komutuyla yapılır. Aynı adrese ulaşan birden fazla arayol olması durumunda ise, kendi yönlendirme tablosunu ağın durumuna göre değiştirebilen dinamik yönlendirmeye başvurulabilir.

    Linux'un yönlendirici olarak kullanılmasına bir örnek verilebilir. Elimizde var olduğunu bildiğimiz iki ağ olsun. Bu ağlardan birincisini, 144.122.71.0 ağı, diğeri de 144.122.1.0 ağı olarak kabul edelim. 144.122.71.0 ağının İnternet'e bağlanabilmesi için 144.122.1.0 ağına ulaşması gereklidir. Yönlendirici olarak kullanılacak makinayı 71.0 ağında kurup gerekli yönlendirme talimatları verildiği anda bu ağa bağlı olan diğer makinalar da İnternet'e açılabilecektir.

    Örnek olarak 144.122.71.0 ağı üzerindeki bir makina için ifconfig satırı

    ifconfig eth0 144.122.71.1 broadcast 144.122.71.255 netmask 255.255.255.0

    olarak görünüyor. Bu makinanın yönlendirici görevi yapabilmesi için route komutu kullanılır. Bu sayede bu bilgisayar, diğerlerine ulaşacaktır.

    route add -net 144.122.71.0 netmask 255.255.255.0 dev eth0

    Bu, 144.122.71.0 ağında olan makinaların eth0 kartı üzerinden erişilebileceğini gösterir. Diğer adreslere erişebilmek için ise bir çıkışa (gateway) ihtiyaç duyulmaktadır.

    route add default gw 144.122.71.1 dev eth0

    Bu satır sayesinde eldeki tablo yardımıyla çözümlenemeyen adreslere gitmesi gereken tüm paketler 144.122.71.1 üzerinden gönderilmektedir. Bu durumda bu makinanın paketleri nereye göndereceğini bildiği varsayılmaktadır.

    Bu makina içinde iki adet ethernet bağlantısı bulunmaktadır. Bunlardan biri yönlendiriciyi 144.122.71.0 ağına bağlarken diğeri 144.122.1.0 ağına bağlamaktadır. İlk olarak bu iki kart için gereken tanımlamalar /etc/rc.d/rc.inet1 içerisinde aşağıdakine benzer şekilde tanımlanmıştır.

    ifconfig eth0 144.122.71.1 broadcast 144.122.71.255 netmask 255.255.255.0
    ifconfig eth1 144.122.1.200 broadcast 144.122.71.255 netmask 255.255.255.0

    Birinci ethernet kartı için eth0, ikinci ethernet kartı için de eth1 kısaltmaları kullanılabilir. Doğal olarak her iki ağ için bir 'route' satırı gerekmekte :

    route add -net 144.122.71.0 netmask 255.255.255.0 dev eth0
    route add -net 144.122.1.0 netmask 255.255.255.0 dev eth1

    Bu sayede diğer makinalardan farklı olarak yönlendirici hem 144.122.1.0 ağı, hem de 144.122.71.0 ağı üzerindeki adreslere doğrudan ulaşabilmektedir. Diğer adreslere ulaşabilmek için benzer bir yöntem ile 144.122.1.0 ağı üzerindeki arayola (gateway) yönlendirme yapılır.

    route add default gw 144.122.1.200 dev eth1

    Bu çeşit yönlendirmeye statik yönlendirme adı verilir. Burada tüm bağlantılar bir tablo halinde verilmiştir. Birbiri arkasına ağ eklendiği zaman statik yönlendirme basitlik avantajını kaybetmeye başlar. Bu amaçla yönlendiricilerin kendi aralarında bildikleri yolları (yönlendirme bilgilerini) birbirlerine aktardıkları dinamik yönlendirme kullanılır.


    9.5.1. Birden Fazla Ethernet Kartının Tanıtılması

    Yukarıda örneğini verdiğimiz Linux yönlendirici üzerinde iki ethernet kartı bulunuyor. Bu sayede Linux makinası iki ethernet ağı arasında bir yönlendirici olarak kullanılabilmektedir. Bir Linux'a birden fazla ethernet kartı takmak mümkündür. Bu kartları takarken aşağıdaki maddelere dikkat etmek gerekir:
    1. Çekirdek içerisinde her iki kart için destek bulunmalıdır.
    2. Ethernet kartları sistemdeki diğer IO ve IRQ ayarlarını çakışmayacak şekilde ve farklı değerlerde olmalıdır.

    Birden fazla ethernet kartı (ya da gibi herhangi iki veya daha fazla PPP, SLIP gibi ağ bağlantısı) olan makina bir yönlendirici olarak kullanılacaksa, çekirdek IP FORWARDING desteğiyle derlenmelidir. Bunun yanı sıra Linux'unuzun birinci görevi yönlendiricilik olacaksa optimize as router sorusuna da `y' yanıtı vermeniz yararlı olacaktır.

    IP: forwarding/gatewaying (CONFIG_IP_FORWARD) [N/y/?] y
    ...
    IP: optimize as router not host (CONFIG_IP_ROUTER) [N/y/?] y

    Linux açılırken çekirdek tanıdığı donanımları teker teker arayarak bulmaya çalışır (probing). Birden fazla ethernet kartı kullanımına sık raslanmadığından Linux ilk ethernet kartını bulduktan sonra ikinci ve daha fazla ethernet kartı aramadığı için iki kartınız bile olsa Linux sadece birini görecektir. Çekirdeğe ethernet kartı ile ilgili parametreler vererek birden fazla ethernet kartının açılışta bulunması sağlanabilir. LILO kullanıldığı zaman /etc/lilo.conf içine

    append="ether=0,0,eth1"

    satırını eklerseniz bu parametre ile çekirdek ikinci bir ethernet kartını (eth1) da arayacaktır. Benzer şekilde arka arkaya ether=.... parametreleri vererek varsa üçüncü, dördüncü ve daha fazla ethernet kartının aratılması da mümkündür. Ethernet kartlarınızın adreslerini biliyorsanız, kartların yanlış sırayla bulunması tehlikesini de önlemek için,

    append="ether=5,0x340,eth0 ether=15,0x300,eth1"

    gibi bir satır eklenmesi yeterli olacaktır. Burada eth0 isimli bağlantı IRQ 5 ve IOBASE 0x340 ve diğer ethernet bağlantısı eth1 IRQ 15 ve IOBASE 0x300 olacak şekilde ayarlanır, bu durumda çekirdek bir daha kartların hangi adres ve IRQ'da olduğuna dair tahmin yürütmez, girilen değerlerde bulunan kartları bulmaya çalışır.

    Sistem açıldıktan sonra gerçekten istenen kartların istenen adreste çalıştığına emin olmak için /var/adm/messages dosyasına bakabilirsiniz, ya da dmesg komutuyla çekirdek mesajlarını görebilirsiniz.


    İnternet Üzerinde Yeralan Linux Dökümanları

    Linux Sıkça Sorulan Sorular (Linux ÇSS) : Bu işletim sistemi hakkında linux@bilkent.edu.tr listesinden seçilerek biraraya getirilen onlarca soru ve cevabı bu belgede bulabilirsiniz. Linux'u hiç bilmeyenler kadar az bilgisi olanlara da yol gösteren ve genel sorunlara çözüm getiren bu kaynak, ASCII ve HTML formatlarında şu adresten temin edilebilir :


    http://www.linux.org.trTürkiye Linux Kullanıcıları Grubu web sayfası
    http://www.ankara.edu.tr/startAnkara Üniversitesi
    Linux-NASIL dokümanları : tr-ldp@metu.edu.tr listesinde bulunan gönüllülerin çıkardığı bu güzel çalışma, çeşitli Linux-HOWTO dokümanlarının çevirisinden oluşuyor. Her bir dosya, özel bir konuyu ele alıp yoğun olarak bu konunun işlenmesinden ibaret olup Linux'u öğrenmek isteyen, fakat ana dili İngilizce olmayanlar için büyük fırsat niteliğini taşıyor. Yaklaşık 20 kadar çeviriden oluşan Linux-NASIL belgelerinin bulunabileceği adresler :


    ftp://ftp.linux.org.trTürkiye Linux Kullanıcıları Grubu ftp sayfası
    http://www.linux.org.trTürkiye Linux Kullanıcıları Grubu web sayfası
    Yukarıdakilerin dışında, ftp.metu.edu.tr/sunsite/docs/howtoODTÜ adresinde, Linux işletim sistemi hakkında yabancı kaynaklı (İngilizce, Fransızca ve Almanca) dokümanlar ve çeviriler vardır. Burada sözkonusu İnternet adresinde neler bulunduğunu belirtmek imkansız. Birkaç HOWTO örneği vermek gerekirse:


    Linux Installation-HOWTO : Genel olarak Linux yüklemeyi anlatan bir kaynak
    Linux Meta FAQ : Genel olarak Linux hakkında bilgi veren bir kaynak
    Linux Bootdisk HOWTO : Boot ve root disketlerini, bunların yaratılmasını inceleyen bir kaynak
    Linux Distribution HOWTO : Hangi dağıtımların bulunduğunu ve nasıl elde edilebileceklerini ayrıntıları ile anlatan bir kaynak.
    Linux Hardware Compatibility HOWTO : Linux tarafından desteklenen donanımları özetleyen bir kaynak.
    Linux INFO-SHEET : Linux hakkında genel bilgi.
    Linux Kernel HOWTO : Çekirdek hakkında bilgi veren, nasıl derlenebileceğini, nereden bulunabileceğini ve çekirdeğin işlevleri hakkında bilgi veren bir kaynak.
    Linux NET-3 HOWTO : Linux'ın ağ desteği hakkında bilgi veren kaynak.
    Linux DOS2Linux mini-HOWTO : DOS kullanıcılarına Linux hakkında kısa bilgiler veren sevimli kısa bir yardım dosyası
    Linux LILO mini-HOWTO : Çeşitli değişik LILO örnekleri
    Linux Linux+DOS+Win95+OS2 mini-HOWTO : Adı üzerinde aynı bilgisayarda hepsi birden.
    Linux Linux+OS2+DOS mini-HOWTO : Adı üzerinde
    Linux Linux+Win95 mini-HOWTO : Adı üzerinde
    Linux Multiple Disks Layout mini-HOWTO : Değişik diskler üzerinde çeşitli disk bölümleri kullanırken dikkat ettiği noktaları açıklayan bir kullanıcının hazırladığı doküman
    Linux Reading List : Linux ile çalışırken yararlanılabilecek kaynakları sıralayan bir doküman.
    Linux Upgrade mini-HOWTO : Bilgisayarda yüklü mevcut Linux dağıtımının nasıl güncellenebileceğini anlatan bir kaynak.
    Linux Win95+Win+Linux mini-HOWTO : Yani belirtmeme gerek var mı ? :)
    Siteye eriştiğiniz zaman farkedeceğiniz zenginlik sizi şaşırtacaktır. Bu adresin yansısını Türkiye'de ODTÜ ve BİLKENT Üniversitelerinde yeralan servisler tutmaktadır.

    Yurtdışı HOWTO adresi

    ftp://sunsite.unc.edu/pub/linuxsunsite arşivi
    Diğer LDP ve HOWTO yansıları

    http://www.metu.edu.tr:8080/ldpODTÜ
    http://www.ehb.itu.edu.tr/ldp/İTÜ
    http://sunsite.bilkent.edu.tr/pub/linuxBilkent sunsite yansısı
    Bu arada, tüm ftp adresleri için 'pub' dizininden sonra gelen neredeyse tek ortak dizin linux'dur. Düşük hız sizin için sorun taşımıyorsa buradaki ftp ve www adreslerine bağımlı kalmak zorunda değilsiniz.

    Linux Documentation Project (Linux belgeleme projesi) adı altında, 1990 yılından beri Linux dokümanları hazırlanıyor. Bu dokümanlar hem İnternet üzerinde bedava bulunmakta, hem de yazıcı ve kağıt masrafı gibi ince işlerle uğraşmak istemeyenler için kitap olarak da bastırılmaktadır. Bir dizi gönüllünün oluşturduğu bu dokümanlar, hem işletim sisteminin hızla gelişmesi, hem de çalışma kapsamının gittikçe genişlemesi nedeniyle hergün güncellenerek geliştirilmektedir. Linux için kullanım kılavuzları (ve bu kılavuzları hazırlayan gruba) LDP Linux Documentation Project adı verilir.




    Bu dokümanlar:
    Linux Installation and Getting Started, Matt Welsh : Yeni başlayanlar için mükemmel denilebilecek bir kitap. Hemen her türlü bilgiye yer verilmiş. Tabii ki tek eksiği Türkçe olmaması.
    Linux System Administrators' Guide, Lars Wirzenius : Linux İşletim Sistemini kurduktan sonra çok kullanıcılı ortama geçmek isteyenlere yol gösteren bir kaynak. Unutmayın ki siz de bir gün sistem görevlisi olabilirsiniz.
    Linux Network Administrator's Guide, Olaf Kirch : Linux altında belli bir mesafe katettikten sonra İnternet ve ağ yapısına girmek için bulunmaz bir kaynak. Gayet güzel hazırlanan bu kitapta hemen her istediğiniz bilgiyi bulabiliyorsunuz.
    The Linux Kernel Hackers' Guide, Michael Johnson : Çekirdek kaynak kodu birlikte verilen tek işletim sistemi olan Linux'un en büyük avantajı, bu canavarı aslında istediğiniz gibi yönetmenize izin vermesi. Linux Kernel Hacker's Guide, sistem programcılığı hakkında biraz altyapısı olanlar için.
    Linux Users' Guide : Temel kullanıcıya Linux'un özelliklerini detaylarıyla verir ve bu işletim sistemi üzerinde açlıktan ölmemesi için yol gösterir.
    The Linux Kernel, David A. Rusling : Çekirdeğin çalışma prensipleri.
    The Linux Programmer's Guide : Programcılara yönelik.
    Linux Gazette ve Linux Journal : Linux Journal, SSC firması tarafından hazırlanıp dünyanın dört bir yanındaki üyelerine dağıtılıyor. Aylık çıkan bu dergi, profesyonel bir yayımcı kitlesi tarafından hazırlanıyor ve Linux ile uğraşanlar tarafından çok tutulan bir kaynak özelliğini taşıyor. Bunun yanında Linux Gazette, içerik olarak Linux Journal'a yakın, ama sadece İnternet üzerinden bedava dağıtılıyor.

    Linux Gazette ve Linux Journal ana sayfası

    http://www.ssc.comSpecialized System Consultants
    Türkiye'deki yansıları

    http://www.metu.edu.tr/ldpODTÜ
    http://www.linux.org.trLinux Kullanıcıları Grubu
    http://www.ehb.itu.edu.trİTÜ
    Haber Grupları : Usenet olarak da bilinen haber grupları, onbinlerce konu altında tartışma gruplarını biraraya getirir. Bu konu yoğunluğu içinde Linux için yaklaşık 10-15 kadar tartışma grubu açıktır. İlk olarak alt.os.linux ismi kullanılarak yapılan tartışmalar, Linux'un büyük bir hızla yayılmasıyla alt konulara ayrılmıştır.


    comp.os.linux: İnternet'in en çok okunan 20 haber grubundan biri olan comp.os.linux'ta her türlü soru ve cevapları bulabilirsiniz.
    comp.os.linux.announce: Linux işletim sistemi hakkında son haberler buraya yönlendiriliyor. Hemen her türlü yazılım, program hataları, Linux seminer ve konferans haberleri anında postalanıyor.
    comp.os.linux.setup: Linux kurulumu ve işletimi hakkında soru ve cevaplarını içerir.
    comp.os.linux.hardware: Linux'un desteklediği donanımlar ve bunlarla ilgili genel tartışma listesi
    comp.os.linux.networking: Linux'un ağ desteği (TCP/IP, SLIP, PPP vs.) konusunda tartışma listesi. Eğer bu grubu takip etmek istiyorsanız, comp.os.linux.hardware'a da göz atın.
    comp.os.linux.x: X Window kurulumu ve kullanımı hakkında soru ve cevaplar. Linux'a özgü olmayan bir diğer X Window haber grubu da comp.windows.x.i386unix'tir.
    comp.os.linux.advocacy: Okumaktan en hoşlandığım haber grubu. Linux'un diğer işletim sistemleri üzerindeki üstünlükleri ve zayıflıkları burada tartışılıyor.
    comp.os.linux.misc: Diğer grupların konuları dışında kalan tartışmalar burada sürdürülüyor.
    Tartışma Listeleri : E-posta atıp alabilme imkanınız varsa, haber gruplarının ayrı olarak listelere de üye olabilirsiniz. Listeler, tartışma gruplarına güzel bir alternatif teşkil ederler. Türkiye'de linux hakkında açılmış 4-5 tartışma listesi bulunmaktadır. Bunların arasında göze çarpan ve en çok kullanıcısı olan tartşma listesi Bilkent Üniversitesi'nde yeralan listedir. Bu listeye üye olmak için mesaj kısmında 'sub linux isim soyisim' yazılı (isim ve soyisim yerine kendi isminizi ve soyadınızı kullanın) bir e-postayı listserv@bilkent.edu.tr adresine yollayın. En kısa zamanda listeye üyeliğiniz gerçekleşecektir.

    RFC (Request For Comment) : Standartlar, tezler ve diğer resmiyet kokan pekçok bilgiye buradan erişilebilir. Başlangıç için önermiyorum. ODTÜ ftp adresinde,ftp://ftp.metu.edu.tr/pub/documents/rfc dizini altında yansısı tutulmaktadır.

    Aşağıda Türkiye'de ve yurtdışında çeşitli Linux kaynak dosyaları bulabileceğiniz ftp adresleri verilmiştir. Türkiye içinde ODTÜ, onlarca gigabyte yer kaplayan sunsite adresinin yansısının sadece bir kısmını tutabilmektedir. Bu yüzden zaman zaman yurtdışı adreslere bağlanmanızı hararetle salık veririm.ftp://tsx-11.mit.edutsx,ftp://sunsite.unc.edusunsite veftp://nic.funet.fifunet adresleri Linux'un ana adresleri olup en yeni yazılımlar önce bu adreslere gelir. İnternet trafiğini meşgul etmemek için size en yakın makinayı seçin.

    Yurtiçi :
    ftp://ftp.linux.org.trLinux Kullanıcıları Grubu
    ftp://ftp.ehb.itu.edu.tr/pub/linuxİTÜ
    ftp://sunsite.bilkent.edu.tr/pub/linuxBilkent
    ftp://ftp.itu.edu.tr/pub/linuxİTÜ
    ftp://ftp.ankara.edu.tr/pub/linuxAnkara Üniversitesi
    Yurtdışı :
    ftp://tsx-11.mit.edu/pub/linuxtsx
    ftp://sunsite.unc.edu/pub/Linuxsunsite
    ftp://nic.funet.fi/pub/OS/linuxfunet







  • güselumarım yardımcı olur.



    < Bu mesaj bu kişi tarafından değiştirildi electronics -- 9 Haziran 2005, 11:14:25 >
  • Eğer bu kitap GPL lisansı altında dağıtılmaya izin veriliyorsa kaynak belirtmek zorundasın yoksa hakkında suç duyusunda bulunabilir.
    Kitap GPL değil de normal parayla satın alınabilir bir kitapsa ve izin alınmada dağıtılamaz ifadesi varsa yine hakkında suç duyurusunda bulunabilir.

    Linux kullanmak isteyenlere yardımcı olacağına inanıyorum.Okumalarında yarar var.


    Dipnot: Sadece uyurmak istedim.Başka hiçbir maksadım yok.
  • Bende alırken çok sordum kendisine Kaynak ve/veya sahibi varmı diye ama konferanstaki herkese dağıtıldığını söyledi...
  • Kaynağını bilmiyorsan bence kaldır.www.belgeler.org sitesinde yeterince kaynak var. İyilik yapayım derken suç işleme.
  • Bugün onu aradım,bunu bu forumda yayınladığımı söyledim ve herhangi bir sorun oluşturup oluşturmayacağını sordum aynı pcforum nickli arkadaşımın söylediklerinden bahsetti.Bence kalsın :)
  • quote:

    Orjinalden alıntı: pcforum

    Kaldırılmasına gerek yok. GNU / GPL işi ile yapılan bilgilerin dağıtımı serbesttir. Kaynağının bilinmesi yada yazılması şart değil. Ben GNU / GPL felsefesine uygun olarak yazdığım nuke modüllerine , bloklarına copyright bile koymuyorum.


    ben okudum GPL Lisansını, tüm kaynaklar belirtilmek zorunda. İşinize geldiği gibi yorumlamayın..
  • Yapay Zeka’dan İlgili Konular
    Daha Fazla Göster
  • belirtilmek zorunda yada değil..benceeğer arkadaşımız belkide abimiz burayakoymuşsa sorumluluk ona aittir.. tabiki uyarmakta iyi birşey ve insanca, uygarca bir davranıştır.. ancak eğer bir konferansta dağıtılmış vede orda kaynak belirtilmemişse suç dağıtanlarındır.. teşekkürler işime yaradı.. ayrıca pcforum nickli arkadaşımız yada abimizde haklı bence.. GNU/GPL felsefesine uygun bir davranıştır.. ki zaten açık kaynak kodlu yazılım vs.lerde üzerinde istediğin değişikliği izin almadan yapabilme hakkın vardır..
  • GPL mutlaka kaynak, yazar belirtme zorunluluğu getirir. Kaynak, yazar belirtilmediği müddetçe GPL ihlal edilmiş olur.
  • beyler, gnu nedir, gpl nedir pek bi bilgim yok ama kaynağın arkadaşın elindeki kopyasında haklarının saklı olduğu belirtilmemişse her türlü kopyalama ve dağıtım hakkı var. eğer hakları saklıysa arkadaşın elindeki kopyayı basanlar suçludur...
    ayrıca herhangi i kaynağın ne olursa olsun forumda(internette) yayınlanması suç olsa da burda yayından kaldırma dışında herhangi bir cezalandırmaya gidilemez çünkü ne forum nickinden, ne de mail adresinden vs. bir kişinin kimliği kesin olarak saptanamaz...
    internette bir çok yasak yayın görüyoruz. dolu crack serial siteleri var. bulsalar en fazla yayından kaldırıyolar. ne kadar dava falan açsalarda herhangi bi tazminat, cezalandırma söz konusu olamıyo. tabiki adamın biri olayı veya sitenin sorumluluğunu sahiplendiğini belirtmemişse...
  • quote:

    Orjinalden alıntı: catalyst
    ayrıca herhangi i kaynağın ne olursa olsun forumda(internette) yayınlanması suç olsa da burda yayından kaldırma dışında herhangi bir cezalandırmaya gidilemez çünkü ne forum nickinden, ne de mail adresinden vs. bir kişinin kimliği kesin olarak saptanamaz...
    internette bir çok yasak yayın görüyoruz. dolu crack serial siteleri var. bulsalar en fazla yayından kaldırıyolar. ne kadar dava falan açsalarda herhangi bi tazminat, cezalandırma söz konusu olamıyo. tabiki adamın biri olayı veya sitenin sorumluluğunu sahiplendiğini belirtmemişse...

    Eğer hakkınızda ciddi bir suçlama varsa (bu yazının burada yayınlanması değil, kaldı ki suç olacağını sanmıyorum) oturduğunuz eve kadar herşeyiniz bulunabilir.
  • Yorumlariniz icin tesekkurler bugun ogrendim bu kitabi konferans üyeleri hazirlamis yani herhangi bir sakincasi yok :D güle güle okuyun :D
  • Uzun sorusturmlarimdan sonra Buyurun telif hakki :P

    (c) TBD Linux Kullanıcıları Çalışma Grubu , Eylül 1997 , Mart 1998


    Aşağıdaki kurallar gözetildiği takdirde kitabın tamamı veya
    bir kısmı kopyalanabilir, basılabilir, herhangi bir elektronik
    alet yardımıyla çoğaltılabilir ve dağıtılabilir.

    0. Her ne şekilde olursa olsun bu kitap ticari amaçlarla kullanılamaz.
    Akademik ve eğitim amaçlı olarak istenildiği kadar kopyalanabilir.

    1. Bu telif ve izin yazısının tamamı akademik ve eğitim amaçlı hazırlanan
    her kopyada bulunmalıdır.

    2. Diğer dillere çeviri yapılmadan önce yazarın yazılı izninin alınması
    şarttır.

    3. Kitabı içeren bilgilerin değiştirilerek kullanılması halinde
    yazar doğrudan veya dolaylı olarak doğabilecek teknik hatalardan dolayı
    sorumluluk kabul etmez.

    4. Linux İşletim Sistemi kitabının bir kısmının herhangi bir şekilde
    dağıtılması durumunda kitabın tamamına hangi yollarla ulaşılabileceği
    açık ve net bir dille belirtilmelidir.

    Bu kitap aşağıdaki Linux severlerin çalışmaları sonucu ortaya
    çıkmıştır. Yukarıdaki maddeler eğitimcilerin ve Linux
    kullanıcılarının haklarını kısıtlamak için değil, yazarların haklarını
    korumak için hazırlanmıştır.


    Görkem Çetin (gorkem@linux.org.tr)
    Çağrı Çöltekin (cagri@knidos.cc.metu.edu.tr)
    Giray Devlet (giray@yeditepe.edu.tr)
    F. Kağan Gürkaynak (kgf@ehb.itu.edu.tr)
    Cenk Kulaçoğlu
    Engür Pişirici (engur@marketweb.net.tr)
    Turgut Uyar (uyar@cs.itu.edu.tr)
    Arife Vural (arife@knidos.cc.metu.edu.tr)




  • işte lisansı bu..
  • lisans sorunuda kalkt11na göre bir sorun kalmamistir umarim
  • word e attım, 106 sayfa etti, süper çok teşekkürler ;)
  • Ellerine sağlık kardeş...
  • çok sagol kardeş bide yüklemeyi becerirsek dahada iyi olacak.
  • yaf yükleme içinde elime bi belge geçerse hemen koyarım buraya ama üstkonu var linux kurulumu için bence bi göz at
  • 
Sayfa: 12
Sayfaya Git
Git
sonraki
- x
Bildirim
mesajınız kopyalandı (ctrl+v) yapıştırmak istediğiniz yere yapıştırabilirsiniz.