Mysql启动选项和配置文件

article/2025/8/29 15:38:15

Mysql启动选项和配置文件

Mysql启动方式

下面的启动命令都需要依赖在Linux环境下配置的Mysql环境变量

vi /etc/profile

在文件末尾加上Mysql的安装路径(演示中mysql配置在/usr/local/mysql-5.7.26下,这个路径需要根据自己的环境而定)

export PATH=/usr/local/mysql-5.7.26/bin/:$PATH

更新文件后刷新配置文件,不然不能立即生效

source /etc/profile

mysqld

mysqld是一个可执行文件,就代表着Mysql服务器程序,执行这个文件可以直接启动一个服务器进程。

如果非root用户可以用如下方式启动,指定启动时读取的配置文件。

mysqld --defaults-file=/etc/my.cnf  &

root用户需要加入启动参数(mysql因为安全问题不让root用户直接启动,所以需要加入启动参数强制使用root账号启动)。

mysqld --defaults-file=/etc/my.cnf --user=root  &

mysqld_safe

mysqld_safe是一个启动脚本,它会间接调用mysqld,而且还会顺带启动一个监控进程,这个监控进程在服务器挂了的时候,可以自动重启服务,另外这个脚本会将服务器程序的错误信息以及诊断信息重定向到某个文件中记录错误日志。

可以不指定默认配置文件,命令如下

mysqld_safe --defaults-file=/etc/my.cnf &

mysqld_multi

mysqld_multi可以启动多个mysql数据库实例,这里不做探讨。

mysql.server

在mysq的安装目录其实还有一个文件夹support-files,具体目录是/usr/local/mysql-5.7.26/support-files,里面的mysql.server也是一个启动脚本,这个脚本会间接调用mysqld_safe脚本,执行命令如下

### 路径依照自己的mysql安装路径来
cd /usr/local/mysql-5.7.26/support-files
./mysql.server start|stop

如果给这个路径指定了软连接

ln -s /usr/local/mysql-5.7.26/support-files/mysql.server /etc/init.d/mysql

那么启动命令可以简化为

service mysql stop/start

Mysql启动方式选项

Mysql服务在启动时就可以指定一些启动参数,如之前讨论过的Mysql服务端和客户端的连接方式有TCP/IP、命名管道和共享内存、Unix域套接字文件,如果客户端启动时满足如下几种情况,就是和服务端采用域套接字文件通信。

  • 没有指定-h选项。

  • 指定-h指定了域名为localhost也就是-hlocalhost

  • 客户端启动参数指定了--protocol=socket

如果客户端指定-h后面接的是IP地址,就算是127.0.0.1那也就是采用TCP/IP连接,那么这都是客户端去操作的,如果是服务端禁止采用TCP/IP通信应该如何去做呢?

root用户采用如下命令,非root用户不需要--user=root

mysqld --user=root --skip-networking &

客户端操作

### 采用unix域套接字文件通信 正常
[root@test ~]# mysql -uroot -p[root@test ~]# mysql -hlocalhsot -uroot -p### 采用TCP/IP连接,直接拒绝
[root@test ~]# mysql -h127.0.0.1 -uroot -p
mysql: [Warning] Using a password on the command line interface can be insecure.
ERROR 2003 (HY000): Can't connect to MySQL server on '127.0.0.1' (111)

又如指定数据库存储引擎,在Mysql中默认是InnoDB,我们可以通过启动选项修改

### 非root用户去除--user=root选项
mysqld --user=root --default-storage-engine=MyISAM

客户端操作

mysql> use test;
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -ADatabase changed
mysql> CREATE TABLE test(->    id INT-> );
Query OK, 0 rows affected (0.00 sec)mysql> show create table test;
+-------+----------------------------------------------------------------------------------------+
| Table | Create Table                                                                           |
+-------+----------------------------------------------------------------------------------------+
| test  | CREATE TABLE `test` (`id` int(11) DEFAULT NULL
) ENGINE=MyISAM DEFAULT CHARSET=utf8 |
+-------+----------------------------------------------------------------------------------------+

