Apabila membangunkan aplikasi menggunakan rangka kerja Laravel, ia selalunya melibatkan interaksi dengan pangkalan data. Walau bagaimanapun, dalam beberapa kes khas, kami mungkin menghadapi masalah tamat masa pangkalan data. Pada masa ini, anda perlu membuat beberapa tetapan untuk sambungan pangkalan data rangka kerja Laravel untuk mengelakkan tamat masa. Artikel ini akan memperkenalkan anda kepada cara menetapkan tamat masa untuk sambungan pangkalan data dalam rangka kerja Laravel.
1. Sambungan pangkalan data dalam rangka kerja Laravel
Dalam rangka kerja Laravel, kita boleh menyambung ke pelbagai jenis pangkalan data dengan menggunakan kelas IlluminateDatabaseDatabaseManager. Kelas ini ialah kelas utama yang digunakan dalam rangka kerja Laravel untuk mengurus sambungan pangkalan data.
Dalam rangka kerja Laravel, kita boleh menggunakan kaedah berikut untuk mendapatkan jenis sambungan pangkalan data yang berbeza:
Dalam rangka kerja Laravel, kami boleh menentukan maklumat konfigurasi sambungan pangkalan data yang berbeza dalam fail config/database.php. Sebagai contoh, berikut ialah contoh konfigurasi sambungan pangkalan data MySQL:
'mysql' => [ 'driver' => 'mysql', 'host' => env('DB_HOST', '127.0.0.1'), 'port' => env('DB_PORT', '3306'), 'database' => env('DB_DATABASE', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'unix_socket' => env('DB_SOCKET', ''), 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', 'strict' => true, 'engine' => null, ],
Dalam maklumat konfigurasi ini, kami boleh menetapkan parameter sambungan pangkalan data yang berbeza, seperti: alamat IP pelayan pangkalan data, nombor port, nama pangkalan data, nama pengguna, kata laluan, dsb.
2. Masalah tamat masa sambungan pangkalan data
Dalam sesetengah kes, kami mungkin menghadapi masalah tamat masa sambungan pangkalan data. Keadaan ini biasanya berlaku apabila pangkalan data tidak bertindak balas untuk masa yang lama atau terdapat masalah dengan sambungan rangkaian. Apabila sambungan pangkalan data tamat, aplikasi kami mungkin mengalami ralat atau ranap. Oleh itu, kita perlu membuat beberapa tetapan untuk sambungan pangkalan data dalam rangka kerja Laravel untuk mengelakkan tamat masa.
3. Penyelesaian kepada tamat masa sambungan pangkalan data
Dalam rangka kerja Laravel, kita boleh menetapkan tempoh tamat masa untuk sambungan pangkalan data dengan mengubah suai maklumat konfigurasi dalam fail config/database.php.
Kami boleh menetapkan tamat masa sambungan dalam maklumat konfigurasi sambungan pangkalan data tunggal. Sebagai contoh, kita boleh menetapkan parameter 'connect_timeout' dalam konfigurasi sambungan pangkalan data MySQL untuk menetapkan tamat masa sambungan:
'mysql' => [ 'driver' => 'mysql', 'host' => env('DB_HOST', '127.0.0.1'), 'port' => env('DB_PORT', '3306'), 'database' => env('DB_DATABASE', 'forge'), 'username' => env('DB_USERNAME', 'forge'), 'password' => env('DB_PASSWORD', ''), 'unix_socket' => env('DB_SOCKET', ''), 'charset' => 'utf8mb4', 'collation' => 'utf8mb4_unicode_ci', 'prefix' => '', 'strict' => true, 'engine' => null, 'options' => [ PDO::ATTR_TIMEOUT => 5, PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, PDO::ATTR_PERSISTENT => false, PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES 'utf8mb4', time_zone = '+08:00'", PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT => false, PDO::MYSQL_ATTR_READ_DEFAULT_FILE => '/usr/local/etc/my.cnf', ], ],
Dalam maklumat konfigurasi ini, kami menetapkan nilai parameter PDO::ATTR_TIMEOUT kepada 5 detik. Ini bermakna jika sambungan mengambil masa lebih lama daripada 5 saat, rangka kerja Laravel akan membuang ralat tamat masa sambungan.
Kami juga boleh menetapkan tamat masa untuk semua sambungan pangkalan data dalam fail config/database.php. Sebagai contoh, kami boleh menambah kod berikut:
'options' => [ PDO::ATTR_TIMEOUT => 5, PDO::ATTR_ERRMODE => PDO::ERRMODE_EXCEPTION, PDO::ATTR_DEFAULT_FETCH_MODE => PDO::FETCH_ASSOC, PDO::ATTR_PERSISTENT => false, PDO::MYSQL_ATTR_INIT_COMMAND => "SET NAMES 'utf8mb4', time_zone = '+08:00'", PDO::MYSQL_ATTR_SSL_VERIFY_SERVER_CERT => false, PDO::MYSQL_ATTR_READ_DEFAULT_FILE => '/usr/local/etc/my.cnf', ],
Dalam maklumat konfigurasi ini, kami juga menetapkan nilai parameter PDO::ATTR_TIMEOUT kepada 5 saat. Ini bermakna tidak kira sambungan pangkalan data mana yang digunakan, tamat masa sambungan mereka ialah 5 saat. Tetapan ini memudahkan untuk mengurus semua sambungan pangkalan data dengan cara yang bersatu dan mudah untuk diselenggara.
4. Ringkasan
Dalam rangka kerja Laravel, masalah tamat masa sambungan pangkalan data adalah masalah yang sangat biasa. Untuk mengelakkan masalah ini berlaku, kita boleh menyelesaikan masalah ini dengan menetapkan tempoh tamat masa sambungan pangkalan data. Sudah tentu, kami juga boleh menggunakan kaedah lain untuk mengoptimumkan sambungan pangkalan data rangka kerja Laravel, seperti menggunakan kumpulan sambungan dan cara teknikal lain. Tidak kira kaedah yang digunakan, kami boleh mengurus dan mengoptimumkan sambungan pangkalan data rangka kerja Laravel dengan lebih baik, dengan itu meningkatkan prestasi dan kestabilan aplikasi.
Atas ialah kandungan terperinci tetapan masa tamat db rangka laravel. Untuk maklumat lanjut, sila ikut artikel berkaitan lain di laman web China PHP!