LINUX下ADG+LVM+DOCKER

LINUX下ADG+LVM+DOCKER
框架原理:
1.利用adg方式将基础库的数据同步到测试库所在的服务器上
2.在测试库所在的服务器上将adg备库数据文件目录利用lvm快照备份
3.利用docker挂在目录方式,将lvm快照备份卷挂在到container里,并启动数据
4.利用shell脚本来自动化这个过程
(因为资源问题,整个测试过程在一台pc机器完成,仅供参考)

一、oracle ADG实现

1.网络参数配置

[oracle@mzhang admin]$ more listener.ora
# listener.ora Network Configuration File: /u01/app/oracle/product/11.2.0/dbhome_1/network/admin/listener.ora
# Generated by Oracle configuration tools.

SID_LIST_LISTENER_STDDG1 =  
  (SID_LIST =  
    (SID_DESC =  
      (GLOBAL_DBNAME = stddg1)  
      (ORACLE_HOME = /u01/app/oracle/product/11.2.0/dbhome_1)  
      (SID_NAME = stddg1)))  
 
SID_LIST_LISTENER_DG1 =  
  (SID_LIST =  
    (SID_DESC =  
      (GLOBAL_DBNAME = dg1)  
      (ORACLE_HOME = /u01/app/oracle/product/11.2.0/dbhome_1)  
      (SID_NAME = dg1)))  
 
LISTENER_STDDG1 =  
  (DESCRIPTION =  
    (ADDRESS = (PROTOCOL = TCP)(HOST = mzhang)(PORT = 1522)))  
ADR_BASE_LISTENER_STDDG1 = /u01/app/oracle
 
LISTENER_DG1 =  
  (DESCRIPTION =  
    (ADDRESS = (PROTOCOL = TCP)(HOST = mzhang)(PORT = 1521)))  
 
ADR_BASE_LISTENER_DG1 = /u01/app/oracle    
[oracle@mzhang admin]$ more tnsnames.ora
dg1 =  
  (DESCRIPTION =  
    (ADDRESS_LIST =  
      (ADDRESS = (PROTOCOL = TCP)(HOST = mzhang)(PORT = 1521)))  
    (CONNECT_DATA =  
      (SERVICE_NAME = dg1)))  
 
stddg1 =  
  (DESCRIPTION =  
    (ADDRESS_LIST =  
      (ADDRESS = (PROTOCOL = TCP)(HOST = mzhang)(PORT = 1522)))  
    (CONNECT_DATA =  
      (SERVICE_NAME = stddg1)))

lsnrctl start listener_dg1
lsnrctl start listener_stddg1

2.主库参数配置

alter system set log_archive_config='dg_config=(dg1,stddg1)';
alter system set log_archive_dest_1='LOCATION=USE_DB_RECOVERY_FILE_DEST valid_for=(all_logfiles,all_roles) db_unique_name=dg1';
alter system set log_archive_dest_2='SERVICE=stddg1 ASYNC db_unique_name=stddg1 valid_for=(ONLINE_LOGFILES,PRIMARY_ROLE)';
alter database force logging;
alter database add standby logfile ('/oradata/datafile/dg1/std_redo01.log') size 50m;
alter database add standby logfile ('/oradata/datafile/dg1/std_redo02.log') size 50m;
alter database add standby logfile ('/oradata/datafile/dg1/std_redo03.log') size 50m;
alter database add standby logfile ('/oradata/datafile/dg1/std_redo04.log') size 50m;

3.备库参数配置

a.密码文件
orapwd file=orapwstddg1 entries=10 force=y ignorecase=y password=oracle

b.参数文件
[oracle@mzhang dbs]$ more initstddg1.ora
db_unique_name=stddg1
db_name=dg1
db_block_size=8192
control_files='/oradata2/datafile/ctl01.ctl'
log_archive_config='DG_CONFIG=(dg1,stddg1)'
db_file_name_convert='/oradata/datafile/dg1','/oradata2/datafile/stddg1'  
log_file_name_convert='/oradata/datafile/dg1','/oradata2/datafile/stddg1'  
standby_file_management='AUTO'
compatible='11.2.0.4.0'
log_archive_max_processes=4  
remote_login_passwordfile='EXCLUSIVE'
fal_server=dg1
db_recovery_file_dest='/oradata2/arc'
db_recovery_file_dest_size=5218762752

