Linux ­Kurulu­m ve Y­onetim­i
  • Döküman Hakkında
  • Linux ve GNU'nun Geçmişi
    • CentOS, Debian ve FreeBSD Ana Sürümlerin Farkları
  • Temel Komutlar
    • Temel Terminal Komutları
    • Yardım Dosyaları
    • Dosya İzinleri, Yetkiler, Kullanıcılar ve Gruplar
    • Dosya Düzenleme Araçları
      • nano ve pico
      • vi
    • Sıkıştırılmış Dosyalar
  • Standart Girdi ve Çıktı
    • Standart Çıktı
    • Standart Girdi
    • UNIX Pipeline
    • Olmazsa Olmaz: stdio.h
    • Standart Hata ve File Descriptor
    • Forkbomb
    • Named Pipe
  • Gelişmiş Terminal Komutları
    • Tarih ve Saat Ayarlama
    • Sistem Yükünü İzleme
    • patch ve diff
    • xargs
    • awk ve sed
    • egrep ve Regular Expressions
    • rename
    • Imagemagick ve Görüntü Dosyaları
    • wget
    • Python ile Dosya Sunuculuğu
  • Temel Dağıtımlar
    • RHEL Tabanlı (CentOS, Rocky, Alma)
      • rpm Paketleri
      • DNF Paket Yöneticisi
      • Repo Ayarları
      • Network Ayarları
    • Debian
      • deb Paketleri
      • apt Paket Yöneticisi
      • Repo Ayarları
      • Network Ayarları
    • FreeBSD
      • Ports ve pkg Yönetimi
      • Güncelleme Teknikleri
      • Network Ayarları
    • Arch Linux
      • pacman ve AUR
      • Network Ayarları
    • Ortak Network Dosyaları
  • SSH
    • Uzak Sunucuya Bağlanma
    • sshd Sunucu Ayarları
    • Private ve Public Anahtarlar
    • Güvenli Dosya Aktarımı
    • sshfs
  • Kernel Boot
    • Sunucu Başlangıcına Genel Bakış
    • Çekirdeğin Yüklenmesi ve Boot Seçenekleri
    • Çekirdek Parametreleri
    • Bootloader Nedir?
  • User Space
    • Başlangıç: Init
    • Init Versiyonunu Belirlemek
    • System V
      • Servislerin Yönetimi
      • Çalışma Seviyeleri (Run Levels)
      • Örnek System V Servis Oluşturma
    • systemd
      • Servislerin Yönetimi
      • Birimler ve Birim Tipleri
      • Örnek systemd Servis Oluşturma
    • Acil Durumlar ve Tek Kullanıcı Modu
  • BASH Programlama
    • Döngüler ve Diğer Kontrol Yöntemleri
    • Menüler
  • Log Dosyaları
    • Log İnceleme ve Filtreleme
  • İnternet Servisleri
    • Bir sayfanın İnternetteki Serüveni
    • Nameserver Servisleri
    • Apache
    • PHP-FPM
    • FTP/FTPS/SFTP
      • vsftpd
      • ProFTPD
      • SFTP
      • Komut Satırından ftp Kullanımı
  • Zamanlanmış Görevler
    • crontab
    • at
  • Veritabanı
    • MySQL
      • MySQL Kurulumu
      • MySQL Servisini Çalıştırmak
      • Veritabanı ve Tablo oluşturmak
      • SQL Tablosuna Veri Eklemek
      • Temel SQL Sorgularına Giriş
        • Birinci bölüm
      • mysqldump ile yedekleme
      • Replikasyon teknikleri
      • Yedekleri içeri alma
    • PostgreSQL
      • PostgreSQL Kurulumu
      • Temel Yapılandırma
      • Temel Kullanım
    • MongoDB
      • MongoDB Kurulumu
      • Temel Yapılandırma
      • Temel Kullanım
    • Redis
      • Redis Kurulumu
      • Temel Yapılandırma
      • Temel Kullanım
  • Temel Network Yapılandırması
  • Gelişmiş Network Komutları
    • ip
    • ifconfig
    • route
    • ping
    • traceroute
    • dig
    • nslookup
    • netcat
    • nmap
    • tcpdump
    • Wireshark (Giriş)
    • Bantgenişliği Ölçümü
  • Güvenlik
    • Firewalld
    • IPTables
      • Temel İzinler
      • IP ve Port Engelleme
    • selinux
  • Disk Sistemleri
    • ext
    • zfs
    • lvm
  • RAID
    • RAID Biçimleri
    • Verinin Disklere Yayılması
    • Cache
    • Terimler ve Tavsiyeler
  • Örnek Kurulumlar ve Modern Yaklaşımlar
    • CentOS 7 Tam Sistem Kurulumu (Arşiv)
    • AlmaLinux ile Hosting Ortamı Kurulumu
    • Ubuntu ile Hosting Ortamı Kurulumu
    • Modern Hosting Yaklaşımları (PaaS, Coolify vb.)
  • Konteynerleştirme (Docker / Podman)
  • Yapılandırma Yönetimi (Ansible)
  • İzleme ve Uyarı (Prometheus / Grafana)
  • Nginx Web Sunucusu
  • Kubernetes (Giriş)
  • PCI-DSS ve Linux Sistemleri
  • İndeks
  • Kaynaklar
