Phân biệt dedicated server và shared server?

Trong Oracle Database, hai kiến trúc kết nối chính để xử lý các yêu cầu của người dùng là dedicated servershared server. Dưới đây là sự phân biệt giữa hai loại kiến trúc này:

1. Dedicated Server (Máy chủ chuyên dụng)

Đặc điểm:

  • Kết nối một-một: Mỗi phiên làm việc của người dùng được liên kết với một quy trình máy chủ riêng lẻ.
  • Hiệu suất: Do mỗi phiên làm việc có quy trình riêng, hiệu suất cao khi số lượng phiên làm việc ít hoặc tải công việc lớn.
  • Bộ nhớ và tài nguyên: Yêu cầu nhiều bộ nhớ và tài nguyên hơn vì mỗi phiên làm việc sử dụng một quy trình riêng.
  • Dễ quản lý: Đơn giản và dễ quản lý vì không có sự chia sẻ giữa các phiên làm việc.

Lợi ích:

  • Hiệu suất tốt: Tốt cho các ứng dụng yêu cầu hiệu suất cao và có lượng người dùng hạn chế.
  • Bảo mật: Tốt hơn trong một số trường hợp bảo mật, do không có sự chia sẻ quy trình.

Hạn chế:

  • Tài nguyên hệ thống: Sử dụng nhiều tài nguyên hệ thống khi số lượng phiên làm việc tăng cao.
  • Quản lý: Quản lý có thể trở nên phức tạp khi số lượng kết nối tăng lên.

2. Shared Server (Máy chủ chia sẻ)

Đặc điểm:

  • Kết nối nhiều-một: Nhiều phiên làm việc của người dùng có thể chia sẻ cùng một quy trình máy chủ.
  • Hiệu quả sử dụng tài nguyên: Tốt hơn trong việc sử dụng bộ nhớ và tài nguyên vì các quy trình máy chủ được chia sẻ giữa các phiên làm việc.
  • Độ phức tạp: Phức tạp hơn trong việc quản lý và cấu hình so với kiến trúc dedicated server.

Lợi ích:

  • Tiết kiệm tài nguyên: Hiệu quả hơn về sử dụng bộ nhớ và CPU khi có nhiều kết nối cùng lúc.
  • Quy mô lớn: Tốt cho các hệ thống có nhiều người dùng kết nối cùng lúc và tải công việc nhẹ hoặc trung bình.

Hạn chế:

  • Hiệu suất: Có thể giảm hiệu suất nếu có nhiều phiên làm việc yêu cầu tài nguyên đồng thời.
  • Quản lý: Phức tạp hơn trong việc quản lý và tối ưu hóa.

Bảng So Sánh

Đặc điểmDedicated ServerShared Server
Kết nốiMột-một (one-to-one)Nhiều-một (many-to-one)
Sử dụng tài nguyênNhiều bộ nhớ và CPUHiệu quả hơn về tài nguyên
Hiệu suấtCao với ít kết nốiTốt với nhiều kết nối, tải nhẹ
Quản lýĐơn giảnPhức tạp hơn
Tài nguyên hệ thốngTăng cao khi số kết nối tăngTiết kiệm tài nguyên hơn
Ứng dụng phù hợpỨng dụng yêu cầu hiệu suất caoỨng dụng có nhiều người dùng kết nối

Khi nào nên chọn Dedicated Server hoặc Shared Server?

  • Dedicated Server: Tốt cho các hệ thống có số lượng người dùng hạn chế nhưng yêu cầu hiệu suất cao và tính bảo mật, hoặc khi các phiên làm việc yêu cầu nhiều tài nguyên.
  • Shared Server: Phù hợp cho các hệ thống có số lượng người dùng lớn nhưng mỗi phiên làm việc không yêu cầu nhiều tài nguyên, chẳng hạn như các hệ thống giao dịch trực tuyến hoặc ứng dụng web.

Cấu hình và quản lý

Dedicated Server:

  • Mặc định, Oracle Database sử dụng chế độ dedicated server.
  • Để sử dụng chế độ dedicated server, không cần cấu hình đặc biệt. Các kết nối sẽ tự động được xử lý theo mô hình một-một.

Shared Server:

  • Để cấu hình shared server, bạn cần thiết lập các tham số khởi động và quản lý dispatcher và server process.
  • Ví dụ cấu hình shared server trong init.ora hoặc spfile:

ALTER SYSTEM SET SHARED_SERVERS = 5;

ALTER SYSTEM SET DISPATCHERS = ‘(PROTOCOL=TCP)(DISPATCHERS=3)’;

Bạn có thể kiểm tra trạng thái của các shared server và dispatcher bằng các chế độ xem động như V$SHARED_SERVER và V$DISPATCHER.

Sự lựa chọn giữa dedicated server và shared server phụ thuộc vào đặc điểm và yêu cầu cụ thể của hệ thống và ứng dụng của bạn.

 

Datalinks.vn

Hello các bạn, mình là Dương Nguyễn tác giả của blog này. Với gần 20 năm làm việc trong lĩnh vực CNTT, VT trong và ngoài nước, mong muốn được chia sẻ kiến thức và kinh nghiệm về database với các bạn đam mê và quan tâm đến lĩnh vực này. Đặc biệt là #OracleDatabase hoặc luyện thi #OCP database admin. Warren Buffett từng nói "Muốn đi nhanh hãy đi một mình, muốn đi xa hãy đi cùng nhau". Các bạn cần người đồng hành thì alo tôi nhé. Call/Zalo: 0765 871 888. Thanks you !.....
5 1 đánh giá
Đánh giá bài viết
Theo dõi
Thông báo của
guest

0 Góp ý
Phản hồi nội tuyến
Xem tất cả bình luận