c.duplicate database
rman target sys/oracle@dg1 axuiliary sys/oracle@stddg1
duplicate target database for standby from active database;

alter database recover managed standby database cancel;
alter database recover managed standby database disconnect from session;

二、LVM快照备份还原

1.查看lv vg信息
[root@mzhang /]# lvs
  LV         VG        Attr       LSize  Pool Origin Data%  Move Log Cpy%Sync Convert
  LogVol01   vg_mzhang -wi-ao---- 58.59g                                             
  LogVol02   vg_mzhang -wi-ao---- 97.66g                                             
  LogVol03   vg_mzhang -wi-ao----  8.00g                                             
  LogVol04   vg_mzhang -wi-ao---- 90.00g                                             
  LogVolroot vg_mzhang -wi-ao---- 58.59g                                             
[root@mzhang /]# df -h
Filesystem                        Size  Used Avail Use% Mounted on
/dev/mapper/vg_mzhang-LogVolroot   58G  9.3G   46G  17% /
tmpfs                             3.9G  320K  3.9G   1% /dev/shm
/dev/sda1                         283M   58M  207M  22% /boot
/dev/mapper/vg_mzhang-LogVol02     96G  2.3G   89G   3% /oradata
/dev/mapper/vg_mzhang-LogVol01     58G  4.4G   51G   8% /u01
/dev/sr0                          4.2G  4.2G     0 100% /media/CentOS_6.5_Final
/dev/mapper/vg_mzhang-LogVol04     89G  1.9G   83G   3% /oradata2
[root@mzhang /]# vgs
  VG        #PV #LV #SN Attr   VSize   VFree  
  vg_mzhang   1   5   0 wz--n- 465.46g 152.62g

2.首先停止备库,针对逻辑卷LogVol04进行snapshot备份
SQL> alter database recover managed standby database cancel;
SQL> shutdown immediate;
[root@mzhang /]# lvcreate -L 50GB -s -n LogVol05_snap /dev/vg_mzhang/LogVol04
  Logical volume "LogVol05_snap" created                                
[root@mzhang /]# mount /dev/vg_mzhang/LogVol05_snap /mnt
[root@mzhang /]# df -h |grep mnt
/dev/mapper/vg_mzhang-LogVol05_snap   89G  1.9G   83G   3% /mnt


三、DOCKER来创建oracle container

1、docker信息
[root@mzhang mnt]# docker version
Client version: 1.7.1
Client API version: 1.19
Go version (client): go1.4.2
Git commit (client): 786b29d/1.7.1
OS/Arch (client): linux/amd64
Server version: 1.7.1l
Server API version: 1.19
Go version (server): go1.4.2
Git commit (server): 786b29d/1.7.1
OS/Arch (server): linux/amd64
[root@mzhang mnt]# docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             VIRTUAL SIZE
oraclelinux         latest              90a41cef53ee        5 days ago          225.3 MB

2、创建container
docker run -dti --name oracl1 --privileged=true -v /proc:/container_proc -v /mnt:/oradata2 oraclelinux /bin/bash
docker run -dti --name oracl2 --privileged=true mzhang/oraclelinux2 /bin/bash
docker run -dti --name oracl3 --privileged=true -v /mnt:/oradata2 mzhang/oraclelinux2 /bin/bash

a.container里安装数据库软件(-ignorePrereq)
./runInstaller -silent -force -ignorePrereq -responseFile /tmp/database/response/db_install.rsp

b.copy备库的密码文件及参数文件到容器中的相关目录下

c.启动container中数据库
SQL> startup mount;
ORACLE instance started.
Total System Global Area  263090176 bytes
Fixed Size            2252256 bytes
Variable Size          205521440 bytes
Database Buffers       50331648 bytes
Redo Buffers            4984832 bytes
Database mounted.
SQL> alter database activate standby database;
SQL> alter database open;
SQL> select open_mode,name from v$database;
OPEN_MODE         NAME
-------------------- ---------
READ WRITE         DG1

3.做个参数配置完毕,rpm包安装完毕,只安装oracle软件的images
 docker commit 79b74f8553ee mzhang/oraclelinux2

如果要做多个容器,需要做多个lvm snapshot。

 

CentOS 6.5 install docker准备工作

CentOS 6.5 install docker准备工作
主要是针对linux内核做升级来完成

1.下载

kernel-ml-aufs-3.10.5-12.1.x86_64.rpm
kernel-ml-aufs-devel-3.10.5-12.1.x86_64.rpm

