ホームページ データベース mysql チュートリアル 在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

Jun 07, 2016 pm 03:38 PM
asm linux oracle インストール 構成

安装Oracle Linux的时候选上Oracle需要的那些rpm包,还有Oracle ASM那些rpm包。 1,修改/boot/grub/grub.conf文件,把default改成1 0对应ELhugemem内核 1对应ELsmp内核 (我这里的虚拟机是vbox,如果启动ELhugemem内核会报错,所以在此修改了grub.conf文件)

安装Oracle Linux的时候选上Oracle需要的那些rpm包,还有Oracle ASM那些rpm包。

1,修改/boot/grub/grub.conf文件,把default改成1
0对应ELhugemem内核
1对应ELsmp内核
(我这里的虚拟机是vbox,如果启动ELhugemem内核会报错,所以在此修改了grub.conf文件)



2,修改/etc/inittab文件,把默认启动级别由5改为3
把id:5:initdefault: 改为id:3:initdefault:
关闭selinux,修改/etc/selinux/config文件:
SELINUX=disabled



3,关闭不需要的服务
因为我这里是为了安装oracle,所以就把一些不需要的service关闭了。
输入chkconfig --list查看服务,然后输入下面这些指令关闭不需要的服务:
chkconfig anacron off
chkconfig atd off
chkconfig crond off
chkconfig apmd off
chkconfig autofs off
chkconfig dund off
chkconfig pand off
chkconfig capi off
chkconfig isdn off
chkconfig dc_client off
chkconfig dc_server off
chkconfig diskdump off
chkconfig netdump off
chkconfig gpm off
chkconfig irda off
chkconfig lm_sensors off
chkconfig mdmonitor off (RAID or LVM)
chkconfig mdmpd off
chkconfig smartd off
chkconfig iptables off(关闭防火墙,这个很重要,当然也可以设置,这里为了简单起见,直接把防火墙关了)
chkconfig bluetooth off
chkconfig cups off
chkconfig sendmail off
chkconfig iiim off



4,软件包检查:(如果是安装的Oracle Enterprise Linux 4.7,那么这些包应该是已经自带了的)
binutils-2.15.92.0.2-13.EL4
compat-db-4.1.25-9
compat-libstdc++-296-2.96-132.7.2
control-center-2.8.0-12
gcc-3.4.3-22.1.EL4
gcc-c++-3.4.3-22.1.EL44
glibc-2.3.4-2.9
glibc-common-2.3.4-2.9
gnome-libs-1.4.1.2.90-44.1
libstdc++-3.4.3-22.1
libstdc++-devel-3.4.3-22.1
make-3.80-5
pdksh-5.2.14-30
sysstat-5.0.5-1
xscreensaver-4.18-5.rhel4.2
setarch-1.6-1



5,修改内核参数(其实Oracle Enterprise Linux 4.7的默认内核参数已经优化过了,基本上不需要我们再修改了)
修改/etc/sysctl.conf的内容:
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
net.core.rmem_default = 1048576
net.core.rmem_max = 1048576
net.core.wmem_default = 262144
net.core.wmem_max = 262144
然后执行sysctl -p使内核参数修改生效



6,提升shell限制
在文件/etc/security/limits.conf中添加如下内容:
oracle              soft    nproc   2047
oracle              hard    nproc   16384
oracle              soft    nofile  1024
oracle              hard    nofile  65536



7,修改文件/etc/pam.d/login
session    required     /lib/security/pam_limits.so
session    required     pam_limits.so



8,在文件中/etc/profile添加
if [ $USER = "oracle" ]; then
        if [ $SHELL = "/bin/ksh" ]; then
              ulimit -p 16384
              ulimit -n 65536
        else
              ulimit -u 16384 -n 65536
        fi
fi



9,用root创建组,用户,目录。
groupadd oinstall
groupadd dba
useradd oracle -g oinstall -G dba
passwd oracle
mkdir -p /u01/app/oracle
chown -R oracle:oinstall /u01
chmod -R 775 /u01



