windows服务器mysql数据库迁移

背景(and 前提)

甲方要换新服务器,要把项目迁移到新服务器上。(这篇主要讲数据库的迁移)

整体都使用的cmd进行操作的,用navicat等软件操作应该会更方便一些,但是我们服务器上没有。

整体流程

1. 将旧服务器上数据库备份成sql文件

2. 新服务器安装mysql,并新增旧服务器上的用户

3. 新服务器恢复备份。

4. 新服务器打开防火墙,并开放3306端口

旧服务器备份sql文件

备份数据库的命令通常使用 mysqldump 工具来完成。格式如下:

mysqldump -u <username> -p<password> <database_name> > <backup_file.sql>

其中:

  • <username> 是连接MySQL的用户名;
  • <password> 是该用户名的密码(注意 -p 与密码之间没有空格,如果密码为空,则直接使用 -p);
  • <database_name> 是要备份的数据库的名称;
  • <backup_file.sql> 是备份的输出文件名,通常以 .sql 扩展名结尾。

        遇到的问题:

mysqldump: Got error: 2005: Unknown MySQL server host 'localhost' (2) when tryin g to connect

        解决:

在备份命令中加入 -h 127.0.0.1

mysqldump -h 127.0.0.1 -u <username> -p<password> <database_name> > <backup_file.sql>

 新服务器安装mysql

我安装的版本是8.0.13

1. 下载mysql

夸克地址链接:https://pan.quark.cn/s/367ec0dc9d23
提取码:KykZ

2. 解压到没有中文和空格的目录下。

3. 加入配置文件my.ini

    自己创建,内容如下:

[mysqld]
# 设置3306端口
port=3306
# 创建新表时将使用的默认存储引擎
default-storage-engine=INNODB
bind-address = 0.0.0.0
[mysql]
# 设置mysql客户端默认字符集
default-character-set=utf8
[client]
# 设置mysql客户端连接服务端时默认使用的端口
port=3306
default-character-set=utf8

4. 配置环境变量:

新增MYSQL_HOME  值填你解压的路径

path中新增%MYSQL_HOME%\bin

5. 管理员身份进入命令行

         win +R 输入cmd

6. mysql初始化:会产生一个临时密码,后面登录要用,登录以后再改密码

        mysqld --initialize --user=mysql --console

7. 安装mysql服务

        mysqld --install

8. 启动mysql服务:(这里遇到一个巨离谱的错误,出错了去看下面遇到的问题)

        net start mysql

9. 登录mysql

        mysql:mysql -u root -p

        输入上面命令,提示输入密码,把刚才的临时密码输入进去

10. 改root用户密码和权限

        改密码:

ALTER USER 'root'@'localhost' IDENTIFIED WITH mysql_native_password BY '123456';

        改权限:

CREATE USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456';

11. 新增用户(一般是你项目中用到的用户,并设置用户权限为任何机器都可以访问)

以我的代码为例:

        创建用户:

CREATE USER 'pacs'@'%' IDENTIFIED WITH mysql_native_password BY 'pacs';

        赋予用户全部权限

GRANT ALL PRIVILEGES ON *.* TO 'pacs'@'%' WITH GRANT OPTION;

12. 恢复数据库(我用的是在mysql内部命令恢复)

        1. 新建要恢复的数据库名:cerate database 数据库名;

        2. 进入数据库 use 数据库名;

        3. sourse sql文件名(把sql文件放在服务器中,写绝对路径就可以访问);

        遇到的问题:

在启动mysql服务的时候,提示错误:

找不到指定文件,具体如下:

C:\MYSQL\mysq\mysql-8.0.13-winx64\bin>net start mysql
发生系统错误 2。

系统找不到指定的文件。

         解决办法

1. win+R输入regedit

2.进入HKEY_LOCAL_MACHINE\SYSTEM\CurrentControlSet\Services\MySQL

3. 双击 MySQL映像文件ImagePath

4. 把它的值修改为正确的(你mysql解压路径下面的bin\mysqld MySQL)

打开防火墙,并开放3306端口

可以参考:win10 打开指定端口号_windows开启3306端口-CSDN博客

特别鸣谢:mysql安装过程来自:Windows安装MySQL8.0详细步骤-CSDN博客

  • 35
    点赞
  • 14
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
MySQL数据库迁移到另一台服务器的过程需要经过以下几个步骤: 1.准备目标服务器:首先,需要准备好目标服务器,确保它符合要求并且已经安装好MySQL数据库。 2.备份源数据库:在迁移之前,需要先对源数据库进行备份,以确保数据的安全性。可以使用MySQL提供的命令行工具(如mysqldump)或者第三方工具(如Navicat)进行备份。备份时要注意设置参数,如是否备份完整数据库、备份表结构还是同时备份数据等。 3.迁移数据库文件:将备份的数据库文件从源服务器拷贝到目标服务器上。可以通过网络传输,也可以先将备份文件拷贝到一个共享存储设备上,再从该设备上复制到目标服务器。 4.恢复数据库:在目标服务器上还原备份文件,将数据库恢复到目标服务器上。可以使用MySQL提供的命令行工具或者导入工具(如Navicat)进行恢复操作。 5.检查和配置:在成功恢复数据库之后,需要检查数据库是否正常运行,并进行必要的配置。确保目标服务器上的MySQL配置与源服务器一致,包括数据库大小、字符集、表引擎等。还需要确认网络连接是否正常,以及设置合适的权限和用户访问。 6.测试和验证:迁移完成后,需要进行测试和验证,确保迁移后的数据库能够正常使用。可以对一些关键的查询和操作进行测试,以确保数据的一致性和正确性。 在整个迁移过程中,需要注意数据的安全性和完整性。在备份、拷贝和恢复过程中,要保证数据文件不被篡改或丢失。此外,还要预留充足的时间和资源,避免对数据库运行造成影响。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值