All about Oracle Technologies

Thursday 22 October 2015

Giới thiệu về Multitenant trong Oracle 12c R1

Bài viết này sẽ giới thiệu về khái niệm Multitenant được sử dụng trong Oracle 12c R1.

1. Giới thiệu:
Để theo kịp xu hướng Cloud Computing và PaaS (Platform as a Service), từ phiên bản Oracle 12c thì Oracle đã giới thiệu tính năng mới là Pluggable Database. Tính năng này cho phép 1 Database độc lập có thể được di chuyển dễ dàng qua các hệ thống  khác nhau hoặc qua các nền tảng khác nhau hoặc giữa các bản phân phối (release) Database khác nhau.

2. Tổng quan:
Multitenant là 1 khái niệm mới được sử dụng trong phiên bản Oracle 12c và là 1 bước thay đổi lớn trong lịch sử kiến trúc của Oracle. Multitenant bao gồm 2 khái niệm nhỏ là Container Database (CDB) and Pluggable Database (PDB).
(Hình 1)

  • Container Database (CDB): một cách hiểu đơn giản thì CDB là 1 vùng chứa cha (root container) chứa các thành phần quan trọng của 1 Database như: controlfiles, datafiles, undo, tempfiles, redo logs, v.v...
  • Pluggable Database (PDB): PDB chỉ chứa các dữ liệu liên quan của chính Database mà nó lưu trữ như datafiles, tempfiles.
Mối quan hệ giữa CDB và PDB là mối quan hệ 1-nhiều. Trong phiên bản Oracle 12c R1 thì 1 CDB có thể chứa tối đa là 250 PDB.

3.Kiến trúc và tính năng:
(Hình 2)
Do đặc tính của PDB là 1 Database độc lập chứa trong 1 CDB nên Oracle cho phép chúng ta có thể gắn hoặc gỡ (plug/unplug) PDB ra khỏi CDB. Chúng ta có thể sử dụng việc gắn/gỡ PDB trong các trường hợp sau:
  • Chuyển Database sang 1 Platform khác
  • Chuyển Database sang máy chủ có phần cứng khác
  • Chuyển Database từ môi trường này sang môi trường khác như từ Testing sang Production
  • Chuyển Database sang môi trường hệ thống khác
  • Tăng độ sẵn sàng (HA) của Database khi di chuyển qua lại giữa các hệ thống
Ngoài những thuận tiện kể trên thì việc gắn/gỡ PDB cũng giúp chúng ta nâng cấp hoặc cập nhật các bản vá dễ dàng cho Oracle Database System mà không sợ ảnh hưởng đến các PDB.

Bên cạnh đó việc sao lưu và phục hồi cũng dễ dàng hơn. Chúng ta có thể sao lưu/phục hồi cho cả CDB bằng RMAN hoặc Data Guard hoặc thực hiện sao lưu/phục hồi cho từng PDB riêng lẻ.

4. Cây thừa kế các đối tượng
Trong các phiên bản Oracle 11g trở về trước thì cấu trúc cây thừa kế các đối tượng như sau:
DBA_ : All objects in the database.
|
--ALL_ : Objects accessible by the current user, including those owned by the current user.
  |
  --USER_ : Objects owned by the current user.

Trong phiên bản Oracle 12c, do có khái niệm Multitenant nên cây thừa kế các đối tượng sẽ như sau:
CDB_ : All objects in all containers (root and all PDBs).
|
--DBA_ : All objects in the current container (root or PDB).
  |
  --ALL_ : Objects accessible by the current user in the current container (root or PDB), including those owned by the current user.
    |
    --USER_ : Objects owned by the current user in the current container (root or PDB).

0 comments :

Post a Comment