10,oracle用户在.bash_profile文件添加如下内容
export TMP=/tmp
export TMPDIR=$TMP
umask 022
export ORACLE_HOSTNAME=asmnode
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/10.2.0/db_1
export ORACLE_SID=orcl
export NLS_LANG=AMERICAN_AMERICA.AL32UTF8
export PATH=$ORACLE_HOME/bin:/usr/sbin:$PATH
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib:/usr/lib
export CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib
(修改主机名可以修改/etc/sysconfig/network)



11,给linux添加磁盘,并且把oracle安装包用FileZilla传到这个磁盘对应的目录/mnt/b
(其实这一步可以跳过,直接把安装包传到oracle用户的目录下再解压就行。
我这样做的目的是不想让虚拟机的第一块磁盘增长过快,这个知识点后面在建asm磁盘的时候会用到)
fdisk /dev/sdb
n(新建分区)
p(主分区)
1(分区号是1)
1(开始cylinder为1)
1566(结束cylinder为1566,相当于12GB)
然后输入p查看分区表
w(保存)
partprobe(让kernel读取分区信息 )
mkfs.ext3 /dev/sdb1 把第二块硬盘的第一个主分区格式化为ext3
mount /dev/sdb1 /mnt/b #将第一个分区挂载到d这个目录
重启后自动挂载:vi /etc/fstab
添加:/dev/sdb1 /mnt/b ext3 default 0 0



12,安装Oracle软件
用户远程登陆用
Xmanager Enterprise 3的Xshell的,然后输入emacs弹出图形界面,说明远程登陆没问题了。
oracle用户在家目录执行/mnt/b/database/runInstaller,根据图形界面一步步做,选择仅安装数据库软件



13,创建asm磁盘(基于ASMLib方式)
先删除第11步创建的磁盘,然后给虚拟机添加4块磁盘
两块属于scsi控制器
另外两块属于sas控制器
如图所示
在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库
配置 ASMLib:
root用户输入/etc/init.d/oracleasm configure
如图:
在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库
输入/etc/init.d/oracleasm createdisk VOL1 /dev/sdb
此时会出错,如下所示:
[root@asmnode ~]# /etc/init.d/oracleasm createdisk VOL1 /dev/sdb
Marking disk "/dev/sdb" as an ASM disk: asmtool: Device "/dev/sdb" is not a partition
解决方案是:
需要对/dev/sdb分区/dev/sdb1
fdisk /dev/sdb
n-p-1-回车-回车-p-w
其他磁盘也是这样分区,最后执行fdisk -l查看分区效果,确保已经分区了
然后再执行partprobe让kernel读取分区信息
这时候我们就可以创建asm磁盘了:
/etc/init.d/oracleasm createdisk VOL1 /dev/sdb1
/etc/init.d/oracleasm createdisk VOL2 /dev/sdc1
/etc/init.d/oracleasm createdisk VOL3 /dev/sdd1
/etc/init.d/oracleasm createdisk VOL4 /dev/sde1
接着我们查看asm磁盘信息:
[root@asmnode ~]# /etc/init.d/oracleasm listdisks
VOL1
VOL2
VOL3
VOL4
[root@asmnode ~]# /etc/init.d/oracleasm querydisk /dev/sdb1
Disk "/dev/sdb1" is marked an ASM disk with the label "VOL1"
如果要删除 ASM 磁盘通过以下命令:
# /etc/init.d/oracleasm deletedisk VOL4
如果是在 RAC 环境中的某一个节点中添加了ASM 磁盘,那么需要在其它的节点上
运行scandisks 来获取这种变化。
/etc/init.d/oracleasm scandisks



14,用dbca创建asm实例:

如图:

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

用root用户创建css服务(这一步的目的是实现asm实例和database实例之间的同步)
/u01/app/oracle/product/10.2.0/db_1/bin/localconfig add
可以用root用户查看css服务是否成功
[root@asmnode ~]# ps -ef | grep css
oracle    5174     1  4 10:12 ?        00:00:06 /u01/app/oracle/product/10.2.0/db_1/bin/ocssd.bin
root      5429  3943  0 10:14 pts/0    00:00:00 grep css
也可以用oracle用户执行crsctl check css来查看
效果:
[oracle@asmnode ~]$ crsctl check css
CSS appears healthy

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