创建后的数据库操作引擎变为MyISAM,配置生效。

综上Mysql如果存在多个启动指令可以采用**–启动选项1=值1 --启动选项2=值2 … --启动选项n=值n**,配置修改启动项。

Mysql启动指令众多,其它指令可以通过命令**mysqld --verbose --help**查看。

选项的长形式和短形式

在myql中其实一直有区分长形式命令和短形式命令,但是我们在使用时并没有注意,对照如下

长形式短形式意义
–host-h主机名
–user-u用户名
–password-p(小写)密码
–port-P(大写)端口
–version-V版本

需要注意的是长连接前面是两个横杠--,短连接只有一个-,另外长连接指令和值之前需要有空格,短连接可以紧挨着不需要空格。

### 长连接形式
mysql --host 127.0.0.1  --user root --port 3306 --password### 短连接形式
mysql -h127.0.0.1 -uroot -P3306 -p

Mysql启动配置文件

采用Mysql启动方式选项虽然是方便,但也带来的一些问题,如果启动选项参数过多导致启动命令毫无可读性而言,启动选项配置的参数只对当前启动的服务生效,也就是如果下次重启所有的启动参数将被还原不会被记录,所以为了将这些启动参数保存,我们就需要一个配置文件默认称为my.cnf。

my.cnf配置文件按照启动的是客户端程序还是服务端程序将配置分为了多个组,如下所示

#### 服务端启动配置
[server]
### 格式一:配置项=具体值
port=3306
### 格式二:配置项(没有值的情况,配置项为禁止客户端采用TCP/IP连接)
skip-networking[mysqld][mysqld_safe]#### 客户端启动配置
[client][mysql][mysqladmin]### 所有配置组的格式同上

mysqladmin:是一个执行管理操作的客户端程序,它可以检查服务器的配置和当前服务的状态,创建和删除数据库等。

[root@test ~]# mysqladmin -uroot -p processlist
Enter password: 
+----+------+-----------+------+---------+------+----------+------------------+
| Id | User | Host      | db   | Command | Time | State    | Info             |
+----+------+-----------+------+---------+------+----------+------------------+
| 33 | root | localhost | test | Sleep   | 5    |          |                  |
| 35 | root | localhost |      | Query   | 0    | starting | show processlist |
+----+------+-----------+------+---------+------+----------+------------------+
[root@test ~]# mysqladmin -uroot -p status
Enter password: 
Uptime: 13335  Threads: 2  Questions: 66  Slow queries: 0  Opens: 121  Flush tables: 3  Open tables: 5  Queries per second avg: 0.004
### 打印系统变量
[root@test ~]# mysqladmin -uroot -p variable

服务端和客户端不同命令启动会读取不同的配置组,对应结构如下

启动命令所属服务读取配置组
mysqld服务端[mysqld]、[server]
mysqld_safe服务端[mysqld]、[server]、[mysqld_safe]
mysql.server服务端[mysqld]、[server]、[mysql.server]
mysql客户端[mysql]、[client]
mysqladmin客户端[mysqladmin]、[client]

如果多个配置组存在相同的配置如下所示

[mysqld]
port = 3306
###.....省略其它配置
[server]
port=3333
[mysqld_safe]
port=5555

会根据书写顺序读取,也就是说后面的配置会覆盖前面的配置

  • 如果服务端采用mysqld启动服务端那么port的最终结果为port=3333(只会读取[mysqld]和[server]配置组)

  • 如果服务端采用mysqld_safe启动服务端那么port的最终结果为port=5555(只会读取[mysqld],[mysqld_safe]和[server]配置组)

My.cnf文件读取优先级

在启动Mysql服务时如果没有指定配置文件的具体路径,那么Mysql服务会到如下几个目录搜索,可以通过命令mysql --help查看,部分说明如下

