Saya telah memperhatikan bahwa beberapa DBA me-restart SQL Server sangat sering, kadang-kadang bahkan setiap malam. Saya percaya mereka melakukannya untuk membebaskan memori, atau mungkin untuk mempercepat permintaan juga. Saya tahu bahwa setelah restart permintaan rencana harus dikompilasi ulang, tetapi bahkan termasuk bahwa saya bertanya-tanya apakah ada manfaat bersih untuk praktik ini.
Apakah benar me-restart SQL Server setiap hari membuatnya berjalan lebih cepat?
sumber
Sementara jawaban lain baik, mereka melewatkan bagian penting: cache file Windows.
Pada Windows 64-bit, tidak ada batasan untuk jumlah memori yang akan digunakan Windows untuk menyimpan file. Windows dapat menguras sistem Anda benar-benar kering memori, dan pada saat itu, Anda akan mulai bertukar ke disk. Sudah didokumentasikan di beberapa tempat:
Dengan me-restart SQL Server, Anda memaksa SQL untuk menyerah memori, sehingga membiarkan Windows mendapatkan lebih banyak, dan paging berhenti sementara. SQL akan mulai lagi pada penggunaan memori mendekati nol dan secara bertahap naik, dan ketika kotak kehabisan memori lagi, restart akan membantu sementara. Dengan me-restart seluruh OS, Anda juga akan memaksa penggunaan file cache Windows.
Cara mengatasinya: hentikan menyalin file dari server Windows atau membatasi jumlah cache file yang digunakan dengan Layanan Cache File Dinamis seperti yang didokumentasikan dalam posting blog di atas.
sumber
Jika mempercepat kueri, sniffing parameter mungkin terlibat. Jika rencana omong kosong di-cache dan diterapkan pada panggilan berikutnya yang tidak sesuai, maka keajaiban rebooting memungkinkan rencana umum / benar untuk di-cache. Jika itu masalahnya, ada cara yang jauh lebih baik untuk memperbaiki perilaku seperti yang telah ditunjukkan oleh orang lain. Tetapi sampai mereka berhenti me-reboot kotak, tidak ada cara untuk melakukan analisis akar penyebab.
sumber
Anda seharusnya tidak me-restart SQL Server kecuali Anda telah mengubah properti layanan atau mengatur jejak startup yang Anda ingin segera lakukan.
Sebagai @RemusRusanu telah menyatakan banyak poin, ia membersihkan banyak cache dan menyebabkan SQL Server melakukan banyak pekerjaan startup yang tidak perlu .
Sepertinya server ini bukan SQL Server / database server khusus. Ini adalah praktik terbaik untuk memiliki server basis data produksi yang hanya memiliki satu tujuan ... untuk menjadi server basis data. Dalam hal ini, Anda akan menyisihkan cukup memori dan sumber daya untuk OS dan memberikan segalanya untuk SQL Server. Ini akan membuat Anda tidak kelaparan aplikasi lain atau peran server.
sumber
Saya setuju dengan sentimen bahwa jika Anda melakukan semuanya dengan benar, maka Anda mungkin tidak perlu me-Reboot / Restart MSSQL Server Anda.
Bagi saya ini berlaku untuk skenario di mana semua orang kompeten dan Anda dapat memperbaiki apa pun.
Saya bukan DBA. Saya seorang Arsitek Perangkat Lunak dan bagian dari itu melibatkan pembangunan seluruh Skema Basis Data dari awal dan, sayangnya , bekerja dengan Basis Data Pihak ke-3 yang sama sekali TIDAK saya kendalikan.
Orang-orang, yang menciptakan dan memelihara salah satu dari Database Pihak ke-3 utama kami, hampir tidak membuatnya berfungsi.
Apakah saya menyebutkan saya juga bukan Pakar Keamanan atau Insinyur Jaringan?
Bagi saya pertanyaannya kemudian menjadi: Haruskah saya Restart SQL Server lebih sering daripada setiap 3 bulan?
Penjadwalan Menghidupkan kembali janji kinerja ekstra, seperti menari untuk hujan.
Mungkin itu akan datang, mungkin tidak, tetapi Anda tidak akan tahu pasti apa yang menyebabkan hujan.
Saya tidak suka mengatakan Anda tidak pernah perlu Restart untuk memecahkan masalah atau memverifikasi failover, tapi saya lakukan memiliki masalah dengan Restart penjadwalan untuk menjaga masalah kinerja yang tidak diketahui dari acak terjadi.
Satu- satunya pengecualian untuk hal ini adalah jika Anda mengelola Basis Data Pihak Ketiga yang nakal tempat me-reboot-nya setiap minggu atau dua tampaknya menjadi satu-satunya cara untuk membuatnya beroperasi dan Anda tidak diizinkan untuk memperbaikinya atau bahkan menyentuhnya.
Bahkan saat itu, Anda harus mencari perbaikan, membaginya dengan pemilik, dan membangkitkan neraka sampai selesai.
sumber