docker-compose启动mysql

1. 下载docker和docker-compose
安装之前最好确认你的防火墙和selinux是关闭状态
#关闭防火墙
systemctl stop firewalld
#关闭防火墙开机自启
systemctl disable firewalld
# 临时关闭selinux,重启会失效
setenforce 0
#永久关闭
sed -i 's/^SELINUX=.*/SELINUX=disabled/g' /etc/selinux/config
安装docker-ce yum源
sudo yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo
安装docker服务端
sudo yum -y install docker-ce
设置docker镜像下载国内加速
在/etc/docker/daemon.json 编辑文件,具体可以参考阿里云镜像加速。
systemctl restart docker #启动docker
systemctl enable docker #设置docker开机自启动
systemctl status docker # 检查docker运行是否是running
docker info #查看安装的版本
docker pull mysql:5.7 #提前拉取好镜像,docker-compose启动也会自动拉取
2. 安装docker-compose
下载安装docker-compose
sudo curl -L https://get.daocloud.io/docker/compose/releases/download/1.25.1/docker-compose-`uname -s`-`uname -m` -o /usr/local/bin/docker-compose
chmod +x
/usr/local/bin/docker-compose #添加执行权限
docker-compose -v #执行检查版本,顺便确认环境变量是否可以
3. docker-compose启动mysql
选择docker启动的目录比如 /data/zhangpei/
上传 docker-compose.yml 文件到/data/zhangsan
mkdir -p /data/zhangsan/mysql
上传mysql配置my.cnf到本地映射文件夹/data/zhangpei/mysql 下
version: '3.1'
services:
mysql:
image: mysql:5.7
restart: always
environment:
MYSQL_ROOT_PASSWORD: my-secret-pw # mysql root用户的密码,自己修改注意复杂度
MYSQL_DATABASE: mydb # 你要跑的mysql数据库名,随你定义,这个也可以不其他创建
MYSQL_USER: myuser # 普通用户可以访问mydb,也可以不创建
MYSQL_PASSWORD: mypassword #普通用户可以访问mydb的密码
ports:
- "3306:3306" # 映射本地3306端口,本地ip可以用3306访问
volumes:
- "./mysql/my.cnf:/etc/mysql/my.cnf"
- "./mysql/datadir:/var/lib/mysql"
启动mysql
在docker-compose.yml所在的文件夹下执行
docker-comose up -d
docker-compose ps # 查看启动状态
docker-compose logs # 查看启动日志,排错使用