Oracle 手動建立資料庫
手動安裝 Oracle 資料庫
一 安裝準備
1.1 配置本地YUM ,安裝軟體
[root@chen ~]# cd /etc/yum.repos.d/
[root@chen yum.repos.d]# cp public-yum-ol6.repo yum.repo
[root@chen yum.repos.d]# mv public-yum-ol6.repo /root/
[root@chen yum.repos.d]# vim yum.repo
[chen_cc]
name=Oracle_chen
baseurl=file:///mnt
gpgcheck=0
enabled=1
[root@chen yum.repos.d]# mount /dev/sr1 /mnt
[root@chen yum.repos.d]# yum list
[root@chen yum.repos.d]# yum -y install compat-libstdc++-33-3.2.3 elfutils-libelf gcc gcc-c++* glibc glibc-common glibc-common glibc-devel libaio libaio-devel libgcc libstdc++-* libstdc++-devel make sysstat
1.2 建立使用者,組
[root@chen ~]# groupadd -g 1000 oinstall
[root@chen ~]# groupadd -g 1001 dba
[root@chen ~]# useradd -u 1000 -g oinstall -G dba oracle
[root@chen ~]# mkdir -p /u01/app/oracle
[root@chen ~]# mv p10404530_112030_Linux-x86-64_* /u01/
[root@chen ~]# chown oracle.oinstall -R /u01/
[oracle@chen u01]$ unzip p10404530_112030_Linux-x86-64_1of7.zip
[oracle@chen u01]$ unzip p10404530_112030_Linux-x86-64_2of7.zip
1.3 配置oracle 使用者環境變數
[oracle@chen ~]$ vim .bash_profile
export ORACLE_BASE=/u01/app/oracle
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0
export ORACLE_SID=orcl
export PATH=$ORACLE_HOME/bin:$PATH
export NLS_LANG='AMERICAN_AMERICA.ZHS16GBK'
~
[oracle@chen ~]$ source .bash_profile
1.4 安全配置
[root@chen ~]# vim /etc/security/limits.conf
# End of file
oracle soft nproc 2047
oracle hard nproc 16384
oracle soft nofile 1024
oracle hard nofile 65536
oracle soft stack 10240
"/etc/security/limits.conf" 56L, 2034C written
[root@chen ~]# vim /etc/sysctl.conf
fs.aio-max-nr = 1048576
fs.file-max = 6815744
kernel.shmall = 2097152
kernel.shmmax = 536870912
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 = 1048586
"/etc/sysctl.conf" 52L, 1461C written
[root@chen ~]# sysctl -p
二 安裝資料庫軟體
[root@chen ~]# xhost +
[oracle@chen ~]$ ./u01/database/runInstaller
。。。。。。
三 手動建立資料庫目錄
[oracle@chen oracle]$ mkdir -p /u01/app/oracle/oradata/orcl
[oracle@chen oracle]$ mkdir -p /u01/app/oracle/flash_recovery_area
[oracle@chen 11.2.0]$ mkdir -p /u01/app/oracle/admin/orcl/{adump,bdump,cdump,dpdump,udump,pfile}
其中
1 adump :審計資訊
2 bdump :後臺程式trace 和alert log
3 cdump :core trace,一般是用來日誌應用程式的
4 pfile :初始化引數檔案 initSID
5 udump :前臺手動trace的 比如sql trace之後session的trace檔案
6 dpdump:Oracle預設的directory,可在dba_directories查到,是expdp,impdp的預設路徑
四 建立引數檔案
[oracle@chen oracle]$ cd /u01/app/oracle/product/11.2.0/dbs/
[oracle@chen dbs]$ cp init.ora initorcl.ora
[oracle@chen dbs]$ vim initorcl.ora
*.compatible='11.2.0.3.0'
*.control_files='/u01/app/oracle/oradata/orcl/control01.ctl'
*.db_block_size=8192
*.db_name='orcl'
*.db_recovery_file_dest='/u01/app/oracle/flash_recovery_area'
*.db_recovery_file_dest_size=1G
*.diagnostic_dest='/u01/app/oracle'
*.memory_target=500M
*.open_cursors=300
*.processes=150
*.remote_login_passwordfile='EXCLUSIVE'
*.undo_tablespace='UNDOTBS1'
*.undo_management=auto
五 建立密碼檔案
[oracle@chen dbs]$ cd $ORACLE_HOME/dbs
[oracle@chen dbs]$ orapwd file=orapworcl password=oracle
六 建立資料庫指令碼
[oracle@chen ~]$ touch create_db.sql
[oracle@chen ~]$ vim create_db.sql
create database orcl
user sys identified by oracle
user system identified by oracle
maxinstances 1
maxloghistory 100
maxlogfiles 5
maxlogmembers 3
maxdatafiles 1000
character set zhs16gbk
national character set al16utf16
logfile
group 1('/u01/app/oracle/oradata/orcl/redo01.log') size 10m,
group 2('/u01/app/oracle/oradata/orcl/redo02.log') size 10m,
group 3('/u01/app/oracle/oradata/orcl/redo03.log') size 10m
datafile
'/u01/app/oracle/oradata/orcl/system.dbf' size 100m autoextend on next 1m maxsize unlimited
sysaux datafile
'/u01/app/oracle/oradata/orcl/sysaux.dbf' size 50m autoextend on next 1m maxsize unlimited
default tablespace users datafile
'/u01/app/oracle/oradata/orcl/user01.dbf' size 50m autoextend on next 1m maxsize unlimited
default temporary tablespace temp tempfile
'/u01/app/oracle/oradata/orcl/temp01.dbf' size 50m autoextend on next 1m maxsize unlimited
undo tablespace undotbs1 datafile
'/u01/app/oracle/oradata/orcl/undotbs01.dbf' size 50m autoextend on next 1m maxsize unlimited;
七 啟動例項,執行指令碼,建立資料庫
[oracle@chen ~]$ sqlplus / as sysdba
SQL*Plus: Release 11.2.0.3.0 Production on Thu Jul 23 18:10:11 2015
Copyright (c) 1982, 2011, Oracle. All rights reserved.
Connected to an idle instance.
SQL> startup nomount
ORACLE instance started.
Total System Global Area 521936896 bytes
Fixed Size 2229944 bytes
Variable Size 314575176 bytes
Database Buffers 201326592 bytes
Redo Buffers 3805184 bytes
SQL> select instance_name,status from v$instance;
INSTANCE_NAME STATUS
-------------------------------- ------------------------
orcl STARTED
SQL> @/home/oracle/create_db.sql
Database created.
SQL> select instance_name,status from v$instance;
INSTANCE_NAME STATUS
---------------- ------------
orcl OPEN
八 建立資料字典
SQL> conn /as sysdba
SQL> @$ORACLE_HOME/rdbms/admin/catalog.sql
SQL> @$ORACLE_HOME/rdbms/admin/catproc.sql
SQL> @$ORACLE_HOME/rdbms/admin/catexp.sql
SQL> conn system/oracle
SQL> @$ORACLE_HOME/sqlplus/admin/pupbld.sql /*Warning:Product user profile information not loaded! You may need to run PUPBLD.SQL as SYSTEM*/
其中
1 catalog.sql /*建立資料庫資料字典檔案,例如:all_users*/
2 catproc.sql /*建立資料庫基本過程和包,例如:substr...*/
3 pupbld.sql /*Warning:Product user profile information not loaded! You may need to run PUPBLD.SQL as SYSTEM*/
4 catexp.sql
5 EXPORT需要的VIEW是由CATEXP.SQL建立,這些內部VIEW用於EXPORT組織DUMP檔案中資料格式。大部分VIEW用於收集建立DDL語句的,其他的主要供ORACLE開發人員用。
這些VIEW在不同ORACLE版本之間有可能不同,每個版本可能都有新的特性加入。所以在新的版本里面執行舊的dump檔案會有錯誤,一般可以執行CATEXP.SQL解決這些問題,
解決向後相容問題的一般步驟如下:
(1)匯出資料庫的版本比目標資料庫老的情況:
:在需要匯入的目標資料庫中執行舊的CATEXP.SQL
:使用舊的EXPORT匯出DUMP檔案
:使用舊的IMPORT匯入到資料庫中
:在資料庫中執行新的CATEXP.SQL,以恢復該版本的EXPORT VIEW
(2)匯出資料庫的版本比目標資料庫新的情況:
:在需要匯入的目標資料庫中執行新的CATEXP.SQL
:使用新的EXPORT匯出DUMP檔案
:使用新的IMPORT匯入到資料庫中
:在資料庫中執行舊的CATEXP.SQL,以恢復該版本的EXPORT VIEW
九 建立監聽檔案
1 在沒有$ORACLE_HOME/network/admin/listener.or 情況下,會預設啟動/u01/app/oracle/diag/tnslsnr/chen/listener/alert/log.xml 檔案啟動監聽
[oracle@chen admin]$ lsnrctl
LSNRCTL> start
LSNRCTL> status
Connecting to (ADDRESS=(PROTOCOL=tcp)(HOST=)(PORT=1521))
STATUS of the LISTENER
------------------------
Alias LISTENER
Version TNSLSNR for Linux: Version 11.2.0.3.0 - Production
Start Date 23-JUL-2015 19:03:14
Uptime 0 days 0 hr. 1 min. 27 sec
Trace Level off
Security ON: Local OS Authentication
SNMP OFF
Listener Log File /u01/app/oracle/diag/tnslsnr/chen/listener/alert/log.xml
Listening Endpoints Summary...
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=chen)(PORT=1521)))
Services Summary...
Service "orcl" has 1 instance(s).
Instance "orcl", status READY, has 1 handler(s) for this service...
The command completed successfully
2 建立listener.ora 檔案
[oracle@chen ~]$ cd $ORACLE_HOME/network/admin
[oracle@chen admin]$ cp samples/* .
[oracle@chen admin]$ ls
listener.ora samples shrept.lst sqlnet.ora tnsnames.ora
[oracle@chen admin]$ echo >listener.ora
[oracle@chen admin]$ vim listener.ora
LISTENR =
(DESCRIPTION_LIST =
(DESCRIPTION =
(ADDRESS = PROTOCOL = TCP)(HOST = chen)(PORT = 1521))
)
)
ADR_BASE_LISTENER = /u01/app/oracle
LOGGING_LISTENER = ON
[oracle@chen admin]$ lsnrctl
LSNRCTL> start
Starting /u01/app/oracle/product/11.2.0/bin/tnslsnr: please wait...
TNSLSNR for Linux: Version 11.2.0.3.0 - Production
System parameter file is /u01/app/oracle/product/11.2.0/network/admin/listener.ora
Log messages written to /u01/app/oracle/diag/tnslsnr/chen/listener/alert/log.xml
Listening on: (DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=chen)(PORT=1521)))
Connecting to (ADDRESS=(PROTOCOL=tcp)(HOST=)(PORT=1521))
STATUS of the LISTENER
------------------------
Alias LISTENER
Version TNSLSNR for Linux: Version 11.2.0.3.0 - Production
Start Date 23-JUL-2015 19:16:44
Uptime 0 days 0 hr. 0 min. 0 sec
Trace Level off
Security ON: Local OS Authentication
SNMP OFF
Listener Parameter File /u01/app/oracle/product/11.2.0/network/admin/listener.ora
Listener Log File /u01/app/oracle/diag/tnslsnr/chen/listener/alert/log.xml
Listening Endpoints Summary...
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=chen)(PORT=1521)))
The listener supports no services
The command completed successfully
Connecting to (ADDRESS=(PROTOCOL=tcp)(HOST=)(PORT=1521))
STATUS of the LISTENER
------------------------
Alias LISTENER
Version TNSLSNR for Linux: Version 11.2.0.3.0 - Production
Start Date 23-JUL-2015 19:16:44
Uptime 0 days 0 hr. 1 min. 44 sec
Trace Level off
Security ON: Local OS Authentication
SNMP OFF
Listener Parameter File /u01/app/oracle/product/11.2.0/network/admin/listener.ora
Listener Log File /u01/app/oracle/diag/tnslsnr/chen/listener/alert/log.xml
Listening Endpoints Summary...
(DESCRIPTION=(ADDRESS=(PROTOCOL=tcp)(HOST=chen)(PORT=1521)))
Services Summary...
Service "orcl" has 1 instance(s).
Instance "orcl", status READY, has 1 handler(s) for this service...
The command completed successfully
3 建立tnsname.ora 檔案
[oracle@chen admin]$ echo >tnsnames.ora
[oracle@chen admin]$ vim tnsnames.ora
199 =
(DESCRIPTION =
(ADDRESS = (PROTOCOL = TCP)(HOST = chen)(PORT = 1521))
(CONNECT_DATA =
(SERVER = DEDICATED)
(SERVICE_NAME = orcl)
)
)
[oracle@chen admin]$ tnsping 199
TNS Ping Utility for Linux: Version 11.2.0.3.0 - Production on 23-JUL-2015 19:21:30
Copyright (c) 1997, 2011, Oracle. All rights reserved.
Used parameter files:
/u01/app/oracle/product/11.2.0/network/admin/sqlnet.ora
Used TNSNAMES adapter to resolve the alias
Attempting to contact (DESCRIPTION = (ADDRESS = (PROTOCOL = TCP)(HOST = chen)(PORT = 1521)) (CONNECT_DATA = (SERVER = DEDICATED) (SERVICE_NAME = orcl)))
OK (0 msec)
十 檢視
SQL> select * from all_users;
USERNAME USER_ID CREATED
------------------------------ ---------- ------------
APPQOSSYS 31 23-JUL-15
DBSNMP 30 23-JUL-15
ORACLE_OCM 21 23-JUL-15
DIP 14 23-JUL-15
OUTLN 9 23-JUL-15
SYSTEM 5 23-JUL-15
SYS 0 23-JUL-15
7 rows selected.
SQL> select name from v$dbfile;
NAME
--------------------------------------------------------------------------------
/u01/app/oracle/oradata/orcl/system.dbf
/u01/app/oracle/oradata/orcl/sysaux.dbf
/u01/app/oracle/oradata/orcl/undotbs01.dbf
/u01/app/oracle/oradata/orcl/user01.dbf
SQL> select name from v$controlfile;
NAME
--------------------------------------------------------------------------------
/u01/app/oracle/oradata/orcl/control01.ctl
SQL> select member from v$logfile;
MEMBER
--------------------------------------------------------------------------------
/u01/app/oracle/oradata/orcl/redo01.log
/u01/app/oracle/oradata/orcl/redo02.log
/u01/app/oracle/oradata/orcl/redo03.log
歡迎關注我的微信公眾號"IT小Chen",共同學習,共同成長!!!
來自 “ ITPUB部落格 ” ,連結:http://blog.itpub.net/29785807/viewspace-1749896/,如需轉載,請註明出處,否則將追究法律責任。
相關文章
- mongodb怎麼手動建立資料庫MongoDB資料庫
- oracle資料庫建立資料庫例項-九五小龐Oracle資料庫
- 【AWR】Oracle資料庫建立awr基線Oracle資料庫
- Oracle DG備庫手動管理新增資料檔案Oracle
- oracle資料庫建立、刪除索引等操作Oracle資料庫索引
- oracle資料庫使用者建立步驟Oracle資料庫
- 揭祕Oracle雲(一):建立雲資料庫Oracle資料庫
- Oracle各種版本下“示例資料庫的建立”的建立Oracle資料庫
- 揭祕Oracle雲(二):建立自治雲資料庫Oracle資料庫
- Oracle資料庫啟動步驟Oracle資料庫
- 4 配置Oracle資料庫自動啟動Oracle資料庫
- 【BUILD_ORACLE】Oracle 19c RAC搭建(六)建立RAC資料庫UIOracle資料庫
- oracle 10g建立資料庫鏈的簡化Oracle 10g資料庫
- Oracle獲取資料庫中的物件建立語句Oracle資料庫物件
- 每天自動備份Oracle資料庫Oracle資料庫
- 建立資料庫資料庫
- oracle dg庫資料檔案建立失敗ORA-01111Oracle
- 使用免費的Oracle雲服務-建立ATP資料庫Oracle資料庫
- 靜默方式安裝、升級oracle(二): 建立資料庫Oracle資料庫
- Oracle同一臺伺服器建立多個資料庫Oracle伺服器資料庫
- 「Oracle」Oracle 資料庫安裝Oracle資料庫
- oracle之 手動建立 emp 表 與 dept 表Oracle
- 建立資料庫表資料庫
- Mysql建立資料庫MySql資料庫
- Oracle資料庫配置Oracle資料庫
- 自己動手寫Android資料庫框架Android資料庫框架
- oracle資料庫與oracle例項Oracle資料庫
- 「Oracle」Oracle資料庫基本概念Oracle資料庫
- 「Oracle」Oracle 資料庫基本概念Oracle資料庫
- Oracle資料庫-----資料庫的基本概念Oracle資料庫
- oracle 備份資料庫,匯出資料庫Oracle資料庫
- Oracle 12.2 Heavy swapping 資料庫自動關閉OracleAPP資料庫
- 11G oracle資料庫重新啟動crsOracle資料庫
- Oracle資料庫啟動問題彙總(一)Oracle資料庫
- Oracle 12c 手動建立CDB和非CDBOracle
- MySQL手動資料校驗+雲資料庫資料校驗MySql資料庫
- 使用免費的Oracle雲服務-建立並使用ADW資料庫Oracle資料庫
- Oracle資料庫scott使用者建立view檢視許可權Oracle資料庫View
- DataX將MySql資料庫資料同步到Oracle資料庫MySql資料庫Oracle