„Wenn ein Arbeiter seine Arbeit gut machen will, muss er zuerst seine Werkzeuge schärfen.“ – Konfuzius, „Die Gespräche des Konfuzius. Lu Linggong“
Titelseite > Programmierung > Einrichten einer PHP-Website auf ECith Nginx, MySQL, PHP und Git

Einrichten einer PHP-Website auf ECith Nginx, MySQL, PHP und Git

Veröffentlicht am 25.08.2024
Durchsuche:266

Setting Up a PHP Website on ECith Nginx, MySQL, PHP, and Git

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 Skripting, und Git zur Versionskontrolle. Wir decken alles ab, von der Ersteinrichtung bis zur Fehlerbehebung bei häufigen Problemen.

Inhaltsverzeichnis

  1. Eine EC2-Instanz starten
  2. Verbinden Sie sich mit Ihrer EC2-Instanz
  3. System aktualisieren und aktualisieren
  4. Nginx installieren
  5. MySQL installieren
  6. PHP installieren
  7. Git installieren
  8. Nginx konfigurieren
  9. Richten Sie Ihr Website-Verzeichnis ein
  10. Klonen Sie Ihr Repository
  11. Korrekte Berechtigungen festlegen
  12. PHP konfigurieren
  13. SSL einrichten (optional, aber empfohlen)
  14. Behebung häufiger Probleme
  15. Best Practices und Sicherheitsüberlegungen

1. Starten Sie eine EC2-Instanz

  1. Melden Sie sich bei Ihrer AWS-Managementkonsole an.
  2. Navigieren Sie zu EC2 und klicken Sie auf „Instanz starten“.
  3. Wählen Sie ein Ubuntu-Server-AMI (z. B. Ubuntu Server 22.04 LTS).
  4. Wählen Sie einen Instanztyp aus (t2.micro ist für die kostenlose Stufe berechtigt).
  5. Konfigurieren Sie Instanzdetails, fügen Sie Speicher und Tags nach Bedarf hinzu.
  6. Konfigurieren Sie die Sicherheitsgruppe, um SSH- (Port 22), HTTP- (Port 80) und HTTPS- (Port 443) Datenverkehr zuzulassen.
  7. Überprüfen und starten Sie die Instanz, indem Sie ein Schlüsselpaar auswählen oder erstellen.

2. Stellen Sie eine Verbindung zu Ihrer EC2-Instanz her

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.

3. Aktualisieren und aktualisieren Sie das System

Sobald die Verbindung hergestellt ist, aktualisieren und aktualisieren Sie Ihr System:

sudo apt update
sudo apt upgrade -y

4. Installieren Sie Nginx

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

5. Installieren Sie MySQL

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

Befolgen Sie die Anweisungen, um ein Root-Passwort festzulegen und unsichere Standardeinstellungen zu entfernen.

6. Installieren Sie PHP

