docker实战练习(一)

systemctl start docker

systemctl pause docker

systemctl unpause docker

systemctl start docker

systemctl restart docker

docker image ls 查看镜像

docker image --digests 显示镜像摘要信息

docker image --digests --no-trunc 显示镜像全部信息

docker search centos 查询镜像

docker search -s 30 centos 查询star超过30的镜像

docker pull centos 下载centos镜像

注:

如果下载镜像超时,需设置国内镜像

vim /etc/docker/daemon.json

{
  "registry-mirrors": ["https://registry.docker-cn.com"]
}

service docker restart 重启docker

docker rmi 镜像名/容器id 镜像名/容器id 删除镜像

docker network create -d bridge test1 网络桥

docker network ls 显示网络桥列表

docker run -d -it -p 8001:22 --network test1 --name centos-test1 centos /bin/bash 创建centos镜像容器 本地的8001指向容器的22端口,在test1的网段里

docker run --privileged  -d -it -p 8002:22 --network test2 --name centos-test2 init-java-mysql:1.1 /usr/sbin/init

docker ps 查看运行容器

docker ps -a 查看所有容器

docker rm -f 镜像名/容器id 删除容器

docker rm $(docker ps -a -q) 删除所有容器

例如我们启动centos后台容器,每隔一秒打印当天的日历。
$ docker run -d -p 8001:22 --network test1 --name centos-test1 centos  /bin/sh -c "while true;do echo hello docker;sleep 1;done"

启动之后,我们使用docker ps -n 5查看容器的信息

要查看启动的centos容器中的输出,可以使用如下方式:
$ docker logs $CONTAINER_ID ##在container外面查看它的输出 

docker logs -f -t --tail 1 9714e2309486 t是加入时间戳 f是追加最新的日志 tail行数
$ docker attach $CONTAINER_ID ##连接上容器实时查看 Ctrl+p Ctrl+q退出但不关闭容器 退不出开启另一个终端 用 pkill -9 -f 'docker.*attach'

docker stop 12bdf4567710/centos-test1 终止容器

docker start centos-test1 启动容器

docker restart centos-test1 重启容器

docker kill centos-test1 强制停止容器

docker ps -l 查看上一次运行过的容器

docker ps -n 3查看上3次运行过的容器

docker top 9714e2309486 查看容器进程

docker inspect 9714e2309486 查看容器详细

运行容器命令但没有进容器

docker exec -t 9714e2309486 /bin/bash 进入容器

docker attach

docker cp 9714e2309486:文件路径 本机的路径 拷贝容器里的文件

自己构建镜像

docker commit -a="wang" -m="dec" 镜像名/容器id 新镜像名:版本号 这样就会生成在本地docker镜像里 docker image

rpm -qa | grep -i java 查看是否有安装java包

rpm -e --nodeps 包名

 

注:

需要远程链接的话需要开启端口,另外,centos镜像要设置密码 passwd 通过ssh连接

安装ssh

yum install passwd openssl openssh-server -y

/usr/sbin/sshd -D

ssh-keygen -q -t rsa -b 2048 -f /etc/ssh/ssh_host_rsa_key -N ''

ssh-keygen -q -t ecdsa -f /etc/ssh/ssh_host_ecdsa_key -N ''

ssh-keygen -t dsa -f /etc/ssh/ssh_host_ed25519_key -N ''

 

 

删除不了commit的镜像,是因为有依赖

保存新镜像

docker save -o java-mysql.tar  java-mysql:1.1

删除新旧镜像

docker rmi 6d7406eeac0e 93ea07f67227 b1172585ba22

load新镜像

docker load -i ./java-mysql.tar 

 

 

 

 

 

 

 

 

 

 

 

 

 

docker pull percona/percona-xtradb-cluster

docker pull docker.io/percona/percona-xtradb-cluster

docker tag docker.io/percona/percona-xtradb-cluster pxc 重命名

 

docker network ls 网段列表

docker network create net1

docker network inspect net1

docker network rm net1

docker network create -d bridge test1 网络桥

docker network create --subnet=172.18.0.0/24 net1 自建网段

 docker volume rm v1

 

 

 

 

 

 

 

 

#数据库负载均衡
listen proxy-mysql
#访问的IP和端口
bind 0.0.0.0:3306
#网络协议
mode tcp
#负载均衡算法(轮询算法)
#轮询算法:roundrobin
#权重算法:static-rr
#最少连接算法:leastconn
#请求源IP算法:source
balance roundrobin
#日志格式
option tcplog
#在MySQL中创建一个没有权限的haproxy用户,密码为空。Haproxy使用这个账户对MySQL数据库心跳检测
option mysql-check user haproxy
server MySQL_1 172.18.0.2:3306 check weight 1 maxconn 2000
server MySQL_2 172.18.0.3:3306 check weight 1 maxconn 2000
server MySQL_3 172.18.0.4:3306 check weight 1 maxconn 2000
server MySQL_4 172.18.0.5:3306 check weight 1 maxconn 2000
server MySQL_5 172.18.0.6:3306 check weight 1 maxconn 2000
#使用keepalive检测死链
option tcpka

监控画面

 

 

 

 

exit是退出交互界面 而不是停止容器运行

apt-get update 很慢需要更换镜像

 

 

 

 

 

全量备份

路径

需要先解散pxc 然后还原一个,然后同步pxc集群

执行冷还原

 

 

 

前面的坑

 

 

yes

 

 测试

 

posted @ 2019-03-18 13:07  apesplan  阅读(826)  评论(0编辑  收藏  举报