Sqlserver
 sql >> Cơ Sở Dữ Liệu >  >> RDS >> Sqlserver

Bạn có đang đo hiệu suất máy chủ SQL bằng các số liệu này không?

Hiệu suất ứng dụng và hệ thống đóng một vai trò rất lớn trong cách người dùng cảm nhận giá trị của sản phẩm và năng lực của công ty bạn. Nếu cùng một trang liên tục hết thời gian chờ hoặc mất nhiều thời gian để truy cập một báo cáo quan trọng, hiệu suất của hệ thống cơ sở dữ liệu sẽ tạo ra vấn đề về độ tin cậy cho tổ chức của bạn.

Tính khả dụng cao và hiệu suất đáng tin cậy là chìa khóa để giữ cho khách hàng và người dùng hệ thống nội bộ hài lòng và thậm chí chúng có thể ảnh hưởng đến lợi nhuận của bạn. Với những mục tiêu này, việc triển khai chiến lược giám sát hiệu suất SQL Server toàn diện là điều bắt buộc.

Lợi ích của việc giám sát hiệu suất máy chủ SQL

Lợi ích được giới thiệu phổ biến nhất của việc giám sát hiệu suất là dễ dàng khắc phục sự cố và giải quyết các vấn đề. Một công cụ giám sát SQL Server được cấu hình tốt là phương tiện hiệu quả nhất để tìm và khắc phục các sự cố máy chủ và cơ sở dữ liệu một cách nhanh chóng trước khi chúng ảnh hưởng đến người dùng cuối hoặc trở thành các vấn đề lớn, tốn kém.

Ngoài việc duy trì tình trạng hệ thống, việc triển khai giám sát hiệu suất SQL Server có thể giúp giảm chi phí cơ sở hạ tầng của bạn. Một ví dụ là chi phí lưu trữ không cần thiết. Khi hiệu suất SQL Server được tối ưu hóa, tốc độ tăng kích thước tệp được theo dõi liên tục. Kích thước tệp tăng quá mức sẽ kích hoạt một cảnh báo để sự cố có thể được giải quyết trước khi dung lượng ổ đĩa bị cạn và các tài nguyên bổ sung được đưa vào khi sự cố xảy ra.

Và nếu bạn chọn giải pháp giám sát dựa trên đám mây, bạn có thể tăng ROI hơn nữa bằng cách tạm biệt chi phí nhà ở và duy trì máy chủ vật lý.

Theo dõi các chỉ số này để cải thiện hiệu suất máy chủ SQL của bạn

Chúng tôi biết giám sát hiệu suất SQL Server là một chiến lược tuyệt vời để khắc phục sự cố và tiết kiệm tiền, nhưng bạn sẽ không nhận được đầy đủ lợi ích từ công cụ giám sát SQL Server của mình trừ khi bạn theo dõi các chỉ số phù hợp. Để có được hiệu suất tối ưu từ SQL Server, đây là năm lĩnh vực bạn sẽ muốn xem và các chỉ số quan trọng nhất cần theo dõi từ mỗi lĩnh vực.

1. Bộ đệm đệm

Bộ đệm đệm lưu trữ các bản sao của các trang cơ sở dữ liệu được sử dụng gần đây. SQL Server tìm kiếm trong bộ nhớ cache trước tiên, nhưng nếu nó không tìm thấy những gì nó đang tìm kiếm ở đó, nó sẽ đi vào đĩa. Đọc từ đĩa chậm, có thể ảnh hưởng tiêu cực đến hiệu suất.

Tỷ lệ truy cập bộ nhớ cache

Tỷ lệ truy cập bộ nhớ cache cho biết tần suất SQL Server truy cập các trang từ bộ nhớ cache. Giá trị cao hơn chỉ ra rằng các trang được truy cập từ bộ nhớ chứ không phải từ đĩa. Nếu bạn thường xuyên thấy tỷ lệ truy cập bộ nhớ cache thấp, hãy kiểm tra nút cổ chai trong bộ nhớ hệ thống.

Kỳ vọng về tuổi thọ của trang

Theo dõi tuổi thọ của trang cho biết thời gian một trang nằm trong bộ nhớ thay vì chuyển sang đĩa. Tuổi thọ trang càng dài, tỷ lệ truy cập bộ nhớ cache càng tốt.

Các trang / giây của trạm kiểm soát

SQL Server thiết lập các điểm kiểm tra để giải phóng dung lượng trong bộ đệm đệm bằng cách chuyển định kỳ các trang đã sửa đổi từ bộ đệm vào đĩa. Số lượng trang bị xóa phụ thuộc vào cài đặt cấu hình và việc sử dụng máy chủ, vì vậy điều quan trọng là phải đặt đường cơ sở để so sánh. Nếu bạn nhận thấy ngày càng nhiều trang bị xóa, bạn có thể gặp sự cố I / O.

2. Chỉ mục

Chỉ mục cơ sở dữ liệu giúp tăng tốc hoạt động trong các bảng có nhiều bản ghi. Mặc dù chỉ mục là một công cụ hữu ích để cải thiện một số chức năng cơ sở dữ liệu, nhưng có những vấn đề cố hữu với chỉ mục có thể làm giảm hiệu suất nếu không được nắm bắt nhanh chóng.

Phân mảnh

Phân mảnh chỉ mục xảy ra khi các bản ghi được thêm và xóa. Theo thời gian, những thay đổi này gây ra các vấn đề về hiệu suất do để lại quá nhiều khoảng trống trên quá nhiều trang và thêm các trang mới không theo thứ tự. Điều này có thể làm chậm quá trình quét và sử dụng quá nhiều bộ nhớ.

