由于现有业务架构已不能知足当前业务需求,在担保数据完全的条件下,现须要将原有数据库迁移到其余一台单独的做事器上,在担保原有做事正常的情形下,将原有LAMP环境中mysql数据库版本5.6.31升级为5.6.35.

任务哀求

1. 在业务掩护韶光(02:00-4:00)段对数据库进行全量备份

php更新mysqlMySQL迁徙进级解决计划 Bootstrap

2. 将MySQL数据库从原有做事器迁移到新做事器上并且升级版本为5.6.35

任务拆解

1. 新做事器安装Centos7.5,并且安装MySQL-5.6.35版本数据库

2. 停滞监控、停滞前端运用、停滞MySQL数据库

3. 备份数据库(省略)

4. 迁移数据库——>同步数据库文件到新的环境中(rsync/scp)

5. 测试验证

任务办理方案

环境解释

详细步骤

1. 老环境停滞相应做事

1) 停滞监控略2) 停滞运用做事apache和数据库[root@lamp ~]# service httpd stop[root@lamp ~]# service mysql stopShutting down MySQL.. SUCCESS!

2. 新环境支配安装MySQL

① 官网下载mysql软件

# du -sh mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz301M mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz

② 安装需求

安装目录(basedir):/usr/local/mysql数据库目录(datadir):/usr/local/mysql/data端口:3306socket文件:/tmp/mysql.sock缺点日志文件:/usr/local/mysql/data/mysql.err

③ glibc办法安装步骤

1) 解压软件包

# tar -xf mysql-5.6.35-linux-glibc2.5-x86_64.tar.gz# cd /usr/local/# ln -s /soft/installer/mysql-5.6.35-linux-glibc2.5-x86_64 mysql把稳:进入到/usr/local目录里软连接

2) 创建用户并修正目录权限

1. 查看用户是否存在[root@db01 mysql]# id mysqlid: mysql: no such user[root@db01 mysql]# useradd -r -s /sbin/nologin mysql[root@db01 mysql]# id mysqluid=997(mysql) gid=995(mysql) 组=995(mysql)2. 变动mysql的安装目录的权限[root@db01 mysql]# chown -R mysql.mysql /usr/local/mysql/[root@db01 mysql]# ll -d /usr/local/mysql/drwxr-xr-x 13 mysql mysql 191 10月 9 10:26 /usr/local/mysql/

3) 修正配置文件

修正/etc/my.cnf文件[root@db01 mysql]# vim /etc/my.cnf[mysqld]basedir=/usr/local/mysqldatadir=/usr/local/mysql/dataport=3307socket=/usr/local/mysql/mysql.socklog-error=/usr/local/mysql/data/mysql3307.err

4) 拷贝启动脚本

[root@db01 mysql]# pwd/usr/local/mysql[root@db01 mysql]# cp support-files/mysql.server /etc/init.d/mysql

5) 初始化解释

1. 正常安装新数据库直策应用,是须要初始化数据库然后再启动利用

2. 当前需求是将原来MySQL数据库文件迁移到新的数据库的数据目录里,故不须要初始化

3. 迁移数据库到新环境

解释:新数据库做事器上操作

① 同步老库数据文件到新库数据目录里

[root@db01 mysql]# rsync -av 10.1.1.1:/usr/local/mysql/data/ /usr/local/mysql/data

② 启动新数据库

直接启动新的数据库,并且检讨日志文件(查看是否有选项不兼容)[root@db01 mysql]# service mysql start

③ 升级数据库(重点,升级数据库文件)

利用mysql_upgrade命令检讨数据文件的兼容性[root@db01 ~]# /usr/local/mysql/bin/mysql_upgrade -S /tmp/mysql.sock -p123把稳:1. 在实际的环境中,建议利用-s参数,不检讨业务表,只检讨系统文件2. 升级是须要连接数据库的,-p密码 -S指定socket文件[root@db01 mysql]# /usr/local/mysql/bin/mysql_upgrade -pEnter password:Looking for 'mysql' as: /usr/local/mysql/bin/mysqlLooking for 'mysqlcheck' as: /usr/local/mysql/bin/mysqlcheckError: Failed while fetching Server version! Could be due to unauthorized access.FATAL ERROR: Upgrade failed缘故原由:连接数据库失落败

4. 原web做事连接新数据库(LAMP=>LNMP)

① 修正php连接mysql的配置文件(如果有)

[root@lamp ~]# find / -name php.ini/usr/local/lib/php.ini[root@lamp ~]# vim /usr/local/lib/php.ini[MySQL]mysql.default_port = 3306mysql.default_host = 10.1.1.37[MySQLi]mysql.default_port = 3306mysql.default_host = 10.1.1.37

② 修正网站配置文件连接数据库

修正www.myblog.net网站所在数据库目录的配置文件[root@lamp www]# pwd/var/html/www[root@lamp www]# vim wp-config.php...// MySQL 设置 - 详细信息来自您正在利用的主机 /// WordPress数据库的名称 /define('DB_NAME', 'myblog');/ MySQL数据库用户名 /define('DB_USER', 'root');/ MySQL数据库密码 /define('DB_PASSWORD', '123');/ MySQL主机 /define('DB_HOST', '10.1.1.37');/ 创建数据表时默认的笔墨编码 /define('DB_CHARSET', 'utf8');

③ 新数据库授权为web做事

新的mysql数据库须要给root@10.1.1.19用户授权mysql> grant all on . to 'root'@'10.1.1.19' identified by '123';Query OK, 0 rows affected (0.00 sec)mysql> flush privileges;Query OK, 0 rows affected (0.00 sec)把稳:把防火墙firewalld和selinux全部关闭掉,不然打去世都连接不上!

④ 启动web做事

[root@lamp ~]# service apache start[root@lamp ~]# netstat -nltp|grep httpdtcp 0 0 :::80 ::: LISTEN 1376/httpd

⑤ 测试验证

1.浏览器访问2. web做事器上利用mysql工具远程访问[root@lamp ~]# mysql -uroot -h10.1.1.37 -uroot -p123

学习资源:

5天玩转MySQL