当前位置: 移动技术网 > IT编程>数据库>Mysql > 在Docker中使用MySQL的教程

在Docker中使用MySQL的教程

2017年12月12日  | 移动技术网IT编程  | 我要评论

女人陷阱,736晋江网736,胥渡搞笑视频

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

docker是什么?

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


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/

如对本文有疑问,请在下面进行留言讨论,广大热心网友会与你互动!! 点击进行留言回复

相关文章:

验证码:
移动技术网