我的编程空间,编程开发者的网络收藏夹
学习永远不晚

Macosx下使用docker/mysql会出现什么问题

短信预约 -IT技能 免费直播动态提醒
省份

北京

  • 北京
  • 上海
  • 天津
  • 重庆
  • 河北
  • 山东
  • 辽宁
  • 黑龙江
  • 吉林
  • 甘肃
  • 青海
  • 河南
  • 江苏
  • 湖北
  • 湖南
  • 江西
  • 浙江
  • 广东
  • 云南
  • 福建
  • 海南
  • 山西
  • 四川
  • 陕西
  • 贵州
  • 安徽
  • 广西
  • 内蒙
  • 西藏
  • 新疆
  • 宁夏
  • 兵团
手机号立即预约

请填写图片验证码后获取短信验证码

看不清楚,换张图片

免费获取短信验证码

Macosx下使用docker/mysql会出现什么问题

这篇文章主要为大家展示了“Macosx下使用docker/mysql会出现什么问题”,内容简而易懂,条理清晰,希望能够帮助大家解决疑惑,下面让小编带领大家一起研究并学习一下“Macosx下使用docker/mysql会出现什么问题”这篇文章吧。

问题描述

在macosx下如果指定本地目录替换/var/lib/mysql,运行时会出现文件权限的错误,导致mysqld无法正常运行

Creating mysql_test-mysql_1
Attaching to mysql_test-mysql_1
test-mysql_1 | Initializing database
test-mysql_1 | 2016-03-23T04:32:37.437789Z 0 [Warning] Setting lower_case_table_names=2 because file system for /var/lib/mysql/ is case insensitive
test-mysql_1 | 2016-03-23T04:32:37.466955Z 0 [ERROR] InnoDB: Operating system error number 13 in a file operation.
test-mysql_1 | 2016-03-23T04:32:37.467828Z 0 [ERROR] InnoDB: The error means mysqld does not have the access rights to the directory.
test-mysql_1 | 2016-03-23T04:32:37.468824Z 0 [ERROR] InnoDB: Operating system error number 13 in a file operation.
test-mysql_1 | 2016-03-23T04:32:37.468912Z 0 [ERROR] InnoDB: The error means mysqld does not have the access rights to the directory.
test-mysql_1 | 2016-03-23T04:32:37.470280Z 0 [ERROR] InnoDB: Cannot open datafile './ibdata1'
test-mysql_1 | 2016-03-23T04:32:37.470309Z 0 [ERROR] InnoDB: Could not open or create the system tablespace. If you tried to add new data files to the system tablespace, and it failed here, you should now edit innodb_data_file_path in my.cnf back to what it was, and remove the new ibdata files InnoDB created in this failed attempt. InnoDB only wrote those files full of zeros, but did not yet use them in any way. But be careful: do not remove old data files which contain your precious data!
test-mysql_1 | 2016-03-23T04:32:37.470317Z 0 [ERROR] InnoDB: InnoDB Database creation was aborted with error Cannot open a file. You may need to delete the ibdata1 file before trying to start up again.
test-mysql_1 | 2016-03-23T04:32:38.073222Z 0 [ERROR] Plugin 'InnoDB' init function returned error.
test-mysql_1 | 2016-03-23T04:32:38.073268Z 0 [ERROR] Plugin 'InnoDB' registration as a STORAGE ENGINE failed.
test-mysql_1 | 2016-03-23T04:32:38.073283Z 0 [ERROR] Failed to initialize plugins.
test-mysql_1 | 2016-03-23T04:32:38.073289Z 0 [ERROR] Aborting
test-mysql_1 | 
mysql_test-mysql_1 exited with code 1

解决方案

  • 创建在scripts目录下mysqld启动脚本

#!/bin/bash
# From https://github.com/docker-library/mysql/issues/99
set -e # fail on any error

echo '* Working around permission errors in Docker on Mac locally by making sure that "mysql" uses the same uid and gid as the host volume'
TARGET_UID=$(stat -c "%u" /var/lib/mysql)
echo '-- Setting mysql user to use uid '$TARGET_UID
usermod -o -u $TARGET_UID mysql || true
TARGET_GID=$(stat -c "%g" /var/lib/mysql)
echo '-- Setting mysql group to use gid '$TARGET_GID
groupmod -o -g $TARGET_GID mysql || true
echo
echo '* Starting MySQL'
chown -R mysql:root /var/run/mysqld/
/entrypoint.sh mysqld --user=mysql --console
  • 创建docker-compose.py,指定run-mysqld.sh脚本为容器入口

