基本Linux操作
uname -r 查看核心版本號碼
df -m 查看各存放裝置空間
du -sh 查看目前的目錄空間大小
查看進程及IO情況: top 、 mpstat -P ALL 1 100 、iostat -x 1 10(測試IO效能)
強制移除目錄 rm -rf
刪除空目錄 rmdir
設定Linux系統vi /etc/sysctl.confg
net.ipv4.ip_forward = 0
net.ipv4.conf.default.rp_filter = 1
net.ipv4.conf.default.accept_source_route = 0
net.ipv4.tcp_syncookies = 1
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
kernel.msgmnb = 65536
kernel.msgmax = 655360
kernel.shmmax = 68719476736
kernel.shmall = 4294967296 (表示頁 32位系統 1頁=4k)
kernel.shmmni=4096
kernel.sysrq = 0
kernel.core_uses_pid = 1
kernel.sem=250 32000 100 128
fs.file-max=6815744
fs.aio-max-nr=1048576
應用參數 sysctl -p
進行 vi /etc/security/limits.conf 設定
Oracle soft nproc 2047
oracle hard nproc 16384
oracle soft nofile 1024
oracle hard nofile 65536
進行 vi /etc/pam.d/login 設定
session required /lib/security/pam_limits.so
session required pam_limits.so
groupadd oinstall
groupadd dba
useradd -g oinstall -g dba -m oracle
passwd oracle
接下來就是建立Oralce 根目錄與安裝目錄
mkdir /data/ora11g
mkdir /data/ora11g/product/11.2.0.1/dbhome_1
設定 Oracle 目錄 .bash_profile
export ORACLE_BASE=/data/ora11g
export ORACLE_HOME=$ORACLE_BASE/product/11.2.0.1/dbhome_1
export ORACLE_SID=xxxx
export ORACLE_TERM=xterm
export PATH=$PATH:$HOME/bin:$ORACLE_HOME/bin
export LD_LIBRARY_PATH=$ORACLE_HOME/lib:/lib64:/usr/lib64:/usr/local/lib64:/usr/X11R6/lib64
#export CLASSPATH=$ORACLE_HOME/JRE:$ORACLE_HOME/jlib:$ORACLE_HOME/rdbms/jlib
export LD_ASSUME_KERNEL=2.6.18
export NLS_LANG="SIMPLIFIED CHINESE_CHINA.ZHS16GBK"
#export NLS_LANG="zh_CN.UTF-8"
export LANG=zh_CN.UTF-8
export LC_ALL=zh_CN.GB2312
umask 022
if [ $USER = "oracle" ]; then
if [ $SHELL = "/bin/ksh" ]; then
ulimit -p 16384
ulimit -n 65536
else
ulimit -u 16384 -n 65536
fi
從 root 使用者切換到 oracle 使用者進行安裝前一定要執行 xhost + 命令,否則找不到顯示輸出
註:第二張盤中的stage中的檔案全部拷貝到第一張盤中的 stage ,否則安裝過程中報錯,就是報找到不第二張盤中的檔案(不知有沒有其他辦法)
安裝好 oracle 軟體(先不建立資料庫)
最後執行 $ORACLE_BASE/oraInventory/orainstRoot.sh 、 $ORACLE_HOME/root.sh 二個指令碼
使用 dbca 、netca 、netmgr 來建立資料、配置本地監聽、管理串連
啟動oracle監聽 lsnrctl start/stop/reload/status
目錄 diag
oracle的alert日誌在ORACLE_BASE下ORACLE_BASE/diag/{product_type}/{product_id}/{instance_id}
alter下是以xml格式 log.xml
trace是文字格式設定 alter_{instance}.log
目錄 admin
目前存放建立資料庫的指令碼,以前的alertlog已經不在這個地方了
安裝好 oracle後,啟動sqlplus提示錯誤
libclntsh.so.11.1: cannot restore segment prot after reloc: Permission deni
解決方案:
在root許可權下
執行
semanage fcontext -a -t textrel_shlib_t 路徑\libclntsh.so.11.1
執行 restorecon -R -v 路徑\libclntsh.so.11.1
再增加環境變數
vi /etc/profile
export
export ORACLE_HOME=路徑
export ORACLE_SID=orcl
export PATH=:$ORACLE_HOME
即可
dbca netca 無法啟動
需設定
vi /etc/sysconfig/network 中的 HOSTNAME=重設定命名
NETWORKING=yes
NETWORKING_IPV6=no
HOSTNAME=mytest
GATEWAY=127.0.0.1
再編輯
vi /etc/hosts
在
127.0.0.1 localhost.localdomain localhost
後台增加上面同樣的命名
127.0.0.1 localhost.localdomain localhost mytest
儲存
[root@localhost#]hostname mytest
即可