service docker start - docker 启动

service docker stop - docker 关闭

1.docker 镜像创建—使用的默认镜像有数据卷

docker pull hub.c.163.com/library/mysql:5.7.18 – 获取镜像

docker images  - 查看镜像(镜像id)

docker tag mysql:latest tmysql:5.7 – 添加镜像标签

docker rmi –f images_id – 删除镜像 (-f 强制删除镜像)

2.docker 容器的创建

docker run --name tmysql -v /home/dly:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456 -p 3306:3306  -d images_id – 创建并启动容器,同时有挂载配置文件,注意/home/dly权限。

docker run --name ttpostgres -p 5433:5432 -e POSTGRES_PASSWORD=123456 -v /home/dly:/var/lib/postgresql -d postgres:9.6 -- postgresql 容器创建与启动

docker start container – 启动容器

docker stop container – 关闭容器

docker ps –a  - 查看容器

docker exec- it container_id  /bin/bash – 进入容器

docker inspect tmysql – 查看容器的元数据

3.通过已有的容器创建镜像 存出和载入

docker ps – 查看备份容器的container_id

docker commit -p container_id container-backup - 使用 docker commit 命令来创建快照,生成一个作为Docker镜像的容器快照,

docker images – 查看是否生成镜像

-- # docker tag a25ddfec4d2a arunpyasi/container-backup:test

docker save -o ~/container-backup.tar container-backup - 作为tar包备份。

ls – 查看tar包是否存在。

scp  –r  ~/ container-backup.tar root@10.2.0.3:/home/dly - 服务器迁移

docker load -i ~/container-backup.tar- 加载该Docker镜像了。

docker images -查看是否镜像下载

docker run -d -p 3306:3306 –-name tmysql  container-backup  - 运行Docker容器。

docker exec –it contain_id /bin/bash –进入容器

4. 通过已有的数据卷容器的存出和载入,以下方法可以实现数据库文件从一个服务器点迁移到另一个服务器

备份

docker run –it –v /var/lib/mysql –name tmysql image_id  - 创建一个带有数据卷的容器.

## 导入数据

docker run --volumes-from container_name -v $(pwd):/backup images_id tar cvf /backup/backup.tar /var/lib/mysql

docker run --volumes-from container_name -v $(pwd):/backup images_id tar cvf /backup/backup.tar /var/lib/postgresql/data

--利用数据卷容器备份,使用 –volumes-from 标记来创建一个加载 data 容器卷的容器,并从主机挂载当前目录到容器的 /backup 目录。容器启动后,在当前目录下生成的backup.tar 文件就是data容器卷的备份文件.

恢复

docker run --name tmysql -p 3306:3306 -v /home/dly:/etc/mysql/conf.d -e MYSQL_ROOT_PASSWORD=123456  -d image_id  -创建一个带有空数据卷的容器 这个镜像自动带有数据卷,i是打开容器中的stdin,t是为容器分配一个伪终端.这里的d是后台运行,并打印容器ID容器,容器运行 。

docker run --volumes-from contain_name  -v $(pwd):/backup image_id tar xvf /backup/backup.tar

重启docker

此时打开数据库,数据库文件已经存在

二.postgresql

源文件服务器-- 因为docker 没有安装必要的ssh 和vim 需要单独安装

apt-get update

apt-get install ssh – 安装ssh

#apt-get install vim-gtk – 安装vim

su – postgress

pg_dumpall | ssh root@10.0.0.96 'cat > /var/pgbackup/db.out' – 目录存在 -- 导出数据文件db.out

目标文件服务器-- /var/lib/postgresql/data

docker run --name ttpostgres2 -p 5410:5432 -e POSTGRES_PASSWORD=123456 -v /var:/var/lib/postgresql/data -d postgres:9.6 -  启动容器挂载

docker exec –it ttpostgres2 /bin/bash –进入容器

su – postgres – 切换超级用户

cd /var/lib/postgresql - 进入目标路径

psql -f db.out postgres -- 导入数据文件db.out

尝试过数据卷的方法导入postgresql 数据文件,但是没有成功,只有使用pg_dumpall插件了。
---------------------
作者:D2012LY
来源:CSDN
原文:https://blog.csdn.net/D2012LY/article/details/77851414
版权声明:本文为博主原创文章,转载请附上博文链接!

