Αυτή είναι μια από τις δημοφιλέστερες ερωτήσεις σχετικά με τον SQL Server. Ποιά είναι όμως η απάντησή της;
Όλοι θα ήμασταν ευτυχισμένοι αν υπήρχε μια εξίσωση όπου λύνοντας την θα είχαμε το αποτέλεσμα που επιθυμούμε. Δεν είναι όμως έτσι τα πράγματα, όπως και πολλά, σχεδόν τα περισσότερα στον SQL Server. Κάθε server έχει διαφορετικές ανάγκες καθώς έχει και διαφορετικό process load.
Αυτό που μπορούμε να κάνουμε όμως είναι να ξεκινήσουμε από μια καλή βάση και με monitoring στην μνήμη του server θα κουρδίσουμε σωστά την μνήμη του.
Όλοι γνωρίζουμε ότι το mix & max server memory στον SQL Server ορίζει την buffer cache του. Όμως ο SQL Server πατάει σε ένα λειτουργικό που και αυτό θέλει την μνήμη του και πιθανότατα σε αυτόν τον server να εκτελούνται και άλλα processes πχ antivirus, storage daemons κλπ.
Πως ξεκινάμε...
Αυτό που όλοι κάνουμε σε ένα SQL Server που δεν γνωρίζουμε ακριβώς το process load του είναι να εφαρμόζουμε την παρακάτω μέθοδο.
Από την διαθέσιμη μνήμη που έχει ο server(μηχανή)
- Αφαιρούμε 1 GB για το λειτουργικό (OS)
- Για κάθε 4GB μετά τα πρώτα 4 GB και μέχρι τα 16GB αφαιρούμε 1GB
- Για κάθε 8GB μετά τα 16B αφαιρούμε 1GB
Αυτό που μένει το βάζουμε στο max server memory του SQL Server.
Παράδειγμα
Για παράδειγμα αν έχω μια μηχανή που έχει 64GB μνήμη τότε υπολογίζουμε
- 1GB για το OS
- 3GB για τα 4-16GB
- 6GB για τα 16-64GB
Το σύνολο των παραπάνω μας κάνει 10GB άρα στο max server memory βάζουμε 54GB και κάνουμε monitoring τον Memory\Available Mbytes performance counter σε συνδυασμό με του Total Server Memory & Target Server Memory performance counters.
Keep rocking
/*antonch*/