Dưới đây là runbook step-by-step patch OJVM 19.29 (patch p38194382_190000_Linux-x86-64) theo kiểu thực chiến. Viết 2 luồng:
- Luồng A (chuẩn nhất): DB RU đã ở 19.29 → patch OJVM 19.29
- Luồng B: DB đang 19.23 → khuyến nghị bắt buộc nâng DB RU lên 19.29 trước, rồi mới OJVM 19.29 (để tránh lệch level).
A. RUNBOOK OJVM 19.29 (khi DB RU đã là 19.29)
0) Chuẩn bị
0.1 Xác định đúng ORACLE_HOME (DB Home)
su - oracle
echo $ORACLE_HOME
$ORACLE_HOME/OPatch/opatch version
0.2 Giải nén patch
Ví dụ:
mkdir -p /u01/setup/patch
cd /u01/setup/patch
unzip p38194382_190000_Linux-x86-64.zip
# sẽ ra thư mục: 38194382/
0.3 Precheck: inventory + hiện trạng SQL patch
$ORACLE_HOME/OPatch/opatch lspatches
Trong SQL:
sqlplus / as sysdba
set lines 200 pages 200
select * from v$version where rownum<=20;
select description, action, status, to_char(action_time,'yyyy-mm-dd hh24:mi:ss') action_time
from dba_registry_sqlpatch
order by action_time;
1) Check conflict trước khi apply (rất nên làm)
cd /u01/setup/patch/38194382
$ORACLE_HOME/OPatch/opatch prereq CheckConflictAgainstOHWithDetail -ph ./
- Nếu báo conflict: thường do OPatch cũ hoặc thiếu RU nền / thiếu patch prerequisite → phải xử lý trước khi apply.
2) Dừng dịch vụ để tránh lỗi “CheckActiveFilesAndExecutables”
2.1 Single instance
lsnrctl stop
sqlplus / as sysdba
shutdown immediate;
exit
2.2 RAC (patch DB home trên từng node / hoặc dùng opatchauto)
Trên node đang patch:
- stop instance trên node đó (khuyến nghị dùng srvctl):
srvctl stop instance -d <db_unique_name> -i <instance_name>
- dừng listener nếu listener chạy từ DB home:
srvctl stop listener
# hoặc lsnrctl stop (nếu quản lý tay)
Nếu trước đó anh hay bị lỗi libclntsh “in-use”, kiểm tra:
lsof $ORACLE_HOME/lib/libclntsh.so.19.1
Phải không còn output.
3) Apply OJVM 19.29 (binary)
cd /u01/setup/patch/38194382
$ORACLE_HOME/OPatch/opatch apply
Verify:
$ORACLE_HOME/OPatch/opatch lspatches | egrep -i "38194382|OJVM"
4) Start DB lên lại
Single:
lsnrctl start
sqlplus / as sysdba
startup;
exit
RAC:
srvctl start instance -d <db_unique_name> -i <instance_name>
# sau khi patch xong toàn bộ node thì start listener/service lại đầy đủ
5) Chạy datapatch (bắt buộc để update DBA_REGISTRY_SQLPATCH)
Chỉ cần chạy 1 lần trên 1 node (thường chạy trên node đang là PRIMARY instance):
su - oracle
cd $ORACLE_HOME/OPatch
./datapatch -verbose
Xem log:
ls -ltr $ORACLE_BASE/cfgtoollogs/sqlpatch | tail -50
Verify trong SQL:
sqlplus / as sysdba
set lines 200 pages 200
select description, action, status, to_char(action_time,'yyyy-mm-dd hh24:mi:ss') action_time
from dba_registry_sqlpatch
order by action_time;
-- kiểm nhanh còn cái nào không SUCCESS:
select description, status
from dba_registry_sqlpatch
where status <> 'SUCCESS';
✅ Kỳ vọng: có record liên quan OJVM 19.29 (p38194382) APPLY SUCCESS.
6) Post-check nhanh
$ORACLE_HOME/OPatch/opatch lsinventory | egrep -i "38194382|OJVM" -n
Trong DB:
select comp_id, comp_name, version, status from dba_registry;
B. DB đang 19.23 nhưng muốn “OJVM 19.29” (khuyến nghị chuẩn)
Không khuyến nghị patch OJVM 19.29 khi DB RU vẫn 19.23, vì rất dễ:
- conflict,
- “binary lên nhưng SQL registry không đúng”,
- hoặc mismatch patch level gây lỗi runtime JVM.
✅ Cách chuẩn:
- Nâng DB RU lên 19.29 (DB Release Update)
- datapatch
- Sau đó mới OJVM 19.29 theo Runbook A.
Nếu anh muốn, em viết luôn runbook “19.23 → 19.29 RU + OJVM 19.29” gộp 1 mạch.
C. RAC: có phải làm từng node không? có phải tắt toàn bộ không?
- Binary patch (OJVM/DB home) trong RAC: phải patch trên tất cả node (đồng bộ ORACLE_HOME).
- Thường làm rolling node-by-node (không cần tắt cả 4 node) nếu patch hỗ trợ rolling và bạn dùng srvctl/opatchauto đúng cách.
- datapatch: chỉ chạy 1 lần sau khi binary đã đồng bộ (thường khi DB mở và cluster ổn).
D. Rollback (khi cần quay lại)
Nếu cần rollback patch OJVM:
cd /u01/setup/patch/38194382
$ORACLE_HOME/OPatch/opatch rollback -id 38194382
Sau đó chạy lại datapatch để đồng bộ registry (nếu có SQL component đã apply).
TƯ VẤN: Click Here hoặc Hotline/Zalo 090.29.12.888
=============================
Website không chứa bất kỳ quảng cáo nào, mọi đóng góp để duy trì phát triển cho website (donation) xin vui lòng gửi về STK 90.2142.8888 - Ngân hàng Vietcombank Thăng Long - TRAN VAN BINH
=============================
Nếu bạn không muốn bị AI thay thế và tiết kiệm 3-5 NĂM trên con đường trở thành DBA chuyên nghiệp hay làm chủ Database thì hãy đăng ký ngay KHOÁ HỌC ORACLE DATABASE A-Z ENTERPRISE, được Coaching trực tiếp từ tôi với toàn bộ bí kíp thực chiến, thủ tục, quy trình của gần 20 năm kinh nghiệm (mà bạn sẽ KHÔNG THỂ tìm kiếm trên Internet/Google) từ đó giúp bạn dễ dàng quản trị mọi hệ thống Core tại Việt Nam và trên thế giới, đỗ OCP.
- CÁCH ĐĂNG KÝ: Gõ (.) hoặc để lại số điện thoại hoặc inbox https://m.me/tranvanbinh.vn hoặc Hotline/Zalo 090.29.12.888
- Chi tiết tham khảo:
https://bit.ly/oaz_w
=============================
2 khóa học online qua video giúp bạn nhanh chóng có những kiến thức nền tảng về Linux, Oracle, học mọi nơi, chỉ cần có Internet/4G:
- Oracle cơ bản: https://bit.ly/admin_1200
- Linux: https://bit.ly/linux_1200
=============================
KẾT NỐI VỚI CHUYÊN GIA TRẦN VĂN BÌNH:
📧 Mail: binhoracle@gmail.com
☎️ Mobile/Zalo: 0902912888
👨 Facebook: https://www.facebook.com/BinhOracleMaster
👨 Inbox Messenger: https://m.me/101036604657441 (profile)
👨 Fanpage: https://www.facebook.com/tranvanbinh.vn
👨 Inbox Fanpage: https://m.me/tranvanbinh.vn
👨👩 Group FB: https://www.facebook.com/groups/DBAVietNam
👨 Website: https://www.tranvanbinh.vn
👨 Blogger: https://tranvanbinhmaster.blogspot.com
🎬 Youtube: https://www.youtube.com/@binhguru
👨 Tiktok: https://www.tiktok.com/@binhguru
👨 Linkin: https://www.linkedin.com/in/binhoracle
👨 Twitter: https://twitter.com/binhguru
👨 Podcast: https://www.podbean.com/pu/pbblog-eskre-5f82d6
👨 Địa chỉ: Tòa nhà Sun Square - 21 Lê Đức Thọ - Phường Mỹ Đình 1 - Quận Nam Từ Liêm - TP.Hà Nội
=============================
cơ sở dữ liệu, cơ sở dữ liệu quốc gia, database, AI, trí tuệ nhân tạo, artificial intelligence, machine learning, deep learning, LLM, ChatGPT, DeepSeek, Grok, oracle tutorial, học oracle database, Tự học Oracle, Tài liệu Oracle 12c tiếng Việt, Hướng dẫn sử dụng Oracle Database, Oracle SQL cơ bản, Oracle SQL là gì, Khóa học Oracle Hà Nội, Học chứng chỉ Oracle ở đầu, Khóa học Oracle online,sql tutorial, khóa học pl/sql tutorial, học dba, học dba ở việt nam, khóa học dba, khóa học dba sql, tài liệu học dba oracle, Khóa học Oracle online, học oracle sql, học oracle ở đâu tphcm, học oracle bắt đầu từ đâu, học oracle ở hà nội, oracle database tutorial, oracle database 12c, oracle database là gì, oracle database 11g, oracle download, oracle database 19c/21c/23c/23ai, oracle dba tutorial, oracle tunning, sql tunning , oracle 12c, oracle multitenant, Container Databases (CDB), Pluggable Databases (PDB), oracle cloud, oracle security, oracle fga, audit_trail,oracle RAC, ASM, oracle dataguard, oracle goldengate, mview, oracle exadata, oracle oca, oracle ocp, oracle ocm , oracle weblogic, postgresql tutorial, mysql tutorial, mariadb tutorial, ms sql server tutorial, nosql, mongodb tutorial, oci, cloud, middleware tutorial, docker, k8s, micro service, hoc solaris tutorial, hoc linux tutorial, hoc aix tutorial, unix tutorial, securecrt, xshell, mobaxterm, putty