Mysql已经提供了Docker image,可以很方便开启一个mysql服务器。官方介绍了两种连接方式,
- 在其他App Docker 容器中通过--link访问Mysql服务端容器
- 启动另外一个Mysql容器当做客户端,通过--link访问Mysql服务端容器
这两种方式的客户端都在容器里面,如果客户端不通过Docker容器访问也是很简单的:
1. Pull Mysql Image
$ docker pull mysql
前提是已经安装Docker,这个可以参考docker官网,步骤很详细。
2. 创建外部数据挂载点
$ sudo mkdir -p /var/docker_data/mysql/data $ sudo chmod 775 -R /var/docker_data/msyql/
除了这种方式,也可选择使用Docker数据卷。
3. 启动Mysql容器
通过-e参数可以设定一下Mysql服务端的参数,这里设置了root的密码,并且创建了一个密码为dev的用户dev。
$ docker run -p 3306:3306 --name mysql-test -v /var/docker_data/mysql/data/:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -e MYSQL_USER=dev -e MYSQL_PASSWORD=dev -d mysql #查看docker是否启动 $ docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES a8ef529a9a1c mysql "docker-entrypoint.sh" 18 seconds ago Up 17 seconds 0.0.0.0:3306->3306/tcp mysql-test
4. 在宿主机链接Mysql容器
使用PORTS显示的ip地址部分作为 -h 参数,如果是不是在宿主机上,则使用宿主机的IP地址。
$ mysql -h 0.0.0.0 -u root -p