Default options are read from the following files in the given order: /etc/my.cnf /etc/mysql/my.cnf /usr/local/mysql/etc/my.cnf ~/.my.cnf

读取文件的顺序为

  1. /etc/my.cnf

  2. /etc/mysql/my.cnf

  3. /usr/local/mysql/etc/my.cnf

  4. ~/.my.cnf(注意:这里的文件名为.my.cnf和其它路径是有区别的,并且文件名前面有一个点那么Linux服务器会将这个文件隐藏,也就是使用ll命令查询不到此文件,只有使用ll -a才能获取,另外这个文件是在登录用户的家目录!!!)。

这四个文件会按照顺序读取,也就是说如果在/etc/my.cnf文件下配置了port=3006,在~/.my.cnf下面配置了port=3307那么最终读取的结果是port为3307。

当然这是Mysql读取默认配置的情况,我们可以自己指定配置文件路径,如下所示

#### --defaults-file后面接任意路径文件,非root用户不需要--user=root
mysqld --defaults-file=/usr/local/mysql/etc/my.cnf.copy --user=root

http://chatgpt.dhexx.cn/article/9sduODvo.shtml

相关文章

如何启动MySQL服务

第一种 1.通过快捷键(WinR)输入 service.msc 调出服务窗口 2.找到MySQL服务,选择打开,或者自动打开即可 第二种 1.通过 cmd 窗口,以管理员身份打开,输入指令: net start mysql 即可 2.不区分…

MySQL数据库如何启动?

本篇文章主要跟大家介绍的是MySQL数据库如何启动,相信很多朋友都不清楚吧,对此,摩杜云小杜整理了一下并分享给大家做个参考,由于内容质量高,且简洁明了,感兴趣的朋友不妨来看看,记得要看完。 前…

模型的参数verbose用法详解

模型的参数verbose含义 verbose是日志显示,有三个参数可选择,分别为0,1和2。 当verbose0时,简单说就是不输出日志信息 ,进度条、loss、acc这些都不输出。当verbose1时,带进度条的输出日志信息,示例如下&am…

解决vue项目的 verbose stack Error: unable to resolve dependency tree问题

项目场景: 安装vue插件的时候出现报错 verbose stack Error: unable to resolve dependency tree 在命令后面加入 –legacy-peer-deps即可 该命令意为绕过版本差异,允许多版本共存安装 npm install iview --save --legacy-peer-deps当把命令加上后缀即…

keras 中fit 和 evaluate中参数 verbose 详解

1、在 fit 和 evaluate 中 都有 verbose 这个参数 fit 中的 verbose verbose:该参数的值控制日志显示的方式 verbose 0 不在标准输出流输出日志信息 verbose 1 输出进度条记录 verbose 2 每个epoch输出一行记录 注意: 默认为 1 verbose 1 …

【cmake】——verbose=1 看编译的具体配置

cmake cmake用如下命令编译,可以看具体的配置项 cmake .. make VERBOSE1 -j8

python django ORM null blank choices help_text verbose_name

null 是针对数据库而言,如果 nullTrue, 表示数据库的该字段可以为空。Default is False.blank 是针对表单的,如果 blankTrue,表示你的表单填写该字段的时候可以不填,Default is False.help_text:这个选项用于在表单中显…

Keras中verbose的作用

在 fit 和 evaluate 中 都有 verbose 这个参数,下面详细说一下 fit 中的 verbose verbose:日志显示 verbose 0 为不在标准输出流输出日志信息 verbose 1 为输出进度条记录 verbose 2 为每个epoch输出一行记录 注意: 默认为 1 verbose …

keras 中的 verbose 详解

在 fit 和 evaluate 中 都有 verbose 这个参数,下面详细说一下 fit 中的 verbose verbose:日志显示 verbose 0 为不在标准输出流输出日志信息 verbose 1 为输出进度条记录 verbose 2 为每个epoch输出一行记录 注意: 默认为 1 evaluate …

