mysqllinux解压版安装教程学习(解决Linux安装mysql 在/etc下没有my.cnf的问题)
mysqllinux解压版安装教程学习
解决Linux安装mysql 在/etc下没有my.cnf的问题今天因为想改mysql的端口,结果发现我的/etc/目录下并没有my.cnf这个文件,我就看了下网上有没有解决的方法。
看了好多关于Linux下没有my.cnf的博客,都是说将my-medium.cnf 移动到etc 并且改名为my.cnf,但是我也没有my-medium.cnf 啊,后面才知道,从5.7.18开始官方不再二进制包中提供my-default.cnf文件。
具体可参考:https://dev.mysql.com/doc/refman/5.7/en/binary-installation.html
那么我们要怎么修改端口号呢?其实我们只需要修改/etc/mysql/mysql.conf.d就可以了。
补充:mysql启动时,提示/etc/my.cnf 被忽略的问题处理
今天在处理测试开发人员的问题是,发现一个MySQL实例启动故障,处理过程如下:
发现mysql实例是关闭的,执行命令启动mysql实例时有警告:
|
# service mysql.server start Warning: World-writable config file '/etc/my.cnf' is ignored Starting MySQL SUCCESS! |
观察mysql的启动日志,在日志中显示:
|
151014 11:39:24 mysqld_safe Starting mysqld daemon with databases from /data/mysql/data Warning: World-writable config file '/etc/my.cnf' is ignored |
大概意思是权限全局可写,任何一个用户都可以写。mysql担心这种文件被其他用户恶意修改,所以忽略掉这个配置文件。这样mysql无法关闭。
此时查询MySQL数据库中的配置,发现一些my.cnf配置的参数,在mysql实例中并没有生效。
这个是因为 /etc/my.cnf 也被修改为 777权限了:
|
# ls -la /etc/my.cnf -rwxrwxrwx 1 root root 1120 Jul 31 10:28 /etc/my.cnf |
/etc/my.cnf 权限过大,会影响实例不能启动,或者不能关闭,需要修改为 644.操作如下:
|
# ls -la /etc/my.cnf -rwxrwxrwx 1 root root 1120 Jul 31 10:28 /etc/my.cnf # # # chmod 644 /etc/my.cnf # # ls -la /etc/my.cnf -rw-r --r-- 1 root root 1120 Jul 31 10:28 /etc/my.cnf # |
确认一下 /etc/my.cnf ,重启实例:
|
151014 14:05:54 mysqld_safe mysqld from pid file /data/mysql/data/yq-xg-dev122.pid ended 151014 14:06:08 mysqld_safe Starting mysqld daemon with databases from /data/mysql/data 151014 14:06:08 [Note] Plugin 'FEDERATED' is disabled. 151014 14:06:08 InnoDB: The InnoDB memory heap is disabled 151014 14:06:08 InnoDB: Mutexes and rw_locks use GCC atomic builtins 151014 14:06:08 InnoDB: Compressed tables use zlib 1.2.3 151014 14:06:08 InnoDB: Using Linux native AIO 151014 14:06:08 InnoDB: Initializing buffer pool, size = 128.0M 151014 14:06:08 InnoDB: Completed initialization of buffer pool 151014 14:06:08 InnoDB: highest supported file format is Barracuda. 151014 14:06:08 InnoDB: Waiting for the background threads to start 151014 14:06:09 InnoDB: 1.1.8 started; log sequence number 18872844901 151014 14:06:09 [Warning] 'proxies_priv' entry '@ root@xinge122' ignored in --skip-name-resolve mode. 151014 14:06:09 [Note] Event Scheduler: Loaded 0 events 151014 14:06:09 [Note] /usr/ local /mysql/bin/mysqld: ready for connections. Version: '5.5.19-log' socket: '/tmp/mysql.sock' port: 3306 MySQL Community Server (GPL) |
可以看到将 /etc/my.cnf 权限修改正常后,MySQL实例就可以正常启动了。
通过这个案例可以得到如下启发:
修改Linux操作系统根目录下目录和文件的权限是非常危险的;
比如修改了 /etc/ssh 目录的权限,ssh就无法使用了;如果是 /etc/security 或者 /etc/init.d/sshd 文件被修改了,则root用户就无法登录到系统了;
所以必须注意系统权限,尤其是 /etc/ 目录下的文件权限,不能随便修改。
不论是开发,还是运维都是需要规范化,尽量避免都以root用户直接操作;对于软件和应用程序的存放位置,也放在单独规定的目录中,使用各个应用单独的用户进行操作;
对于系统文件轻易不要修改,尤其不要随便修改/etc/相关的系统文件,如果要修改,可以先测试,确认没有问题后再进行修改。
以上为个人经验,希望能给大家一个参考,也希望大家多多支持开心学习网。如有错误或未考虑完全的地方,望不吝赐教。
原文链接:https://blog.csdn.net/qq_35823078/article/details/88874493
- mysql 用户权限配置(详解MySQL 用户权限管理)
- mysqlsql语句的优化(MySQL优化之如何写出高质量sql语句)
- mysql与oracle体系结构(详解MySQL实时同步到Oracle解决方案)
- mysql8.0关键字段使用(MySQL 8.0新特性之隐藏字段的深入讲解)
- windows7mysql服务无法启动(Windows系统下MySQL无法启动的万能解决方法)
- navicat不能连接到mysql报错2013(Navicat连接SQL Server数据:报错08001-命名管道提供程序的完美解决方法)
- 怎么查看mysql运行日志(通过Query Profiler查看MySQL语句运行时间的操作方法)
- 怎么查看mysql异常链接(MySQL 查看链接及杀掉异常链接的方法)
- python在mysql创建数据库(python3对接mysql数据库实例详解)
- centos系统mysql安装及连接教程(CentOS8安装SQLServer2019的过程)
- mysql8.0详解(MySQL 8.0 的 5 个新特性,太实用了!)
- linuxmysql安装教程5.7.25学习(linux mysql5.5升级至mysql5.7的步骤与踩到的坑)
- docker怎么创建mysql服务(Docker部署MySQL8集群一主二从的实现步骤)
- mysql主从同步失败原因(mysql 主从复制如何跳过报错)
- thinkphp伪静态实例(thinkPHP+mysql+ajax实现的仿百度一下即时搜索效果详解)
- mysql删除数据库的命令(MySQL 线上数据库清理数据的方法)
- 为什么现在社会越来越卷了(现在社会为什么发展那么快呢)
- 直播带货能赚到很多钱吗(直播带货能赚到很多钱吗现在)
- 做网红真的很能赚钱吗(做网红真的很能赚钱吗)
- 10句英语常用(英语常用900句)
- 爱情能当饭吃吗(爱情能当饭吃吗说说)
- 白T恤穿法(白t恤)
热门推荐
- python散点图(python scatter散点图用循环分类法加图例)
- h5禁用返回键(可能这些是你想要的H5软键盘兼容方案小结)
- mysql默认的事务隔离级别是哪一种(MySql学习笔记之事务隔离级别详解)
- 怎么查看python的安装路径(查看python安装路径及pip安装的包列表及路径)
- SqlTransaction事务的用法
- python时间类的实现(Python日期时间Time模块实例详解)
- php检查语法(使用 PHP Masked Package 屏蔽敏感数据的实现方法)
- sql如何把重复数据记录删除(sql分组后二次汇总处理表重复记录查询和删除的实现方法)
- js中arguments的用法
- 用js编写tab栏切换(JavaScript实现简易tab栏切换内容栏)
排行榜
- 1
- 2
- 3
- 4
- 5
- 6
- 7
- 8
- 9