http://rpm.pbone.net/index.php3/stat/4/idpl/23675425/dir/centos_6/com/kernel-ml-aufs-devel-3.10.5-12.1.x86_64.rpm.html
http://rpm.pbone.net/index.php3/stat/4/idpl/23675424/dir/centos_6/com/kernel-ml-aufs-3.10.5-12.1.x86_64.rpm.html

2.安装(有点慢,一定要等rpm安装完全完成,否则内核解压会有问题)

[root@mzhang Downloads]# rpm -ivh kernel-ml-aufs-3.10.5-12.1.x86_64.rpm  kernel-ml-aufs-devel-3.10.5-12.1.x86_64.rpm
warning: kernel-ml-aufs-3.10.5-12.1.x86_64.rpm: Header V3 RSA/SHA1 Signature, key ID 41df2091: NOKEY
Preparing...                ########################################### [100%]
   1:kernel-ml-aufs-devel   ########################################### [ 50%]
   2:kernel-ml-aufs         ########################################### [100%]

3.修改grub的主配置文件/etc/grub.conf,修改default=1 ===>>default=0,表示第一个title下的内容为默认启动的kernel(3.10.5-12.1.x86_64)

default=0
timeout=5
splashimage=(hd0,0)/grub/splash.xpm.gz
hiddenmenu
title CentOS (3.10.5-12.1.x86_64)
        root (hd0,0)
        kernel /vmlinuz-3.10.5-12.1.x86_64 ro root=/dev/mapper/vg_mzhang-LogVolroot rd_NO_LUKS LANG=en_US.UTF-8 rd_LVM_LV=vg_mzhang/LogVol03 rd_NO_MD SYSFONT=latarcyrheb-sun16  KEYBOARDTYPE=pc KEYTABLE=us rd_LVM_LV=vg_mzhang/LogVolroot rd_NO_DM rhgb quiet crashkernel=auto
        initrd /initramfs-3.10.5-12.1.x86_64.img
title CentOS (2.6.32-431.el6.x86_64)
        root (hd0,0)
        kernel /vmlinuz-2.6.32-431.el6.x86_64 ro root=/dev/mapper/vg_mzhang-LogVolroot rd_NO_LUKS LANG=en_US.UTF-8 rd_LVM_LV=vg_mzhang/LogVol03 rd_NO_MD SYSFONT=latarcyrheb-sun16  KEYBOARDTYPE=pc KEYTABLE=us rd_LVM_LV=vg_mzhang/LogVolroot rd_NO_DM rhgb quiet
        initrd /initramfs-2.6.32-431.el6.x86_64.img

4.重启后验证

[root@mzhang Desktop]# uname -r
3.10.5-12.1.x86_64
[root@mzhang Desktop]# grep aufs /proc/filesystems
nodev    aufs

5.关闭selinux和防火墙(因此服务需要配置oracle数据库在上面)

[root@mzhang Desktop]# more /etc/selinux/config |grep SELINUX=
# SELINUX= can take one of these three values:
SELINUX=disabled
[root@mzhang Desktop]# chkconfig iptables off
[root@mzhang Desktop]# chkconfig --list|grep iptables
iptables           0:off    1:off    2:off    3:off    4:off    5:off    6:off

 

DOCKER里实现oracle库容器化一

DOCKER里实现oracle库容器化一

实现功能:
将在docker所在的宿机上oracle数据文件目录放到container里从而快速构建一个oracle环境

部署环境:
docker所在的宿主机OS:centOS 7.2
container里的OS:oraclelinux 7.0
db版本:11.2.0.4

实现过程(docker启动安装不废话,底层架构实现原理必须要了解)

一、db配置:宿主机和container里都是这样


1.centOS 7.2 安装 oracle11.2.0.4(记录以下雷区,基本配置不废话),建议采用silent安装
./runInstaller -silent -force -ignoreSysPrereqs -responseFile /tmp/database/response/db_install.rsp
-ignoreSysPrereqs 这个参数很重要,因为要忽略kdsh这个东东,不然会报错
2.dbca采用脚本方式,官方文档
[oracle@localhost ~]$ export $ORACLE_BASE
/home/app/oracle
[oracle@localhost ~]$ export $ORACLE_HOME
/home/app/oracle/product/11.2.0/dbhome_1

二、docker container配置