完成



15,用oracle用户执行验证
export ORACLE_SID=+ASM
sqlplus / as sysdba
select name,state from v$asm_diskgroup;
select name||header_status||path from v$asm_disk;



16,用dbca创建基于ASM的数据库
这里除了第6,7,8步,其它跟普通的dbca创建数据库是一样的。我们选择的是ASM存储方式。

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

创建完数据库后
export ORACLE_SID=orcl
sqlplus / as sysdba
然后执行查询
select * from scott.dept;
select name from v$datafile;
select name from v$tempfile;
select member from v$logfile;

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

到此我们完成了基于Oracle ASM的数据库的创建。

还有就是记得用netca创建oracle监听程序
然后用sys用户执行alter system register;
最后来查看进程ps -ef | grep oracle

在Oracle Linux 4.7上安装配置Oracle 10g ASM数据库

17,体验一下rebanlance
执行alter diskgroup dgroup1 drop disk asmvol2;
SELECT group_number, operation, state, est_work, sofar, est_rate,
est_minutes FROM v$asm_operation;
返回
GROUP_NUMBER OPERATION       STATE          EST_WORK      SOFAR   EST_RATE
------------ --------------- ------------ ---------- ---------- ----------
EST_MINUTES
-----------
           1 REBAL           RUN                1021         44        343
          2


然后


GROUP_NUMBER OPERATION       STATE          EST_WORK      SOFAR   EST_RATE
------------ --------------- ------------ ---------- ---------- ----------
EST_MINUTES
-----------
           1 REBAL           RUN                1139       1063        322
          0


然后
GROUP_NUMBER OPERATION       STATE          EST_WORK      SOFAR   EST_RATE
------------ --------------- ------------ ---------- ---------- ----------
EST_MINUTES
-----------
           1 EXPEL           RUN                   0          0          0
          0


然后
no rows selected
SQL> select  STATE,REDUNDANCY,TOTAL_MB,FREE_MB,NAME,FAILGROUP from v$asm_disk;


STATE      REDUNDANCY              TOTAL_MB    FREE_MB NAME            FAILGROUP
---------- --------------------- ---------- ---------- --------------- --------------------
NORMAL     UNKNOWN                    12284          0
NORMAL     UNKNOWN                    12284      11157 ASMVOL1         FGROUP1
NORMAL     UNKNOWN                    12284      11719 ASMVOL3         FGROUP2
NORMAL     UNKNOWN                    12284      11720 ASMVOL4         FGROUP2

[oracle@asmnode ~]$ ps -ef | grep arb0
oracle    7036     1 12 16:37 ?        00:00:26 asm_arb0_+ASM
oracle    7056  6942  0 16:41 pts/0    00:00:00 grep arb0


[oracle@asmnode ~]$ ps -ef | grep arb0
oracle    7069  6942  0 16:47 pts/0    00:00:00 grep arb0
由此可见当删除磁盘重新平衡的时候,会出现asm_arb0_+ASM进程,平衡结束后这个进程也就结束了


在asm实例中查询:
SQL> SELECT disk_number, label FROM V$asm_disk;


DISK_NUMBER LABEL
----------- ---------------------------------------------------------------------------------------------
          0 VOL2
          2 VOL1
          0 VOL3
          1 VOL4


而在数据库实例中查询:
SQL> SELECT disk_number, label FROM V$asm_disk;


DISK_NUMBER LABEL
----------- -------------------------------
          0 VOL3
          1 VOL4
          2 VOL1

我们可以从上面的SQL 知道在ASM 实例中可以查询到所有可以用的磁盘,而在数据库实
例中只可以查询到让自己使用的磁盘

18,创建表空间和用户
连接asm实例:
export ORACLE_SID=+ASM
sqlplus / as sysdba
create diskgroup dgtest external redundancy
disk 'ORCL:VOL2' name testvol2;