Wir installieren PHP 8.1 (oder die neueste stabile Version, die in den Ubuntu-Repositories 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

7. Installieren Sie Git

Git zur Versionskontrolle installieren:

sudo apt install git -y

Git-Installation überprüfen:

git --version

8. Konfigurieren Sie Nginx

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

9. Richten Sie Ihr Website-Verzeichnis ein

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

10. Klonen Sie Ihr Repository

Wenn Sie über ein bestehendes Git-Repository für Ihre Website verfügen, klonen Sie es in Ihr Webstammverzeichnis:

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

11. Legen Sie die richtigen Berechtigungen fest

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 {} \;

So erlauben Sie dem Ubuntu-Benutzer, Dateien zu verwalten:

sudo usermod -a -G www-data ubuntu
sudo chmod g s /var/www/your_domain

Möglicherweise müssen Sie sich abmelden und erneut anmelden, damit die Gruppenänderungen wirksam werden.

12. Konfigurieren Sie PHP

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

13. SSL einrichten (optional, aber empfohlen)

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.

14. Fehlerbehebung bei häufigen Problemen

Fehler „Berechtigung verweigert“.

Wenn in den Nginx-Fehlerprotokollen der Fehler „Berechtigung verweigert“ auftritt:

  1. Überprüfen Sie den Dateieigentum:
   ls -l /var/www/your_domain
  1. Stellen Sie sicher, dass Nginx als der richtige Benutzer ausgeführt wird:
   ps aux | grep nginx
  1. Überprüfen Sie die Nginx-Konfiguration:
   sudo nano /etc/nginx/nginx.conf

Stellen Sie sicher, dass der Benutzer auf www-data eingestellt ist.

PHP-Fehler

Für PHP-bezogene Fehler:

  1. PHP-FPM-Protokolle prüfen:
   sudo tail -f /var/log/php8.1-fpm.log
  1. Stellen Sie sicher, dass PHP-FPM ausgeführt wird:
   sudo systemctl status php8.1-fpm
  1. Überprüfen Sie, ob die PHP-FPM-Socket-Datei vorhanden ist:
   ls /var/run/php/php8.1-fpm.sock

Git-Probleme

Wenn Sie auf Git-Berechtigungsprobleme stoßen:

  1. Stellen Sie sicher, dass das .git-Verzeichnis Ihrem Benutzer gehört:
   sudo chown -R ubuntu:ubuntu /var/www/your_domain/.git
  1. Verwenden Sie sudo für Git-Vorgänge oder ändern Sie vorübergehend den Besitzer:
   sudo chown -R ubuntu:ubuntu /var/www/your_domain
   git pull
   sudo chown -R www-data:www-data /var/www/your_domain

15. Best Practices und Sicherheitsüberlegungen

  1. Aktualisieren Sie Ihr System und Ihre Software regelmäßig:
   sudo apt update && sudo apt upgrade -y
  1. Verwenden Sie sichere Passwörter für alle Dienste (MySQL, SSH usw.).

  2. Konfigurieren Sie eine Firewall (z. B. UFW), um eingehenden Datenverkehr einzuschränken:

   sudo ufw allow OpenSSH
   sudo ufw allow 'Nginx Full'
   sudo ufw enable
  1. Implementieren Sie fail2ban, um sich vor Brute-Force-Angriffen zu schützen:
   sudo apt install fail2ban -y
   sudo systemctl start fail2ban
   sudo systemctl enable fail2ban
  1. Sichern Sie regelmäßig Ihre Website und Datenbank.

  2. Überwachen Sie Ihre Serverprotokolle auf ungewöhnliche Aktivitäten:

   sudo tail -f /var/log/nginx/access.log
   sudo tail -f /var/log/nginx/error.log
  1. Verwenden Sie die Versionskontrolle (Git) für alle Ihre Codeänderungen.

  2. Implementieren Sie eine ordnungsgemäße Fehlerbehandlung und Protokollierung in Ihrer PHP-Anwendung.

  3. Verwenden Sie vorbereitete Anweisungen oder ORM, um SQL-Injection-Angriffe zu verhindern.

  4. Halten Sie Ihre Anwendungsabhängigkeiten auf dem neuesten Stand und verwenden Sie einen Abhängigkeitsmanager wie Composer für PHP-Projekte.

Wenn Sie dieser Anleitung folgen, sollten Sie eine voll funktionsfähige PHP-Website haben, die auf einer EC2-Instanz mit Nginx, MySQL und Git läuft.
Denken Sie daran, die Anweisungen an Ihre spezifischen Bedürfnisse anzupassen und der Sicherheit bei Ihrer Einrichtung stets Priorität einzuräumen.

Freigabeerklärung Dieser Artikel ist abgedruckt unter: https://dev.to/manojspace/setting-up-a-php-website-on-ec2-with-nginx-mysql-php-and-git-3471?1 Falls ein Verstoß vorliegt Bitte kontaktieren Sie Study_golang @163.comdelete
Neuestes Tutorial Mehr>

Haftungsausschluss: Alle bereitgestellten Ressourcen stammen teilweise aus dem Internet. Wenn eine Verletzung Ihres Urheberrechts oder anderer Rechte und Interessen vorliegt, erläutern Sie bitte die detaillierten Gründe und legen Sie einen Nachweis des Urheberrechts oder Ihrer Rechte und Interessen vor und senden Sie ihn dann an die E-Mail-Adresse: [email protected] Wir werden die Angelegenheit so schnell wie möglich für Sie erledigen.

Copyright© 2022 湘ICP备2022001581号-3