Mysql 5.7.17 离线版安装和数据迁移(centos 7)

本贴最后更新于 2313 天前,其中的信息可能已经事过景迁

总结下离线版 mysql 5.7.17 的安装步骤:

1.从官网下载mysql 离线版版安装包 mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz;
2.上传安装包mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz 到 centos 7 的 /usr/tool/ 目录 ;
3.进入/usr/tool/ ---> cd /usr/tool;
4.解压安装包:tar -zxvf mysql-5.7.17-linux-glibc2.5-x86_64.tar.gz;
5.安装依赖: yum -y install perl perl-devel autoconf libaio;
6.进入/usr/local/mysql/ --->cd /usr/local/mysql/;
7.创建data目录:mkdir /usr/local/mysql/data;
8.添加mysql用户组和用户:
  groupadd mysql;
  useradd -r -g mysql -s /bin/false mysql;
9. 修改目录拥有者为mysql:chown -R mysql:mysql ./
10.初始化数据(下面是一条语句):
  ./bin/mysqld --initialize --user=mysql 
  --basedir=/usr/local/mysql 
  --datadir=/usr/local/mysql/data 
  --pid-file=/usr/local/mysql/data/mysql.pid
  --tmpdir=/tmp
11.复制生成的密码(登录mysql时用):

mysqllixianpng

12.复制配置文件到/etc/my.cnf:cp -a ./support-files/my-default.cnf /etc/my.cnf (选择y)
13.mysql的服务脚本放到系统服务中:
  cp -a ./support-files/mysql.server /etc/init.d/mysqld
14.赋予可执行权限:chmod +x /etc/init.d/mysqld
15.添加服务:chkconfig --add mysqld (可用chkconfig --list命令查看,3,4,5都是ON证明已启动)
16.修改my.cnf文件:vi /etc/my.cnf, 编辑添加如下内容:
  log-bin = /home/data/logs/mysql/binlog/mysql-bin #开启二进制日志功能,binlog数据位置
  log-bin-index = /home/data/logs/mysql/binlog/mysql-bin.index
  log_bin_trust_function_creators = 1
  binlog_cache_size = 1M
  binlog_format = ROW
  expire_logs_days = 30 #超过30天的binlog删除

  max_connections = 500 #最大连接数
  port = 3306
  socket = /tmp/mysql.sock
  pid-file = /usr/local/mysql/mysql.pid
  basedir = /usr/local/mysql  
  datadir = /usr/local/mysql/data 
  log_error =/home/data/logs/mysql/mysql-error.log 
  user = mysql

  character-set-server = utf8 
  back_log = 1024
  server-id = 1

  long_query_time = 1 #开启慢查询
  slow_query_log = 2 #慢查询时间(s)
  slow_query_log_file = /home/data/logs/mysql/mysql-slow.log
17.创建相应的日志目录和文件:
  mkdir /home/data/logs (存在则不创建)
  mkdir /home/data/logs/mysql
  mkdir /home/data/logs/mysql/binlog
  touch /home/data/logs/mysql/mysql-slow.log
  mkdir /home/data/logs/mysql/binlog/mysql-bin
  touch /home/data/logs/mysql/binlog/mysql-bin.index
  chown -R mysql:mysql /home/data/logs
18.把mysql客户端放到默认路径:
  ln -s /usr/local/mysql/bin/mysqld /usr/local/bin/mysqld
  ln -s /usr/local/mysql/bin/mysql /usr/local/bin/mysql
19.启动服务:service mysqld start (ps -ef |grep mysqld查看是否启动)
20.登录mysql:mysql -uroot -p,输入前面复制的密码
21.使用mysql库: use mysql:
  修改root密码:set password for root@localhost = password('要设置的密码admin123');
  创建mystest用户:CREATE USER 'mystest'@'localhost' IDENTIFIED BY '要设置的密码admin123'';
  查看是否创建成功:SELECT host, user FROM user WHERE user='soonfor';
  赋权限(除了DROP权限):
  GRANT ALL ON *.* TO 'mystest'@'localhost'; //全部
  REVOKE DROP ON *.* FROM 'mystest'@'localhost'; //删除DROP权限
  SHOW GRANTS FOR 'mystest'@'localhost'; //查看权限
22.设置远程访问:
  update user set host='%' where user='root' limit 1;
  update user set host='%' where user='mytest' limit 1;
刷新权限:flush privileges;
23.安装完成,可以使用创建的用户登录。

由于开始安装的时候没有注意到 Linux 磁盘大小的问题,没有过久硬盘就爆了,需要挂载新的数据盘,将 mysql

数据迁移到新的挂载盘上。

查看 mysql 的安装路径

执行查询 SQL

show variables like '%dir%';

sqldatapng

datadir 就是数据路径

