docker常用操作

175 阅读3分钟

docker常用操作

1. CentOS7离线安装Docker和卸载Docker步骤

https://www.gold404.cn/info/140
http://www.ay1.cc/article/7600.html
https://blog.csdn.net/lingfeian/article/details/125482271

2. 国内镜像加速

在下面添加如下 "registry-mirrors": [    "https://iotekdjw.mirror.aliyuncs.com"  ]          

3. docker 镜像命令

# 1. 搜索,也可以直接到 dockerHub 搜索
docker search 镜像名称
​
# 2. 下载
docker pull 镜像名称:版本号,如果不加,默认latest
​
# 3. 查看已经下载镜像
docker images
​
# 4. 删除镜像
docker rmi 镜像名/id# 5. 导出镜像
docker save -o hello-world.tar 镜像名/id# 6. 导入镜像
docker load --input [镜像名] 

容器ID不需要全部输入,前几个就可以

4. docker 容器命令

# 1. 创建、启动容器
docker run 容器名/容器id# 2. 查看容器,-a 查看所有,不加代表查询正在运行的
docker ps -a
​
# 3. 启动/停止容器
docker run/stop 容器名/ID
​
# 3. 删除容器
docker rm 容器名/ID
​
# 4. 进入容器
docker exec -it 容器名/ID /bin/bash 
​
# 5. 导出容器,有时候需要加 -o,不然导入的时候会报错
docker export 1e560fca3906 > ubuntu.tar
​
# 6. 导入容器
cat docker/ubuntu.tar | docker import - test/ubuntu:v1
​
# 7. 查询容器日志, -f 是持续输出
docker logs 容器名/ID -f
​
# 7. 进入容器
docker exec -it 容器名/ID /bin/bash

docker run各个参数解释,参考链接:www.runoob.com/docker/dock…

--name      容器名称
-p 3307:3306    前面宿主机,后面容器里
-link redis:redis   和其他容器交互
-e      设置容器的环境参数
-d          后台启动
-v          挂载宿主机目录/文件
-m      设置容器使用内存最大值     

5. docker 网络命令

参考官网链接:传送门

# ps
# docker network 是容器间双向通信的,--link 是单向通信 # 1. 查看网络列表
docker network ls
​
# 2. 创建一个自定义网络
docker network create my-network
​
# 3. 启动容器时指定网络并指定别名
docker run -itd --name mysql --network my-network --network-alias mysql -e MYSQL_ROOT_PASSWORD=root mysql:5.6# 4. 删除网络
docker network rm my-network
​
# 5. 删除所有未使用的网络
docker network prune
​
# 6. 为启动好的容器指定一个网络
docker network connect [OPTIONS] NETWORK CONTAINER
docker network connect --alias mysql my-network mysql
​
# 7. 为容器删除一个网络
docker network disconnect multi-host-network container1 
​
# 8. 检查网络的详细信息
docker network inspect [OPTIONS] NETWORK

具体实例:

1. mysql

docker pull mysql:5.6
​
docker run --name mysql -d -p 3306:3306 -e MYSQL_ROOT_PASSWORD=123456 -v D:\dockerFile\mysql:/var/lib/mysql mysql:5.6

2. mariadb

docker run -d -p 3307:3306 -e MYSQL_ROOT_PASSWORD=123456 --name mariadb mariadb:latest
docker run --name mariadb --privileged -d -e TIMEZONE=Asis/Shanghai -e MYSQL_ROOT_PASSWORD=123ABCdef*# -p 3307:3306 6d5c5ed114ad
​
启动 centos 
docker run -i -t -d --link mariadb:mariadb -p 8088:8088 -p 8888:8888 --privileged=true centos:centos7
# 连接容器
docker run -it -p 8080:8080 --link db001:dbhost -d tomcat
# db001是步骤3中创建的mysql容器的名字,可以通过其访问数据库;
# dbhost是个别名,web程序访问mysq数据可以通过其访问

3. redis

docker pull redis
docker run -p 6379:6379 --name redis 
-v D:\data\redis\redis.conf:/etc/redis/redis.conf 
-v D:\data\redis\data:/data 
-d redis:latest 
redis-server /etc/redis/redis.conf 
--appendonly yes --requirepass 123456

4. Kafka

# 1. 下载zookeeper镜像
docker pull wurstmeister/zookeeper
​
# 2. 启动zookeeper
docker run -d --name zookeeper -p 2181:2181 -t wurstmeister/zookeeper
​
# 3. 下载kafka镜像
docker pull wurstmeister/kafka
​
# 4. 启动kafka
docker run  -d --name kafka2 -p 9092:9092 --link zookeeper:zookeeper -e KAFKA_BROKER_ID=0  -e KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181 -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://127.0.0.1:9092  -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092  -t wurstmeister/kafka 
​
# 启动kafka参数解释
# -d                后台启动
# --name kafka          容器名称
# -p 9092:9092          绑定端口,前面宿主机,后面容器
# --link zookeeper:zookeeper    链接上一个容器,zookeeper
# -e KAFKA_BROKER_ID=0      设置broker Id
# -e KAFKA_ZOOKEEPER_CONNECT=zookeeper:2181         指定zookeeper 地址
# -e KAFKA_ADVERTISED_LISTENERS=PLAINTEXT://127.0.0.1:9092 将Broker的Listener信息发布到Zookeeper中
# -e KAFKA_LISTENERS=PLAINTEXT://0.0.0.0:9092       就是主要用来定义Kafka Broker的Listener的配置项
# -t wurstmeister/kafka