Oracle 单机和集群环境部署教程
目录
- 一、Oracle 单机环境部署
- 1. 环境准备
- 2. 安装 Oracle Database
- 2.1 下载 Oracle Database
- 2.2 创建 Oracle 用户和组
- 2.3 配置内核参数和系统限制
- 2.4 解压和安装
- 2.5 配置监听程序
- 2.6 创建数据库
- 3. 单机部署注意事项
- 二、Oracle 集群环境部署 (Oracle RAC)
- 1. 环境准备
- 2. 安装 Grid Infrastructure
- 2.1 下载和解压 Grid Infrastructure 软件
- 2.2 运行 Grid Setup
- 2.3 配置 ASM(Automatic Storage Management)
- 3. 安装 Oracle Database RAC
- 4. 集群部署注意事项
- 三、Oracle 使用案例
- 1. Java 示例:使用 JDBC 连接 Oracle
- 1.1 添加 Maven 依赖
- 1.2 编写 Java 代码
- 2. Python 示例:使用 cx_Oracle 连接 Oracle
- 2.1 安装 cx_Oracle
- 2.2 编写 Python 代码
- 总结
- 部署过程中的注意事项
一、Oracle 单机环境部署
1. 环境准备
- 操作系统:Linux(推荐 Oracle Linux、RedHat、CentOS 等),或 Windows Server。
- Oracle 版本:Oracle Database 19c(推荐最新长期支持版本)。
- 硬件要求:
- 内存:至少 8 GB。
- 磁盘空间:至少 45 GB。
- CPU:至少 2 核。
2. 安装 Oracle Database
2.1 下载 Oracle Database
从 Oracle 官网 下载适合你操作系统的 Oracle Database 19c 安装包。
2.2 创建 Oracle 用户和组
在 Linux 上,Oracle 需要独立的用户和组进行管理。
# 创建 Oracle 用户和组
sudo groupadd oinstall
sudo groupadd dba
sudo useradd -g oinstall -G dba oracle
2.3 配置内核参数和系统限制
编辑 /etc/sysctl.conf,添加以下内容:
fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.shmall = 2097152
kernel.shmmax = 1073741824
kernel.shmmni = 4096
kernel.sem = 250 32000 100 128
net.ipv4.ip_local_port_range = 9000 65500
net.core.rmem_default=262144
net.core.rmem_max=4194304
net.core.wmem_default=262144
net.core.wmem_max=1048576
应用配置:
sudo sysctl -p
编辑 /etc/security/limits.conf,添加以下内容:
oracle soft nproc 2047
oracle hard nproc 16384
oracle soft nofile 1024
oracle hard nofile 65536
2.4 解压和安装
-
解压下载的 Oracle 软件包:
unzip linuxx64_193000_db_home.zip -d /u01/app/oracle/product/19.0.0/dbhome_1 -
切换为 Oracle 用户并运行安装程序:
sudo su - oracle cd /u01/app/oracle/product/19.0.0/dbhome_1 ./runInstaller
安装过程将启动图形界面,按照提示完成安装。
2.5 配置监听程序
-
启动监听程序配置工具:
netca -
按照提示完成监听程序的配置。
2.6 创建数据库
使用 dbca(Database Configuration Assistant)创建数据库:
dbca
选择创建数据库,设置 SID、存储选项等。
3. 单机部署注意事项
- 系统资源配置:确保 Oracle 数据库有足够的内存和 CPU 资源。
- 监听配置:确保监听程序配置正确,特别是外部访问时要注意开放端口。
- 备份:配置 RMAN 进行定期备份,防止数据丢失。
- 安全性:配置用户权限,确保数据库的安全访问。
二、Oracle 集群环境部署 (Oracle RAC)
Oracle Real Application Cluster (RAC) 允许多个服务器共享一个 Oracle 数据库实例,提供高可用性和负载均衡。
1. 环境准备
- 操作系统:Linux(推荐 Oracle Linux)。
- 集群节点数量:至少 2 台服务器。
- 存储要求:共享存储(例如 ASM、NFS)。
- 网络要求:
- 公共网络:所有节点之间的通信。
- 私有网络:用于节点间心跳检测和数据传输。
2. 安装 Grid Infrastructure
Grid Infrastructure 提供集群服务和共享存储管理。
2.1 下载和解压 Grid Infrastructure 软件
下载 Grid Infrastructure 软件,并解压到每个节点。
unzip linuxx64_193000_grid_home.zip -d /u01/app/19.0.0/grid
2.2 运行 Grid Setup
以 oracle 用户身份执行以下命令:
cd /u01/app/19.0.0/grid
./gridSetup.sh
选择“Configure Oracle Grid Infrastructure for a Cluster”,并根据提示完成安装。
2.3 配置 ASM(Automatic Storage Management)
安装完成后,使用 asmca 配置 ASM 以管理共享存储。
3. 安装 Oracle Database RAC
-
解压 Oracle Database 软件:
解压 Oracle Database 安装包。
-
执行 Oracle 安装程序:
在每个节点上执行安装程序:
./runInstaller选择“Oracle Real Application Cluster”并安装。
4. 集群部署注意事项
- 共享存储:确保所有节点能够访问共享存储。
- 网络配置:配置私有网络和公共网络,确保集群通信正常。
- 心跳检测:配置好节点之间的心跳检测机制,防止脑裂现象。
- 高可用性:使用 Grid Infrastructure 提供的高可用功能,确保节点故障时自动故障转移。
三、Oracle 使用案例
1. Java 示例:使用 JDBC 连接 Oracle
1.1 添加 Maven 依赖
在 pom.xml 中添加 Oracle JDBC 驱动依赖:
<dependencies><dependency><groupId>com.oracle.database.jdbc</groupId><artifactId>ojdbc8</artifactId><version>19.8.0.0</version></dependency>
</dependencies>
1.2 编写 Java 代码
import java.sql.Connection;
import java.sql.DriverManager;
import java.sql.ResultSet;
import java.sql.Statement;public class OracleExample {public static void main(String[] args) {String url = "jdbc:oracle:thin:@localhost:1521:ORCLCDB";String user = "myuser";String password = "mypassword";try {Connection conn = DriverManager.getConnection(url, user, password);Statement stmt = conn.createStatement();ResultSet rs = stmt.executeQuery("SELECT * FROM employees");while (rs.next()) {System.out.println(rs.getString("name") + ", " + rs.getString("position"));}rs.close();stmt.close();conn.close();} catch (Exception e) {e.printStackTrace();}}
}
2. Python 示例:使用 cx_Oracle 连接 Oracle
2.1 安装 cx_Oracle
pip install cx_Oracle
2.2 编写 Python 代码
import cx_Oracledef query_database():conn = cx_Oracle.connect("myuser/mypassword@localhost:1521/ORCLCDB")cursor = conn.cursor()cursor.execute("SELECT * FROM employees")for row in cursor:print(row)cursor.close()conn.close()if __name__ == "__main__":query_database()
总结
通过以上步骤,我们完成了 Oracle 单机和集群环境的部署,并实现了 Java 和 Python 的简单连接示例。Oracle 数据库作为企业级数据库管理系统,适用于各种高可用性和高性能需求的场景。
部署过程中的注意事项
- 硬件要求:确保服务器满足 Oracle 数据库的资源要求,尤其是 RAC 集群部署。
- 网络配置:在集群环境下,确保网络配置正确,特别是节点间通信和存储访问。
- 存储管理:在 RAC 中使用 ASM 管理共享存储,确保数据高效管理和安全性。
- 安全性:配置用户权限、启用 SSL 和网络加密,确保数据安全。
相关文章:
Oracle 单机和集群环境部署教程
目录 一、Oracle 单机环境部署1. 环境准备2. 安装 Oracle Database2.1 下载 Oracle Database2.2 创建 Oracle 用户和组2.3 配置内核参数和系统限制2.4 解压和安装2.5 配置监听程序2.6 创建数据库 3. 单机部署注意事项 二、Oracle 集群环境部署 (Oracle RAC)1. 环境准备2. 安装 …...
springboot 整合酷狗获取MV视频最高画质(使用自己账户)
在此声明,本内容仅供个人学习、研究或娱乐之用,严禁任何形式的商业用途。若您发现本内容被用于商业目的,请立即删除,及时与小编联系,我们将删除原代码。 请根据上一篇文章使用该代码:SpringBoot 整合酷狗获…...
数字孪生平台,助力制造设备迈入超感知与智控新时代!
痛点剖析 当前,制造业面临系统分散导致的数据孤岛问题,严重阻碍了有效监管与统计分析;同时,设备多样化且兼容性不足,增加了管理难度;台账记录方式混乱,工单审批流程繁琐且效率低下;…...
音视频入门基础:AAC专题(10)——FFmpeg源码中计算AAC裸流每个packet的pts、dts、pts_time、dts_time的实现
音视频入门基础:AAC专题系列文章: 音视频入门基础:AAC专题(1)——AAC官方文档下载 音视频入门基础:AAC专题(2)——使用FFmpeg命令生成AAC裸流文件 音视频入门基础:AAC…...
pycirclize python包画circos环形图
pycirclize python包画circos环形图 很多小伙伴都有画环形图的需求,网上也有很多画环形图的教程,讲解circos软件和circlize R包的比较多,本文介绍一款python包:pyCirclize。适合喜欢python且希望更灵活作图的小伙伴。 pyCirclize包实际上也…...
Redis Sorted Set 跳表的实现原理和分析
跳表(Skip List)是一种随机化的数据结构,基于有序链表,通过在链表上增加多级索引来提高数据的查找效率。它是由 William Pugh 在 1990 年提出的。 为什么 Redis 中的 Sorted Set 使用跳跃表 Redis 的有序集合(Sorted …...
新手教学系列——在MySQL分表中批量调整表结构的实践与优化
在当今的互联网业务中,随着数据量的不断增长,单个数据库的处理能力往往难以满足高并发、高性能的要求。因此,分库分表已经成为解决数据库扩展性问题的主流方案之一。然而,分表虽然能有效提升数据库的读写性能,但也带来了一个新的挑战:当业务需求变化时,需要对大量分表进…...
解决事务提交延迟问题:Spring中的事务绑定事件监听机制解析
目录 一、背景二、事务绑定事件介绍三、事务绑定事件原理四、结语 一、背景 实际工作中碰到一个场景,现存系统有10w张卡需要进行换卡,简单来说就是为用户生成一张新卡,批量换卡申请需要进行审核,审核通过后异步进行处理。 为什么…...
Python 异步编程的秘密武器:Asyncio
python编程中,异步编程是一个重要概念。它允许我们在等待某些操作(如网络请求或文件读写)时,不阻塞程序的其他部分运行。 在 Python 中,asyncio 是实现异步编程的强大工具。今天,我们将一同探索 asyncio 的…...
10年计算机考研408-计算机网络
【题33】下列选项中,不属于网络体系结构所描述的内容是() A.网络的层次 B.每一层使用的协议 C.协议的内部实现细节 D.每一层必须完成的功能 解析: 本题考查的是网络体系结构相关的概念。 图1描述了网络的7层架构以及每一层所要完成…...
深信服校招面试总结
许久没有更新博客,这两个月里发生的事情有些多。最近稍微稳定下来了,应该可以重新开始吧。 背景 首先感觉自己的笔试做的还行,除了第三个编程题没做出来,其他的应该都做出来了。当时忘记并查集的路径压缩怎么写了,加上…...
【LeetCode热题100】模拟
这篇博客记录了模拟相关的题目,也就是按照题目的描述写代码,很锻炼代码实现能力,包括了替换所有的问号、Z字形变换、外观数列、数青蛙4道题。 class Solution { public:string modifyString(string s) {int n s.size();for(int i 0 ; i <…...
如何在Chrome最新浏览器中调用ActiveX控件?
小编最近登陆工商银行网上银行,发现工商银行的个人网银网页,由于使用了ActiveX安全控件,导致不能用高版本Chrome浏览器打开,目前只有使用IE或基于IE内核的浏览器才能正常登录网上银行,而IE已经彻底停止更新了ÿ…...
一款好用的远程连接工具:MobaXterm
在日常工作中,作为开发者或运维人员,你是否经常需要远程连接服务器进行调试和管理?传统的SSH工具常常不够灵活,操作繁琐,无法满足日益复杂的工作需求。而MobaXterm的出现,带来了远程连接工具的全新体验。它…...
Spring Boot使用配置方式整合MyBatis
文章目录 一、实战目标二、步骤概览1. 创建部门映射器接口2. 创建映射器配置文件3. 配置全局映射器4. 测试映射器接口 三、详细步骤1、创建部门映射器接口2、创建映射器配置文件3、配置全局映射器4、测试映射器接口 四、结语 一、实战目标 在本实战课程中,我们将学…...
HarmonyOS第一课-应用程序框架基础习题答案
声明:本题库为最新的HarmonyOS第一课的学习题库,仅供参考学习! 一、判断题 1. 在基于Stage模型开发的应用项目中都存在一个app.json5配置文件、以及一个或多个module.json5配置文件。(正确) 正确(True) 错误(False) -…...
滚雪球学SpringCloud[10.2讲]:微服务项目的性能优化与调优
全文目录: 前言性能优化与调优概述性能优化的核心目标常见的性能瓶颈来源 性能瓶颈分析与调优策略1. 服务间通信优化优化策略: 2. 数据库优化优化策略: 3. 线程池优化优化策略: 4. 缓存优化优化策略: 常见问题的排查与解决1. 慢查…...
EasyExcel将数据库里面的数据生成excel文件
EasyExcel官方文档 1.在model模块导入依赖 <!-- 生成报表--> <dependency><groupId>com.alibaba</groupId><artifactId>easyexcel</artifactId><version>4.0.3</version> </dependency> 2.修饰实体类 package…...
【YOLO学习】YOLOv1详解
文章目录 1. 概述2. 算法流程3. 网络结构4. 损失函数 1. 概述 1. YOLO 的全称是 You Only Look Once: Unified, Real-Time Object Detection。YOLOv1 的核心思想就是利用整张图作为网络的输入,直接在输出层回归 bounding box 的位置和 bounding box 所属的类别。简单…...
HarmonyOS应用开发(组件库)--组件模块化开发、工具包、设计模式(持续更新)
致力于,UI开发拿来即用,提高开发效率 常量格式枚举enum格式正则表达式...手机号校验...邮箱校验 文件判断文件是否存在 网络下载下载图片从沙箱中图片转为Base64格式从资源文件中读取图片转Base64 组件输入框...矩形输入框...输入框堆叠效果(…...
利用最小二乘法找圆心和半径
#include <iostream> #include <vector> #include <cmath> #include <Eigen/Dense> // 需安装Eigen库用于矩阵运算 // 定义点结构 struct Point { double x, y; Point(double x_, double y_) : x(x_), y(y_) {} }; // 最小二乘法求圆心和半径 …...
C++_核心编程_多态案例二-制作饮品
#include <iostream> #include <string> using namespace std;/*制作饮品的大致流程为:煮水 - 冲泡 - 倒入杯中 - 加入辅料 利用多态技术实现本案例,提供抽象制作饮品基类,提供子类制作咖啡和茶叶*//*基类*/ class AbstractDr…...
前端倒计时误差!
提示:记录工作中遇到的需求及解决办法 文章目录 前言一、误差从何而来?二、五大解决方案1. 动态校准法(基础版)2. Web Worker 计时3. 服务器时间同步4. Performance API 高精度计时5. 页面可见性API优化三、生产环境最佳实践四、终极解决方案架构前言 前几天听说公司某个项…...
ElasticSearch搜索引擎之倒排索引及其底层算法
文章目录 一、搜索引擎1、什么是搜索引擎?2、搜索引擎的分类3、常用的搜索引擎4、搜索引擎的特点二、倒排索引1、简介2、为什么倒排索引不用B+树1.创建时间长,文件大。2.其次,树深,IO次数可怕。3.索引可能会失效。4.精准度差。三. 倒排索引四、算法1、Term Index的算法2、 …...
GruntJS-前端自动化任务运行器从入门到实战
Grunt 完全指南:从入门到实战 一、Grunt 是什么? Grunt是一个基于 Node.js 的前端自动化任务运行器,主要用于自动化执行项目开发中重复性高的任务,例如文件压缩、代码编译、语法检查、单元测试、文件合并等。通过配置简洁的任务…...
从面试角度回答Android中ContentProvider启动原理
Android中ContentProvider原理的面试角度解析,分为已启动和未启动两种场景: 一、ContentProvider已启动的情况 1. 核心流程 触发条件:当其他组件(如Activity、Service)通过ContentR…...
跨平台商品数据接口的标准化与规范化发展路径:淘宝京东拼多多的最新实践
在电商行业蓬勃发展的当下,多平台运营已成为众多商家的必然选择。然而,不同电商平台在商品数据接口方面存在差异,导致商家在跨平台运营时面临诸多挑战,如数据对接困难、运营效率低下、用户体验不一致等。跨平台商品数据接口的标准…...
本地部署drawDB结合内网穿透技术实现数据库远程管控方案
文章目录 前言1. Windows本地部署DrawDB2. 安装Cpolar内网穿透3. 实现公网访问DrawDB4. 固定DrawDB公网地址 前言 在数字化浪潮席卷全球的背景下,数据治理能力正日益成为构建现代企业核心竞争力的关键因素。无论是全球500强企业的数据中枢系统,还是初创…...
ABB馈线保护 REJ601 BD446NN1XG
配电网基本量程数字继电器 REJ601是一种专用馈线保护继电器,用于保护一次和二次配电网络中的公用事业和工业电力系统。该继电器在一个单元中提供了保护和监控功能的优化组合,具有同类产品中最佳的性能和可用性。 REJ601是一种专用馈线保护继电器…...
JS设计模式(5): 发布订阅模式
解锁JavaScript发布订阅模式:让代码沟通更优雅 在JavaScript的世界里,我们常常会遇到这样的场景:多个模块之间需要相互通信,但是又不想让它们产生过于紧密的耦合。这时候,发布订阅模式就像一位优雅的信使,…...