转移操作

  • 新建 mysql 数据目录:

    mkdir -p /home/mysqldata
    # 改变数据库的归属为    mysql
    chown -R mysql.mysql /data/mysql
    
  • 停止 sql 服务:

    service mysqld stop
    
  • 把原来 mysql 安装的数据路径复制到新的文件目录下:

    cp -rf /usr/local/mysql/data /data/mysqlData/
    
  • 修改 mysql 的 my.cnf 文件:

    cp /etc/my.cnf /etc/my.cnf.bak
    vi /etc/my.cnf
    
    # 文件内容如下, 需要修改 datadir , socket 对应的目录
    log-bin = /home/data/logs/mysql/binlog/mysql-bin #开启二进制日志功能,binlog数据位置
    log-bin-index = /home/data/logs/mysql/binlog/mysql-bin.index
    log_bin_trust_function_creators = 1
    binlog_cache_size = 1M
    binlog_format = ROW
    expire_logs_days = 30 #超过30天的binlog删除
    
    max_connections = 500 #最大连接数
    port = 3306
    socket = /tmp/mysql.sock
    pid-file = /usr/local/mysql/mysql.pid
    basedir = /usr/local/mysql  
    datadir = /usr/local/mysql/data 
    log_error =/home/data/logs/mysql/mysql-error.log 
    user = mysql
    
    character-set-server = utf8 
    back_log = 1024
    server-id = 1
    
    long_query_time = 1 #开启慢查询
    slow_query_log = 2 #慢查询时间(s)
    slow_query_log_file = /home/data/logs/mysql/mysql-slow.log
    
  • 修改 MySQL 启动脚本:

    vi /etc/init.d/mysqld
    

mysqldpng

  • 重启 mysql 服务:

    service mysqld restart
    
  • 最后执行下 show variables like '%dir%' :
    sqldatapng

  • MySQL

    MySQL 是一个关系型数据库管理系统,由瑞典 MySQL AB 公司开发,目前属于 Oracle 公司。MySQL 是最流行的关系型数据库管理系统之一。

    692 引用 • 535 回帖
  • CentOS

    CentOS(Community Enterprise Operating System)是 Linux 发行版之一,它是来自于 Red Hat Enterprise Linux 依照开放源代码规定释出的源代码所编译而成。由于出自同样的源代码,因此有些要求高度稳定的服务器以 CentOS 替代商业版的 Red Hat Enterprise Linux 使用。两者的不同在于 CentOS 并不包含封闭源代码软件。

    238 引用 • 224 回帖

相关帖子

欢迎来到这里!

我们正在构建一个小众社区,大家在这里相互信任,以平等 • 自由 • 奔放的价值观进行分享交流。最终,希望大家能够找到与自己志同道合的伙伴,共同成长。

注册 关于
请输入回帖内容 ...

