· 背景

公司要把一些老设备退服,一些陪伴我多年的DB要下线了,舍不得。正好借此机会,手贱把自己3个"回收站"DB迁移到MySQL上,也算是赶一把时髦。等真正看着这些老设备下线了的那一天,也会不尽感叹一个时代结束了。

· 心得

  1. 芒果:爱你不容易,开始我想是往上迁,因为文档多/API多,游刃有余,支持不规则列,最符合我的需要。可惜,除了字符集之外。。。详见后面第7点。
  2. 共享OR独立:最早碰到的问题当属目标数据库的容量和存储设计,两者表空间管理上各有优势。开始一心想用Raw设备+innodb,但发现在共享和独立表空间上出现了卡壳,共享表空间可以发挥RAW设备优势,但是独立表空间怎么配置貌似都无法支持。不过好在我的单表MAX大约15G,最大记录数在7E不到。算了还是图方便,独立吧,弃用RAW。大家迁移前可以MAX下原表dba_segments。对未来也算有个数了。
  3. EXT3 OR EXT4:由于没有了RAW设备,在建盘的时候没有多想,等命令敲下去,发现建成EXT3,于是找理由安慰自己。有机会再改EXT4吧。
  4. DATE转DATETIME/TIMESTAMP:这个算是比较麻烦的,原先无论是C/JAVA的函数还是CONTROLFILE,对于日期时间处理都能个性化设置,方便了外部程序的各种时间形式。但当入MYSQL表时候就得严格遵守了,尤其是LOAD DATA,找了半天也没找到SKIP,这点上ORACLE还是比较厚道的。好吧,只能这样了。一个个程序得改。
  5. WITHOUT UPDATE PID FILE:我X,真心迷宫啊。最早是在自己VM+CENTOS上测试,一改数据目录就报错了,最后发现居然是SELINUX的问题。红帽默认DISABLE,良心啊。改完之后,各种破坏测试一路推平。
  6. DBLINK:这个东西纯技术角度上将是个神器,但管理上会有很大麻烦。为了迁移历史数据,当然希望是越方便越好,有ORACLE到MYSQL的,但反向的没有。怎么办呢?之后自己动手写脚本迁移。话说ORACLE收购了它也有段时日了,怎么不融通一下呢?
  7. 图形工具:又一个大坑。个人信仰:"任何再NB的软件,最终无法逃不了用户CTRL+C/CTRL+V的双指"。最直接的问题,我也复制1~N列怎么办?我要智能联想怎么办?。有时候,个人觉得ORACLE的成功之后80%归功于PL/SQL。这个需求到MYSQL上理所当然需要继承。于是从各种GUI工具试了一把,最终选定了Navicat。
  8. SHOW PARAMETERS:从ORACLE改MYSQL,当然这一关少不了。粗糙点讲:SGA按比例扩大后打9折设定INNODB_BUFFER_POOL,REDOLOG按比例扩大设定LOG_BUFFER。其他自己按需微调吧。
  9. PROC/FUNCTION:这块原来库中用的不多,暂时先按着新语法改。另外一些VARCHAR最长LENGTH INDEX就不多说了。
  10. DDL:ORACLE比较厚道也比较蛋疼,我也比较懒,最好一键把DDL+INDEX结构导入新表,这个会有很多细节上麻烦,算了,还是自己弄个SHELL过渡过去吧。小心INDEX。
  11. 八国联军:Oracle确实很强大,也充分展现着美帝强大的霸权主义,眼红什么买什么。切记:人心不足蛇吞象,难怪股价上不去。

最后,我把整个操作中的过程展现一下,供感兴趣的朋友参考,轻拍砖~!

· 命令日志(从无到有,供参考)

==准备素材==

