• 企业400电话
  • 微网小程序
  • AI电话机器人
  • 电商代运营
  • 全 部 栏 目

    企业400电话 网络优化推广 AI电话机器人 呼叫中心 网站建设 商标✡知产 微网小程序 电商运营 彩铃•短信 增值拓展业务
    解决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/相关的系统文件,如果要修改,可以先测试,确认没有问题后再进行修改。

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

    您可能感兴趣的文章:
    • 通过shell脚本对mysql的增删改查及my.cnf的配置
    • mysql 5.7 的 /etc/my.cnf 参数介绍
    • MySQL中配置文件my.cnf因权限问题导致无法启动的解决方法
    • mysql服务性能优化—my.cnf_my.ini配置说明详解(16G内存)
    • MySQL修改my.cnf配置不生效的解决方法
    • MySQL 5.5.x my.cnf参数配置优化详解
    • MySQL配置文件my.cnf优化详解(mysql5.5)
    • MySQL性能优化之路---修改配置文件my.cnf
    • MariaDB(Mysql分支)my.cnf配置文件中文注释版
    • MySQL配置文件my.cnf参数优化和中文详解
    • MySQL配置文件my.cnf中文详解附mysql性能优化方法分享
    • MySQL配置文件my.cnf中文版对照
    • 对MySQL配置参数 my.ini/my.cnf的详细解析
    • MySQL读取my.cnf的顺序问题详情
    上一篇:MySQL将select结果执行update的实例教程
    下一篇:安装Mysql时可能会遇到的一些疑难杂症
  • 相关文章
  • 

    © 2016-2020 巨人网络通讯 版权所有

    《增值电信业务经营许可证》 苏ICP备15040257号-8

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