推荐标签 标签

  • 996
    13 引用 • 200 回帖 • 11 关注
  • Q&A

    提问之前请先看《提问的智慧》,好的问题比好的答案更有价值。

    8447 引用 • 38477 回帖 • 154 关注
  • danl
    146 关注
  • 笔记

    好记性不如烂笔头。

    308 引用 • 793 回帖
  • 禅道

    禅道是一款国产的开源项目管理软件,她的核心管理思想基于敏捷方法 scrum,内置了产品管理和项目管理,同时又根据国内研发现状补充了测试管理、计划管理、发布管理、文档管理、事务管理等功能,在一个软件中就可以将软件研发中的需求、任务、bug、用例、计划、发布等要素有序的跟踪管理起来,完整地覆盖了项目管理的核心流程。

    5 引用 • 15 回帖 • 102 关注
  • V2Ray
    1 引用 • 15 回帖 • 1 关注
  • SpaceVim

    SpaceVim 是一个社区驱动的模块化 vim/neovim 配置集合,以模块的方式组织管理插件以
    及相关配置,为不同的语言开发量身定制了相关的开发模块,该模块提供代码自动补全,
    语法检查、格式化、调试、REPL 等特性。用户仅需载入相关语言的模块即可得到一个开箱
    即用的 Vim-IDE。

    3 引用 • 31 回帖 • 105 关注
  • 安装

    你若安好,便是晴天。

    132 引用 • 1184 回帖 • 1 关注
  • Git

    Git 是 Linux Torvalds 为了帮助管理 Linux 内核开发而开发的一个开放源码的版本控制软件。

    209 引用 • 358 回帖 • 1 关注
  • 爬虫

    网络爬虫(Spider、Crawler),是一种按照一定的规则,自动地抓取万维网信息的程序。

    106 引用 • 275 回帖 • 1 关注
  • Sandbox

    如果帖子标签含有 Sandbox ,则该帖子会被视为“测试帖”,主要用于测试社区功能,排查 bug 等,该标签下内容不定期进行清理。

    409 引用 • 1246 回帖 • 587 关注
  • Ubuntu

    Ubuntu(友帮拓、优般图、乌班图)是一个以桌面应用为主的 Linux 操作系统,其名称来自非洲南部祖鲁语或豪萨语的“ubuntu”一词,意思是“人性”、“我的存在是因为大家的存在”,是非洲传统的一种价值观,类似华人社会的“仁爱”思想。Ubuntu 的目标在于为一般用户提供一个最新的、同时又相当稳定的主要由自由软件构建而成的操作系统。

    126 引用 • 169 回帖
  • JavaScript

    JavaScript 一种动态类型、弱类型、基于原型的直译式脚本语言,内置支持类型。它的解释器被称为 JavaScript 引擎,为浏览器的一部分,广泛用于客户端的脚本语言,最早是在 HTML 网页上使用,用来给 HTML 网页增加动态功能。

    728 引用 • 1273 回帖 • 1 关注
  • 面试

    面试造航母,上班拧螺丝。多面试,少加班。

    325 引用 • 1395 回帖 • 1 关注
  • Notion

    Notion - The all-in-one workspace for your notes, tasks, wikis, and databases.

    7 引用 • 40 回帖
  • TensorFlow

    TensorFlow 是一个采用数据流图(data flow graphs),用于数值计算的开源软件库。节点(Nodes)在图中表示数学操作,图中的线(edges)则表示在节点间相互联系的多维数据数组,即张量(tensor)。

    20 引用 • 19 回帖 • 1 关注
  • 创造

    你创造的作品可能会帮助到很多人,如果是开源项目的话就更赞了!

    178 引用 • 997 回帖
  • Latke

    Latke 是一款以 JSON 为主的 Java Web 框架。

    71 引用 • 535 回帖 • 789 关注
  • 酷鸟浏览器

    安全 · 稳定 · 快速
    为跨境从业人员提供专业的跨境浏览器

    3 引用 • 59 回帖 • 26 关注
  • 七牛云

    七牛云是国内领先的企业级公有云服务商,致力于打造以数据为核心的场景化 PaaS 服务。围绕富媒体场景,七牛先后推出了对象存储,融合 CDN 加速,数据通用处理,内容反垃圾服务,以及直播云服务等。

    27 引用 • 225 回帖 • 163 关注
  • 新人

    让我们欢迎这对新人。哦,不好意思说错了,让我们欢迎这位新人!
    新手上路,请谨慎驾驶!

    52 引用 • 228 回帖
  • Markdown

    Markdown 是一种轻量级标记语言,用户可使用纯文本编辑器来排版文档,最终通过 Markdown 引擎将文档转换为所需格式(比如 HTML、PDF 等)。

    167 引用 • 1520 回帖
  • ZooKeeper

    ZooKeeper 是一个分布式的,开放源码的分布式应用程序协调服务,是 Google 的 Chubby 一个开源的实现,是 Hadoop 和 HBase 的重要组件。它是一个为分布式应用提供一致性服务的软件,提供的功能包括:配置维护、域名服务、分布式同步、组服务等。

    59 引用 • 29 回帖 • 14 关注
  • Webswing

    Webswing 是一个能将任何 Swing 应用通过纯 HTML5 运行在浏览器中的 Web 服务器,详细介绍请看 将 Java Swing 应用变成 Web 应用

    1 引用 • 15 回帖 • 637 关注
  • Sillot

    Insights(注意当前设置 master 为默认分支)

    汐洛彖夲肜矩阵(Sillot T☳Converbenk Matrix),致力于服务智慧新彖乄,具有彖乄驱动、极致优雅、开发者友好的特点。其中汐洛绞架(Sillot-Gibbet)基于自思源笔记(siyuan-note),前身是思源笔记汐洛版(更早是思源笔记汐洛分支),是智慧新录乄终端(多端融合,移动端优先)。

    主仓库地址:Hi-Windom/Sillot

    文档地址:sillot.db.sc.cn

    注意事项:

    1. ⚠️ 汐洛仍在早期开发阶段,尚不稳定
    2. ⚠️ 汐洛并非面向普通用户设计,使用前请了解风险
    3. ⚠️ 汐洛绞架基于思源笔记,开发者尽最大努力与思源笔记保持兼容,但无法实现 100% 兼容
    29 引用 • 25 回帖 • 86 关注
  • InfluxDB

    InfluxDB 是一个开源的没有外部依赖的时间序列数据库。适用于记录度量,事件及实时分析。

    2 引用 • 76 关注
  • VirtualBox

    VirtualBox 是一款开源虚拟机软件,最早由德国 Innotek 公司开发,由 Sun Microsystems 公司出品的软件,使用 Qt 编写,在 Sun 被 Oracle 收购后正式更名成 Oracle VM VirtualBox。

    10 引用 • 2 回帖