docker install
docker install参考网址
较老的版本docker所所支持命令和和部分文件路径会有偏差所以统一卸载它以及所属依赖库
yum remove docker docker-common docker-selinux docker-engine
使用存储库进行安装
yum-config-manager \ --add-repo \ https://download.docker.com/linux/centos/docker-ce.repo
安装依依环境
yum install -y yum-utils \ device-mapper-persistent-data \ lvm2
安装docker-ce
yum -y install docker-ce
-- 启动docker
systemctl start docker
-- 检查状态
systemctl status docker
*卸载Docker
yum remove docker-ce
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
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 –进入容器
- 通过已有的数据卷容器的存出和载入
备份
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
源文件服务器
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' – 目录存在
目标文件服务器-- /var/lib/postgresql/data
docker run --name ttpostgres2 -p 5410:5432 -e POSTGRES_PASSWORD=123456 -v /var:/var/lib/postgresql -d postgres_vim:9.6 - 启动容器挂载
Docker ps
docker exec –it ttpostgres2 /bin/bash –进入容器
Vim var/lib/postgresql.sql i-> Esc ->:wq(保存退出) ,:q!(不保存退出)
su – postgres – 切换超级用户
cd /var/lib/postgresql - 进入目标路径
psql -f db.out postgres
Postgresql 数据表导入导出
1.导出
pg_dump -U postgres(用户名) (-t 表名) 数据库名(缺省时同用户名) > 路径/文件名.sql
postgres@debian:~$ pg_dump -U postgres -t system_calls wangye > ./test.sql
2.导入
$ createdb newdatabase
$ psql -d newdatabase -U postgres -f mydatabase.sql // sql 文件在当前路径下
$ psql -d databaename(数据库名) -U username(用户名) -f < 路径/文件名.sql // sql 文件不在当前路径下
$ su postgres #切换到psql用户下
$ psql -d wangye -U postgres -f system_calls.sql # sql 文件在当前路径下