test-mysql:
    image: mysql 
    ports:
        - "3306:3306"
    volumes:   
        - /localhost/mysql/data:/var/lib/mysql 
        - ./scripts/run-mysqld.sh:/run-mysqld.sh
    environment:
        - MYSQL_DATABASE=play
        - MYSQL_USER=play
        - MYSQL_PASSWORD=play
        - MYSQL_ROOT_PASSWORD=123456
    entrypoint: /run-mysqld.sh
  • 运行docker-compose up命令,启动容器

以上是“Macosx下使用docker/mysql会出现什么问题”这篇文章的所有内容,感谢各位的阅读!相信大家都有了一定的了解,希望分享的内容对大家有所帮助,如果还想学习更多知识,欢迎关注亿速云行业资讯频道!

免责声明:

① 本站未注明“稿件来源”的信息均来自网络整理。其文字、图片和音视频稿件的所属权归原作者所有。本站收集整理出于非商业性的教育和科研之目的,并不意味着本站赞同其观点或证实其内容的真实性。仅作为临时的测试数据,供内部测试之用。本站并未授权任何人以任何方式主动获取本站任何信息。

② 本站未注明“稿件来源”的临时测试数据将在测试完成后最终做删除处理。有问题或投稿请发送至: 邮箱/279061341@qq.com QQ/279061341

Macosx下使用docker/mysql会出现什么问题

下载Word文档到电脑,方便收藏和打印~

下载Word文档

猜你喜欢

HashMap在高并发下会出现什么问题

本篇内容介绍了“HashMap在高并发下会出现什么问题”的有关知识,在实际案例的操作过程中,不少人都会遇到这样的困境,接下来就让小编带领大家学习一下如何处理这些情况吧!希望大家仔细阅读,能够学有所成!前言众所周知,HashMap不是线程安全
2023-06-20

主板有问题会出现什么现象

这篇文章给大家分享的是有关主板有问题会出现什么现象的内容。小编觉得挺实用的,因此分享给大家做个参考,一起跟随小编过来看看吧。主板有问题会出现的现象:1、开机无显示;2、CMOS设置不能保存;3、安装主板驱动程序后出现死机或光驱读盘速度变慢;
2023-06-14

golang出现内存逃逸会导致什么问题

当Golang程序出现内存逃逸时,会导致以下几个问题:垃圾回收开销增加:内存逃逸会导致对象分配在堆上,而不是在栈上。这意味着垃圾回收器需要更频繁地扫描堆内存,增加了垃圾回收的开销。性能下降:由于内存逃逸会导致对象在堆上分配,而堆上的内存分配
2023-10-26

MySql分页时使用limit+order by会出现数据重复问题解决

目录摘要问题描述分析问题解决问题摘要能把复杂的知识讲的简单很重要在学习的过程中我们看过很多资料、视频、文档等,因为现在资料视频都较多所以往往一个知识点会有多种多样的视频形式讲解。除了推广营销以外,确实有很多人的视频讲解非常优秀,例如李永乐老
2022-05-15

腾讯云服务器为什么会出现卡顿问题?

1.资源配置不足腾讯云服务器的性能与所选的配置密切相关。如果你选择的配置不足以支撑你的应用程序或网站的需求,就容易出现卡顿问题。在购买服务器时,需要根据实际需求选择适当的配置,包括CPU、内存、存储和带宽等。2.网络延迟网络延迟是指数据在传输过程中的延迟时间。如果你的服务器与用户之间的网络连接存在延迟,就会导致用户访问
2023-10-27

腾讯云服务器:为什么会出现卡顿问题?

1.硬件配置不足腾讯云服务器的性能与硬件配置直接相关。如果你选择的服务器配置较低,例如CPU、内存或存储空间不足,那么在处理大量请求或运行复杂应用程序时,服务器可能会出现卡顿现象。2.网络延迟网络延迟是另一个可能导致腾讯云服务器卡顿的因素。如果你的服务器与用户之间的网络连接不稳定或带宽不足,那么用户访问你的网站或应用程
2023-10-27

vbs生成静态页面过程中会出现什么问题

这篇文章主要介绍了vbs生成静态页面过程中会出现什么问题,具有一定借鉴价值,感兴趣的朋友可以参考下,希望大家阅读完这篇文章之后大有收获,下面让小编带着大家一起了解一下。vbs是否能够实现如下的:访问某个aspx页面,然后把服务器返回的页面以
2023-06-08

编程热搜

目录