vim /etc/selinux/config
SELINUX=disabled
Yum –e mysql*
Yum install –y cron*
/etc/init.d/crond restart
cd /usr/share/selinux
setenforce 0
tar -xvf MySQL-5.6.12-1.el6.x86_64.rpm-bundle.tar
rpm -qa|grep -i mysql
yum -y remove mysql-libs*
rpm -e mysql*
rpm -ivh MySQL-server-5.6.12-1.el6.x86_64.rpm
rpm -ivh MySQL-client-5.6.12-1.el6.x86_64.rpm
rpm -ivh MySQL-devel-5.6.12-1.el6.x86_64.rpm
service mysql stop
cp ./usr/share/doc/MySQL-server-5.6.12/my-default.cnf /etc/my.cnf
vim /etc/my.cnf

==准备盘==

mkdir /mydata
chown mysql:mysql -R /mydata
关机加盘
fdisk -l认盘
fdisk /dev/sdb
输入m、输入n、输入PrimaryPartID,2,回车到底,输入w
start_udev 为后续RawDevice做准备
vgcreate -s 4M datavg /dev/sdb
lvcreate -L 980M -n data_lv datavg
mke2fs -j -b 4096 /dev/datavg/data_lv
mount -t ext4 /dev/datavg/data_lv /mydata
mv /var/lib/mysql /mydata
vim /etc/fstab
/dev/mapper/datavg-data_lv /mydata ext3 defaults 0 0
Reboot 测试,看自动加载。

==DB参数调整==

Service mysql stop
Mv /var/lib/mysq /mydata
mysql_install_db --user=mysql --datadir=/mydata
chown –R mysql:mysql /mydata
cat /root/.mysql_secret 拿密码:
service mysql start
mysql -u root –pxxxxx mysql
mysql> UPDATE user SET Password=PASSWORD('111') where USER='root';
mysql> FLUSH PRIVILEGES;
mysql> quit;
alias pp='ps –ef|grep –i mysql'
service mysql restart
mysql -uroot -p111
mysql> SET PASSWORD = PASSWORD('123');
mysql> show variables like '%char%';
mysql> use mysql;
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.168.137.1' IDENTIFIED BY '123' WITH GRANT OPTION;
mysql> GRANT ALL PRIVILEGES ON *.* TO 'root'@'192.167.137.102' IDENTIFIED BY '123' WITH GRANT OPTION;
mysql> select user,host from user;
mysql> set sql_mode='no_auto_create_user,no_engine_substitution';
db2db.sh
Reboot 测试,看能否自动启动。

==DB2DB.sh==

所在位置 https://github.com/zacard-orc/Zacard_DB2DB

脱O把妹,记录这一周来迁移至MySQL的一些心得的更多相关文章

  1. 分布式监控系统Zabbix--完整安装记录(7)-使用percona监控MySQL

    前面已经介绍了分布式监控系统Zabbix-3.0.3-完整安装记录(2)-添加mysql监控,但是没有提供可以直接使用的Key,太过简陋,监控效果不佳.要想更加仔细的监控Mysql,业内同学们都会选择 ...

  2. 记录PHP post提交表单导入mysql中文乱码的问题

    记录记录PHP post提交表单导入mysql中文乱码的问题 关于乱码,这是个糟糕的问题!涉及到很多地方 解决思路:程序所涉及的环境字符集不一致导致 mysql出现乱码一般是mysql数据库内部的字符 ...

  3. 程序语言与编程实践4-> 蓝桥杯C/C++备赛记录2 | 第二周学习训练

    0323,又是一周星期三,按道理该总结了.这周前几天写题比较多,后面事情多了起来,就没怎么写了.主要方向是洛谷的基本语法熟悉,PTA平台数据结构的一些题目. 0323附上: 题目比较多,所以文章可能有 ...

  4. 记录下这周的mysql调优工作

    这周一至周四基本都在做mysql的测试和调优工作,包括erlang端对mysql的写入测试,到今天为止暂且告一段落,下周先做下其他的开发.    测试环境    使用的测试环境是aliyun的杭州节点 ...

  5. 分布式监控系统Zabbix-3.0.3-完整安装记录(7)-使用percona监控MySQL

    前面已经介绍了分布式监控系统Zabbix-3.0.3-完整安装记录(2)-添加mysql监控,但是没有提供可以直接使用的Key,太过简陋,监控效果不佳.要想更加仔细的监控Mysql,业内同学们都会选择 ...

  6. 记录自己对EventLoop和性能问题处理的一点心得

    1.EventLoop 这里说的EventLoop不是指某一个具体的库或是框架,而是指一种程序实现结构.这种结构多是基于IO多路转接的API(select.poll.epoll之类)以reactor模 ...

  7. MySQL之 InnoDB记录结构(转自掘金小册 MySQL是怎样运行的,版权归作者所有!)

    以下内容来自掘金小册 MySQL 是怎样运行的:从根儿上理解 MySQL 版权归原作者所有! 页是MySQL中磁盘和内存交互的基本单位,也是MySQL是管理存储空间的基本单位. 指定和修改行格式的语法 ...

  8. 记录自己对EventLoop和性能问题处理的一点心得【转】

    转自:http://www.cnblogs.com/lanyuliuyun/p/4483384.html 1.EventLoop 这里说的EventLoop不是指某一个具体的库或是框架,而是指一种程序 ...

  9. SQL查询月、天、周、年(MySql的实例对比)

    SQL Server实现 日期部分 缩写 year yy, yyyy quarter qq, q month mm, m dayofyear dy, y day dd, d week wk, ww w ...

