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

安装 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 等服务的安装。

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

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

图南日晟-互联网技术服务
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 204,590评论 6 478
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 86,808评论 2 381
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 151,151评论 0 337
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 54,779评论 1 277
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 63,773评论 5 367
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 48,656评论 1 281
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 38,022评论 3 398
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 36,678评论 0 258
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 41,038评论 1 299
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 35,659评论 2 321
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 37,756评论 1 330
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 33,411评论 4 321
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 39,005评论 3 307
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 29,973评论 0 19
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 31,203评论 1 260
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 45,053评论 2 350
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 42,495评论 2 343