美文网首页
Centos7 安装Mysql-寻找共性-万变不离其宗

Centos7 安装Mysql-寻找共性-万变不离其宗

作者: needrunning | 来源:发表于2020-07-23 17:25 被阅读0次

    安装 Mysql 服务的文章数不胜数,本文的不同之处在于

    提炼安装 Mysql 服务的共性之处。

    追寻道的规律和术的方法

    阅读本文你将了解到

    • 服务器安装 Mysql 服务的两种方式
    • Mysql 服务 基本的初始化操作步骤
    • Mysql5.7 在安装过程中的更新细节

    确认基础环境

    首先确认服务器 版本环境,这个至关重要

    cat /etc/redhat-release

    CentOS Linux release 7.6.1810 (Core)

    安装方式

    通常安装方式有两种,Docker 安装不在讨论范围

    • 源码安装
    • 使用编译包安装

    使用源码包安装

    下载源截图,本文中不介绍这种安装方式

    源码安装

    使用编译包安装

    mysql57

    构建服务器目录

    源码路径

    /usr/local/mysql

    执行用户

    mysql

    chown -R mysql:mysql /usr/local/mysql

    启动脚本

    cd /usr/local/mysql

    第一点 mysql5.7 与其它版本的区别

    5.7.x 之后的版本初始化数据库不再使用 mysql_install_db,而是使用: bin/mysqld --initialize.

    不推荐的版本

    ./scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql
    

    初始化脚本

    ./mysqld --initialize --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql   --mysqld_safe --basedir=/usr/local/mysql
    

    Can't find error-message file '/usr/local/mysql/share/errmsg.sys

    原因 /usr/local/mysql 目录下应该包含原始安装文件

    ./mysqld --initialize --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data  --user=mysql
    2019-08-24T00:40:14.925998Z 0 [Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
    2019-08-24T00:40:16.935351Z 0 [Warning] InnoDB: New log files created, LSN=45790
    2019-08-24T00:40:17.323153Z 0 [Warning] InnoDB: Creating foreign key constraint system tables.
    2019-08-24T00:40:17.435647Z 0 [Warning] No existing UUID has been found, so we assume that this is the first time that this server has been started. Generating a new UUID: be7ba77f-c607-11e9-adc8-525400cff66a.
    2019-08-24T00:40:17.441071Z 0 [Warning] Gtid table is not ready to be used. Table 'mysql.gtid_executed' cannot be opened.
    2019-08-24T00:40:17.441884Z 1 [Note] A temporary password is generated for root@localhost: 1aauQhoscU_k
    
    

    构建 mysqld

    了解两个概念

    • mysql
    • mysqld

    众所周知 Mysql 数据库是一个客户端服务器架构的服务.

    服务器端启动 mysql 服务后,会生成 mysqld 服务。

    客户端如果想连接服务端,使用 mysql 工具,在终端命令行模式下运行,

    总结下来就是下面两句话:

    mysqld - it's a server daemon. this is the database server main binary (executable)
    MYSQL 服务

    mysql - it's a commandline (administration) tool

    命令行工具

    第二点 mysql5.7 与其它版本的区别

    从 5.7.18 开始不在二进制包中提供 my-default.cnf 文件

    [client]
    port = 3355
    ;socket = /data/3355/mysql.sock
    
    [mysqld]
    basedir = /usr/mysql
    datadir = /usr/mysql/data
    ;socket = /tmp/mysql.sock
    log-error = /usr/local/mysql/data/error.log
    #临时目录 比如load data infile会用到
    tmpdir  = /tmp
    symbolic-links = 0
    max-connections = 320
    connect_timeout = 20
    #数据库默认字符集,主流字符集支持一些特殊表情符号(特殊表情符占用4个字节)
    character-set-server = utf8mb4
    
    #数据库字符集对应一些排序等规则,注意要和character-set-server对应
    collation-server = utf8mb4_general_ci
    
    #设置client连接mysql时的字符集,防止乱码
    init_connect=‘SET NAMES utf8mb4‘
    

    设置开机启动

    移动可执行文件 并改名

    cp mysql.server  /etc/init.d/
    cd /etc/init.d/
    mv mysql.server mysqld
    chmod +x /etc/init.d/mysqld
    chkconfig --add mysqld
    
    

    启动 mysql

    service mysqld start

    初始化密码

    You must reset your password using ALTER USER statement before executing this statement

    ALTER USER USER() IDENTIFIED BY '123456';

    第三点

    这条命令是 5.7 和 5.6 区别之一

    MySQL 5.7.4 版开始,用户的密码过期时间这个特性得以改进。

    可以通过一个全局变量 default_password_lifetime 来设置密码过期的策略。

    此全局变量可以设置一个全局的自动密码过期策略。

    在 MySQL 的 my.cnf 配置文件中设置一个默认值,这会使得所有 MySQL 用户的密码过期时间都为 120 天。

    MySQL 会从启动时开始计算时间。

    继续执行命令

    update user set authentication_string=password('123456') where user='root'
    flush privileges;
    

    开放外网连接权限

    use mysql;
    
    update user set host = '%' where user = 'root'; (使 mysql root 用户可以连接上任意的 ip 地址)
    
    FLUSH PRIVILEGES
    

    疑难杂症排查

    重启服务器造成的 mysql 服务启动失败

    service mysqld start
    Starting MySQL.. ERROR! The server quit without updating PID file (/usr/local/mysql/data/10-9-77-82.pid).
    
    

    看提示是 PID 文件丢失

    解决方案

    • 首先查看磁盘使用量

    df -h

    /dev/vda1 20G 20G 12M 100% /
    devtmpfs 923M 0 923M 0% /dev
    tmpfs 934M 0 934M 0% /dev/shm
    tmpfs 934M 17M 917M 2% /run
    tmpfs 934M 0 934M 0% /sys/fs/cgroup
    tmpfs 187M 0 187M 0% /run/user/0
    

    这次是磁盘的问题导致

    修改主账号密码区别

    • 修改主账号密码

    UPDATE user SET password=PASSWORD("新密码") WHERE user='你的用户名';
    出现字段找不到的错误

    Unknown column 'password' in 'field list'
    

    解决方案

    采用如下语句来更新,新版本 mysql 采用 authentication_string 替代了 password 字段

    update mysql.user set authentication_string=password('root') where user='root' ;
    
    flush privileges;
    
     quit;
    
    • 重新启动 mysql
      service mysql restart
    
    

    服务启动完成

    本文列举安装 Mysql 服务的几个错误和排查思路。实际生产环境中需要从具体的日志,用户等多个方面考虑。

    分析总结

    软件开发流程中,服务器相关服务安装维护属于运维的职责。

    作为软件开发工程师,却是绕不过去的一个环节。

    实际的操作可以深入了解服务的运行机制。

    像我之前文章 程序设计理念-CentOs7实践Nginx-带来安装服务的通用法则
    中介绍的那样

    输出 Linux 上安装服务的通用法则

    • 1 确定服务器环境
    • 2 确定待安装服务的安装方式和安装版本
    • 3 确定服务运行账户和相应的配置
    • 4 确定服务正常启动运行
    • 5 确定是否自启动

    以上同样适用于 Redis PHP 等服务的安装。

    我是王明明,互联网技术开发者,阅读写作实践者。

    输出我的技术思想,探索个人品牌实践之路,期待认识优秀的你。

    图南日晟-互联网技术服务

    相关文章

      网友评论

          本文标题:Centos7 安装Mysql-寻找共性-万变不离其宗

          本文链接:https://www.haomeiwen.com/subject/gkjrqhtx.html