docker 下mysql 和postgresql 数据库的搭建以及数据文件的迁移和备份的更多相关文章

  1. ubuntu 下 mysql数据库的搭建 及 数据迁移

    1.mysql的安装 我是使用apt-get直接安装的 :sudo apt-get install mysql-server sudo apt-get install mysql-client 2.配 ...

  2. 关于PDF.NET开发框架对Mysql Sqlite PostgreSQL数据库分页支持的个人看法

    关于PDF.NET开发框架的名字由来  在设计www.pwmis.com站点的时候,考虑到架构的兼容性和将来升级的可能性,最重要的是没有足够的时间去为网站添加和维护很多复杂的程序,所以在借鉴前人成功经 ...

  3. Linux下MySQL/MariaDB Galera集群搭建过程【转】

    MariaDB介绍 MariaDB是开源社区维护的一个MySQL分支,由MySQL的创始人Michael Widenius主导开发,采用GPL授权许可证. MariaDB的目的是完全兼容MySQL,包 ...

  4. 对Oracle 、SQL Server、MySQL、PostgreSQL数据库优缺点分析

    对Oracle .SQL Server.MySQL.PostgreSQL数据库优缺点分析 Oracle Database Oracle Database,又名Oracle RDBMS,或简称Oracl ...

  5. Docker下mysql容器开启binlog日志(保留7天)

    现有需求开启用Docker容器启动的mysql数据库的binlog,以作为 日志记录 和 数据恢复,我们了解了MySQL的binlog日志的开启方式以及binlog日志的一些原理和常用操作,我们知道, ...

  6. postgreSQL数据库的监控及数据维护

    目前postgreSQL数据库的管理,数据查询等都需要安装postgreSQL软件或安装pgadmin等,远程访问都需要先登录到服务器等繁琐的操作.如果是开发团队,那么每个开发,测试,管理人员都要经历 ...

  7. MySQL 查询某个数据库中所有包含数据记录的表名

    MySQL 查询某个数据库中所有包含数据记录的表名 有时根据实际应用需要,需要对数据进行备份. 如果一个数据库中有很多数据表,但是只想备份包含数据记录的那些表数据(空表不做数据备份). 如果通过如下S ...

  8. Oracle数据库表空间与数据文件的关系描述正确的是( )

    Oracle数据库表空间与数据文件的关系描述正确的是( ) A.一个表空间只能对应一个数据文件 B.一个表空间可以对应多个数据文件 C.一个数据文件可以对应多个表空间 D.表空间与数据文件没任何对应关 ...

  9. docker下MySQL的主从复制

    MySql的主从复制 sudo docker pull MySQL:5.7 拉取MySQL的镜像文件(版本号为 5.7) sudo docker run -p 3339:3306 --name mas ...

随机推荐

  1. Mac 下Wireshark 找不到网卡

    终端上面,执行如下命令: sudo chgrp admin /dev/bpf* sudo chmod g+rw /dev/bpf*

  2. 自用 微信小程序跳小程序

    "window": { "navigationBarTextStyle": "black", "navigationBarTitl ...

  3. git 查看项目代码统计命令

    git log --author="xxxxxxxx" --pretty=tformat: --numstat | gawk '{ add += $1 ; subs += $2 ; ...

  4. noi.ac #30 思维

    \(des\) 给定升序数组 \(A, B\) 对于任意两个集合 \(a, b\) 分别是 \(A, B\) 的子集,总价值为较小的集合的和, 总代价为 \((|a| + |b|) \times w\ ...

  5. 记录一个webstorm的设置或者说小技巧

    在 html 的元素中,如果输入属性,默认会填充 引号,在 react 书写中非常不方便. 其中的JSX很多时候是不需要 quotation 的,只是需要一个 括号 {} 即可. 自己找了下webst ...

  6. P5049 旅行(数据加强版)(基环树)

    做法 把环找出来,如果在环上(u,v)两点的时候,u的其他子树都走完了,v上第一个还有除v存在的子树没走完的 祖先,祖先的最小子节点小于v,则回去 Code #include<bits/stdc ...

  7. ElasticSearch : 基础简介

    1.安装 我用的docker安装,这个用起来比较方便,我是在腾讯云部署的docker,具体的过两天总结一下 安装: docker pull elasticsearch 运行: docker run - ...

  8. 2018-2019-2 《网络对抗技术》Exp7 网络欺诈防范 20165326

    网络欺诈防范 实践内容 本实践的目标理解常用网络欺诈背后的原理,以提高防范意识,并提出具体防范方法.具体实践有 简单应用SET工具建立冒名网站 ettercap DNS spoof 结合应用两种技术, ...

  9. 各种推导式 详情见EVA_J的博客

    #[每一个元素或者是和元素相关的操作 for 元素 in 可迭代数据类型] #遍历之后挨个处理 #[满足条件的元素相关的操作 for 元素 in 可迭代数据类型 if 元素相关的条件] #筛选功能 # ...

  10. Perl看完这个,再不敢说自己会玩贪吃蛇

    某天闲逛时看见一副动图: 真的是非常贪吃,各种拐弯各种吃,感觉十分有趣. 用Perl来实现自动吃满,蓄谋已久,之前的字符贪吃蛇.深度优先算法.A*算法,都是为此篇做铺垫. 那么,怎样让蛇不吃到自己呢? ...