Powered by GitBook
On this page
  • atd Servisi
  • Görev Zamanlama
  • Zamanlanmış Görevleri Yönetme
  • Erişim Kontrolü
  1. Zamanlanmış Görevler

at

cron tekrarlayan görevler için kullanılırken, at komutu belirli komutların veya betiklerin gelecekte belirli bir zamanda sadece bir kez çalıştırılmasını sağlamak için kullanılır.

atd Servisi

at komutu ile zamanlanan görevlerin çalıştırılabilmesi için sistemde atd (at daemon) servisinin çalışıyor olması gerekir. Çoğu dağıtımda varsayılan olarak kurulu ve etkin olabilir, ancak kontrol etmek gerekebilir:

# Servisin durumunu kontrol et
sudo systemctl status atd

# Gerekirse başlat ve etkinleştir
# sudo systemctl start atd
# sudo systemctl enable atd

Görev Zamanlama

at komutuna çalıştırılacak zaman parametre olarak verilir. Zaman belirtildikten sonra, at komutu standart girdiden çalıştırılacak komutları okumaya başlar. Komutları girdikten sonra, genellikle yeni bir satırda Ctrl+D tuş kombinasyonuna basarak girdi sonlandırılır ve görev zamanlanır.

Zaman Belirtme Formatları:

at komutu oldukça esnek bir zaman belirtme formatını anlar:

  • Kesin Zaman:

    • HH:MM: Bugün belirtilen saatte (eğer saat geçmişse yarın). Örn: at 14:30

    • HH:MM YYYY-MM-DD: Belirtilen tarih ve saatte. Örn: at 09:00 2025-12-25

    • noon (öğlen), midnight (gece yarısı), teatime (16:00) gibi anahtar kelimeler.

    • HH:MM <gün_adı>: Gelecek belirtilen günde. Örn: at 11:00 Sunday

  • Göreceli Zaman:

    • now + <sayı> <birim>: Şu andan itibaren belirtilen süre sonra. Birimler: minutes, hours, days, weeks. Örn: at now + 1 hour, at now + 30 minutes

    • HH:MM tomorrow: Yarın belirtilen saatte.

    • HH:MM next <birim>: Gelecek hafta/ay/yıl belirtilen saatte. Örn: at 10:00 next week

Örnek Kullanım (İnteraktif):

$ at 10:30 tomorrow 
warning: commands will be executed using /bin/sh
at> echo "Bu mesaj yarın sabah 10:30'da loglanacak" >> /home/user/at_test.log
at> echo "İkinci komut" >> /home/user/at_test.log
at> <Ctrl+D>  # Girdiyi bitir
job 1 at Mon Mar 31 10:30:00 2025 

Bu komutlar, belirtilen zamanda (Mon Mar 31 10:30:00 2025) /bin/sh kabuğu kullanılarak çalıştırılacaktır.

Örnek Kullanım (Pipe ile):

Tek bir komutu zamanlamak için echo ve pipe kullanılabilir:

echo "/usr/local/bin/gece_yarisi_betigi.sh" | at midnight

Örnek Kullanım (Dosyadan):

Çalıştırılacak komutları içeren bir dosyayı -f seçeneği ile belirtebilirsiniz:

# komutlar.txt dosyasının içeriği:
# echo "Dosyadan gelen görev"
# date

at -f komutlar.txt now + 5 minutes 

Zamanlanmış Görevleri Yönetme

  • Görevleri Listeleme (atq veya at -l): Kullanıcının bekleyen at görevlerini listeler. Her görevin bir iş numarası (job ID) vardır.

    $ atq
    1   Mon Mar 31 10:30:00 2025 a user
    2   Tue Apr  1 00:00:00 2025 a user
  • Görevi Silme (atrm veya at -d): Belirtilen iş numarasına sahip görevi kuyruktan kaldırır.

    atrm 1
    # veya
    at -d 2 
  • Görevin İçeriğini Görme (at -c): Belirtilen iş numarasına sahip görevin çalıştıracağı komutları (ve ortam değişkenlerini) gösterir.

    at -c 1 

Erişim Kontrolü

Hangi kullanıcıların at komutunu kullanabileceği /etc/at.allow ve /etc/at.deny dosyaları ile kontrol edilebilir:

  • Eğer /etc/at.allow dosyası varsa, sadece bu dosyada listelenen kullanıcılar at kullanabilir.

  • Eğer /etc/at.allow yoksa ama /etc/at.deny varsa, bu dosyada listelenen kullanıcılar dışındaki herkes at kullanabilir.

  • Eğer iki dosya da yoksa, genellikle sadece root kullanıcısı at kullanabilir (dağıtıma göre değişebilir).

at komutu, tek seferlik görevleri basitçe zamanlamak için kullanışlı bir araçtır. Tekrarlayan görevler için cron veya systemd timer'ları daha uygundur.

PreviouscrontabNextVeritabanı

Last updated 1 month ago