Cẩm nang NQDEV
HomeCheat SheetsContact
Công nghệ
Công nghệ
  • Introduction
  • Developer Roadmaps
    • Developer Roadmaps: Mô tả chi tiết
    • Roadmaps: ASP.NET Core Developer
    • Bảng phân loại cấp độ nhà phát triển .NET
    • ClearPath cho Team .NET Core
  • DotNET
    • ASP.NET Core
      • Hướng dẫn sử dụng tệp .http trong Visual Studio 2022 để thực hiện HTTP Requests
    • Message Queue
      • ZeroMQ
        • Xây dựng ZeroMQ Server trong dotNET 8 với CSharp
    • Playwright
      • Playwright: Tự Động Hóa Trình Duyệt Hiệu Quả
    • Optimize
      • Optimize - Một số cách tối ưu code và performance CSharp
    • Dev Blogs
      • Versions of .NET
        • Cập nhật từ .NET 9 lên .NET 10: Những thay đổi quan trọng
      • ASP.NET Core Web API với ASP.NET Core Web API (Native AOT): Bạn nên chọn loại nào?
      • Hướng dẫn xây dựng ứng dụng multi-tenant với .NET Core và MongoDB
      • Kiến Trúc Monolithic và Microservices: Lựa Chọn Phù Hợp Cho Dự Án Của Bạn
  • Design Patterns
    • CQRS Pattern
      • CQRS and MediatR trong .NET Core
    • Microservices
      • Ocelot
  • SQL Server
    • SQL Server Basics
    • SQL Server: DBCC
      • DBCC
      • DBCC SHOW_STATISTICS
      • DBCC SHRINKDATABASE
      • DBCC SHRINKFILE
      • DBCC SQLPERF
      • DBCC FREEPROCCACHE
    • SQL Server Replication
      • Giới thiệu SQL Server Replication
      • Hướng dẫn cấu hình và quản lý SQL Server Replication với Distribution Agent
    • SQL Server: Tập lệnh
      • SQL Server: Tập lệnh để tìm tất cả các giá trị Mặc định với Cột
    • Bảng tạm và sự linh hoạt trong xử lý dữ liệu lớn
    • Các bước để thay đổi nơi lưu trữ tệp log trong SQL Server
    • Các bước di chuyển tệp log trong SQL Server
    • Query Store trong SQL Server - Tổng Quan và Cách Quản Lý Hiệu Quả
    • SQL Server: Error Code
      • SQL Server Error : 14151, Severity: 18. Replication agent
  • Caching
    • Phân tích các phương pháp Caching dữ liệu trong .NET Core và .NET Framework
    • Redis
      • Redis mất dữ liệu khi restart
    • Varnish Cache
      • Hướng Dẫn Cài Đặt Varnish Cache với HAProxy Sử Dụng Docker Compose
  • NodeJS
    • NextJS
      • Hướng dẫn NextJS cho người mới bắt đầu
      • Parallel Routes trong Next.js
      • Hướng dẫn cấu hình Swagger trong NextJS
    • ReactJS
      • Hiểu về hook useRef của React như thế nào cho đúng
      • Tìm hiểu sâu hơn về useEffect từ A-Z
  • OS Linux
    • Tập lệnh Linux hay dùng
    • Centos 7
      • Hướng dẫn cài đặt và cấu hình Centos 7 dành cho người mới bắt đầu
      • Hướng Dẫn Kiểm Tra Các Cổng Đang Mở Trên Hệ Thống CentOS
      • Hướng Dẫn Sử Dụng zip Trên CentOS
      • Hướng dẫn cấu hình iptables để mở tất cả các cổng cho IP private
    • Windows
      • Hướng dẫn quản lý ứng dụng khởi động Windows bằng Registry Editor
  • VMware
    • Cách ảo hóa macOS Sierra trong VMWare Windows 10
    • Tự tin làm chủ mạng lưới: Cẩm nang tính toán địa chỉ IP từ A đến Z
  • Docker
    • Getting Started with Docker
    • Docker HUB
      • nqdev/nginx
  • Templates
    • Tabler Admin Template: Xây dựng Dashboard Quản trị đẹp mắt và dễ dàng
  • Open Source
    • shadcn-ui/ui
    • Kuma UI
    • Midone
  • Ứng dụng
    • Ansible
      • Ansible: Giới thiệu
      • Hướng dẫn chi tiết cài đặt Ansible
    • Apache JMeter
      • Features
        • Hướng dẫn chi tiết về Test Plan trong JMeter
        • Hướng dẫn chi tiết về Thread Group trong JMeter
    • DocFX
      • Những khái niệm cơ bản trong DocFX
      • DocFX - Hướng dẫn cài đặt, cấu hình sử dụng
      • DocFX - Hướng dẫn Markdown
      • DocFX - Hướng dẫn cấu hình file docfx.json
      • DocFX - Hướng dẫn sử dụng và tùy chỉnh Template
    • ETL Tools
      • Công cụ ETL Tools List & Software
      • Airbyte
        • Docker Compose
    • Elasticsearch
      • _reindex
        • Tìm hiểu sâu về API _reindex trong Elasticsearch
        • Hướng dẫn di chuyển dữ liệu trong Elasticsearch sử dụng API _reindex
      • _transform
    • HAProxy
      • HAProxy - Lập trình Lua và tích hợp Redis
    • Localtunnel
      • Hướng dẫn sử dụng Localtunnel để đưa ứng dụng Local lên Internet
    • LoopBack
      • Hướng dẫn cài đặt LoopBack 4 và khởi tạo dự án đầu tiên
    • N8N
      • Hướng dẫn cài đặt n8n bằng docker compose
    • NGINX Plus
      • NGINX: Hiệu suất vượt trội và giải pháp tối ưu cho hệ thống web
      • NGINX: Hướng dẫn chi tiết sử dụng GeoIP2 trên Alpine
      • NGINX: Hướng dẫn sử dụng Lua trên Alpine
      • NGINX: Hướng Dẫn Chi Tiết Cấu Hình Load Balancer
      • NGINX: Hướng Dẫn Sử Dụng Dynamic Modules
      • NGINX: Hướng dẫn Cài đặt và Sử dụng Module njs
      • Tích Hợp NGINX Làm API Gateway với Các Bước Xử Lý Phổ Biến
    • NTP - Secure Timeserver
      • Hướng dẫn cài đặt NTP an toàn với Docker Compose
    • Playwright
      • Playwright: Tự Động Hóa Trình Duyệt Hiệu Quả
    • Wordpress
      • Cách dùng Docker để phát triển ứng dụng Wordpress
  • Tin tức
    • DevSecOps là gì?
    • Giới thiệu bộ công cụ hỗ trợ lập trình từ SmallDev.tools và Code Beautify
    • Giới Thiệu và Hướng Dẫn Về DuckDB
    • Giới thiệu về Các Loại Cơ Sở Dữ Liệu
      • 1. HSQLDB (HyperSQL Database)
    • Hệ thống phân giải tên miền (DNS) và các loại bản ghi
    • Giải thích về Tiền Tố Path Nổi Tiếng – /.well-known
    • Giải mã Hệ thống tạo mã OTP của Google Authenticator
    • Quishing là gì? Hiểu và phòng tránh lừa đảo qua mã QR
  • Hướng dẫn
    • Hướng dẫn chi tiết tạo tài khoản Google bằng email công ty
    • Top 10 ASP .NET Open Source Projects GitHub 2024
    • Free Themes and Templates from Creative Tim
    • Hướng dẫn sử dụng Voler và Mazer Dashboard từ Zuramai
  • So Sánh
    • So Sánh Apache Parquet và CSV: Bảng So Sánh Chi Tiết, Ưu và Nhược Điểm
    • So Sánh Varnish Cache, Memcached và Redis: Ba Công Cụ Caching Phổ Biến trong Tối Ưu Hóa Hiệu Suất
  • Affiliate
    • Tuyển dụng
      • Bộ câu hỏi phỏng vấn T-SQL – Đánh giá ứng viên hiệu quả
    • eSMSvn: Chăm sóc khách hàng hiệu quả với SMS và ZNS
    • eSMS.vn: Giải pháp SMS Marketing hiệu quả cùng các chương trình ưu đãi hấp dẫn
