docker安装mariadb并在本地持久化数据方式
作者:Asimov__
这篇文章主要介绍了docker安装mariadb并数据持久化方式,具有很好的参考价值,希望对大家有所帮助,如有错误或未考虑完全的地方,望不吝赐教
安装mariadb
查找hub仓库的mariadb镜像
docker search mariadb
NAME DESCRIPTION STARS OFFICIAL AUTOMATED mariadb MariaDB is a community-developed fork of MyS… 3374 [OK] linuxserver/mariadb A Mariadb container, brought to you by Linux… 124
拉一个最新的mariadb镜像
docker pull mariadb
latest: Pulling from library/mariadb 5bed26d33875: Pull complete f11b29a9c730: Pull complete
docker images
REPOSITORY TAG IMAGE ID CREATED SIZE mariadb latest 37f5f0a258bf 3 weeks ago 356MB centos 7 5e35e350aded 5 months ago 203MB django latest eb40dcf64078 3 years ago 436MB
数据持久化的方法
一:docker数据卷容器
创建一个名为myblogdb数据卷(volume Manage volumes)
docker volume create myblogdb
查看myblogdb数据卷信息
docker volume inspect myblogdb
[
{
"CreatedAt": "2020-04-17T11:47:53+08:00",
"Driver": "local",
"Labels": {},
"Mountpoint": "/var/lib/docker/volumes/myblogdb/_data",
"Name": "myblogdb",
"Options": {},
"Scope": "local"
}
]查看所有数据卷信息
[root@asimov ~]# docker volume ls DRIVER VOLUME NAME local myblogdb
删除数据卷
docker volume rm 数据卷名
数据卷 是被设计用来持久化数据的,它的生命周期独立于容器,Docker 不会在容器被删除后自动删除 数据卷,并且也不存在垃圾回收这样的机制来处理没有任何容器引用的 数据卷。
如果需要在删除容器的同时移除数据卷。可以在删除容器的时候使用 docker rm -v 这个命令
清除无主的数据卷
docker volume prune
WARNING! This will remove all local volumes not used by at least one container. Are you sure you want to continue? [y/N] y Deleted Volumes: myblogdb
启动一个挂载数据卷的容器
[root@asimov ~]# docker run -d -P --mount source=myblog,target=/opt --name mysql_volume mariadb
--mount: 挂载目录(或-v:目录不存在时会自动创建目录)source=:创建的数据卷名(myblog),或本地目录target=:挂载到容器中的目录
查看mysql_volume容器
docker inspect mysql_volume
"Mounts": [
{
"Type": "volume",
"Name": "myblog", #数据卷名
"Source": "/var/lib/docker/volumes/myblog/_data", # 本地目录
"Destination": "/opt", # 挂载到容器中的目录
"Driver": "local",
"Mode": "z",
"RW": true,
"Propagation": ""
}
],删除容器同时移除数据卷
[root@asimov ~]# docker rm -v mysql_volume mysql_volume
二:挂载一个本地主机文件作为数据卷
创建mariadb容器并持久化到本地
[root@asimov data]# pwd /root/docker_data/mysql/data [root@asimov data]# docker run -d -p 3306:3306 -v /root/docker_data/mysql/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD="asimov" --name mysqlblog mariadb 7b962746a9407faefe40f0f3744c81a0d3b1e301adcc69f561e41a33785d4329
-d:后台运行-p 3306:3306:将内部的3306端口映射到外部的3306-v /root/docker_data/mysql/data:/var/lib/mysql:将内部数据库挂载到外部-e MYSQL_ROOT_PASSWORD=yourpasswd:设置root用户密码--name mysqlblog:容器名mariadb:镜像
指定mysql的配置文件
通过-v将本地的配置文件映射到docker内部的mysql(/etc/mysql/my.cnf)
查看容器
[root@asimov data]# docker ps CONTAINER ID IMAGE COMMAND CREATED STATUS PORTS NAMES 7b962746a940 mariadb "docker-entrypoint.s…" 16 minutes ago Up 16 minutes 0.0.0.0:3306->3306/tcp mysqlblog 61c1a2f92913 centos:7 "/bin/bash" 46 hours ago Up 28 hours 0.0.0.0:3333->8080/tcp blog
进入容器
[root@asimov ~]# docker exec -it mysqlblog /bin/bash
进入数据库
root@7b962746a940:~# mysql -uroot -p passwd Welcome to the MariaDB monitor. Commands end with ; or \g. Your MariaDB connection id is 10 Server version: 10.4.12-MariaDB-1:10.4.12+maria~bionic mariadb.org binary distribution Copyright (c) 2000, 2018, Oracle, MariaDB Corporation Ab and others. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. MariaDB [(none)]>
创建数据库
MariaDB [(none)]> show databases; +--------------------+ | Database | +--------------------+ | information_schema | | mysql | | performance_schema | +--------------------+ 3 rows in set (0.002 sec) MariaDB [(none)]> create database asimov default charset 'utf8'; Query OK, 1 row affected (0.000 sec)
退出容器,查看本地挂载的目录
[root@asimov data]# pwd /root/docker_data/mysql/data [root@asimov data]# ls aria_log.00000001 aria_log_control asimov ib_buffer_pool ibdata1 ib_logfile0 ib_logfile1 ibtmp1 multi-master.info mysql performance_schema [root@asimov data]# cd asimov/ [root@asimov asimov]# ls db.opt
总结
以上为个人经验,希望能给大家一个参考,也希望大家多多支持脚本之家。