随机推荐

  1. STL之容器适配器queue的实现框架

    说明:本文仅供学习交流,转载请标明出处,欢迎转载! 上篇文章STL之容器适配器stack的实现框架已经介绍了STL是怎样借助基础容器实现一种经常使用的数据结构stack (栈),本文介绍下第二种STL ...

  2. JVM学习(1)——通过实例总结Java虚拟机的运行机制(转)

    俗话说,自己写的代码,6个月后也是别人的代码……复习!复习!复习!涉及到的知识点总结如下: JVM的历史 JVM的运行流程简介 JVM的组成(基于 Java 7) JVM调优参数:-Xmx和-Xms ...

  3. rabbitmq技术的一些感悟(一)

    Rabbitmq 初识rabbitmq RabbitMQ是流行的开源消息队列系统,用erlang语言开发.RabbitMQ是AMQP(高级消息队列协议)的标准实现.假设不熟悉AMQP,直接看Rabbi ...

  4. Unicode字段也有collation

    原文:Unicode字段也有collation 转自:http://blogs.msdn.com/b/apgcdsd/archive/2011/01/11/unicode-collation.aspx ...

  5. java通过抛异常来返回提示信息

    结论:如果把通过抛异常的方式得到提示信息,可以使用java.lang.Throwable中的构造函数: public Throwable(String message) { fillInStackTr ...

  6. Youtube最佳Red5 官方视频下载指南,字幕【亲测成功】

    前言 最近在研究Red5 流媒体服务框架,官网上的信息足以让一个新手入门 有官方參考手冊 -- 高速了解red5的相关信息 有Red5 on Stackoverflow  -- 在上面能够提问或者回答 ...

  7. 怎么样Ubuntu正在使用root账号登录

    一个. 因为当你需要 root 权限,使用 sudo 我们将能够做到这一点.假设你真的需要在 Ubuntu 启用 root 帐户的话,这是最好的运行下面的操作: 1.再次设置 root 的passwo ...

  8. 阿里云ECSserver部署django

    highlight=uwsgi%20django">參考 server安装的是Centos 系统. uwsgi是使用pip安装的. nginx是使用yum install nginx安 ...

  9. 使用reserve要再次避免不必要的分配

     关于STL容器,最了不起的一点是,它们会自己主动增长以便容纳下你放入当中的数据,仅仅要没有超出它们的最大限制就能够.对于vector和string,增长过程是这样来实现的:每当须要很多其它空间时 ...

  10. dp related problems (update continuously)

    Leetcode Maximum Product Subarray 这个问题是说给一个整数数组.求最大连续子阵列产品. 纠结了包括阵列中的很长一段时间0而如何处理负数,关键的事实是,负治疗,所以我们录 ...