Powered by GitBook
On this page
  • 1. DBCC FREEPROCCACHE là gì?
  • 2. Cú pháp lệnh DBCC FREEPROCCACHE
  • 3. Khi nào nên sử dụng DBCC FREEPROCCACHE?
  • 3.1. Thay đổi cấu trúc cơ sở dữ liệu
  • 3.2. Tối ưu hóa hiệu suất
  • 3.3. Giải quyết vấn đề hiệu suất bất thường
  • 3.4. Kiểm tra và thử nghiệm
  • 4. Ví dụ sử dụng DBCC FREEPROCCACHE
  • 4.1. Làm sạch toàn bộ Procedure Cache
  • 4.2. Làm sạch Execution Plan cụ thể
  • 4.3. Không hiển thị thông báo
  • 5. Các lưu ý khi sử dụng DBCC FREEPROCCACHE
  • 6. So sánh với các lệnh DBCC khác liên quan đến bộ nhớ
  • 7. Kết luận

Was this helpful?

  1. SQL Server
  2. SQL Server: DBCC

DBCC FREEPROCCACHE

DBCC FREEPROCCACHE: Cách hoạt động và Ứng dụng trong SQL Server

Trong quá trình vận hành SQL Server, việc quản lý bộ nhớ đóng vai trò cực kỳ quan trọng trong hiệu suất hệ thống. Một trong những công cụ hữu ích được cung cấp bởi SQL Server để kiểm soát và tối ưu hóa bộ nhớ là lệnh DBCC FREEPROCCACHE. Bài viết này sẽ giúp bạn hiểu rõ hơn về chức năng, cách sử dụng, và những trường hợp áp dụng thực tế của lệnh này.


