mysql 安装
搜索mysql
选择版本
拉取镜像
docker pull mysql:版本
查看当前所有镜像
创建实例并启动
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 \
-e MYSQL_ROOT_PASSWORD=root \
-d mysql:5.7
-p 3306:3306 将容器的3306映射到主机的3306端口
-v /mydata/mysql/conf:/etc/mysql 将配置文件夹挂载到主机
-v /mydata/mysql/data:/var/lib/mysql 将数据挂载到主机
-v /mydata/mysql/log/:/var/log/mysql 将日志挂载到主机
-e MYSQL_ROOT_PASSWORD=root 初始mysql密码
-d 后台启动
通过 -v 将容器内部的文件映射到linux上,方面修改
查看正在运行中的容器
docker ps
进入容器内
配置mysql
vi /mydata/mysql/conf/my.cnf
[client]
default-character-set=utf8
[mysql]
default-character-set=utf8
[mysqld]
init_connect='SET collation connection = utf8_unicode_ci'
init_connect='SET NAMES utf8'
character-set-server=utf8
collation-server=utf8_unicode_ci
skip-character-set-client-handshake
skip-name-resolve
skip-name-resolve 可以解决mysql连接慢问题,既跳过域名解析
重启
docker restart mysql
进入mysql容器
docker exec -it mysql /bin/bash
redis安装
下载 redis 镜像
docker pull redis
创建配置文件
mkdir -p /mydata/redis/conf
touch /mydata/redis/conf/redis.conf
启动容器
docker run -p 6379:6379 --name redis \
-v /mydata/redis/data:/data \
-v /mydata/redis/conf/redis.conf:/etc/redis/redis.conf \
-d redis redis-server /etc/redis/redis.conf
运行 redis
docker exec -it redis redis-cli
开启 aof 持久化
vi /mydata/redis/conf/redis.conf
# 添加如下内容
appendonly yes
重启 redis
docker restart redis
配置每次打开都是自动启动