Docker 快速搭建 MySQL 和 Redis

Docker 快速搭建 MySQL 和 Redis

MySQL 环境搭建

最近做开发的时候遇到一个比较有意思的事情,如何搭建一个数据库,还有相关的redis等。因为没有外网,不可能说直接yum安装,又不想到每个官网去找相应的安装包。自然的,就想到了用Docker。一开始用到docker安装一个mysql的时候确实也是非常方便,比如一个docker run命令就启动了一个mysql,但是开发到一部分的时候,发现。我去!怎么又乱码?? 咦,怎么市区也不对了?GG,发现还有很多小问题。今天有空一并总结下,下次如果有这种事就可以直接用了。

使用Docker启动启动Mysql容器

如果需要一个mysql数据库,直接使用docker来运行一个容器:docker run -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root123456 mysql:5.7

这样你就可以在本地ip+3306端口来访问一个mysql数据库了,root密码是:root123456。第一次使用docker的时候就是因为这个原因被吸引了。想想如果本地安装需要做多少配置,而是用docker一条命令就帮你把那些复杂的操作都隐藏了。这种便利性,我想谁都不会说不想要。

不过虽然便利是便利了,但是还是需要注意一些问题:

字符问题

mysql默认其实是latin的字符集,docker 启动mysql的时候其实也是使用的默认字符。而我们做开发一般都是使用UTF-8的字符集,那出现这种情况该如何更改配置了?可以在启动的时候加上两个变量:docker run -d -e MYSQL_ROOT_PASSWORD=root123456 mysql:5.7 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

数据磁盘问题

一个容器,如果那天不小心删除了,然后你重建就会发现之前的数据没有了,这种情况当然是不行啦。那么怎么将数据盘挂载出来:加上 -v,让存储在容器里面的数据存储到本地自定义的盘中:-v /data/mysql:/var/lib/mysql

默认数据库,以及时区修改

有的时候我们会需要导入一些表或者一些数据,这个时候该怎么操作? 其实也有一个环境变量:MYSQL_DATABASE;然后将数据库的初始化脚本放到/docker-entrypoint-initdb.d/目录下也就是将sql挂载到该目录下:

docker run -d --name mysql -p 13306:3306 -e MYSQL_ROOT_PASSWORD=root123456 -e MYSQL_DATABASE=DB_USER -e TZ=Asia/Shanghai -v $PWD/sql-scripts/:/docker-entrypoint-initdb.d/ -v /data/mysql:/var/lib/mysql mysql:5.7 --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci

将数据库的sql放到当前目录的sql-scripts/目录下。

Redis 环境搭建

redis的搭建其实要比mysql要简单些,毕竟redis我们一般都只是用来当作缓存,而不会将数据持久化,所以只需要将一个容器run起来就可以了。不过我们一般会有redis的密码需要,所以完整的命令如下:

docker run -d --name redis -p 6379:6379 redis:latest --requirepass "123456"

这样redis就启动了,如果需要开机启动,加上--restart=always

好了,今天一篇搭建mysql和redis的过程就到这里了。

原文链接:Docker 快速搭建 MySQL 和 Redis
文章作者:牛肉饺子
发布时间:2018-12-16 20:04:12
原始链接:http://chenzhijun.me/2018/12/16/docker-mysql-and-redis/
转载请保留原文链接及作者。

©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 《Docker环境下的前后端分离部署与运维》课程脚本 [TOC] 一、Docker虚拟机常用命令 先更新软件包yu...
    mingminy阅读 611评论 0 0
  • Docker — 云时代的程序分发方式 要说最近一年云计算业界有什么大事件?Google Compute Engi...
    ahohoho阅读 15,591评论 15 147
  • 在我的docker安装redis里,已经说明过docker安装redis的流程,对于redis的安装下面文章很多部...
    szgl_lucifer阅读 12,782评论 1 23
  • 文/张敏 人生在世,难免有苦痛纠结。其实,哪有过不去的事,只有过不去的心,人最难掌控的不是别人,恰恰是自己!累与...
    祥云ZM阅读 417评论 0 2
  • 交通费在历史上一直都是稳定的支出,属于衣食住行四大类之一。 消费的理由第一是"脚力不及",第二是"便利"。 ...
    吴少杰1988阅读 156评论 0 0