1.pull oraclelinux images (此过程在连接网络的情况下,上uat环境就拿已有的镜像即可)
docker search oraclelinux
docker pull oraclelinux
2.创建并启动一个oraclelinux image的container(容器参数更改另讨论)
docker run -it -v /home/app:/home/app oraclelinux /bin/bash
3.查看
[root@localhost 桌面]# docker ps
CONTAINER ID        IMAGE                                   COMMAND                  CREATED             STATUS              PORTS                    NAMES
28b7cc0d3177        oraclelinux                             "bash"                   24 hours ago        Up 24 hours                                  elated_easley
21b22e21c2dd        hub.c.163.com/library/registry:latest   "/entrypoint.sh /e..."   2 months ago        Up 25 hours         0.0.0.0:5000->5000/tcp   handpay_registry
4.进入
docker exec -it  28b7cc0d3177 /bin/bash
5.container里的目录结构
[root@28b7cc0d3177 app]# df -h
Filesystem                                                                                          Size  Used Avail Use% Mounted on
/dev/mapper/docker-253:0-67481202-8421f8ec1c1fc2483ce4de9b86494072eb42069d96b0bebc7e7524252348a837   10G  8.2G  1.9G  82% /
tmpfs                                                                                               3.8G     0  3.8G   0% /dev
tmpfs                                                                                               3.8G     0  3.8G   0% /sys/fs/cgroup
/dev/mapper/centos-home                                                                             408G  6.1G  402G   2% /home/app
/dev/mapper/centos-root                                                                              50G   23G   28G  46% /etc/hosts
shm                                                                                                  64M     0   64M   0% /dev/shm
tmpfs                                                                                               3.8G     0  3.8G   0% /sys/firmware
6.启动container里的库注意操作
create pfile from spfile;
去除memory_target参数
create spfile from pfile;
启动

三、docker container参数更改,针对oracle

1.添加-v /proc:/container_proc
docker run  -ti --name oracle1 -v /proc:/container_proc -v /home/app:/home/app  oraclelinux /bin/bash
[root@localhost tmp]# docker run --rm -ti --name oracle1 -v /proc:/container_proc -v/home/app:/home/app  oraclelinux /bin/bash
[root@1132e7baf144 /]# ls
bin  boot  container_proc  dev  etc  home  lib  lib64  media  mnt  opt  proc  root  run  sbin  srv  sys  tmp  usr  var
2.修改参数
echo 4050407424 > /container_proc/sys/kernel/shmmax
echo 4096 > /container_proc/sys/kernel/shmmni
echo 2097152 > /container_proc/sys/kernel/shmall
echo 250 32000 100 128 > /container_proc/sys/kernel/sem
echo 6815744 > /container_proc/sys/fs/file-max
echo 1048576 > /container_proc/sys/fs/aio-max-nr
echo 9000 65500 > /container_proc/sys/net/ipv4/ip_local_port_range
/*需要注意的是,如果内核版本过低(<3.12), 有些参数是无法修改的*/
[root@1132e7baf144 kernel]# uname -a
Linux 1132e7baf144 3.10.0-514.10.2.el7.x86_64 #1 SMP Fri Mar 3 00:04:05 UTC 2017 x86_64 x86_64 x86_64 GNU/Linux
echo 262144 > /container_proc/sys/net/core/rmem_default
echo 262144 > /container_proc/sys/net/core/wmem_default
echo 4194304 > /container_proc/sys/net/core/rmem_max
echo 1048576 > /container_proc/sys/net/core/wmem_max

总结:
1.centOS 7对oracle11gR2版本的兼容性不是很好,安装过程中会出现安装界面卡四问题
解决方案:使用silent方式安装,此方式安装oracle,一般情况不建议在生产上使用,除非很了解所以安装调用过程是怎么处理的和报错原因
预测:测试环境在今后使用中可能会出现奇怪问题
2.oracle11gR2安装后报出ORA-07445,然重新启动数据库又没有报错
3.宿主机目录挂在到container里,注意用户机用户组的id需要里外统一,否则因权限问题无法启动oracle
4.container里的参数调优需要经过特殊处理
5.container里需要安装oracle软件的目录及路径都要和外面宿主机环境的目录做好统一规划,不然问题很大
6.container里oracle dbs目录下密码文件和参数文件来自与宿主机
7.搭建完成后数据库可以正常启动
8.docker 网络配置不解