1. DBCC FREEPROCCACHE là gì?

DBCC FREEPROCCACHE là một câu lệnh trong SQL Server thuộc nhóm các Database Console Commands (DBCC), được sử dụng để làm sạch Procedure Cache. Procedure Cache là nơi SQL Server lưu trữ các Execution Plan (kế hoạch thực thi) của các truy vấn đã thực hiện, nhằm tái sử dụng chúng cho các truy vấn tương tự, giúp giảm chi phí tính toán và tăng tốc độ thực thi.

Tuy nhiên, trong một số trường hợp, Procedure Cache có thể chứa những kế hoạch lỗi thời hoặc không còn hiệu quả. Việc làm sạch Procedure Cache bằng DBCC FREEPROCCACHE sẽ buộc SQL Server phải tạo lại Execution Plan mới cho các truy vấn sau đó.


2. Cú pháp lệnh DBCC FREEPROCCACHE

DBCC FREEPROCCACHE [ WITH NO_INFOMSGS ];
  • WITH NO_INFOMSGS: Tùy chọn này giúp ẩn các thông báo không cần thiết khi thực hiện lệnh.


3. Khi nào nên sử dụng DBCC FREEPROCCACHE?

Mặc dù Procedure Cache giúp cải thiện hiệu suất, nhưng có một số trường hợp việc làm sạch cache là cần thiết:

3.1. Thay đổi cấu trúc cơ sở dữ liệu

  • Khi bạn thực hiện các thay đổi lớn như chỉnh sửa bảng, thêm/xóa cột, hoặc cập nhật index, các Execution Plan cũ có thể không còn phù hợp.

3.2. Tối ưu hóa hiệu suất

  • Trong quá trình tinh chỉnh truy vấn, bạn cần kiểm tra hiệu quả của các Execution Plan mới sau khi thay đổi các chỉ số (index), thống kê (statistics) hoặc query hints.

