MySQL 和 Redis 在实际的项目中已经是非常常用的环境了,在开发时也是不能缺少的,总不至于用线上环境当作开发环境来用吧。一般情况下,这样的开发环境我们都有,但是在新机器上如果没有,找人要安装包、或者自己去网上找安装包又十分的麻烦。那么,不如试试通过 Docker 来搭建这些开发环境,既轻松也省事。
这里安装 MySQL 5.7 和 最新版的 Redis 来进行简单的演示。
一、安装MySQL 5.7
1、直接通过 docker pull 拉取 MySQL 5.7
代码语言:javascript复制[root@localhost ~]# docker pull mysql:5.7
5.7: Pulling from library/mysql
9a0b9cd2dfe6: Pull complete
c637408ee7df: Pull complete
4c517093c276: Pull complete
301cc7d68c2a: Pull complete
17ca9bf9231a: Pull complete
9ae101e5c786: Pull complete
04baa409344e: Pull complete
f0b6015bf853: Pull complete
6005bb052ef8: Pull complete
99f303d57050: Pull complete
307a9a80c1df: Pull complete
Digest: sha256:0e3435e72c493aec752d8274379b1eac4d634f47a7781a7a92b8636fa1dc94c1
Status: Downloaded newer image for mysql:5.7
docker.io/library/mysql:5.7
2、查看拉取下来的镜像
代码语言:javascript复制[root@localhost ~]# docker images
REPOSITORY TAG IMAGE ID CREATED SIZE
mysql 5.7 eef0fab001e8 2 weeks ago 495MB
3.启动 MySQL 5.7
代码语言:javascript复制docker run -p 3306:3306
--name mysql
-v /mydata/mysql/log:/var/log/mysql
-v /mydata/mysql/data:/var/lib/mysql
-v /mydata/mysql/conf:/etc/mysql/conf
-e MYSQL_ROOT_PASSWORD=root
-d mysql:5.7
这里需要说明一下,-e 用来设置环境变量,这里设置 MySQL 5.7 的 root 密码为 root。
4.查看 Docker 运行的容器
代码语言:javascript复制[root@localhost containers]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES
4f6de6ccec9f mysql:5.7 "docker-entrypoint.s…" 3 seconds ago Up 2 seconds 0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp mysql
5.创建 my.conf 文件并重启 MySQL
在上面的步骤虽然挂载了 conf 目录,但是在 conf 目录下并没有具体的配置文件,这里可以在 /mydata/mysql/conf 目录下创建一个 my.conf 文件作为 mysql 的配置文件(去找一份现成的配置改改,或者直接用现成,改也不用改)。创建好文件以后,重启 MySQL 容器,命令如下:
代码语言:javascript复制[root@localhost containers]# docker restart 4f
4f
[root@localhost containers]# docker ps
CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS
NAMES
4f6de6ccec9f mysql:5.7 "docker-entrypoint.s…" 2 minutes ago Up 2 seconds 0.0.0.0:3306->3306/tcp, :::3306->3306/tcp, 33060/tcp mysql
6. 测试连接
上面的步骤就已经完成了 MySQL 5.7 的安装,我们可以通过命令行,或者 Navicate 工具连接 MySQL 进行测试。发现 MySQL 可以被 Navicate 进行远程连接。
二、安装 Redis
Redis 的安装与 MySQL 的安装基本是一样的,这里直接上操作。
1、直接通过 docker pull 拉取 Redis
代码语言:javascript复制[root@localhost containers]# docker pull redis
Using default tag: latest
latest: Pulling from library/redis
a603fa5e3b41: Pull complete
77631c3ef092: Pull complete
ed3847cf62b8: Pull complete
261a8b530567: Pull complete
7d9005a8af6d: Pull complete
828da1afb5be: Pull complete
Digest: sha256:1e3207c292225b6dd21cb74d59255748a50e8f739dd983040df38fa913927cf1
Status: Downloaded newer image for redis:latest
docker.io/library/redis:latest
2、创建 Redis 的配置文件并启动 Redis
我们在 /mydata/redis/conf 目录下创建一个 Redis 的配置文件,这里一样是找个现成的配置文件即可。
代码语言:javascript复制[root@localhost conf]# docker run -d -p 6379:6379 --name mall-redis -v /mydata/redis/data:/data -v /mydata/redis/conf:/etc/redis redis redis-server /etc/redis/redis.conf
6284d4089225fb0c311507cc14d11ca9e4d4ca02dd48f766bf70c604a1ccbcb3
启动 MySQL 时没有 my.conf 文件是可以启动的,启动 Redis 的时候因为我们要指定一个配置文件,如果没有配置文件,则 Redis 会启动失败。因此提前准备一份 Redis 的配置文件即可。
3、修改配置并进行远程连接
Redis 的默认配置不支持远程访问,只需要修改配置文件中的 bind 参数,并给 Redis 加一个密码,或者关掉它的保护模式的参数就可以了。
4、让容器可以开机自启动
让我们的 MySQL 和 Redis 随着虚拟机的启动而启动,只需要使用 docker up --restart=always 进行设置即可。
到此,一份Docker快速搭建MySQL和Redis的教程就完毕了!