Rumah  >  Artikel  >  rangka kerja php  >  tetapan masa tamat db rangka laravel

tetapan masa tamat db rangka laravel

WBOY
WBOYasal
2023-05-29 09:50:071402semak imbas

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:

  1. DB::connection('connection_name'): Dapatkan sambungan pangkalan data dengan nama tertentu.
  2. DB::getPdo(): Dapatkan contoh PDO yang sedang digunakan.
  3. DB::table('table_name'): Dapatkan contoh pembina pertanyaan bagi jadual data yang ditentukan.

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.

  1. Tetapan tamat masa untuk sambungan pangkalan data tunggal

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.

  1. Tetapan tamat masa untuk semua sambungan pangkalan data

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!

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