解决Linux安装mysql 在/etc下没有my.cnf的问题_Mysql

来源:脚本之家  责任编辑:小易  

今天因为想改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/相关的系统文件,如果要修改,可以先测试,确认没有问题后再进行修改。

以上为个人经验,希望能给大家一个参考,也希望大家多多支持真格学网。如有错误或未考虑完全的地方,望不吝赐教。

您可能感兴趣的文章:mysql 5.7 的 /etc/my.cnf 参数介绍MySQL将select结果执行update的实例教程MYSQL慢查询与日志的设置与测试MySQL用户管理与PostgreSQL用户管理的区别说明Mysql 获取表的comment 字段操作MySQL为Null会导致5个问题(个个致命)MySQL存储过程in、out和inout参数示例和总结PostgreSQL使用MySQL外表的步骤详解(mysql_fdw)

  • 本文相关:
  • 完美解决mysql启动后随即关闭的问题(ibdata1文件损坏导致)
  • mysql “ every derived table must have its own alias”出现错
  • mysql8.0 如何快速加列
  • 修改mysql密码与忘记mysql密码的处理方法
  • linux下mysql自动备份数据库与自动删除临时文件
  • windows下mysql5.6版本安装及配置过程附有截图和详细说明
  • mysql使用命令创建、删除、查询索引的介绍
  • mysql排序和分页(order by&limit)及存在的坑
  • mysql出生日期转换为年龄并分组统计人数的方法示例
  • mysql 5.7.20常用下载、安装和配置方法及简单操作技巧(解压版免安
  • Linux中安装mysql初始化的时候不能找到my.cnf文件,...
  • linux】redhat 6.2 86_x64 下安装的mysql 5.5.23 ...
  • linux下安装mysql时,初始化的时候提示找不到cp su...
  • linux下安装MYsql cp ./support-files/my-huge.cnf...
  • 在Linux中的MySQL数据库内,/etc/my.cnf配置文件中...
  • mysql的配置文件my.cnf 或者 my.ini在哪啊? 想修改...
  • 请问在linux下,mysql的mysql_config和 my.cnf两个...
  • linux 或者说 ubuntu 下mysql 的配置文件 my.cnf ...
  • linux下mysql没有配置my.cnf的时候用的是那个配置
  • Mysql的配置文件/etc/my.cnf 可不可以指定放到别的...
  • 网站首页网页制作脚本下载服务器操作系统网站运营平面设计媒体动画电脑基础硬件教程网络安全mssqlmysqlmariadboracledb2mssql2008mssql2005sqlitepostgresqlmongodbredisaccess数据库文摘数据库其它首页mysqlmysql 5.7 的 /etc/my.cnf 参数介绍mysql将select结果执行update的实例教程mysql慢查询与日志的设置与测试mysql用户管理与postgresql用户管理的区别说明mysql 获取表的comment 字段操作mysql为null会导致5个问题(个个致命)mysql存储过程in、out和inout参数示例和总结postgresql使用mysql外表的步骤详解(mysql_fdw)完美解决mysql启动后随即关闭的问题(ibdata1文件损坏导致)mysql “ every derived table must have its own alias”出现错mysql8.0 如何快速加列修改mysql密码与忘记mysql密码的处理方法linux下mysql自动备份数据库与自动删除临时文件windows下mysql5.6版本安装及配置过程附有截图和详细说明mysql使用命令创建、删除、查询索引的介绍mysql排序和分页(order by&limit)及存在的坑mysql出生日期转换为年龄并分组统计人数的方法示例mysql 5.7.20常用下载、安装和配置方法及简单操作技巧(解压版免安mysql安装图解 mysql图文安装教程can""""t connect to mysql servwindows下mysql5.6版本安装及配置mysql字符串截取函数substring的mysql创建用户与授权方法mysql提示:the server quit withmysql日期数据类型、时间类型使用mysql——修改root密码的4种方法mysql之timestamp(时间戳)用法mysql update语句的用法详解mysql必知必会读书笔记第五章之排序检索数mysql优化必须调整的10项配置记一次因线上mysql优化器误判引起慢查询事解决mysql8.0 输入无误仍然提示access demysql中字段名和保留字冲突的解决办法在linux系统的命令行中为mysql创建用户的教会你完全搞定mysql数据库 轻松八句话mysql insert if not exists防止插入重复sql执行步骤的具体分析详解mysql中的死锁情况以及对死锁的处理方
    免责声明 - 关于我们 - 联系我们 - 广告联系 - 友情链接 - 帮助中心 - 频道导航
    Copyright © 2017 www.zgxue.com All Rights Reserved