当前位置: 首页 > news >正文

DockerでOracle Database 23ai FreeをセットアップしMAX_STRING_SIZEを拡張する手順

DockerでOracle Database 23c FreeをセットアップしMAX_STRING_SIZEを拡張する手順

    • はじめに
    • 環境準備
      • ディレクトリ作成
      • Dockerコンテナ起動
    • データベース設定変更
      • コンテナ内でSQL*Plus起動
      • PDB操作と文字列サイズ拡張
      • 設定検証
    • 管理者ユーザー作成
    • 注意事項
    • まとめ

はじめに

Oracle Database 23ai FreeをDocker環境でセットアップし、拡張文字列サイズ(MAX_STRING_SIZE=EXTENDED)の設定とPDB操作を行う手順を解説します。開発環境構築時の参考にしてください。

環境準備

ディレクトリ作成

データ永続化用のディレクトリを作成(権限設定は開発環境用):

mkdir -p /u01/data/free/
chmod 777 /u01/data/free/  # 本番環境では適切な権限設定を推奨

Dockerコンテナ起動

Oracle Database 23c Freeのコンテナを起動:

docker run -d --name oracle-db \-p 1521:1521 \-e ORACLE_PDB=FREEPDB1 \-e ORACLE_PWD=<任意のパスワード> \-v /u01/data/free/:/opt/oracle/oradata \container-registry.oracle.com/database/free:23.7.0.0-amd64

データベース設定変更

コンテナ内でSQL*Plus起動

docker exec -it oracle-db bash
sqlplus / as sysdba

PDB操作と文字列サイズ拡張

-- PDB状態確認
SHOW PDBS;-- PDBをアップグレードモードで再オープン
ALTER PLUGGABLE DATABASE FREEPDB1 CLOSE;
ALTER PLUGGABLE DATABASE FREEPDB1 OPEN UPGRADE;-- コンテナ切り替え
ALTER SESSION SET CONTAINER=FREEPDB1;-- 文字列サイズ拡張設定
ALTER SYSTEM SET MAX_STRING_SIZE=EXTENDED;-- 変更適用スクリプト実行
@?/rdbms/admin/utl32k.sql-- 通常モードで再起動
ALTER PLUGGABLE DATABASE FREEPDB1 CLOSE;
ALTER PLUGGABLE DATABASE FREEPDB1 OPEN;

設定検証

-- 拡張文字列サイズでのテーブル作成テスト
CREATE TABLE large_text_table (large_text_column VARCHAR2(20000)
);DROP TABLE large_text_table;

管理者ユーザー作成

-- DBA権限付与
CREATE USER admin IDENTIFIED BY <パスワード>;
GRANT DBA TO admin;
GRANT EXECUTE ON CTX_DDL TO admin;  -- Text検索機能利用の場合

注意事項

  1. データ永続化のためボリュームマウントを実施
  2. MAX_STRING_SIZE変更はデータベース作成直後のみ可能
  3. 本番環境では権限設定を見直し(777は開発用)
  4. パスワードは強固なものを設定

まとめ

Dockerを使ったOracle Databaseのセットアップと重要な設定変更の流れを解説しました。開発環境構築の参考になれば幸いです。本番環境ではセキュリティ設定の見直しをお忘れなく!

http://www.lryc.cn/news/544952.html

相关文章:

  • Unity 运用正则表达式保留字符串中的中文英文字母和数字
  • vue el-table-column 单元表格的 省略号 实现
  • 企业微信里可以使用的企业内刊制作工具,FLBOOK
  • 【数据挖掘】Pandas
  • explore与explode词源故事
  • CAM350_安装
  • 51c自动驾驶~合集22
  • games101 作业5
  • 【高并发秒杀系统设计:从Guava到Redis的6级缓存架构演进】
  • 2-程序语言基础知识
  • 【AIGC系列】4:Stable Diffusion应用实践和代码分析
  • 小米火龙CPU和其他几代温度太高的CPU是由谁代工的
  • 在 ASP.NET Core 中压缩并减少图像的文件大小
  • 网络流算法: Dinic算法
  • 【Godot4.3】自定义简易菜单栏节点ETDMenuBar
  • 如何杀死僵尸进程?没有那个进程?
  • Solana 核心概念全解析:账户、交易、合约与租约,高流量区块链技术揭秘!
  • Leetcode-853. Car Fleet [C++][Java]
  • 012 rocketmq事务消息
  • ChatGPT与DeepSeek:开源与闭源的AI模型之争
  • Ollama的底层实现原理分析
  • nginx 动态计算拦截非法访问ip
  • 商业秘密维权有哪些成本开支?
  • 使用UA-SPEECH和TORGO数据库验证自动构音障碍语音分类方法
  • WebSocketHandler 是 Spring Framework 中用于处理 WebSocket 通信的接口
  • Pikachu
  • 如何使用 Jenkins 实现 CI/CD 流水线:从零开始搭建自动化部署流程
  • Vue.js 学习笔记
  • 数据存储:一文掌握RabbitMQ的详细使用
  • 辛格迪客户案例 | 祐儿医药科技GMP培训管理(TMS)项目