Heim > Datenbank > MySQL-Tutorial > Hauptteil

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

PHPz
Freigeben: 2024-07-28 14:49:33
Original
1003 Leute haben es durchsucht

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 Scripting, und Git zur Versionskontrolle. Wir decken alles von der Ersteinrichtung bis zur Behebung häufiger Probleme ab.

Inhaltsverzeichnis

  1. Starten Sie eine EC2-Instanz
  2. Verbinden Sie sich mit Ihrer EC2-Instanz
  3. Aktualisieren und aktualisieren Sie das System
  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 so, dass SSH- (Port 22), HTTP- (Port 80) und HTTPS- (Port 443) Datenverkehr zugelassen werden.
  7. Überprüfen und starten Sie die Instanz und wählen oder erstellen Sie ein Schlüsselpaar.

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
Nach dem Login kopieren

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
Nach dem Login kopieren

4. Installieren Sie Nginx

Nginx-Webserver installieren:

sudo apt install nginx -y
sudo systemctl start nginx
sudo systemctl enable nginx
Nach dem Login kopieren

Überprüfen Sie, ob Nginx ausgeführt wird:

sudo systemctl status nginx
Nach dem Login kopieren

5. Installieren Sie MySQL

MySQL-Server installieren:

sudo apt install mysql-server -y
sudo systemctl start mysql
sudo systemctl enable mysql
Nach dem Login kopieren

Sichern Sie Ihre MySQL-Installation:

sudo mysql_secure_installation
Nach dem Login kopieren

Folgen Sie den 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-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
Nach dem Login kopieren

PHP-Installation überprüfen:

php -v
Nach dem Login kopieren

7. Installieren Sie Git

Installieren Sie Git zur Versionskontrolle:

sudo apt install git -y
Nach dem Login kopieren

Git-Installation überprüfen:

git --version
Nach dem Login kopieren

8. Konfigurieren Sie Nginx

Erstellen Sie eine neue Nginx-Serverblockkonfiguration:

sudo nano /etc/nginx/sites-available/your_domain
Nach dem Login kopieren

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;
    }
}
Nach dem Login kopieren

Aktivieren Sie die neue Website:

sudo ln -s /etc/nginx/sites-available/your_domain /etc/nginx/sites-enabled/
Nach dem Login kopieren

Nginx-Konfiguration testen:

sudo nginx -t
Nach dem Login kopieren

Wenn der Test erfolgreich ist, laden Sie Nginx neu:

sudo systemctl reload nginx
Nach dem Login kopieren

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
Nach dem Login kopieren

10. Klonen Sie Ihr Repository

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 .
Nach dem Login kopieren

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
Nach dem Login kopieren

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 {} \;
Nach dem Login kopieren

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
Nach dem Login kopieren

Möglicherweise müssen Sie sich abmelden und wieder 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
Nach dem Login kopieren

Allgemeine Einstellungen zum Anpassen:

upload_max_filesize = 64M
post_max_size = 64M
max_execution_time = 300
memory_limit = 256M
Nach dem Login kopieren

Nachdem Sie Änderungen vorgenommen haben, starten Sie PHP-FPM neu:

sudo systemctl restart php8.1-fpm
Nach dem Login kopieren

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
Nach dem Login kopieren

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
Nach dem Login kopieren
  1. Stellen Sie sicher, dass Nginx als der richtige Benutzer ausgeführt wird:
   ps aux | grep nginx
Nach dem Login kopieren
  1. Überprüfen Sie die Nginx-Konfiguration:
   sudo nano /etc/nginx/nginx.conf
Nach dem Login kopieren

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

PHP-Fehler

Bei PHP-bezogenen Fehlern:

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

Git-Probleme

Wenn Sie auf Git-Berechtigungsprobleme stoßen:

  1. Ensure the .git directory is owned by your user:
   sudo chown -R ubuntu:ubuntu /var/www/your_domain/.git
Nach dem Login kopieren
  1. Use sudo for Git operations or temporarily change ownership:
   sudo chown -R ubuntu:ubuntu /var/www/your_domain
   git pull
   sudo chown -R www-data:www-data /var/www/your_domain
Nach dem Login kopieren

15. Best Practices and Security Considerations

  1. Regularly update your system and software:
   sudo apt update && sudo apt upgrade -y
Nach dem Login kopieren
  1. Use strong passwords for all services (MySQL, SSH, etc.).

  2. Configure a firewall (e.g., UFW) to restrict incoming traffic:

   sudo ufw allow OpenSSH
   sudo ufw allow 'Nginx Full'
   sudo ufw enable
Nach dem Login kopieren
  1. Implement fail2ban to protect against brute-force attacks:
   sudo apt install fail2ban -y
   sudo systemctl start fail2ban
   sudo systemctl enable fail2ban
Nach dem Login kopieren
  1. Regularly backup your website and database.

  2. Monitor your server logs for unusual activity:

   sudo tail -f /var/log/nginx/access.log
   sudo tail -f /var/log/nginx/error.log
Nach dem Login kopieren
  1. Use version control (Git) for all your code changes.

  2. Implement proper error handling and logging in your PHP application.

  3. Use prepared statements or ORM to prevent SQL injection attacks.

  4. 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!

Quelle:dev.to
Erklärung dieser Website
Der Inhalt dieses Artikels wird freiwillig von Internetnutzern beigesteuert und das Urheberrecht liegt beim ursprünglichen Autor. Diese Website übernimmt keine entsprechende rechtliche Verantwortung. Wenn Sie Inhalte finden, bei denen der Verdacht eines Plagiats oder einer Rechtsverletzung besteht, wenden Sie sich bitte an admin@php.cn
Beliebte Tutorials
Mehr>
Neueste Downloads
Mehr>
Web-Effekte
Quellcode der Website
Website-Materialien
Frontend-Vorlage