Theo dõi phân mảnh chỉ mục sẽ cho bạn biết khi nào bạn cần chạy Xây dựng lại hoặc Tổ chức lại trên một chỉ mục để khắc phục sự phân mảnh và cải thiện hiệu suất.

Hệ số lấp đầy và Tách trang

Cài đặt hệ số lấp đầy cho phép các chỉ mục của bạn biết mỗi trang phải đầy như thế nào. Nếu một trang quá đầy, sẽ xảy ra hiện tượng tách trang; nếu một trang không đủ đầy, bạn đang lãng phí tài nguyên.

Việc theo dõi phân chia trang có thể giúp xác định khi nào cần điều chỉnh hệ số lấp đầy. Để có hiệu suất tốt nhất, không đặt giá trị hệ số lấp đầy trên toàn hệ thống. Đánh giá các chỉ số riêng lẻ và đặt hệ số lấp đầy ở mức thích hợp cho từng chỉ số.

3. T-SQL

Để tối ưu hóa hiệu suất, SQL Server phân lô các câu lệnh SQL, sau đó biên dịch chúng thành các kế hoạch thực thi và lưu vào bộ nhớ cache để sử dụng lại. Nếu SQL Server không thể sử dụng lại kế hoạch thực thi, thì kế hoạch này sẽ được biên dịch lại, điều này sử dụng nhiều CPU và làm giảm hiệu suất. Do đó, tốt nhất là giữ cho số lượng biên dịch lại câu lệnh SQL càng thấp càng tốt.

Việc giám sát tốc độ biên dịch và biên dịch lại SQL sẽ cho thấy liệu bạn có cần phải cấu hình lại một số khu vực, chẳng hạn như các thủ tục được lưu trữ và các tham số truy vấn hay không.

4. Chặn

Việc chặn SQL Server là do nhiều máy khách và quy trình yêu cầu quyền truy cập vào cùng một tài nguyên cùng một lúc. Nếu một tài nguyên đã được sử dụng, quyền truy cập sẽ bị khóa và tài nguyên đó không khả dụng cho các yêu cầu tiếp theo. Điều này đặt quá trình ở trạng thái chờ cho đến khi tài nguyên được giải phóng và khả dụng trở lại.

Khóa Chờ

Các yêu cầu thường không phải đợi khi có khóa, vì vậy chỉ số này sẽ ở quanh mức 0. Số lần chờ khóa tăng lên cho thấy có vấn đề với thời gian tải, vì vậy bạn cần phải tìm ra nguyên nhân gốc rễ của vấn đề.

Các quy trình bị chặn

Theo dõi các quy trình bị chặn là một cách tốt để tránh nhiều email thông báo cho bạn về một quy trình bị chặn. Sử dụng SQL Server Profiler để nắm bắt dữ liệu về các quy trình bị chặn và xem xét báo cáo thường xuyên.

5. Sử dụng tài nguyên

Theo dõi các chỉ số sử dụng tài nguyên là một cách hiệu quả không chỉ để xác định các vấn đề về hiệu suất mà còn giúp lập kế hoạch năng lực.

Số lượng hàng

Theo dõi số lượng hàng cung cấp thông tin chi tiết trực tiếp, có thể theo dõi dễ dàng về khối lượng dữ liệu được liên kết với một bảng nhất định theo thời gian. Số hàng tăng hoặc giảm bất ngờ sẽ thúc đẩy một cuộc điều tra về nguyên nhân.

I / O Tệp Cơ sở dữ liệu

Bằng cách đo lường các chỉ số I / O dựa trên các tệp cơ sở dữ liệu, bạn có thể theo dõi lượng dữ liệu đang được ghi và đọc bởi bất kỳ tệp dữ liệu nhất định nào. Nếu bạn quan sát thấy một vấn đề tiềm ẩn, số liệu này có thể giúp thu hẹp nguyên nhân gốc rễ. Theo dõi I / O tệp cơ sở dữ liệu cũng giúp lập kế hoạch cơ sở hạ tầng vì nó có thể giúp bạn dự đoán thông lượng dữ liệu trong tương lai và điều chỉnh tài nguyên cho phù hợp.

Kích thước sao lưu nhật ký giao dịch

Khi máy chủ gặp sự cố vì quá tải, SQL Server sử dụng các bản ghi nhật ký cơ sở dữ liệu được lưu trữ trong các tệp nhật ký ảo (VLF) để khôi phục. Điều quan trọng là phải theo dõi có bao nhiêu VLF trong nhật ký giao dịch, vì quá nhiều có thể làm chậm quá trình khôi phục khi khôi phục sau khi ngừng hoạt động.

Giám sát hiệu suất SQL Server là một thành phần quan trọng trong chiến lược kiểm soát chất lượng của tổ chức. Theo dõi một số chỉ số hiệu suất chính có thể mang lại cho bạn danh tiếng về việc cung cấp cho người dùng của bạn một hệ thống mà họ có thể tin tưởng và dựa vào; nếu không làm như vậy có thể khiến hệ thống của bạn chỉ là một ứng dụng có lỗi khác mà người dùng sợ hãi.


  1. Database
  2.   
  3. Mysql
  4.   
  5. Oracle
  6.   
  7. Sqlserver
  8.   
  9. PostgreSQL
  10.   
  11. Access
  12.   
  13. SQLite
  14.   
  15. MariaDB
  1. Chèn hàng loạt tệp dữ liệu vào máy chủ SQL

  2. DATEPART () Ví dụ trong SQL Server

  3. Tại sao kết nối ODBC của tôi không thành công khi chạy tải SSIS trong Visual Studio nhưng không phải khi chạy cùng một gói sử dụng Tiện ích gói thực thi

  4. Cách cập nhật thống kê máy chủ SQL cho bảng lớn

  5. Tôi có thể sử dụng nhiều con trỏ trên một kết nối với pyodbc và MS SQL Server không?