3.3. Giải quyết vấn đề hiệu suất bất thường

  • Nếu hệ thống gặp các vấn đề về hiệu suất, việc làm sạch Procedure Cache có thể là một bước khắc phục tạm thời để loại bỏ các Execution Plan không hiệu quả.

3.4. Kiểm tra và thử nghiệm

  • Khi bạn đang kiểm tra trong môi trường phát triển, làm sạch cache giúp đảm bảo rằng bạn đang đo hiệu suất của các Execution Plan mới, thay vì các kế hoạch đã được lưu trữ trước đó.


4. Ví dụ sử dụng DBCC FREEPROCCACHE

4.1. Làm sạch toàn bộ Procedure Cache

DBCC FREEPROCCACHE;
  • Lệnh này sẽ xóa tất cả các Execution Plan trong Procedure Cache của hệ thống.

4.2. Làm sạch Execution Plan cụ thể

Nếu bạn chỉ muốn xóa kế hoạch thực thi của một truy vấn cụ thể, bạn có thể sử dụng DBCC FREEPROCCACHE với Plan Handle.

  1. Lấy Plan Handle của một truy vấn:

SELECT plan_handle 
FROM sys.dm_exec_cached_plans
CROSS APPLY sys.dm_exec_sql_text(plan_handle)
WHERE text LIKE '%<từ khóa truy vấn>%';
  1. Xóa kế hoạch với Plan Handle:

DBCC FREEPROCCACHE (<plan_handle>);

4.3. Không hiển thị thông báo

DBCC FREEPROCCACHE WITH NO_INFOMSGS;
  • Lệnh này giúp hạn chế các thông báo không cần thiết, giữ sạch nhật ký hệ thống.


5. Các lưu ý khi sử dụng DBCC FREEPROCCACHE

  • Ảnh hưởng đến hiệu suất: Sau khi làm sạch Procedure Cache, SQL Server sẽ phải tạo lại Execution Plan mới cho các truy vấn, dẫn đến tăng tải hệ thống trong thời gian ngắn.

  • Không khuyến khích trong môi trường sản xuất: Chỉ sử dụng khi cần thiết vì có thể gây ra hiện tượng giảm hiệu suất tạm thời.

  • Yêu cầu quyền cao: Bạn cần có quyền sysadmin hoặc serveradmin để chạy lệnh này.

  • Không hoàn tác được: Một khi đã làm sạch Procedure Cache, không thể khôi phục các Execution Plan cũ.


6. So sánh với các lệnh DBCC khác liên quan đến bộ nhớ

Lệnh DBCC

Chức năng

DBCC FREEPROCCACHE

Xóa Procedure Cache, buộc SQL Server tạo lại Execution Plan.

DBCC DROPCLEANBUFFERS

Làm sạch Buffer Cache, buộc SQL Server đọc dữ liệu từ đĩa thay vì từ bộ nhớ.

DBCC FLUSHPROCINDB

Làm sạch Procedure Cache của một database cụ thể (SQL Server 2008 trở lên).


7. Kết luận

DBCC FREEPROCCACHE là một công cụ mạnh mẽ trong SQL Server, giúp bạn kiểm soát và tối ưu hóa Procedure Cache để cải thiện hiệu suất hệ thống. Tuy nhiên, hãy sử dụng nó cẩn thận, đặc biệt trong môi trường sản xuất, để tránh gây ra các vấn đề không mong muốn.

Hy vọng bài viết này cung cấp cho bạn cái nhìn chi tiết và đầy đủ về DBCC FREEPROCCACHE. Nếu bạn có bất kỳ câu hỏi hoặc góp ý nào, hãy để lại bình luận dưới bài viết.


PreviousDBCC SQLPERFNextSQL Server Replication

Last updated 5 months ago

Was this helpful?

Hãy theo dõi blog để cập nhật thêm nhiều kiến thức hữu ích về SQL Server và lập trình!

Cẩm nang NQDEV