开源中国

我们不支持 IE 10 及以下版本浏览器

It appears you’re using an unsupported browser

为了获得更好的浏览体验,我们强烈建议您使用较新版本的 Chrome、 Firefox、 Safari 等,或者升级到最新版本的IE浏览器。 如果您使用的是 IE 11 或以上版本,请关闭“兼容性视图”。
在 Docker 中使用 MySQL - 技术翻译 - 开源中国社区

在 Docker 中使用 MySQL 【已翻译100%】

标签: Docker MySQL
oschina 推荐于 4年前 (共 2 段, 翻译完成于 01-17) 评论 10
收藏  
52
推荐标签: Docker MySQL 待读
参与翻译 (1人) : petert 仅中文 | 中英文对照 | 仅英文 | 打印此文章

提及虚拟化技术,我可是linuxContainer(LXC)的热爱者。但随着Docker技术的声名鹊起,我想在这展示一下如何使用带有Docker的Mysql

Docker是什么?

实际上,Docker就是LXC的封装。使用起来很有意思。Docker采用LXC来虚拟化每个应用。所以在接下来的示例中,我们会启动chroot环境中一个被封装在自己命名空间内的mysql实例(你也可以设置Cgroups对应的资源)使用Docker的一个亮点就是统一文件系统(aufs)。所以当启动一个Docker容器后,它会记录其aufs总数并只会更新新写入的数据。

petert
 翻译得不错哦!

Aufs对于大多数应用来说十分有用,并且也能很好地支持数据库测试。在这我只想做个简单的示例-仅仅抛砖引玉,实用性也许并不高- Dockerfile. Dockerfile是Docker镜像的构建脚本

咱们来看看Dockerfile的内容:

FROM ubuntu
MAINTAINER erkan yanar <erkan.yanar@linsenraum.de>

ENV DEBIAN_FRONTEND noninteractive
RUN apt-get install -y  python-software-properties
RUN apt-key adv --recv-keys --keyserver hkp://keyserver.ubuntu.com:80 0xcbcb082a1bb943db
RUN add-apt-repository 'deb http://mirror2.hs-esslingen.de/mariadb/repo/10.0/ubuntu precise main'
RUN apt-get update
RUN apt-get install -y mariadb-server
RUN echo "[mysqld]"                       >/etc/mysql/conf.d/docker.cnf
RUN echo "bind-address   = 0.0.0.0"      >>/etc/mysql/conf.d/docker.cnf
RUN echo "innodb_flush_method = O_DSYNC" >>/etc/mysql/conf.d/docker.cnf
RUN echo "skip-name-resolve"             >>/etc/mysql/conf.d/docker.cnf
RUN echo "init_file = /etc/mysql/init"   >>/etc/mysql/conf.d/docker.cnf
RUN echo "GRANT ALL ON *.* TO supa@'%' IDENTIFIED BY 'supa';" >/etc/mysql/init

EXPOSE 3306
USER mysql
ENTRYPOINT mysqld

你可以按自己的需求更改。明白了大意后,可以进一步优化代码。比如,较少运行步骤:)

运行一下看看 (命名为mysql)


> cat $DOCKERFILENAME | docker build -t mysql -

很好!启动51个容器看看:

> time for i in $(seq 10 60 ) ; do docker  run -d -p 50$i:3306   mysql ; done                                                              
..      
real    0m27.446s
user    0m0.264s
sys     0m0.211s

这都是在我笔记本上的结果. 如果使用KVM性能会更好 :)

>  docker ps | grep mysqld |wc -l 
51
> docker ps | head -2
CONTAINER ID        IMAGE               COMMAND             CREATED              STATUS              PORTS                    NAMES
6d3a5181cd56        mysql:latest        /bin/sh -c mysqld   About a minute ago   Up About a minute   0.0.0.0:5060->3306/tcp   lonely_pare

快来试试吧 \o/

petert
 翻译得不错哦!
本文中的所有译文仅用于学习和交流目的,转载请务必注明文章译者、出处、和本文链接
我们的翻译工作遵照 CC 协议,如果我们的工作有侵犯到您的权益,请及时联系我们
评论(10)
Ctrl/CMD+Enter

ok
支持
mysql都不算数据库

引用来自“布尔道长”的评论

mysql都不算数据库

@宏哥 这是你马甲,还是你小弟?

引用来自“吕秀才”的评论

引用来自“布尔道长”的评论

mysql都不算数据库

@宏哥 这是你马甲,还是你小弟?

这是事实

和马甲, 小弟无关
连阿里巴巴都弃oracle用mysql还说mysql都不算数据库?
菜鸟年年有,今年特别多,呵呵

引用来自“宏哥”的评论

引用来自“吕秀才”的评论

引用来自“布尔道长”的评论

mysql都不算数据库

@宏哥 这是你马甲,还是你小弟?

这是事实

和马甲, 小弟无关
那你认为什么样才算是数据库?
数据库都没恭喜出来,重启docker或者image数据就没了。

引用来自“宏哥”的评论

引用来自“吕秀才”的评论

引用来自“布尔道长”的评论

mysql都不算数据库

@宏哥 这是你马甲,还是你小弟?

这是事实

和马甲, 小弟无关
2B
没法使用,这个有问题python-software-properties
顶部