Rumah  >  Artikel  >  pangkalan data  >  Menyediakan Laman Web PHP pada ECith Nginx, MySQL, PHP dan Git

Menyediakan Laman Web PHP pada ECith Nginx, MySQL, PHP dan Git

PHPz
PHPzasal
2024-07-28 14:49:331024semak imbas

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

Panduan ini akan memandu anda melalui proses menyediakan tapak web PHP pada contoh Amazon EC2 menggunakan Nginx sebagai pelayan web, MySQL sebagai pangkalan data, PHP untuk skrip sebelah pelayan, dan Git untuk kawalan versi. Kami akan membincangkan segala-galanya daripada persediaan awal hingga menyelesaikan masalah biasa.

Jadual Kandungan

  1. Lancarkan Instance EC2
  2. Sambung ke Instance EC2 Anda
  3. Kemas kini dan Naik Taraf Sistem
  4. Pasang Nginx
  5. Pasang MySQL
  6. Pasang PHP
  7. Pasang Git
  8. Konfigurasikan Nginx
  9. Sediakan Direktori Laman Web Anda
  10. Klon Repositori Anda
  11. Tetapkan Kebenaran Betul
  12. Konfigurasikan PHP
  13. Sediakan SSL (Pilihan tetapi Disyorkan)
  14. Menyelesaikan masalah Isu Biasa
  15. Amalan Terbaik dan Pertimbangan Keselamatan

1. Lancarkan Contoh EC2

  1. Log masuk ke Konsol Pengurusan AWS anda.
  2. Navigasi ke EC2 dan klik "Lancarkan Instance".
  3. Pilih AMI Pelayan Ubuntu (cth., Pelayan Ubuntu 22.04 LTS).
  4. Pilih jenis tika (t2.micro layak mendapat peringkat percuma).
  5. Konfigurasikan butiran contoh, tambah storan dan teg mengikut keperluan.
  6. Konfigurasikan kumpulan keselamatan untuk membenarkan trafik SSH (port 22), HTTP (port 80) dan HTTPS (port 443).
  7. Semak dan lancarkan contoh, memilih atau mencipta pasangan kunci.

2. Sambung ke Instance EC2 Anda

Gunakan SSH untuk menyambung ke tika anda:

ssh -i /path/to/your-key.pem ubuntu@your-instance-public-dns

Ganti /path/to/your-key.pem dengan laluan ke fail kunci anda dan your-instance-public-dns dengan nama DNS awam instance anda.

3. Kemas kini dan Naik Taraf Sistem

Setelah disambungkan, kemas kini dan tingkatkan sistem anda:

sudo apt update
sudo apt upgrade -y

4. Pasang Nginx

Pasang pelayan web Nginx:

sudo apt install nginx -y
sudo systemctl start nginx
sudo systemctl enable nginx

Sahkan Nginx sedang berjalan:

sudo systemctl status nginx

5. Pasang MySQL

Pasang pelayan MySQL:

sudo apt install mysql-server -y
sudo systemctl start mysql
sudo systemctl enable mysql

Lindungi pemasangan MySQL anda:

sudo mysql_secure_installation

Ikuti gesaan untuk menetapkan kata laluan akar dan alih keluar tetapan lalai yang tidak selamat.

6. Pasang PHP

Kami akan memasang PHP 8.1 (atau versi stabil terkini yang tersedia dalam repositori Ubuntu):

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

Sahkan pemasangan PHP:

php -v

7. Pasang Git

Pasang Git untuk kawalan versi:

sudo apt install git -y

Sahkan pemasangan Git:

git --version

8. Konfigurasikan Nginx

Buat konfigurasi blok pelayan Nginx baharu:

sudo nano /etc/nginx/sites-available/your_domain

Tambah konfigurasi berikut (ganti your_domain dengan domain atau alamat IP sebenar anda):

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

Dayakan tapak baharu:

sudo ln -s /etc/nginx/sites-available/your_domain /etc/nginx/sites-enabled/

Uji konfigurasi Nginx:

sudo nginx -t

Jika ujian berjaya, muat semula Nginx:

sudo systemctl reload nginx

9. Sediakan Direktori Laman Web Anda

Buat direktori akar web:

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. Klon Repositori Anda

Jika anda mempunyai repositori Git sedia ada untuk tapak web anda, klon ke dalam akar web anda:

cd /var/www/your_domain
git clone https://github.com/your-username/your-repo.git .

Gantikan https://github.com/your-username/your-repo.git dengan URL repositori sebenar anda.

Jika anda memulakan projek baharu, mulakan repositori Git baharu:

cd /var/www/your_domain
git init

11. Tetapkan Kebenaran Betul

Tetapkan kebenaran yang betul untuk fail web anda:

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

Untuk membenarkan pengguna Ubuntu mengurus fail:

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

Anda mungkin perlu log keluar dan log masuk semula untuk perubahan kumpulan berkuat kuasa.

12. Konfigurasikan PHP

Laraskan tetapan PHP jika perlu:

sudo nano /etc/php/8.1/fpm/php.ini

Tetapan biasa untuk dilaraskan:

upload_max_filesize = 64M
post_max_size = 64M
max_execution_time = 300
memory_limit = 256M

Selepas membuat perubahan, mulakan semula PHP-FPM:

sudo systemctl restart php8.1-fpm

13. Sediakan SSL (Pilihan tetapi Disyorkan)

Untuk melindungi tapak web anda dengan HTTPS, anda boleh menggunakan Let's Encrypt:

sudo apt install certbot python3-certbot-nginx -y
sudo certbot --nginx -d your_domain -d www.your_domain

Ikuti gesaan untuk menyediakan SSL.

14. Menyelesaikan masalah Isu Biasa

Kebenaran Ditolak Ralat

Jika anda menghadapi ralat "Kebenaran ditolak" dalam log ralat Nginx:

  1. Semak pemilikan fail:
   ls -l /var/www/your_domain
  1. Pastikan Nginx berjalan sebagai pengguna yang betul:
   ps aux | grep nginx
  1. Periksa konfigurasi Nginx:
   sudo nano /etc/nginx/nginx.conf

Pastikan pengguna ditetapkan kepada www-data.

Ralat PHP

Untuk ralat berkaitan PHP:

  1. Semak log PHP-FPM:
   sudo tail -f /var/log/php8.1-fpm.log
  1. Pastikan PHP-FPM berjalan:
   sudo systemctl status php8.1-fpm
  1. Sahkan fail soket PHP-FPM wujud:
   ls /var/run/php/php8.1-fpm.sock

Isu Git

Jika anda menghadapi masalah kebenaran Git:

  1. Ensure the .git directory is owned by your user:
   sudo chown -R ubuntu:ubuntu /var/www/your_domain/.git
  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

15. Best Practices and Security Considerations

  1. Regularly update your system and software:
   sudo apt update && sudo apt upgrade -y
  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
  1. Implement fail2ban to protect against brute-force attacks:
   sudo apt install fail2ban -y
   sudo systemctl start fail2ban
   sudo systemctl enable fail2ban
  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
  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.

Atas ialah kandungan terperinci Menyediakan Laman Web PHP pada ECith Nginx, MySQL, PHP dan Git. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!

Kenyataan:
Kandungan artikel ini disumbangkan secara sukarela oleh netizen, dan hak cipta adalah milik pengarang asal. Laman web ini tidak memikul tanggungjawab undang-undang yang sepadan. Jika anda menemui sebarang kandungan yang disyaki plagiarisme atau pelanggaran, sila hubungi admin@php.cn