Bu bölümde, popüler bir Debian tabanlı dağıtım olan Ubuntu LTS (Uzun Süreli Destek) üzerine temel bir web hosting ortamının (Apache/Nginx, MariaDB/MySQL, PHP-FPM) nasıl kurulabileceğine dair örnek adımlar sunulmaktadır.
Not: Bu rehber temel bir kurulumu kapsar. Üretim ortamları için daha detaylı güvenlik sıkılaştırmaları, performans optimizasyonları ve yedekleme stratejileri gereklidir. Ubuntu'nun farklı sürümlerinde komutlar veya varsayılan ayarlar küçük farklılıklar gösterebilir.
1. Sistem Güncelleme ve Temel Paketler
# Sistemi en güncel hale getirsudoaptupdatesudoaptupgrade-y# Gerekli temel araçları kursudoaptinstallwgetcurlbind9-utilsdnsutilsnet-toolslsofatopufw-y
(bind9-utilsdig içerir, dnsutilsnslookup içerir, ufw güvenlik duvarı aracıdır).
2. Güvenlik Ayarları
UFW (Uncomplicated Firewall): Ubuntu'nun varsayılan güvenlik duvarı aracıdır. Kullanımı firewalld'ye göre daha basittir.
# UFW durumunu kontrol et (genellikle başlangıçta inaktiftir)sudoufwstatus# Varsayılan olarak gelenleri engelle, gidenlere izin versudoufwdefaultdenyincomingsudoufwdefaultallowoutgoing# SSH, HTTP ve HTTPS'e izin versudoufwallowssh# veya sudo ufw allow 22/tcpsudoufwallowhttp# veya sudo ufw allow 80/tcpsudoufwallowhttps# veya sudo ufw allow 443/tcp# UFW'yi etkinleştirsudoufwenable# Durumu tekrar kontrol etsudoufwstatusverbose
SSH Güvenliği:/etc/ssh/sshd_config dosyasında en azından şunları yapın:
PermitRootLogin no
PasswordAuthentication no (SSH anahtarı kullanılıyorsa)
Gerekirse AllowUsers veya AllowGroups ile erişimi kısıtlayın.
sudo systemctl restart sshd
AppArmor: Ubuntu, SELinux yerine AppArmor'ı MAC sistemi olarak kullanır. Genellikle varsayılan profiller yeterlidir, ancak özel durumlar için profiller düzenlenebilir (/etc/apparmor.d/).
3. Web Sunucusu Kurulumu (Apache veya Nginx)
Seçenek A: Apache (apache2)
Seçenek B: Nginx
4. Veritabanı Sunucusu Kurulumu (MariaDB veya MySQL)
Ubuntu depolarında genellikle hem MariaDB hem de MySQL bulunur.
Seçenek A: MariaDB (Genellikle Önerilen)
Seçenek B: MySQL
5. PHP ve PHP-FPM Kurulumu
Ubuntu depoları genellikle güncel bir PHP sürümü içerir. Daha spesifik veya en yeni sürümler için Ondřej Surý PPA'sı yaygın olarak kullanılır.
6. Web Sunucusu ve PHP-FPM Entegrasyonu
Apache ile:
Gerekli modüllerin (proxy_fcgi, setenvif) etkin olduğundan emin olun (sudo a2enmod proxy_fcgi setenvif).
/etc/apache2/sites-available/ altında sanal ana bilgisayar yapılandırmanızı oluşturun.
Siteyi etkinleştirin (genellikle /etc/nginx/sites-enabled/ altına sembolik link oluşturarak).
sudo systemctl restart nginx
7. Web Sitesi Dosyaları ve İzinler
Web sitesi kullanıcısı oluşturun (örn. webuser).
Site dosyaları için dizin oluşturun (örn. /var/www/example.com/html).
Dosyaların sahipliğini ve izinlerini ayarlayın (örn. sudo chown -R webuser:www-data /var/www/example.com, sudo chmod -R 775 /var/www/example.com). www-data genellikle Apache/Nginx'in çalıştığı gruptur.
Gerekirse AppArmor profillerini kontrol edin.
Bu adımlar, Ubuntu üzerinde temel bir LAMP veya LEMP yığını kurmak için bir başlangıç noktasıdır. Dağıtım sürümleri ve kullanılan yazılım versiyonlarına göre küçük farklılıklar olabilir.
sudo apt install mariadb-server -y
# Servis genellikle otomatik başlar ve etkinleştirilir
# sudo systemctl status mariadb
# İlk güvenlik ayarlarını yap
sudo mariadb-secure-installation
sudo apt install mysql-server -y
# Servis genellikle otomatik başlar ve etkinleştirilir
# sudo systemctl status mysql
# İlk güvenlik ayarlarını yap
sudo mysql_secure_installation
# Depodaki varsayılan sürümü kurma (örn. Ubuntu 22.04 için PHP 8.1 olabilir)
sudo apt install php-fpm php-mysql php-gd php-xml php-mbstring php-intl php-opcache -y
# Kurulan sürümü kontrol edin, örn: php -v
# PHP-FPM servisini başlat ve etkinleştir (sürüm numarasını kontrol edin)
sudo systemctl enable --now php8.1-fpm # Örnek sürüm
location ~ \.php$ {
include snippets/fastcgi-php.conf;
fastcgi_pass unix:/run/php/php8.1-fpm.sock;
# fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; # Genellikle fastcgi-php.conf içinde bulunur
}