连接数据库实例:
export ORACLE_SID=orcl
sqlplus / as sysdba
create tablespace testtblsp datafile '+dgtest';

create user lmc identified by lmc
temporary tablespace temp default tablespace testtblsp;

grant connect,resource to lmc;
conn lmc/lmc
create table tt(id int,name varchar2(20));
insert into tt values(1,'wilson');
insert into tt values(2,'scott');
commit;
conn / as sysdba

注意:释放内存可以用

echo 3 > /proc/sys/vm/drop_caches

Oracle11g R2的ASM安装可以参考http://blog.csdn.net/liumengcheng/article/details/37565931


このウェブサイトの声明
この記事の内容はネチズンが自主的に寄稿したものであり、著作権は原著者に帰属します。このサイトは、それに相当する法的責任を負いません。盗作または侵害の疑いのあるコンテンツを見つけた場合は、admin@php.cn までご連絡ください。

ホットAIツール

Undresser.AI Undress

Undresser.AI Undress

リアルなヌード写真を作成する AI 搭載アプリ

AI Clothes Remover

AI Clothes Remover

写真から衣服を削除するオンライン AI ツール。

Undress AI Tool

Undress AI Tool

脱衣画像を無料で

Clothoff.io

Clothoff.io

AI衣類リムーバー

AI Hentai Generator

AI Hentai Generator

AIヘンタイを無料で生成します。

ホットツール

メモ帳++7.3.1

メモ帳++7.3.1

使いやすく無料のコードエディター

SublimeText3 中国語版

SublimeText3 中国語版

中国語版、とても使いやすい

ゼンドスタジオ 13.0.1

ゼンドスタジオ 13.0.1

強力な PHP 統合開発環境

ドリームウィーバー CS6

ドリームウィーバー CS6

ビジュアル Web 開発ツール

SublimeText3 Mac版

SublimeText3 Mac版

神レベルのコード編集ソフト(SublimeText3)

マルチスレッドをC言語で実装する4つの方法 マルチスレッドをC言語で実装する4つの方法 Apr 03, 2025 pm 03:00 PM

言語のマルチスレッドは、プログラムの効率を大幅に改善できます。 C言語でマルチスレッドを実装する4つの主な方法があります。独立したプロセスを作成します。独立して実行される複数のプロセスを作成します。各プロセスには独自のメモリスペースがあります。擬似マルチスレッド:同じメモリ空間を共有して交互に実行するプロセスで複数の実行ストリームを作成します。マルチスレッドライブラリ:pthreadsなどのマルチスレッドライブラリを使用して、スレッドを作成および管理し、リッチスレッド操作機能を提供します。 Coroutine:タスクを小さなサブタスクに分割し、順番に実行する軽量のマルチスレッド実装。

web.xmlを開く方法 web.xmlを開く方法 Apr 03, 2025 am 06:51 AM

web.xmlファイルを開くには、次の方法を使用できます。テキストエディター(メモ帳やテキストエディットなど)を使用して、統合開発環境(EclipseやNetBeansなど)を使用してコマンドを編集できます(Windows:Notepad web.xml; Mac/Linux:Open -A Textedit Web.xml)

Linuxは何に最適なものですか? Linuxは何に最適なものですか? Apr 03, 2025 am 12:11 AM

Linuxは、サーバー管理、組み込みシステム、デスクトップ環境として最適です。 1)サーバー管理では、LinuxはWebサイト、データベース、アプリケーションをホストするために使用され、安定性と信頼性を提供します。 2)組み込みシステムでは、Linuxは柔軟性と安定性のため、スマートホームおよび自動車電子システムで広く使用されています。 3)デスクトップ環境では、Linuxは豊富なアプリケーションと効率的なパフォーマンスを提供します。

c言語条件付き編集:初心者向けの詳細なガイドへの実践的なアプリケーション c言語条件付き編集:初心者向けの詳細なガイドへの実践的なアプリケーション Apr 04, 2025 am 10:48 AM

