Cara menggunakan kill all proses php
Halo semuanya, pernahkah anda mengalami kondisi pada server MySQL dimana banyak proses yang berada dalam status sleep? . Beberapa hari yang lalu saya mengalami kondisi yang membuat operasional aplikasi web menjadi terhambat. Penumpukan proses yang berada dalam status sleep dapat meningkatkan penggunaan CPU dan sumber daya memori lainnya, sehingga memperlambat kinerja server. Proses dengan status tidur biasanya terjadi ketika sesi mysql tidak ditutup dengan benar. Banyak kasus yang dapat memicu hal tersebut, jika pada kasus di server saya yang memicu penumpukan proses status sleep adalah ketika aplikasi/program gagal mengolah data dari mysql, sehingga sesi mysql tidak dapat ditutup dengan baik dan menjadi status sleep proses. Jika hal seperti itu terjadi, kita perlu mematikan proses yang berstatus tidur. Jika tidak (secara default) proses dengan status tidur hanya akan ditutup setelah 28800 detik atau 8 jam. Untuk mempermudah, saya membuat script yang fungsinya mematikan proses sleep mysql secara otomatis yang saya jadwalkan di cronjob. Berikut cara membuatnya Show
1. Buat file sql untuk menghasilkan query kill mysql sleep processPertama-tama, kami membuat file sql untuk menghasilkan kueri untuk menghentikan proses tidur mysql, misalnya saya beri nama create_kill_query. sql (Anda bebas memberikan nama apa saja)
Untuk pathnya anda bisa custom dimana anda ingin meletakkannya, setelah itu isikan kode dibawah ini select concat('KILL ',id,';') as '# kill this' from information_schema.processlist where Command = 'Sleep' and Time > '30'; 2. Buat file shellscript untuk mematikan proses tidur mysqlKedua, buat file shellscript, misalnya saya beri nama kill_mysql_sleep_process. sh (Anda bebas memberikan nama apa pun yang Anda inginkan)
Untuk pathnya anda bisa custom dimana anda ingin meletakkannya, setelah itu isikan kode dibawah ini #!/bin/bash USER="yourUser" PASSWORD="yourPassword" HOST="yourIpHost" cat /dev/null > /usr/local/sbin/kill_query.sql && mysql -u $USER -p$PASSWORD -h $HOST < /usr/local/sbin/check_kill_query.sql > /usr/local/sbin/kill_query.sql && cat /usr/local/sbin/kill_sleep_query.sql > /var/log/mysql_kill_sleep_query.log && mysql -u $USER -p$PASSWORD -h $HOST < /usr/local/sbin/kill_query.sql && ( echo "`date` === Sleep query has been killed" && echo "================================================") >> /var/log/mysql_kill_sleep_query.log 2>&1_ Dalam skrip shell yang saya buat ini, saya mencatat prosesnya di log yang saya tempatkan di
3. Buat cronjob untuk dijalankan secara otomatisTerakhir kita tinggal mengatur agar cronjob berjalan otomatis pada waktu yang kita inginkan, berikut saya berikan contoh agar cronjob berjalan otomatis setiap 30 menit sekali pada jam 08. 00 – 17. 00 setiap hari. Pertama, kita buka editor cronjob
lalu jadwalkan waktu untuk menjalankan skrip shell seperti ini
setelah itu simpan. Jadi setiap 30 menit sekali pada jam 8 pagi. 00 – 17. 00 cronjob akan menjalankan shellscript untuk menghentikan proses tidur mysql secara otomatis. Untuk aturan cronjob lainnya, Anda dapat membaca artikel saya tentang cronjob pada Aturan CronJob Nah itulah sedikit informasi yang dapat saya bagikan, semoga informasi ini dapat bermanfaat, Terimakasih 😀 Penanganan sesi adalah konsep kunci dalam PHP yang memungkinkan informasi pengguna dipertahankan di semua halaman situs web atau aplikasi. Dalam posting ini, Anda akan mempelajari dasar-dasar penanganan sesi di PHP Kami akan mulai dengan penjelasan tentang cara kerja sesi dan bagaimana kaitannya dengan cookie. Kemudian kita akan melihat beberapa cuplikan kode yang mendemonstrasikan cara bekerja dengan sesi. Anda akan belajar cara membuat dan menghancurkan sesi, dan cara mengubah variabel sesi Cookie vs. Variabel SesiTidak yakin apakah Anda memerlukan cookie atau variabel sesi? . Cookie adalah cara untuk menyimpan data tentang pengguna di komputer pengguna. Variabel sesi biasanya digunakan dalam aplikasi yang perlu melacak aktivitas pengguna. Cookie biasanya digunakan dalam aplikasi yang perlu menyimpan informasi tentang pengguna untuk satu situs Anda juga dapat mempelajari tentang variabel sesi di postingan saya tentang penggunaan cookie di PHP
Apa itu Sesi di PHP?Sesi adalah mekanisme untuk mempertahankan informasi di berbagai halaman web untuk mengidentifikasi pengguna saat mereka membuka situs atau aplikasi. Apakah Anda bertanya-tanya mengapa sesi diperlukan untuk situs web? Protokol HTTP adalah protokol tanpa kewarganegaraan, yang berarti tidak mungkin server dapat mengingat pengguna tertentu di antara banyak permintaan. Misalnya, ketika Anda mengakses halaman web, server hanya bertanggung jawab untuk menyediakan konten halaman yang diminta. Jadi, ketika Anda mengakses halaman lain dari situs web yang sama, server web menginterpretasikan setiap permintaan secara terpisah, seolah-olah tidak terkait satu sama lain. Tidak ada cara bagi server untuk mengetahui bahwa setiap permintaan berasal dari pengguna yang sama Diagram berikut menggambarkan protokol HTTP secara singkat Dalam model ini, jika Anda ingin menampilkan informasi khusus pengguna, Anda harus mengautentikasi pengguna di setiap permintaan. Bayangkan jika Anda harus mengetikkan username dan password di setiap halaman yang menampilkan informasi profil Anda. Ya, itu akan merepotkan dan tidak praktis sama sekali, dan di situlah sesi muncul Sesi memungkinkan Anda untuk berbagi informasi di berbagai halaman dari satu situs atau aplikasi—sehingga membantu mempertahankan status. Ini memungkinkan server mengetahui bahwa semua permintaan berasal dari pengguna yang sama, sehingga memungkinkan situs untuk menampilkan informasi dan preferensi khusus pengguna Alur Masuk Dengan Sesi dan CookieMari kita segera melalui alur login umum untuk sebuah situs web guna memahami apa yang terjadi di balik layar
Dengan cara ini, data pengguna disimpan di beberapa permintaan, dan pengguna tetap masuk selama satu sesi Diagram berikut menggambarkan bagaimana protokol HTTP bekerja dengan sesi Sekarang setelah Anda melihat pengantar singkat tentang cara kerja sesi, kami akan membuat beberapa contoh praktis untuk menunjukkan cara membuat dan memanipulasi variabel sesi Cara Memulai SesiPada bagian ini, kita akan membahas cara memulai sesi di PHP Setiap kali Anda ingin berurusan dengan variabel sesi, Anda perlu memastikan bahwa sesi sudah dimulai. Ada beberapa cara untuk memulai sesi di PHP Gunakan Fungsi 3_53Ini adalah metode yang paling sering Anda lihat, di mana sesi dimulai oleh fungsi _______2_______53 1
2 // start a session
3 session_start(); 4 5 // manipulate session variables
0
1Yang penting adalah fungsi 3_53 harus dipanggil di awal skrip, sebelum keluaran apa pun dikirim ke browser. Jika tidak, Anda akan menemukan kesalahan ________2______56 yang terkenal Mulai Sesi Secara OtomatisJika ada kebutuhan untuk menggunakan sesi di seluruh aplikasi Anda, Anda juga dapat ikut serta untuk memulai sesi secara otomatis tanpa menggunakan fungsi _______2_______53 Ada opsi konfigurasi di php. file ini yang memungkinkan Anda memulai sesi secara otomatis untuk setiap permintaan— 358. Secara default, ini disetel ke _______2_______59, dan Anda dapat menyetelnya ke _______2_______60 untuk mengaktifkan fungsi mulai otomatis 1
3Di sisi lain, jika Anda tidak memiliki akses ke php. file ini, dan Anda menggunakan server web Apache, Anda juga dapat menyetel variabel ini menggunakan. file htaccess 1
5Jika Anda menambahkan baris di atas di. htaccess, yang akan memulai sesi secara otomatis di aplikasi PHP Anda Cara Mendapatkan Id SesiSeperti yang telah kita bahas sebelumnya, server membuat nomor unik untuk setiap sesi baru. Jika Anda ingin mendapatkan session id, Anda dapat menggunakan fungsi _______2_______61, seperti yang ditunjukkan pada cuplikan berikut 1
2 session_start(); 3 21 4
1Itu akan memberi Anda id sesi saat ini. Fungsi 3_61 menarik karena dapat mengambil satu argumen—id sesi. Jika Anda ingin mengganti id sesi yang dihasilkan sistem dengan id Anda sendiri, Anda dapat memberikannya ke argumen pertama dari fungsi _______2_______61 1
2 27 3 session_start(); 4
1Penting untuk diperhatikan bahwa fungsi _______2________61 harus ditempatkan sebelum panggilan _______2_______53 saat Anda ingin memulai sesi dengan id sesi khusus Cara Membuat Variabel SesiPada bagian ini, kita akan mengeksplorasi cara menginisialisasi variabel sesi di PHP Seperti yang telah kita bahas sebelumnya, setelah sesi dimulai, array super-global 352 diinisialisasi dengan informasi sesi yang sesuai. Secara default, ini diinisialisasi dengan larik kosong, dan Anda dapat menyimpan lebih banyak informasi dengan menggunakan key-value pair Mari kita lihat skrip contoh berikut yang menunjukkan cara menginisialisasi variabel sesi 1
2 // start a session
3 session_start(); 4 5 31
033 34 35 36 38 39 session_start();0 session_start();1 session_start();15_______1 session_start();1________11 Seperti yang Anda lihat, kami telah memulai sesi di awal skrip menggunakan fungsi _______2_______53. Setelah itu, kami menginisialisasi beberapa variabel sesi. Akhirnya, kami telah mengakses variabel tersebut menggunakan 352 super-global Ketika Anda menyimpan data dalam sesi menggunakan _______2_______52 super-global, akhirnya disimpan dalam file sesi yang sesuai di server yang dibuat saat sesi dimulai. Dengan cara ini, data sesi dibagikan ke beberapa permintaan Seperti yang telah kita diskusikan, informasi sesi dibagikan di seluruh permintaan, dan dengan demikian variabel sesi yang diinisialisasi pada satu halaman juga dapat diakses dari halaman lain, hingga sesi berakhir. Umumnya, sesi berakhir saat browser ditutup Cara Memodifikasi dan Menghapus Variabel SesiAnda dapat memodifikasi atau menghapus variabel sesi yang dibuat sebelumnya dalam aplikasi dengan cara yang sama seperti variabel PHP biasa Mari kita lihat bagaimana memodifikasi variabel session 1
2 session_start(); 3 4 43 5 45
047 34 49 36 1 38 45 session_start();0 5 session_start();2 49 session_start();4 50 51 52
1Dalam skrip di atas, kami telah memeriksa apakah variabel _______2_______70 disetel di tempat pertama. Jika tidak disetel, kami akan menyetelnya ke _______2_______60, jika tidak, kami akan menambahnya dengan _______2_______60. Jadi, jika Anda me-refresh halaman ini beberapa kali, Anda akan melihat bahwa penghitung bertambah satu setiap kali. Di sisi lain, jika Anda ingin menghapus variabel sesi, Anda dapat menggunakan fungsi _______2_______73, seperti yang ditunjukkan pada cuplikan berikut 1
2 // start a session
3 session_start(); 4 5 // manipulate session variables
3
033 34 36 // manipulate session variables
938_______11_____1_____5______1______1______1 Dengan demikian, Anda tidak dapat lagi mengakses variabel _______2________74 karena telah dihapus oleh fungsi _______2_______73. Jadi begitulah cara Anda dapat mengubah informasi sesi Cara Menghancurkan SesiDi bagian ini, kita akan melihat bagaimana Anda dapat menghancurkan sebuah sesi. Pada bagian sebelumnya, kita membahas fungsi _______2________73, yang digunakan jika Anda ingin menghapus variabel sesi tertentu. Di sisi lain, jika Anda ingin menghapus semua data terkait sesi sekaligus, Anda dapat menggunakan fungsi _______2_______77 Fungsi 3_77 menghapus semua yang disimpan di sesi saat ini. Karena itu, itu tidak menghapus variabel global yang terkait dengan sesi atau menghapus cookie sesi Jadi jika Anda menggunakan fungsi _______2________77 untuk mengeluarkan pengguna, Anda harus menghapus variabel 352 dan menghapus cookie sesi juga. Jadi, cara yang disarankan untuk menghancurkan sesi sepenuhnya adalah 1
2 // start a session
3 session_start(); 4 5
13
034
1736
1938
21session_start();0
23session_start();2 49 session_start();4 50
2952
1Penangan SesiSejauh ini, kita telah membahas bagaimana Anda dapat melakukan operasi yang berbeda dengan variabel sesi. Pada bagian ini, kita akan membahas apa itu session handler dan bagaimana Anda dapat menggunakannya Handler sesi PHP adalah mekanisme yang menginstruksikan PHP bagaimana seharusnya mengelola sesi. Penangan sesi default adalah sistem file, dan itu berarti bahwa PHP menyimpan sesi pada disk. Pada dasarnya, ini adalah file kecil di server yang diasosiasikan dengan id sesi unik. Itu adalah id yang sama yang disimpan dalam cookie sesi di browser klien Penangan sesi default di PHP memberi Anda semua fitur yang diperlukan, tetapi terkadang Anda ingin menyimpan sesi secara berbeda. Misalnya, Anda mungkin ingin mengelola sesi di database, Redis, atau penyimpanan lainnya. Dalam hal ini, Anda perlu menerapkan penangan sesi khusus yang menggantikan perilaku default Untuk memahami cara kerja penangan sesi khusus, kami akan membahas secara singkat bagaimana Anda dapat mengimplementasikan penangan sesi database yang mengelola sesi dalam database MySQL Bagaimana Menerapkan Handler Sesi DatabaseDalam siklus hidup sesi PHP, ada tahapan yang berbeda seperti buka, baca, tulis, dan tutup. Selain itu, ada dua tahap lagi. menghancurkan dan pengumpulan sampah. Jadi, saat Anda menerapkan penangan sesi khusus, Anda harus menangani setiap tahapan ini untuk mengelola data sesi dengan benar Ada dua cara Anda dapat menerapkan penangan sesi khusus, Anda dapat menentukan fungsi panggilan balik untuk berbagai tahapan dalam siklus hidup sesi atau Anda dapat menulis kelas yang mengimplementasikan antarmuka 381. Dalam kedua kasus tersebut, Anda perlu menggunakan fungsi _______2________82 untuk menginisialisasi pengendali sesi khusus Anda. Dalam kasus kita, kita akan menggunakan implementasi interface _______2______81 Dalam contoh kami, kami akan menyimpan sesi di database MySQL. Jadi mari buat tabel yang menyimpan data sesi dengan menggunakan cuplikan berikut 1
332
353
374
395
41
0
43Selanjutnya, mari kita lihat bagaimana tampilan session handler custom database kita 1
2
473 45 4
515
0
5434
5636
5838
60session_start();0 session_start();2
63session_start();4
5650
6752
69
70
71
72
73
74
75
76
60
78
79
80
81
56
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97 Kelas penangan sesi khusus kami _______2________84 mengimplementasikan antarmuka _______2_______81. Oleh karena itu, ia harus mengimplementasikan metode yang dideklarasikan di antarmuka _______2______81. Kita akan melihat metode ini satu per satu untuk memahami cara kerjanya masing-masing 1
542
563
584
60Pertama, untuk menggunakan kode ini, pastikan untuk mengganti _______2_______87, _______2_______88, dan placeholder lainnya dengan nilai aktual dalam metode _______2_______89 1
632
563
674
695
71
0
7334
7_____11_______5____1Saat sesi dimulai, metode 3_90 dipanggil. Ini mengembalikan _______2________91 jika koneksi database berhasil. Jika ada masalah saat menyiapkan koneksi database, ia mengembalikan 392 1
802
563
844
865
88
0
9034
9236
9438
96session_start();0 session_start();2
99session_start();4 201 50 203 52
75
70
60Selanjutnya, PHP memanggil metode _______2________93 untuk membaca data sesi. Metode 3_93 menerima id sesi sebagai argumen pertama. Kami akan memeriksa apakah ada entri yang tersedia untuk id sesi ini di tabel _______2_______95. Jika ada, kami akan mengembalikan data sesi; 1 210 2
563
844 216 5 218
0
9034
9636 38
69session_start();0 201 session_start();2
73session_start();4
7550
60Ketika PHP perlu menyimpan atau menutup sesi, itu memanggil metode _______2_______96. Ini digunakan untuk menulis data sesi dalam database. Kami telah menggunakan sintaks _______2________97 untuk memastikan bahwa jika ada entri, itu akan diperbarui; 1 291 2
563 295 4
60Metode 3_98 dipanggil setelah metode sesi 396 dipanggil. Ia bekerja mirip dengan destruktor di kelas. Dalam kasus kami, tidak ada hal khusus yang perlu dilakukan dalam metode 398 1 236 2
563
844 242 5
88
0
9034
9636 38
69session_start();0 201 session_start();2
73session_start();4
7550
60Metode session_start();_01 dipanggil saat sesi dihancurkan dengan fungsi 377 atau session_start();03. Dalam metode ini, data sesi dihapus dari database jika ada 1 262 2
563 266 4 5
84
0271 34 273 36
9038
96session_start();0 session_start();2
69session_start();4 201 50
7352
75
70
60Saat PHP menjalankan pengumpul sampah secara berkala, metode session_start();04 dipanggil. Variabel session_start();_05 memegang nilai opsi konfigurasi session_start();06 di php. ini filenya. Dalam metode ini, kami akan menghapus semua sesi yang kedaluwarsa sebagai bagian dari proses pengumpulan sampah Menggunakan Kelas Handler Sesi MySQLSekarang, mari kita lihat bagaimana menggunakan kelas handler _______2______84 1 340 2 342 3 session_start(); 4 346 Seperti yang Anda lihat, kita hanya perlu menginisialisasi kelas 384 dan meneruskannya ke fungsi _______2_______82 untuk menginstruksikan PHP bahwa ia perlu menggunakan kelas _______2_______84 untuk manajemen sesi. Selanjutnya, kami memanggil fungsi _______2________53 untuk memulai sesi. Terakhir, kami telah menginisialisasi variabel sesi untuk tujuan pengujian Jika semuanya berjalan dengan baik, Anda akan melihat entri sesi di tabel _______15_______12 seperti yang ditunjukkan pada tangkapan layar berikut Dan dengan itu, Anda telah membuat penangan sesi khusus yang berfungsi yang mengelola sesi dalam database KesimpulanPada artikel ini, kami telah menjelajahi dasar-dasar penanganan sesi di PHP. Ini adalah konsep utama yang memungkinkan Anda menyimpan informasi di seluruh halaman web Di paruh pertama artikel, kami membahas konsep dasar sesi, dan selanjutnya kami membuat beberapa contoh PHP untuk mendemonstrasikan bagaimana Anda dapat membuat dan menghancurkan sesi serta memanipulasi variabel sesi. |