docker搭建mysql服务实践

问题提出

在实际的测试开发过程中需要用到很多的库,为了模拟远程数据库连接的场景需要在阿里云服务器上搭建一个mysql数据库服务

技术方案

1、为了更好的管理远程服务器,让服务器更加的纯净话,排除服务器环境的影响,我想到了容器话部署
截图从网络非本人原创
容器就是一个视图隔离、资源可限制、独立文件系统的进程集合,在容器中运行mysql服务的镜像,可以实现我要的需求,纯净,可移植。
镜像可实现运行的步骤
1.1、从镜像仓库中将相应的镜像下载下来
1.2、当镜像下载完成之后就可以通过 docker images 来查看本地镜像,这里会给出一个完整的列表,我们可以在列表中选中想要的镜像
1.3、当选中镜像之后,就可以通过 docker run 来运行这个镜像得到想要的容器,当然可以通过多次运行得到多个容器。一个镜像就相当于是一个模板,一个容器就像是一个具体的运行实例,因此镜像就具有了一次构建、到处运行的特点

2、当使用容器部署时考虑到外部服务访问容器的问题时,很自然需要映射一下端口,使的外部服务可以很好的访问到容器内部
3、考虑到容器的生命周期,在容器中存储的数据需要持久化到卷才行,在本地保存才是最合理的,那么就需要在启动docker时保证持久化

解决问题

实践

a、创建宿主机数据存放目录

mkdir -p /opt/data/mysql

b、启动容器,设置root的密码为xsd7823wadrcsefbjjbshjjd

docker run -d -v /opt/data/mysql/:/var/lib/mysql -p 3306:3306 --name flasken_mysql -e MYSQL_ROOT_PASSWORD=xsd7823wadrcsefbjjbshjjd  docker.io/mysql

检查容器是否正确运行

docker container ls
docker logs mysql ##查看日志
docker ps #查看容器

c、查看端口

lsof -i:3306

开机自动启动设置

docker update --restart=always <CONTAINER ID>

最后我们部署成功的截图如下:
在这里插入图片描述
通过navicat premium连接来看一下效果。
在这里插入图片描述

分析

上述的mysql服务,可以用于多个项目使用,没有使用的和强大的编排。实际项目部署中可以使用到docker-compose简单的编排,以及k8s这种复杂的编排。

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值