python中if verbose是啥意思呀讲解

👨‍🎓个人主页:研学社的博客 💥💥💞💞欢迎来到本博客❤️❤️💥💥 🏆博主优势:🌞🌞🌞博客内容尽量做到思维缜…

Keras:ModelCheckpoint和model.fit的verbose有什么差异?

Keras:ModelCheckpoint和model.fit的verbose有什么差异? 1.软件环境⚙️2.问题描述🔍3.解决方法🐡3.1.只打开model.fit的verbose3.2.只打开ModelCheckpoint的verbose3.3.同时打开ModelCheckpoint和model.fit的verbose 4.结论🤔 ⚡…

keras 中的verbose详解

转载自https://www.jianshu.com/p/159a9ac413fa 在 fit 和 evaluate 中 都有 verbose 这个参数,下面详细说一下 fit 中的 verbose verbose:日志显示 verbose 0 为不在标准输出流输出日志信息 verbose 1 为输出进度条记录 verbose 2 为每个epoch输出…

力扣1002. 查找共用字符

题目 给你一个字符串数组 words ,请你找出所有在 words 的每个字符串中都出现的共用字符( 包括重复字符),并以数组形式返回。你可以按 任意顺序 返回答案。 示例: 输入:words ["bella","…

杭电OJ 1002 题目解答

HDOJ 1002 AB Problem Ⅱ AC 代码&#xff1a; #include <iostream> #include <string> #include <algorithm> using namespace std;int x[1001],y[1001],res[1001];int main() {int n;cin>>n;for(int k1;k<n;k){//重点//不是第一组时要做两个操…

东秦oj 1002

题目描述 输入两个数A,B&#xff0c;输出AB的值。 输入描述 第一行是数据的组数N&#xff0c;从第二行开始是NN组由两个整数&#xff08;A和B&#xff09;构成的数据&#xff0c;AA和BB之间用空格隔开&#xff0c;每组输入单独占一行 输出描述 每组的两个整数&#xff08;…

PAT 1002 解析

一、题目详情 问题描述&#xff1a;写出这个数 读入一个正整数 n&#xff0c;计算其各位数字之和&#xff0c;用汉语拼音写出和的每一位数字。 输入格式&#xff1a; 每个测试输入包含 1 个测试用例&#xff0c;即给出自然数 n 的值。这里保证 n 小于 10100。 输出格式&…

题1000、1001、1002

第一次使用上交的online judge&#xff0c;都翻译成了中文的&#xff0c;也还不错。只是没有提示使用环境的&#xff0c;我写的程序在VS2010下编译正确&#xff0c;但提交竟然报错&#xff0c;后来限制了一些。 1000题就是计算两个整数的相加&#xff1b; 1001题是判断一个列…

1002 写出这个数

想好好写一下这个题&#xff0c;因为一开始写了一百多行都没有写正确… 如果不想看那么多直接拉到最后看代码&#xff0c;但是也许我的解题过程会对你有帮助。 之前的思路&#xff1a; 用除10取余循环计算得到一个sum也就是各个数字的和&#xff0c;然后把sum倒转回来在除10取…

1002 写出这个数 ——c++实现

1.题目介绍 2. 思路 这道题目较好理解&#xff0c;只是实现起来有几点要注意&#xff1a; &#xff08;1&#xff09;正整数的范围。题目中规定n<10^100&#xff0c;这是个很大的数字。long long类型最大到2^63-1&#xff0c;也远小于这个数。但我最开始没有考虑这一点&am…

1002 写出这个数 (C语言实现)

题目描述&#xff1a; 读入一个正整数 n&#xff0c;计算其各位数字之和&#xff0c;用汉语拼音写出和的每一位数字。 输入格式&#xff1a; 每个测试输入包含 1 个测试用例&#xff0c;即给出自然数 n 的值。这里保证 n 小于 10^100。 输出格式&#xff1a; 在一行内输出…