Diese Anleitung führt Sie durch den Prozess der Einrichtung einer PHP-Website auf einer Amazon EC2-Instanz mit Nginx als Webserver, MySQL als Datenbank, PHP für serverseitiges Scripting, und Git zur Versionskontrolle. Wir decken alles von der Ersteinrichtung bis zur Behebung häufiger Probleme ab.
Verwenden Sie SSH, um eine Verbindung zu Ihrer Instanz herzustellen:
ssh -i /path/to/your-key.pem ubuntu@your-instance-public-dns
Ersetzen Sie /path/to/your-key.pem durch den Pfad zu Ihrer Schlüsseldatei und your-instance-public-dns durch den öffentlichen DNS-Namen Ihrer Instanz.
Sobald die Verbindung hergestellt ist, aktualisieren und aktualisieren Sie Ihr System:
sudo apt update sudo apt upgrade -y
Nginx-Webserver installieren:
sudo apt install nginx -y sudo systemctl start nginx sudo systemctl enable nginx
Überprüfen Sie, ob Nginx ausgeführt wird:
sudo systemctl status nginx
MySQL-Server installieren:
sudo apt install mysql-server -y sudo systemctl start mysql sudo systemctl enable mysql
Sichern Sie Ihre MySQL-Installation:
sudo mysql_secure_installation
Folgen Sie den Anweisungen, um ein Root-Passwort festzulegen und unsichere Standardeinstellungen zu entfernen.
Wir installieren PHP 8.1 (oder die neueste stabile Version, die in den Ubuntu-Repositorys verfügbar ist):
sudo apt install php8.1-fpm php8.1-mysql php8.1-common php8.1-cli php8.1-curl php8.1-mbstring php8.1-xml php8.1-zip -y
PHP-Installation überprüfen:
php -v
Installieren Sie Git zur Versionskontrolle:
sudo apt install git -y
Git-Installation überprüfen:
git --version
Erstellen Sie eine neue Nginx-Serverblockkonfiguration:
sudo nano /etc/nginx/sites-available/your_domain
Fügen Sie die folgende Konfiguration hinzu (ersetzen Sie Ihre_Domäne durch Ihre tatsächliche Domäne oder IP-Adresse):
server { listen 80; server_name your_domain www.your_domain; root /var/www/your_domain; index index.php index.html index.htm; location / { try_files $uri $uri/ /index.php?$query_string; } location ~ \.php$ { fastcgi_pass unix:/var/run/php/php8.1-fpm.sock; fastcgi_index index.php; include fastcgi_params; } location ~ /\.ht { deny all; } }
Aktivieren Sie die neue Website:
sudo ln -s /etc/nginx/sites-available/your_domain /etc/nginx/sites-enabled/
Nginx-Konfiguration testen:
sudo nginx -t
Wenn der Test erfolgreich ist, laden Sie Nginx neu:
sudo systemctl reload nginx
Erstellen Sie das Web-Stammverzeichnis:
sudo mkdir -p /var/www/your_domain sudo chown -R $USER:$USER /var/www/your_domain sudo chmod -R 755 /var/www/your_domain
Wenn Sie über ein bestehendes Git-Repository für Ihre Website verfügen, klonen Sie es in Ihr Web-Root:
cd /var/www/your_domain git clone https://github.com/your-username/your-repo.git .
Ersetzen Sie https://github.com/your-username/your-repo.git durch Ihre tatsächliche Repository-URL.
Wenn Sie ein neues Projekt starten, initialisieren Sie ein neues Git-Repository:
cd /var/www/your_domain git init
Legen Sie die richtigen Berechtigungen für Ihre Webdateien fest:
sudo chown -R www-data:www-data /var/www/your_domain sudo find /var/www/your_domain -type d -exec chmod 755 {} \; sudo find /var/www/your_domain -type f -exec chmod 644 {} \;
Um dem Ubuntu-Benutzer die Verwaltung von Dateien zu ermöglichen:
sudo usermod -a -G www-data ubuntu sudo chmod g+s /var/www/your_domain
Möglicherweise müssen Sie sich abmelden und wieder anmelden, damit die Gruppenänderungen wirksam werden.
Passen Sie die PHP-Einstellungen bei Bedarf an:
sudo nano /etc/php/8.1/fpm/php.ini
Allgemeine Einstellungen zum Anpassen:
upload_max_filesize = 64M post_max_size = 64M max_execution_time = 300 memory_limit = 256M
Nachdem Sie Änderungen vorgenommen haben, starten Sie PHP-FPM neu:
sudo systemctl restart php8.1-fpm
Um Ihre Website mit HTTPS zu sichern, können Sie Let's Encrypt verwenden:
sudo apt install certbot python3-certbot-nginx -y sudo certbot --nginx -d your_domain -d www.your_domain
Folgen Sie den Anweisungen, um SSL einzurichten.
Wenn in den Nginx-Fehlerprotokollen der Fehler „Berechtigung verweigert“ auftritt:
ls -l /var/www/your_domain
ps aux | grep nginx
sudo nano /etc/nginx/nginx.conf
Stellen Sie sicher, dass der Benutzer auf www-data eingestellt ist.
Bei PHP-bezogenen Fehlern:
sudo tail -f /var/log/php8.1-fpm.log
sudo systemctl status php8.1-fpm
ls /var/run/php/php8.1-fpm.sock
Wenn Sie auf Git-Berechtigungsprobleme stoßen:
sudo chown -R ubuntu:ubuntu /var/www/your_domain/.git
sudo chown -R ubuntu:ubuntu /var/www/your_domain git pull sudo chown -R www-data:www-data /var/www/your_domain
sudo apt update && sudo apt upgrade -y
Use strong passwords for all services (MySQL, SSH, etc.).
Configure a firewall (e.g., UFW) to restrict incoming traffic:
sudo ufw allow OpenSSH sudo ufw allow 'Nginx Full' sudo ufw enable
sudo apt install fail2ban -y sudo systemctl start fail2ban sudo systemctl enable fail2ban
Regularly backup your website and database.
Monitor your server logs for unusual activity:
sudo tail -f /var/log/nginx/access.log sudo tail -f /var/log/nginx/error.log
Use version control (Git) for all your code changes.
Implement proper error handling and logging in your PHP application.
Use prepared statements or ORM to prevent SQL injection attacks.
Keep your application dependencies up-to-date and use a dependency manager like Composer for PHP projects.
By following this guide, you should have a fully functional PHP website running on an EC2 instance with Nginx, MySQL, and Git.
Remember to adapt the instructions to your specific needs and always prioritize security in your setup.
Das obige ist der detaillierte Inhalt vonEinrichten einer PHP-Website auf ECith Nginx, MySQL, PHP und Git. Für weitere Informationen folgen Sie bitte anderen verwandten Artikeln auf der PHP chinesischen Website!