- 浏览: 273297 次
- 性别:
- 来自: 南京
文章分类
最新评论
-
Java_zhou:
...
Oracle自定义函数 -
wmj007:
SELECT USER_TAB_COLS.TABLE_NAME ...
Oracle 查询字段详细信息 -
avi9111:
怎么可以个人有一个MQ? 咁威的
使用c#操作IBM WebSphere MQ -
chouchouzzj:
8个小时。。。让我想起了世界时和北京时之间的差距,MQ存在时区 ...
使用c#操作IBM WebSphere MQ
学习在 RHEL 2.1、RHEL 3 或 SLES 8 上从头安装 Oracle 数据库 10g 的基础知识(仅用于评估)
目录概述
第 1 部分:安装 Linux
RHEL 2.1
RHEL 3
SLES 8
第 2 部分:针对 Oracle 配置 Linux
验证系统要求
创建目录
创建 Oracle 组和用户帐户
配置 Linux 内核参数
为 Oracle 用户设置 Shell 限制
避免错误!(仅限 SLES 8)
Oracle 用户的环境变量
第 3 部分:安装 Oracle
安装软件
第 4 部分:配置存储
文件系统
自动存储管理
结论
附录
这是在 Linux 上安装 Oracle 10g 软件主要组件指南系列的第一部分。这些文章详细介绍了 Linux 的所有三个已认证的英语发行套件(未介绍 Asianux),并假设使用廉价的 Intel x86 硬件。同时,还逐步演示了为评估主要 Oracle 10g 产品而在常见硬件上进行安装和配置的过程。
该系列的根本目标是逐步演示如何安装和配置 10g 网格的所有组件。通过这个系列,您将了解如何安装和配置单实例 Oracle 10g 数据库(本文)、双节点 Oracle RAC 10g 数据库、Oracle 应用服务器 10g 和 Oracle Enterprise Manager 10g 网格控制的所有主要组件。
该系列提供的方法将采用最简单的途径(步骤数最少)来完成任务。该方法通常意味着所选择的配置将只适用于评估。因此,该系列既不适用于构建生产品质的环境,也不反映最佳实践。
以下是这些文章所介绍的获得 Oracle 10g 认证的三个 Linux 发行套件:
- Red Hat Enterprise Linux 2.1
- Red Hat Enterprise Linux 3
- Novell SUSE Linux Enterprise Server 8
本文由四部分组成:第 1 部分介绍了如何安装 Linux 操作系统,第 2 部分介绍了如何针对 Oracle 配置 Linux,第 3 部分介绍了 Oracle 数据库安装的要点,第 4 部分介绍了如何创建其他文件系统并介绍了自动存储管理 (ASM)(Oracle 数据库 10g 中一个出色的新特性,它显著简化了存储管理)。附录提供了帮助您了解新数据库用法的信息,其中包括如何交互地访问该数据库、如何停止和启动数据库及相关服务。
本指南采用具有以下硬件配置的服务器:
- 两个 800MHz Pentium III CPU
- 512MB RAM
- 两个 SCSI 主机适配器 (Ultra SCSI 160)
- 八个 SCSI 磁盘驱动器 (2 x 9GB + 6 x 36GB)
- 一个 100Base-T 以太网适配器
- 一个 1000Base-T 以太网适配器
对磁盘进行配置,使每个 SCSI 主机适配器连接到一个 9GB 磁盘和三个 36GB 磁盘。
请注意,尽管这根本算不上是一个“强大”的设置,但即便是使用再低的设置也可以完成本指南介绍的大部分任务。基本数据库安装只需要一个 CPU、512MB 内存和一个可用空间至少为 6.5GB 的磁盘驱动器(IDE、SCSI 或 FireWire)。
现在,我们将逐步演示在服务器上安装 Linux 操作系统的过程。本文假设进行 Linux 系统全新安装(有别于升级),并假设服务器为 Oracle 所专用,且服务器上没有其他操作系统或数据。
Oracle 10g 经认证可以在 Red Hat Enterprise Linux 2.1(Advanced Server 和 Enterprise Server)(Update 3) 或更高版本上运行。Red Hat Network (RHN) 提供更新,这些更新可以作为用于创建 CD 的 ISO 文件或作为单个程序包更新下载。
要对全新 Linux 安装应用更新,最简单、最快速的方法是使用更新 CD 执行安装。如果 Linux 已经安装或 CD 上没有更新,则可以通过 RHN 应用这些更新。由于本指南针对的是全新 Linux 安装,因此您将使用更新 CD。
- 使用更新 CD 集中的第一张 CD 启动服务器。
- 您可能需要更改 BIOS 设置,以允许从 CD 启动。
- 启动屏幕上出现时在底部显示 boot:。
- 选择 Enter,从控制台上执行图形安装。(对于其他安装方法和选项,请参阅 Red Hat 安装指南。)
- 安装程序扫描硬件,短暂显示 Red Hat 闪屏,然后开始显示一系列屏幕提示。
- 选择语言
- 接受默认值。
- 配置键盘
- 接受默认值。
- 配置鼠标
- 接受默认值。
- 安装类型
- 接受默认值。
- 设置磁盘分区
- 本文不介绍磁盘分区的详细方法,而是假设您熟悉磁盘分区方法。
(警告:对磁盘进行错误分区是删除硬盘上所有内容的最可靠、最快捷的方法之一。如果不确定如何分区,请先停下来,找人帮帮您,否则您将冒丢失数据的危险!)
本文使用以下分区方案(文件系统均为 ext3):
第一个控制器 (/dev/sda) 上的 9GB 磁盘包含以下分区,用于存放所有 Linux 和 Oracle 软件:
- 100MB /boot 分区(对于 RHEL 2.1,最小为 50MB)
-1,500MB 交换分区 — 将此分区大小至少设置为系统 RAM 的两倍,但不要超过 2GB(32 位系统不支持大于 2GB 的交换文件)。如果需要大于 2GB 的交换空间,则创建多个交换分区。
-7,150MB 根分区 — 该分区将用于所有目录,包括 /usr、/tmp、/var、/opt、/home 等。这样做纯粹是为了讲解本指南而简化安装。更可靠的分区方案是将这些目录划分到单独的文件系统。
- 本文不介绍磁盘分区的详细方法,而是假设您熟悉磁盘分区方法。
- 配置启动加载程序
- 接受默认值。
- 配置启动加载程序口令
- 如果要为 GRUB 设置口令,请在此处输入。对于评估系统,无需设置该项。
- 配置网络
- 通常情况下,最好使用静态 IP 地址配置数据库服务器。为此,取消选中 Configure using DHCP 并输入服务器的网络配置。确保输入了主机名且已选中 Activate on boot。
- 配置防火墙
- 出于本演示的需要,将不配置防火墙。选择 No firewall(安全管理员,请不要生气)。
- 其他语言支持
- 接受默认值。
- 选择时区
- 选择适合您区域的时间设置。将系统时钟设置为 UTC 对服务器而言通常是一个很好的做法。为此,单击 System clock uses UTC。
- 配置帐户
- 为 root 用户选择一个口令,并将其输入所给的域中。为自己创建一个帐户。(不要在此时创建 oracle 帐户;我们将在稍后创建它。)
- 选择程序包组
- 选择 Gnome 或 KDE(或两者都选择)图形用户界面(默认为 Gnome)。注意:这两个 GUI 都非常受欢迎,其中 Gnome 在美国使用更普遍。我个人偏爱 KDE,这是因为它的终端模拟器可轻松实现剪切和粘贴,从而可将输入复制到多个连接(例如,当您在多个节点上配置 RAC 时,这将节省键入操作)。
- 选择 Software Development
- 未解决的相关性
- 如果看到此屏幕,只需选择 Install packages to satisfy dependencies(默认值)并继续操作。
- 配置图形界面 (X)
- 接受默认值,除非安装程序无法识别您的视频卡。如果您的视频卡无法被识别,则将无法继续操作。
- 准备安装
- 单击 Next
- 安装程序包
- 软件将被复制到硬盘并被安装。根据提示更改磁盘,然后在安装完成时单击 Next。
- 创建启动磁盘
- 如果需要,创建一张启动磁盘,或选择 Skip boot disk creation。
- 配置监视器
- 如果安装程序正确识别了您的监视器,则接受默认值。否则,从列表中选择一个兼容的监视器。
- 恭喜
- 从系统中取出安装介质,然后单击 Next。
验证您的安装
如果完成了以上步骤,您应该具备 Oracle 10g 所需的所有程序包和更新。您可以执行以下步骤验证您的安装。
所需内核版本:2.4.9-e.25(或更高版本)
通过运行以下命令检查内核版本:
uname -r 例如: # uname -r 2.4.9-e.27smp其他所需程序包的版本(或更高版本):
- gcc-2.96-124
- make-3.79
- binutils-2.11
- openmotif-2.1.30-11
- glibc-2.2.4-31
rpm -q gcc make binutils openmotif glibc 例如: # rpm -q gcc make binutils openmotif glibc gcc-2.96-118.7.2 make-3.79.1-8 binutils-2.11.90.0.8-12 openmotif-2.1.30-11 glibc-2.2.4-32.8如果系统上缺少任何程序包版本,或版本比以上指定的版本旧,则可以从 Red Hat Network 下载并安装更新。
Oracle 10g 经认证可以在不需要更新的情况下运行 Red Hat Enterprise Linux 3(Advanced Server 和 Enterprise Server)的基本版本。如果拥有更新 CD,则可以使用更新版本中的启动 CD 而非基本版本中的启动 CD 在安装过程中自动应用所有更新。Oracle 支持 Red Hat 的所有更新。
- 使用第一张 CD 启动服务器。
- 您可能需要更改 BIOS 设置,以允许从 CD 启动。
- 启动屏幕上出现时在底部显示 boot:。
- 选择 Enter,从控制台上执行图形安装。(对于其他安装方法和选项,请参阅 Red Hat 安装指南。)
- 安装程序扫描硬件,短暂显示 Red Hat 闪屏,然后开始显示一系列屏幕提示。
- 选择语言
- 接受默认值。
- 配置键盘
- 接受默认值。
- 欢迎屏幕
- 单击 Next。
- 配置鼠标
- 接受默认值。
- 安装类型
- 选择 Custom。
- 设置磁盘分区
- 本文不介绍磁盘分区的详细方法,而是假设您熟悉磁盘分区方法。
(警告:对磁盘进行错误分区是删除硬盘上所有内容的最可靠、最快捷的方法之一。如果不确定如何分区,请先停下来,找人帮帮您,否则您将冒丢失数据的危险!)
本文使用以下分区方案(文件系统均为 ext3):
第一个控制器 (/dev/sda) 上的 9GB 磁盘包含以下分区,用于存放所有 Linux 和 Oracle 软件:
- 100MB /boot 分区
-1,500MB 交换分区 — 将此分区大小至少设置为系统 RAM 的两倍,但不要超过 2GB(32 位系统不支持大于 2GB 的交换文件)。如果需要大于 2GB 的交换空间,则创建多个交换分区。
-7,150MB 根分区 — 该分区将用于所有目录,包括 /usr、/tmp、/var、/opt、/home 等。这样做纯粹是为了讲解本指南而简化安装。更可靠的分区方案是将这些目录划分到单独的文件系统。
- 本文不介绍磁盘分区的详细方法,而是假设您熟悉磁盘分区方法。
- 配置启动加载程序
- 接受默认值。
- 配置网络
- 通常情况下,最好使用静态 IP 地址配置数据库服务器。为此,单击 Edit。
- 出现一个弹出窗口。取消选中 Configure using DHCP 复选框,并输入服务器的 IP 地址和网络掩码。确保选中 Activate on boot,然后单击 OK。
- 在 Hostname 框中,选择 manually 并输入主机名。
- 在 Miscellaneous Settings 框中,输入其他网络设置。
- 配置防火墙
- 出于本演示的需要,将不配置防火墙。选择 No firewall。
- 其他语言支持
- 接受默认值。
- 选择时区
- 选择适合您区域的时间设置。将系统时钟设置为 UTC 对服务器而言通常是一个很好的做法。为此,单击 System clock uses UTC。
- 设置 Root 口令
- 输入 root 的口令,并再次输入以进行确认。
- 选择程序包组
- 只选择此处显示的程序包集,其他选项不要选。
- 桌面
- X Window 系统
- Gnome
- KDE
- 请参阅我在 RHES 2.1 部分中提供的有关 GUI 选择的意见。
- 应用程序
- 编辑器
- 图形因特网
- 服务器
- 不要选择该组中的任何选项。
- 开发
- 开发工具
- 系统
- 管理工具
- Red Hat Enterprise Linux
- 不要选择该组中的任何选项。
- 杂项
- 原有软件开发 - 单击 Next 继续操作。
- 准备安装
- 单击 Next。
- 安装程序包
- 软件将被复制到硬盘并被安装。根据提示更改磁盘,然后在安装完成时单击 Next。
- 配置图形界面 (X)
- 接受默认值,除非安装程序无法识别您的视频卡。如果您的视频卡无法被识别,则将无法继续操作。
- 配置监视器
- 如果安装程序正确识别了您的监视器,则接受默认值。否则,从列表中选择一个兼容的监视器。
- 定制图形配置
- 接受默认值。
- 恭喜
- 从系统中取出安装介质,然后单击 Next。
- 系统自动重新启动并显示一个新的欢迎屏幕。
- 单击 Next。
- 许可协议
- 阅读许可协议。如果同意其中的条款,则选择 Yes, I agree to the License Agreement 并单击 Next。
- 日期和时间
- 设置日期和时间。
- 如果要使用 NTP 服务器(推荐),则选择 Enable Network Time Protocol 并输入 NTP 服务器的名称。
- 用户帐户
- 为自己创建一个帐户。
- 此时不要为 oracle 创建帐户。本部分稍后将介绍如何创建 oracle 帐户。
- Red Hat Network
- 如果要立即使用或激活 Red Hat Network 帐户,则接受默认值,单击 Next 并遵循 Red Hat 产品附带的产品激活说明。
- 其他 CD
- 单击 Next。
- 完成设置
- 单击 Next。
- 出现一个图形登录屏幕。
- 恭喜!您的 Linux 软件现已安装完毕。
如果完成了以上步骤,您应该具备 Oracle 10g 所需的所有程序包和更新。您可以执行以下步骤验证您的安装。
所需内核版本:2.4.21-4.EL(这是 RHEL 3 的基本版本附带的内核版本。此内核或更新中提供的任何版本的内核均适用于 Oracle 10g。)
通过运行以下命令检查内核版本:
uname -r 例如: # uname -r 2.4.21-4.0.1.ELsmp其他所需程序包的版本(或更高版本):
- gcc-3.2.3-2
- make-3.79
- binutils-2.11
- openmotif-2.2.2-16
- setarch-1.3-1
- compat-gcc-7.3-2.96.122
- compat-gcc-c++-7.3-2.96.122
- compat-libstdc++-7.3-2.96.122
- compat-libstdc++-devel-7.3-2.96.122
- compat-db-4.0.14.5(Oracle 10g 数据库安装指南 中将其列为是必需的,但此处并不需要)
rpm -q gcc make binutils openmotif setarch compat-db compat-gcc \ compat-gcc-c++ compat-libstdc++ compat-libstdc++-devel 例如: # rpm -q gcc make binutils openmotif setarch compat-db compat-gcc \ > openmotif compat-gcc-c++ compat-libstdc++ compat-libstdc++-devel gcc-3.2.3-20 make-3.79.1-17 binutils-2.14.90.0.4-26 openmotif-2.2.2-16 setarch-1.3-1 package compat-db is not installed compat-gcc-7.3-2.96.122 compat-gcc-c++-7.3-2.96.122 compat-libstdc++-7.3-2.96.122 compat-libstdc++-devel-7.3-2.96.122请注意,尚未安装 compat-db 程序包。安装过程中可用的任何程序包组均不包含此程序包,因此必须在单独的步骤中安装。如果系统上缺少任何其他程序包版本,或版本比以上指定的版本旧(compat-db 除外),则可以从 Red Hat Network 下载并安装更新。
安装 compat-db
插入原始 Red Hat Enterprise Linux 介质的第二张 CD。(Update 2 中未包含该程序包,它仅存在于原始介质中。)
此 CD 自动挂载。
以 root 用户身份运行以下命令:
rpm -ivh /mnt/cdrom/RedHat/RPMS/compat-db-4.0.14-5.i386.rpm 例如: # rpm -ivh /mnt/cdrom/RedHat/RPMS/compat-db-4.0.14-5.i386.rpm Preparing... ########################################### [100%] 1:compat-db ########################################### [100%]
SUSE Linux Enterprise Server 8
Oracle 10g 经认证可以在 Novell SUSE Linux Enterprise Server (SLES) 8 上运行。Novell 通过 CD 或通过其支持门户在线提供 Service Pack 和程序包更新。在本指南中,我们将从 CD 安装 SLES 8 (Service Pack 3)。
- 使用 SLES 8 CD 启动服务器。
- 您可能需要更改 BIOS 设置,以允许从 CD 启动。
- 出现 SUSE Linux Enterprise Server 安装屏幕。
- 选择 Installation。
- 安装程序扫描您的硬件并显示 YaST 界面。
- 选择语言
- 接受许可协议。
- 接受默认值 English (US)。
- 安装设置
- 选择 New Installation。
- 分区
- 本文不介绍磁盘分区的详细方法,而是假设您熟悉磁盘分区方法。
(警告:对磁盘进行错误分区是删除硬盘上所有内容的最可靠、最快捷的方法之一。如果不确定如何分区,请先停下来,找人帮帮您,否则您将冒丢失数据的危险!)
本文使用以下分区方案(文件系统均为 ext3):
第一个控制器 (/dev/sda) 上的 9GB 磁盘包含以下分区,用于存放所有 Linux 和 Oracle 软件:
- 100MB /boot 分区
-1,500MB 交换分区 — 将此分区大小至少设置为系统 RAM 的两倍,但不要超过 2GB(32 位系统不支持大于 2GB 的交换文件)。如果需要大于 2GB 的交换空间,则创建多个交换分区。
-7,150MB 根分区 — 该分区将用于所有目录,包括 /usr、/tmp、/var、/opt、/home 等。这样做纯粹是为了讲解本指南而简化安装。更可靠的分区方案是将这些目录划分到单独的文件系统。
- 本文不介绍磁盘分区的详细方法,而是假设您熟悉磁盘分区方法。
- 软件
- 单击 Software 的链接。
- 出现 Software Selection 屏幕。
- 单击 Detailed Selection。
- 左侧窗口显示软件选择列表。单击每个选项旁的复选框以将其选中/取消选中。
- 选择以下软件(这是推荐的软件集;不要选中其他软件):
- C/C++ 编译器和工具
- KDE(或 Gnome)
- LSB 运行时环境
- 帮助与支持文档
- 图形基本系统
- YaST2 配置模块
- SLES 管理工具
- 建议不要安装以下项,因为它们可能与提供相同服务的 Oracle 产品冲突:
- 简单 Web 服务器
- 身份验证服务器(NIS、LDAP、Kerberos)
- 时区
- 设置您的时区。
- 单击 Accept。
- 出现一个警告对话框。准备好继续操作时,单击 Yes, install。
- 根据安装程序的提示更换 CD。
- 安装此软件后,将显示一个窗口,提示基本系统已经安装成功。
- 取出安装 CD,然后单击 OK。
- 系统重新启动。
- 输入 root 用户的口令,并再次输入以进行确认。
- 为自己创建一个帐户。不要在此时创建 oracle 帐户;我们将在稍后创建它。
- 桌面设置
- 接受默认值。
- 出现一个有关自动检测本地打印机的警告窗口。
- 单击 Skip detection。
- 配置网络接口,并在准备好继续操作后单击 Next。
- 建议为服务器设置静态 IP 地址。
- 构建数据库无需配置打印机、调制解调器、ISDN 适配器或声卡。
- 出现一个图形登录屏幕。
- 现在,您需要安装 Service Pack 3。以您自己的身份登录。
- 插入更新 CD,然后单击 Patch CD Update。
- 启动 YaST2(SUSE 的系统管理工具)。
- 选择 SUSE > System > YaST2。(SUSE 是位于屏幕左下部带微笑蜥蜴侧脸的绿色圆按钮。它相当于“开始”。)
- 出现一个窗口,提示输入 root 用户口令。输入口令,然后单击 OK。
- 出现 YaST Control Center。
- 出现 YaST Online Update 窗口。
- 接受默认值,然后单击 Next。
- 出现一个窗口,显示一个补丁更新列表。
- YaST 在更新系统其他部分之前需要先对自身进行更新。所需程序包已被选中。此时不要选择任何其他程序包。
- 单击 Accept。
- 出现一个窗口,提示重新启动在线更新。
- 单击 OK。
- 出现一个窗口,提示安装已成功。
- 单击 OK。
- 在 YaST Online Update 窗口中,单击 Finish。
- 在 YaST Control Center 窗口中,单击 Close。
- 重复步骤 21 和 22。
- 出现一个窗口,显示一个补丁更新列表。
- 单击 Accept 接受默认值。
- 可能出现包含各种提示(如“Make sure you update sendmail”)的小弹出窗口。单击 OK 关闭它们。
- 此步骤需要一些时间。将光标悬停在 Next 按钮上。如果更新仍在运行,则显示一个时钟图标。
- 出现一个窗口,提示安装已成功。
- 单击 OK。
- 在 YaST Online Update 屏幕上,单击 Next。
- 安装程序写系统配置。
- 在 YaST Control Center 中,单击 Close。
- 注销。
- SUSE > Logout。
- 取出更新 CD。
- 重新启动系统。
- 在图形登录屏幕上,单击 Menu。
- 选择 Shutdown。
- 选择 Restart computer。
- 输入 root 口令。
- 单击 OK。
- 恭喜!您的 Linux 软件现已安装完毕。
如果完成了以上步骤,您应该具备 Oracle 10g 所需的所有程序包和更新。您可以执行以下步骤验证您的安装。
所需内核版本:2.4.21-138(或更高版本)
通过运行以下命令检查内核版本:
uname -r 例如: # uname -r k_smp-2.4.21-138其他所需程序包的版本(或更高版本):
- gcc-3.2.2-38
- make-3.79
- binutils-2.12
- openmotif-2.2.2-124
rpm -q gcc make binutils openmotif 例如: # rpm rpm -q gcc make binutils openmotif gcc-3.2.2-38 make-3.79.1-407 binutils-2.12.90.0.15-50 openmotif-2.2.2-124如果系统上缺少任何程序包版本,或版本比以上指定的版本旧,则可以从 SUSE Linux Portal 下载和安装更新。
Linux 软件现已安装完毕,您需要针对 Oracle 对其进行配置。本部分将逐步讲解针对 Oracle 数据库 10g 配置 Linux 的过程。
要验证系统是否满足 Oracle 10g 数据库的最低要求,以 root 用户身份登录并运行以下命令。
要查看可用 RAM 和交换空间大小,运行以下命令:grep MemTotal /proc/meminfo grep SwapTotal /proc/meminfo 例如: # grep MemTotal /proc/meminfo MemTotal:512236 kB # grep SwapTotal /proc/meminfo SwapTotal:1574360 kB
所需最小 RAM 为 512MB,而所需最小交换空间为 1GB。对于 RAM 小于或等于 2GB 的系统,交换空间应为 RAM 数量的两倍;对于 RAM 大于 2GB 的系统,交换空间应为 RAM 数量的一到两倍。
Oracle 10g 软件还需要 2.5GB 的可用磁盘空间,而数据库则另需 1.2GB 的可用磁盘空间。/tmp 目录至少需要 400MB 的可用空间。要检查系统上的可用磁盘空间,运行以下命令:
df -h 例如: # df -h Filesystem Size Used Avail Use% Mounted on /dev/sda3 6.8G 1.3G 5.2G 20% / /dev/sda1 99M 17M 77M 18% /boot
该示例表明,/tmp 目录没有自己的文件系统。(对本指南而言,它是根文件系统的一部分。)根文件系统可用空间为 5.2 GB,除了满足安装 (2.5 + 1.2 + 0.4 = 4.1GB) 外还小有富余。
接下来,创建用于安装和维护 Oracle 10g 软件的 Linux 组和用户帐户。用户帐户将称为 oracle,而组将称为 oinstall 和 dba。以 root 用户身份执行以下命令:
/usr/sbin/groupadd oinstall /usr/sbin/groupadd dba /usr/sbin/useradd -m -g oinstall -G dba oracle id oracle 例如: # /usr/sbin/groupadd oinstall # /usr/sbin/groupadd dba # /usr/sbin/useradd -m -g oinstall -G dba oracle # id oracle uid=501(oracle) gid=501(oinstall) groups=501(oinstall),502(dba)
设置 oracle 帐户的口令:
passwd oracle 例如: # passwd oracle Changing password for user oracle. New password: Retype new password: passwd:all authentication tokens updated successfully.
现在,创建存储 Oracle 10g 软件和数据库文件的目录。本指南在创建目录结构时所用的命名惯例符合最佳灵活结构 (OFA) 规范。有关 OFA 标准的更多信息,请参阅针对 UNIX 系统的 Oracle 数据库 10g 安装指南 的附录 D。
以下假设在根文件系统中创建目录。这样做是为了简便起见,不建议将其作为通用做法。这些目录通常被创建为单独的文件系统。
以 root 用户身份执行以下命令:
mkdir -p /u01/app/oracle mkdir -p /u02/oradata chown -R oracle:oinstall /u01/app/oracle /u02/oradata chmod -R 775 /u01/app/oracle /u02/oradata 例如: # mkdir -p /u01/app/oracle # mkdir -p /u02/oradata # chown -R oracle:oinstall /u01/app/oracle /u02/oradata # chmod -R 775 /u01/app/oracle /u02/oradata
Linux 内核非常出色。与大多数其他 *NIX 系统不同,Linux 允许在系统启动和运行时修改大多数内核参数。完成内核参数更改后不必重新启动系统。Oracle 数据库 10g 需要以下所示的内核参数设置。其中给出的是最小值,因此如果您的系统使用的值较大,则不要更改它。
kernel.shmall = 2097152 kernel.shmmax = 2147483648 kernel.shmmni = 4096 kernel.sem = 250 32000 100 128 fs.file-max = 65536 net.ipv4.ip_local_port_range = 1024 65000
如果您按照以上说明安装了 Linux,且内核参数全部采用默认值,则只需在以 root 用户身份登录后执行下命令。
cat >> /etc/sysctl.conf <<EOF kernel.shmall = 2097152 kernel.shmmax = 2147483648 kernel.shmmni = 4096 kernel.sem = 250 32000 100 128 fs.file-max = 65536 net.ipv4.ip_local_port_range = 1024 65000 EOF /sbin/sysctl -p 例如: # cat >> /etc/sysctl.conf <<EOF > kernel.shmall = 2097152 > kernel.shmmax = 2147483648 > kernel.shmmni = 4096 > kernel.sem = 250 32000 100 128 > fs.file-max = 65536 > net.ipv4.ip_local_port_range = 1024 65000 > EOF # /sbin/sysctl -p net.ipv4.ip_forward = 0 net.ipv4.conf.default.rp_filter = 1 kernel.sysrq = 0 kernel.shmall = 2097152 kernel.shmmax = 2147483648 kernel.shmmni = 4096 kernel.sem = 250 32000 100 128 fs.file-max = 65536 net.ipv4.ip_local_port_range = 1024 65000
以 root 用户身份运行以下命令来验证您的设置:
/sbin/sysctl -a | grep shm /sbin/sysctl -a | grep sem /sbin/sysctl -a | grep file-max /sbin/sysctl -a | grep ip_local_port_range 例如: # /sbin/sysctl -a | grep shm kernel.shmmni = 4096 kernel.shmall = 2097152 kernel.shmmax = 2147483648 kernel.shm-use-bigpages = 0 # /sbin/sysctl -a | grep sem kernel.sem = 250 32000 100 128 # /sbin/sysctl -a | grep file-max fs.file-max = 65536 # /sbin/sysctl -a | grep ip_local_port_range net.ipv4.ip_local_port_range = 1024 65000
如果系统的参数设置的比上述参数值小,则编辑 /etc/sysctl.conf 文件,添加或更改这些参数。完成后,运行以下命令激活更改:
/sbin/sysctl -p
对于 SLES 8,在完成以上步骤后运行以下命令。
/sbin/chkconfig boot.sysctl on
Oracle 建议对每个 Linux 帐户可以使用的进程数和打开的文件数设置限制。要进行这些更改,以 root 用户的身份执行下列命令:
cat >> /etc/security/limits.conf <<EOF oracle soft nproc 2047 oracle hard nproc 16384 oracle soft nofile 1024 oracle hard nofile 65536 EOF cat >> /etc/pam.d/login <<EOF session required /lib/security/pam_limits.so EOF
对于 RHEL 2.1 和 RHEL 3,使用以下命令:
cat >> /etc/profile <<EOF if [ \$USER = "oracle" ]; then if [ \$SHELL = "/bin/ksh" ]; then ulimit -p 16384 ulimit -n 65536 else ulimit -u 16384 -n 65536 fi umask 022 fi EOF cat >> /etc/csh.login <<EOF if ( \$USER == "oracle" ) then limit maxproc 16384 limit descriptors 65536 umask 022 endif EOF
对于 SLES 8,使用以下命令:
cat >> /etc/profile.local <<EOF if [ \$USER = "oracle" ]; then if [ \$SHELL = "/bin/ksh" ]; then ulimit -p 16384 ulimit -n 65536 else ulimit -u 16384 -n 65536 fi umask 022 fi EOF cat >> /etc/csh.login.local <<EOF if ( \$USER == "oracle" ) then limit maxproc 16384 limit descriptors 65536 umask 022 endif EOF
在 SLES 8 上安装 Oracle Enterprise Manager 10g 时存在一个错误 — 由于所需端口以为 /etc/services 所保留而导致安装失败。OEM DBConsole 需要端口 1830,而在 SLES8 环境中,此端口已经为 /etc/services 所保留。此错误在 MetaLink 上的错误号为 3513603。
要避免安装过程中出现问题,以 root 用户身份登录,并在安装 Oracle 10g 软件之前将 /etc/services 文件中的端口 1830 至 1849 对应的行注释掉。(注意:此时,您最好重新启动服务器以确保以上更改生效。)
要使用 Oracle 产品,应该或必须设置几个环境变量。对于数据库服务器,建议设置以下环境变量:
ORACLE_BASE
ORACLE_HOME
ORACLE_SID
PATH
如果您在同一服务器上安装了多个 Oracle 产品或数据库,则 ORACLE_HOME、ORACLE_SID 和 PATH 变量可能会更改。ORACLE_BASE 变量不应更改,并可以在需要时在您的登录配置文件中设置它。Oracle 提供了一个称作 oraenv 的实用程序来设置其他变量。
以 oracle 身份登录,并通过在 .bash_profile 或 .profile(bash 或 ksh)中添加以下行,将 ORACLE_BASE 添加到登录配置文件:
ORACLE_BASE=/u01/app/oracle; export ORACLE_BASE
或在 .login (csh) 中添加以下行:
setenv ORACLE_BASE /u01/app/oracle
此更改将在您下次登录到 oracle 帐户时生效。要使更改对当前会话为活动状态,只需从命令行运行此命令。
可以从 OTN 下载 Oracle 数据库 10g。Oracle 提供了一个免费的开发和测试许可。但不提供支持,且该许可不允许用于生产目的。OTN 提供了完整的许可协议。
要使 Oracle 10g 发行套件介质可以在服务器上使用,最简单的方法是将其直接下载到服务器。
使用图形登录以 oracle 身份登录。
创建一个目录以存放 Oracle 10g 发行套件:
mkdir 10g_db
要从 OTN 下载 Oracle 数据库 10g,请将浏览器(Mozilla 比较好用)指向 http://www.oracle.com/technology/software/products/database/oracle10g/htdocs/linuxsoft.html。填写 Eligibility Export Restrictions 页面,并阅读 OTN 许可协议。如果您接受限制和许可协议,则单击 I Accept。
单击 ship.db.cpio.gz 链接,并将该文件保存在为此目的创建的目录 (10g_db) 中 — 如果尚未登录到 OTN,则此时可能提示您登录。
解压缩此文件:
cd 10g_db gunzip ship.db.cpio.gz cpio -idmv < ship.db.cpio
使用 oracle 帐户登录。
指定数据库名称 (ORACLE_SID)。该名称通常不多于五个字符。对此安装使用 demo1。
设置环境变量:
- Borne shell 和 Korn shell
ORACLE_BASE=/u01/app/oracle; export ORACLE_BASE ORACLE_SID=demo1; export ORACLE_SID
- C shell
setenv ORACLE_BASE /u01/app/oracle setenv ORACLE_SID demo1
例如: $ cd $HOME/10g_db
将目录更改为 Disk1。
例如: $ cd Disk1
启动 Oracle 通用安装程序。
$ ./runInstaller
- 欢迎
- 单击 Next。
- 指定清单目录和证书
- 如果您一直在依循本指南中的步骤,则使用默认值即可。否则,编辑清单目录的路径,以指向正确目录。
- 操作系统组名称应为 oinstall。
- 如果这是首次在此机器上安装 Oracle,则您将收到一个弹出窗口,提示需要以 root 用户身份运行 orainstRoot.sh 脚本。以 root 用户身份登录,更改到窗口中指定的目录,执行该脚本,然后继续操作。
- 指定文件位置
- 如果您一直在依循本指南中的步骤,则使用默认值即可。否则,在继续操作前确保源路径和目标路径正确。
- 选择安装类型
- 接受默认值 Enterprise Edition。
- 与特定产品相关的先决条件的检查
- 如果您一直在依循本指南中的步骤,则所有检查都应顺利通过。如果一个或多个检查失败,则在继续操作前纠正该问题。
- 选择数据库配置
- 接受默认值 Create a starter database 和 General Purpose。
- 指定数据库配置选项
- 输入数据库的全局数据库名称。该名称应包含 ORACLE_SID 和服务器域名(例如,demo1.orademo.org,其中 demo1 是 ORACLE_SID,orademo.org 是域名)。
- 输入全局数据库名称时,SID 框将自动填充。
- 接受默认的数据库字符集。
- 选择 Create database with sample schemas。
- 选择数据库管理选项
- 选择 Use Database Control for Database Management。
- 指定数据库文件存储选项
- 选择 File System,然后输入数据库文件要使用的路径名(在本例中为 /u02/oradata)。
- 指定备份和恢复选项
- 选择 Do not enable Automated backups。
- 指定数据库模式口令
- 选择 Use the same password for all the accounts。
- 选择一个口令,然后输入两次进行确认。
- 摘要
- 显示已安装产品的摘要。
- 单击 Install。
- 安装
- 此屏幕历经安装和链接 Oracle 软件的几个阶段。
- 安装过程结束时弹出一个窗口显示配置信息。记下 Enterprise Manager URL,然后单击 OK 关闭该窗口。
- 弹出一个“Setup Privileges”窗口,提示需要以 root 用户身份运行配置脚本。以 root 用户身份登录,切换到该窗口中指示的目录,然后执行 root.sh 脚本。该脚本提示输入本地 bin 目录的位置。按 Enter 键接受默认值。当脚本完成时,返回到 Setup Privileges 窗口并单击 OK。(如下所示。)
- 安装结束
- 记下摘要中显示的 URL,并在准备好时单击 Exit。
- 恭喜!您的新 Oracle 10g 数据库已经启动并可以使用。
我们在第 3 部分中创建的数据库使用单一文件系统 (/u02/oradata) 进行磁盘存储。但为 Oracle 数据库配置存储的方式有多种。
第 4 部分介绍了为此数据库配置磁盘存储的其他方法。尤其是,它描述了如何创建其他文件系统以及如何使用自动存储管理 (ASM)。如何使用原始设备和 Oracle 集群文件系统 (OCFS) 将在本系列的另一篇文章中介绍,该篇文章介绍了如何使用 Oracle 真正应用集群 (RAC) 创建集群数据库。
文件系统是为 Oracle 数据库存储数据文件、重做日志和控制文件最常用的方法。文件系统易于实施,并且无需第三方软件来管理。
大多数情况下,文件系统在 Linux 的初始安装过程中创建。但有时必须在初始安装后(如安装新磁盘驱动器后)创建新文件系统。
本部分介绍了如何构建新文件系统以及如何在 Oracle 数据库中使用它。除非另有说明,否则必须以 root 用户身份运行所有命令。
对磁盘进行分区
必须使用空磁盘分区来创建文件系统。如果已经有一个空的可用磁盘分区,则跳到下一步。
以下是一个为 Linux 文件系统创建新分区的示例。(警告:对磁盘进行错误分区是删除硬盘上所有内容的最可靠、最快捷的方法之一。如果不确定如何分区,请先停下来,找人帮帮您,否则您将冒丢失数据的危险。)
此示例使用 /dev/sdb(一个没有分区的空 SCSI 磁盘)为整个磁盘 (36 GB) 创建单个分区。
例如: # fdisk /dev/sdb Device contains neither a valid DOS partition table, nor Sun, SGI or OSF disklabel Building a new DOS disklabel.Changes will remain in memory only, until you decide to write them.After that, of course, the previous content won't be recoverable. The number of cylinders for this disk is set to 4427. There is nothing wrong with that, but this is larger than 1024, and could in certain setups cause problems with: 1) software that runs at boot time (e.g., old versions of LILO) 2) booting and partitioning software from other OSs (e.g., DOS FDISK, OS/2 FDISK) Command (m for help):p Disk /dev/sdb:255 heads, 63 sectors, 4427 cylinders Units = cylinders of 16065 * 512 bytes Device Boot Start End Blocks Id System Command (m for help):n Command action e extended p primary partition (1-4) p Partition number (1-4): 1 First cylinder (1-4427, default 1): Using default value 1 Last cylinder or +size or +sizeM or +sizeK (1-4427, default 4427): Using default value 4427 Command (m for help):w The partition table has been altered! Calling ioctl() to re-read partition table. WARNING:If you have created or modified any DOS 6.x partitions, please see the fdisk manual page for additional information. Syncing disks.
现在验证新分区:
例如: # fdisk /dev/sdb The number of cylinders for this disk is set to 4427. There is nothing wrong with that, but this is larger than 1024, and could in certain setups cause problems with: 1) software that runs at boot time (e.g., old versions of LILO) 2) booting and partitioning software from other OSs (e.g., DOS FDISK, OS/2 FDISK) Command (m for help):p Disk /dev/sdb:255 heads, 63 sectors, 4427 cylinders Units = cylinders of 16065 * 512 bytes Device Boot Start End Blocks Id System /dev/sdb1 1 4427 35559846 83 Linux Command (m for help):q
创建文件系统
使用 ext3 创建这个新的文件系统。也可以使用其他文件系统,但 ext3 在系统崩溃时可提供最快的恢复。
例如: # mke2fs -j /dev/sdb1 mke2fs 1.26 (3-Feb-2002) Filesystem label= OS type:Linux Block size=4096 (log=2) Fragment size=4096 (log=2) 4447744 inodes, 8889961 blocks 444498 blocks (5.00%) reserved for the super user First data block=0 272 block groups 32768 blocks per group, 32768 fragments per group 16352 inodes per group Superblock backups stored on blocks: 32768, 98304, 163840, 229376, 294912, 819200, 884736, 1605632, 2654208, 4096000, 7962624 Writing inode tables:done Creating journal (8192 blocks):done Writing superblocks and filesystem accounting information:done This filesystem will be automatically checked every 23 mounts or 180 days, whichever comes first.Use tune2fs -c or -i to override.
创建挂载点
文件系统必须有一个挂载点,它只是一个空的目录,新文件系统在这里与系统目录树“相连”。挂载点的命名应遵循 Oracle 灵活结构 (OFA) 标准。有关 OFA 标准的更多信息,请参阅 Oracle 10g 数据库安装指南 的附录 D。
由于您已经在第 1 部分中使用了 /u01 和 /u02 目录名称,因此在本示例中使用 /u03。
例如: # mkdir /u03
将新文件系统添加到 /etc/fstab
因此新文件系统将在系统启动时自动挂载,您需要向描述新文件系统及其安装位置的 /etc/fstab 文件中添加一行。使用文本编辑器向 /etc/fstab 中添加如下所示的一行。
/dev/sdb1 /u03 ext3 defaults 1 1
挂载新文件系统
文件系统挂载后就可以使用了。只有挂载了文件系统,才能在其中存储文件。使用以下命令挂载文件系统并验证它是否可用。
mount /u03 df -h /u03 例如: # mount /u03 # df -h /u03 Filesystem Size Used Avail Use% Mounted on /dev/sdb1 33G 33M 31G 1% /u03
创建 Oracle 目录并设置权限
现在,创建一个用于存放 Oracle 文件的目录。该示例中使用的目录名遵循数据库的 OFA 标准命名惯例,即 ORACLE_SID=demo1。
mkdir -p /u03/oradata/demo1 chown -R oracle:oinstall /u03/oradata chmod -R 775 /u03/oradata
在新文件系统中创建一个新表空间
新文件系统已可以使用。接下来,在文件系统中创建一个用于存储数据库对象的新表空间。以 SYSTEM 用户身份连接到数据库,然后执行 CREATE TABLESPACE 语句,并在新文件系统中指定数据文件。
例如: $ sqlplus SQL*Plus:Release 10.1.0.2.0 - Production on Sun Jun 13 15:01:08 2004 Copyright (c) 1982, 2004, Oracle.All rights reserved. Enter user-name:system Enter password: Connected to: Oracle Database 10g Enterprise Edition Release 10.1.0.2.0 - Production With the Partitioning, OLAP and Data Mining options SQL> create tablespace data1 2 datafile '/u03/oradata/demo1/data1_01.dbf' size 100M 3 extent management local 4 segment space management auto; Tablespace created.
现在,可以使用此新表空间存储数据库对象,如表和索引。
例如: SQL> create table demotab (id number(5) not null primary key, 2 name varchar2(50) not null, 3 amount number(9,2)) 4 tablespace data1; Table created.
我把最重要的内容留在了最后。ASM 是 Oracle 数据库 10g 中一个非常出色的新特性,它以平台无关的方式提供了文件系统、逻辑卷管理器以及软件 RAID 等服务。ASM 可以条带化和镜像磁盘,从而实现了在数据库被加载的情况下添加或移除磁盘以及自动平衡 I/O 以删除“热点”。它还支持直接和异步的 I/O 并使用 Oracle9i 中引入的 Oracle 数据管理器 API(简化的 I/O 系统调用接口)。
ASM 不是一个通用的文件系统,并只能用于 Oracle 数据文件、重做日志以及控制文件。ASM 中的文件既可以由数据库自动创建和命名(通过使用 Oracle 管理文件特性),也可以由 DBA 手动创建和命名。由于操作系统无法访问 ASM 中存储的文件,因此对使用 ASM 文件的数据库执行备份和恢复操作的唯一途径就是通过恢复管理器 (RMAN)。
ASM 作为单独的 Oracle 实例实施,只有它在运行时其他数据库才能访问它。在 Linux 上,只有运行 OCSSD 服务(由 Oracle 通用安装程序默认安装)才能使用 ASM。ASM 需要的内存不多:对大多数系统,只需 64 MB。
安装 ASM
在 Linux 平台上,ASM 可以使用原始设备,或通过 ASMLib 接口管理的设备。出于易于使用和性能方面的原因,Oracle 建议在原始设备上使用 ASMLib。ASMLib 现在可以从 OTN 免费下载。本部分逐步讲解使用 ASMLib 配置一个简单 ASM 实例和构建一个使用 ASM 进行磁盘存储的数据库的全过程。
确定所需的 ASMLib 版本
ASMLib 以三个 Linux 程序包组成的程序包集提供:
- oracleasmlib - ASM 库
- oracleasm-support - 用于管理 ASMLib 的实用程序
- oracleasm - ASM 库的内核模块
首先,以 root 用户身份登录并运行以下命令来确定所使用的内核:
uname -rm 例如: # uname -rm 2.4.9-e.27smp i686
该示例表明,这是一个使用 Intel i686 CPU 的 SMP(多处理器)系统的 2.4.9 内核。
使用此信息在 OTN 上查找相应的 ASMLib 程序包:
- 将 Web 浏览器指向 http://www.oracle.com/global/cn/technology/tech/linux/asmlib
- 选择适用于您的 Linux 版本的链接。
- 下载适用于您的 Linux 版本的 oracleasmlib 和 oracleasm-support 程序包
- 下载与您的内核相对应的 oracleasm 程序包。对于以上示例,下载 oracleasm-2.4.9-e-smp-1.0.0-1.i686.rpm 程序包。
接下来,通过以 root 用户身份执行以下命令来安装程序包:
rpm -Uvh oracleasm-kernel_version-asmlib_version.cpu_type.rpm \ oracleasmlib-asmlib_version.cpu_type.rpm \ oracleasm-support-asmlib_version.cpu_type.rpm 例如: # rpm -Uvh \ > oracleasm-2.4.9-e-smp-1.0.0-1.i686.rpm \ > oracleasmlib-1.0.0-1.i386.rpm \ > oracleasm-support-1.0.0-1.i386.rpm Preparing... #################################### [100%] 1:oracleasm-support #################################### [ 33%] 2:oracleasm-2.4.9-e-smp #################################### [ 66%] Linking module oracleasm.o into the module path [ OK ] 3:oracleasmlib #################################### [100%]
配置 ASMLib
使用 ASMLib 之前,必须运行配置脚本以准备驱动程序。以 root 用户身份运行以下命令,并响应如下示例中所显示的提示。
# /etc/init.d/oracleasm configure Configuring the Oracle ASM library driver. This will configure the on-boot properties of the Oracle ASM library driver.The following questions will determine whether the driver is loaded on boot and what permissions it will have.The current values will be shown in brackets ('[]').Hitting <ENTER> without typing an answer will keep that current value.Ctrl-C will abort. Default user to own the driver interface []:oracle Default group to own the driver interface []:dba Start Oracle ASM library driver on boot (y/n) [n]:y Fix permissions of Oracle ASM disks on boot (y/n) [y]:y Writing Oracle ASM library driver configuration [ OK ] Creating /dev/oracleasm mount point [ OK ] Loading module "oracleasm" [ OK ] Mounting ASMlib driver filesystem [ OK ] Scanning system for ASM disks [ OK ]
现在,如下所示启用 ASMLib 驱动程序。
# /etc/init.d/oracleasm enable Writing Oracle ASM library driver configuration [ OK ] Scanning system for ASM disks [ OK ]
为 ASM 配置磁盘
接下来,告诉 ASM 驱动程序您要使用的磁盘。请注意,这些磁盘是不包含任何内容(甚至不包含分区)的空磁盘。可以将磁盘分区用于 ASM,但建议您不要这样做。
通过以 root 用户身份运行以下命令来标记由 ASMLib 使用的磁盘:
/etc/init.d/oracleasm createdisk DISK_NAME device_name
(提示:DISK_NAME 应由大写字母组成。当前版本有一个错误,即如果使用小写字母,ASM 实例将无法识别磁盘。)
例如: # /etc/init.d/oracleasm createdisk VOL1 /dev/sdb Marking disk "/dev/sdb" as an ASM disk [ OK ] # /etc/init.d/oracleasm createdisk VOL2 /dev/sdc Marking disk "/dev/sdc" as an ASM disk [ OK ] # /etc/init.d/oracleasm createdisk VOL3 /dev/sdd Marking disk "/dev/sdd" as an ASM disk [ OK ] # /etc/init.d/oracleasm createdisk VOL4 /dev/sdf Marking disk "/dev/sdf" as an ASM disk [ OK ] # /etc/init.d/oracleasm createdisk VOL5 /dev/sdg Marking disk "/dev/sdg" as an ASM disk [ OK ] # /etc/init.d/oracleasm createdisk VOL6 /dev/sdh Marking disk "/dev/sdh" as an ASM disk [ OK ]
以下示例演示了如何列出标记为由 ASMLib 使用的所有磁盘。
# /etc/init.d/oracleasm listdisks VOL1 VOL2 VOL3 VOL4 VOL5 VOL6
既然已经
相关推荐
在Linux x86 上安装Oracle 数据库10g 的详细步骤和配置说明
在 Linux x86 上安装 Oracle 数据库 10g
在Linux x86平台上安装Oracle数据库10g RAC(Real Application Clusters)是一个复杂而精细的过程,涉及到多个步骤和组件。Oracle RAC是一种高可用性解决方案,它允许多个数据库实例同时访问同一个物理数据库,从而...
本资料来至于oracle官方网站,我只是保存了他的网页而已,请大家放心下载。
在本篇指南中,我们将详细介绍如何在 Linux x86 架构上安装 Oracle 数据库 10g,并针对三种不同的 Linux 发行版进行具体讲解:Red Hat Enterprise Linux (RHEL) 2.1 和 RHEL 3 以及 SUSE Linux Enterprise Server ...
在 Linux x86 上安装 Oracle 数据库 10g 本文详细介绍了在 Linux x86 平台上安装 Oracle 数据库 10g 的步骤,包括安装 Linux 操作系统、配置 Linux 环境、安装 Oracle 软件、配置存储文件系统等步骤。本文还提供了...
在Linux环境下离线安装Oracle数据库19c是一个涉及多个步骤的过程,需要准备相应的安装文件,并且对系统进行预安装配置。以下是对整个流程的详细解释: 1. **文件准备** - `compat-libstdc++-33-3.2.3-72.el7.x86_...
《在Linux x86上安装Oracle RAC 10g》这篇文章主要介绍了如何在Red Hat Enterprise Linux或Novell SUSE Enterprise Linux上安装Oracle Real Application Clusters (RAC) 10g的步骤,适合对Linux和Oracle不太熟悉的...