AskOverflow.Dev

AskOverflow.Dev Logo AskOverflow.Dev Logo

AskOverflow.Dev Navigation

  • 主页
  • 系统&网络
  • Ubuntu
  • Unix
  • DBA
  • Computer
  • Coding
  • LangChain

Mobile menu

Close
  • 主页
  • 系统&网络
    • 最新
    • 热门
    • 标签
  • Ubuntu
    • 最新
    • 热门
    • 标签
  • Unix
    • 最新
    • 标签
  • DBA
    • 最新
    • 标签
  • Computer
    • 最新
    • 标签
  • Coding
    • 最新
    • 标签
主页 / ubuntu / 问题 / 797670
Accepted
hussam
hussam
Asked: 2016-07-13 00:00:02 +0800 CST2016-07-13 00:00:02 +0800 CST 2016-07-13 00:00:02 +0800 CST

如何为 MySQL 创建数据库目录结构?

  • 772

我正在关注本教程:

https://www.digitalocean.com/community/tutorials/how-to-use-mysql-with-your-ruby-on-rails-application-on-ubuntu-14-04

到目前为止,我安装了mysql-server mysql-client libmysqlclient-dev,我想告诉 MySQL 创建它的数据库目录结构,它将使用sudo mysql_install_db.

$ sudo mysql_install_db

[WARNING] mysql_install_db is deprecated. Please consider switching to mysqld --initialize
[ERROR]   The data directory needs to be specified.

我认为跑步mysqld --initialize可以解决问题:

$ mysqld --initialize 

mysqld: Can't create directory '/var/lib/mysql/' (Errcode: 17 - File exists)
[Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit_defaults_for_timestamp server option (see documentation for more details).
[ERROR] Aborting

我如何告诉 MySQL 创建它的数据库目录结构来存储它的信息?

mysql
  • 2 2 个回答
  • 6921 Views

2 个回答

  • Voted
  1. Best Answer
    hussam
    2016-07-13T01:12:19+08:002016-07-13T01:12:19+08:00

    我设法使用先前回答的问题“ 如何在 Ubuntu 16.04 上安装 mysql”解决了该问题,但我需要修改该解决方案以适合我。

    当我删除/移动/var/lib/mysql目录时,mysqld --initialize无法创建我想要替换的数据库目录/var/lib/mysql,Errcode: 13 - Permission denied即使我在它前面加上sudo.

    我删除/移动了 的内容/var/lib/mysql/,但没有删除目录本身。我再次尝试运行sudo mysql --initialize,它成功了,并在/var/lib/mysql/目录中创建了新内容。产生的mysql --initialize内容与我之前删除/移动的内容不同。

    我继续本教程中的其余步骤,并且工作得很好。

    PS我需要用来sudo -i访问/var/lib/mysql。

    • 3
  2. Pandian Le
    2018-11-13T12:50:52+08:002018-11-13T12:50:52+08:00

    这是您问题的完整解决方案。

    根据fromdual,建议只是遵循错误的建议。某些功能已被弃用。

    我们的建议是现在在您的测试系统上启用变量explicit_defaults_for_timestamp,这样您就可以查看您的应用程序是否表现良好,然后您就可以为下一个版本做好准备,该功能将成为默认功能。

    在短期内,这个警告并不危险。从长远来看,您必须为已弃用的功能做好准备。您摆脱了 my.cnf [mysqld] 部分中 my setting explicit_defaults_for_timestamp = 1 的警告。

    您可以在以下位置找到该my.cnf文件,并且按此顺序,这些值会相互覆盖:

    • /etc/my.cnf
    • /etc/mysql/my.cnf
    • $MYSQL_HOME/my.cnf
    • [数据目录]/my.cnf
    • ~/.my.cnf

    您还可以通过以下方式找到您的文件

    find / -name my.cnf
    

    我在 /etc/mysql/my.cnf 中添加了以下内容

    [mysqld]
    explicit_defaults_for_timestamp = 1
    

    现在试试

    mysqld --initialize
    

    没有时间戳的东西我得到了一个减少的错误

    mysqld: Can't create directory '/var/lib/mysql/' (Errcode: 17 - File exists)
    2018-11-12T20:13:45.024116Z 0 [ERROR] Aborting
    

    这个好吗?不确定,所以我看起来更深入。根据上面接受的堆栈答案,您需要

    sudo -i #log into root
    cd /var/lib/mysql
    rm -r *
    
    su username  # get back to the original user
    
    mysqld --initialize 
    

    这仍然给了我完全相同的错误。没变!

    mysqld: Can't create directory '/var/lib/mysql/' (Errcode: 17 - File exists)
    2018-11-12T20:13:45.024116Z 0 [ERROR] Aborting
    

    我不确定上述接受的答案是否有助于删除 /var/lib/mysql,但sudo有助于:

    sudo mysqld --initialize
    

    工作......完全没有错误!

    • 1

相关问题

  • 上网本上的 MySQL 数据建模

  • 从终端备份mysql

  • 为什么 /etc/init.d/mysql 会运行错误的暴发户工作?

  • 将引号添加到文件中的字符串

  • 如何将 MySQL 数据文件移动到不同的分区?

Sidebar

Stats

  • 问题 205573
  • 回答 270741
  • 最佳答案 135370
  • 用户 68524
  • 热门
  • 回答
  • Marko Smith

    如何运行 .sh 脚本?

    • 16 个回答
  • Marko Smith

    如何安装 .tar.gz(或 .tar.bz2)文件?

    • 14 个回答
  • Marko Smith

    如何列出所有已安装的软件包

    • 24 个回答
  • Marko Smith

    无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗?

    • 25 个回答
  • Martin Hope
    Flimm 如何在没有 sudo 的情况下使用 docker? 2014-06-07 00:17:43 +0800 CST
  • Martin Hope
    Ivan 如何列出所有已安装的软件包 2010-12-17 18:08:49 +0800 CST
  • Martin Hope
    La Ode Adam Saputra 无法锁定管理目录 (/var/lib/dpkg/) 是另一个进程在使用它吗? 2010-11-30 18:12:48 +0800 CST
  • Martin Hope
    David Barry 如何从命令行确定目录(文件夹)的总大小? 2010-08-06 10:20:23 +0800 CST
  • Martin Hope
    jfoucher “以下软件包已被保留:”为什么以及如何解决? 2010-08-01 13:59:22 +0800 CST
  • Martin Hope
    David Ashford 如何删除 PPA? 2010-07-30 01:09:42 +0800 CST

热门标签

10.10 10.04 gnome networking server command-line package-management software-recommendation sound xorg

Explore

  • 主页
  • 问题
    • 最新
    • 热门
  • 标签
  • 帮助

Footer

AskOverflow.Dev

关于我们

  • 关于我们
  • 联系我们

Legal Stuff

  • Privacy Policy

Language

  • Pt
  • Server
  • Unix

© 2023 AskOverflow.DEV All Rights Reserve