c言語条件付きコンパイルは、コンパイル時間条件に基づいてコードブロックを選択的にコンパイルするメカニズムです。導入方法には、#IFおよび#ELSEディレクティブを使用して、条件に基づいてコードブロックを選択します。一般的に使用される条件付き式には、STDC、_WIN32、Linuxが含まれます。実用的なケース:オペレーティングシステムに従って異なるメッセージを印刷します。システムの数字数に応じて異なるデータ型を使用します。コンパイラに応じて、異なるヘッダーファイルがサポートされています。条件付きコンパイルにより、コードの移植性と柔軟性が向上し、コンパイラ、オペレーティングシステム、CPUアーキテクチャの変更に適応できます。

Oracle PL/SQL Deep Dive:マスタリング手順、機能、パッケージ Oracle PL/SQL Deep Dive:マスタリング手順、機能、パッケージ Apr 03, 2025 am 12:03 AM

OraclePl/SQLの手順、機能、パッケージは、それぞれ操作、返品値、および整理コードを実行するために使用されます。 1.プロセスは、挨拶の出力などの操作を実行するために使用されます。 2。関数は、2つの数値の合計を計算するなど、値を計算して返すために使用されます。 3.パッケージは、関連する要素を整理し、在庫を管理するパッケージなど、コードのモジュール性と保守性を向上させるために使用されます。

libvは2つです libvは2つです Apr 03, 2025 pm 08:03 PM

私はLua-Libuvというプロジェクトを開発しましたが、私の経験を喜んで共有しています。プロジェクトの当初の意図は、libuv(cで書かれた非同期I/Oライブラリ)を使用して、C言語を深く学習せずに簡単なHTTPサーバーを構築する方法を探ることです。 ChatGptの助けを借りて、http.cの基本コードを完了しました。永続的な接続を扱うとき、私は正しいタイミングでリソースを閉鎖し、解放することに成功しました。最初は、接続を閉じることでメインプログラムを終了するシンプルなサーバーを作成しようとしましたが、いくつかの問題がありました。ストリーミングを使用してデータのブロックを送信しようとしましたが、機能している間、これによりメインスレッドがブロックされます。最終的に、私の目標はC言語を深く学ぶことではなかったので、このアプローチをあきらめることにしました。最後に、i

ERPシステムソフトウェアとは何ですか?推奨されるERPシステムソフトウェア ERPシステムソフトウェアとは何ですか?推奨されるERPシステムソフトウェア Apr 03, 2025 pm 12:54 PM

ERPソフトウェアを選択するときは、最初に業界、スケール、予算、ITインフラストラクチャなどの企業のニーズを明確にし、コアビジネスプロセスに従ってニーズを満たすシステムを選択します。一般的なERPシステムには次のものが含まれます。SAPは大規模な企業に適しており、強力な機能を備えていますが、高価な機能を備えています。 Oracleには包括的な機能がありますが、高価で、大企業に適しています。 ODOOは、中小企業に適しており、低コストでカスタマイズ可能です。 SaaS ERPはクラウドに展開され、オンデマンドで支払い、急速に発展している企業に適しています。選択する前に、トライアルを実施し、専門家のアドバイスに相談し、アフターセールスサービスに注意を払い、あなたに最も適したERPシステムを選択する必要があります。

rust錆自明】はじめに rust錆自明】はじめに Apr 04, 2025 am 08:03 AM

1.0.1序文このプロジェクト(コードとコメントを含む)は、私の独学の錆の間に記録されました。不正確または不明確な声明があるかもしれませんが、謝罪してください。あなたがそれから利益を得るなら、それはさらに良いです。 1.0.2なぜRustrustは信頼性が高く効率的ですか? Rustは、CとCを同様のパフォーマンスであり、セキュリティが高くなり、CやCのようなエラーを確認するために頻繁な再コンパイルを必要としません。主な利点には、メモリセキュリティ(nullポインターの防止、ぶら下がりポインター、およびデータ競合の防止)が含まれます。スレッドセーフ(実行前にマルチスレッドコードが安全であることを確認してください)。未定義の動作を避けてください(例:境界のない配列、未知の変数、または解放されたメモリへのアクセス)。 Rustは、ジェネリックなどの最新の言語機能を提供します

See all articles