docker常用的命令

#1、修改源命令
vim /etc/docker/daemon.json
#2、 添加源。否则会报错:===》ERROR: Get https://registry-1.docker.io/v2/: net/http: TLS handshake timeout in Docker
{
"registry-mirrors": [
"https://registry.docker-cn.com",
"https://kfwkfulq.mirror.aliyuncs.com",
"https://2lqq34jg.mirror.aliyuncs.com",
"https://pee6w651.mirror.aliyuncs.com",
"http://hub-mirror.c.163.com"
],
"dns": ["8.8.8.8","114.114.114.114"]
}
#3、重启docker服务
systemctl restart docker

# 镜像和容器:一堆文件---》镜像运行就是容器---》当成一个操作系统【用过windows.iso重装过系统】
# docker search         ===》搜索镜像
# docker pull 镜像名字   ===》获取镜像
# docker images         ===》查看镜像
# docker rm             ===》删除/多个镜像

# 查找镜像网址:https://hub.docker.com/
docker search helloworld
docker search centos
NAME     DESCRIPTION                    STARS          OFFICIAL         AUTOMATED
centos  The official build of CentOS.   5956            [OK]            是否是自动构建

# 获取镜像:
docker pull centos     # 拉取最新的:相当于docker pull centos:latest  
docker pull centos:centos7  # 拉取一个centos7
docker pull centos:centos6.7
docker pull centos:centos10 # 这个 没有,就报错
  
# 查看本地镜像
docker images
REPOSITORY          TAG                 IMAGE ID            CREATED             SIZE
centos              latest              470671670cac        3 months ago        237MB
centos              centos7             5e35e350aded        5 months ago        203MB

# 删除本地镜像
docker rmi 470671670cac  # 通过id号删除
docker rmi centos:centos7 # 通过名字删除
  
# 删除所有镜像
# docker rmi `docker images -q`
相当于删除后面加一堆id号
docker rmi  470671670cac 5e35e350aded 
Docker容器操作
docker ps   # 查看正在运行的容器《=============
docker ps –a  # 查看所有容器(暂停的,停止,正在运行的。。。)《=============
docker ps –l # 查看最后一次运行的容器《=============
docker ps -f status=exited  # 查看停止的容器《=============
=======================================================================================================================
# 重点:通过镜像创建并运行容器(两步并做一步)《=============
创建容器命令:docker run
-i:表示运行容器
-t:表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端。
--name :为创建的容器命名。容器名字不能重
-v:表示目录映射关系(前者是宿主机目录,后者是容器的目录),可以使用多个-v做多个目录或文件映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上。
-d:在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t两个参数,创建后就会自动进去容器)。
-p:表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射

# -v:数据卷,做目录映射
# -p 网络,做端口映射

# 演示
#基于哪个镜像跑容器:centos:centos7   如果写成centos表示跑最新的 
#如果没有这个镜像呢?去远程拉,拉下来再跑
# 容器要运行,需要有一个前台进程
docker run -it --name=mycentos7 centos:centos7 /bin/bash
  
 # 以守护进程形式跑
docker run -di  --name=mycentos2_2 centos:centos7
  
# 进入到容器内部操作容器
1 exec(用的最多):在docker中执行命令
docker exec -it mycentos2_2 /bin/bash
exit 退出

docker exec mycentos2_2 ls

2 attach (当没有)
3 ssh连接(容器要启动ssh服务22端口没有服务在监听)


# 容器的启动与停止
docker stop 容器id/名字
docker start 容器id/名字
docker restart 容器id/名字

# 文件拷贝
# 从宿主机copy到容器内部
docker cp untitled3.tar mycentos2_2:/home
 # 从容器内部copy出来 
docker cp mycentos2_2:/home/untitled3.tar ./

   
# 数据卷(目录映射)
docker run -di  --name=mycentos2_3 -v /root/test:/home centos:centos7
# 以后操作宿主机目录和操作容器目录会相互影响

# 查看容器信息
docker inspect 容器名字/容器id
# 查看ip地址
docker inspect --format='{{.NetworkSettings.IPAddress}}' 容器id/名字

# 删除容器
# 停止才能删
docker rm 容器名字/id

# 删除镜像,如果有容器,能删除吗?支持,但是不推荐做


自动化运维脚本:人输命令,shell脚本,python:subprocess执行命令
自动化运维平台:web框架,就是在网页上点点点的操作,就可以完成一些事(宝塔:python2.7+flask做的)
正在运行的容器,启动


# 总结:
docker run  -di/-it --name=名字  -v 目录映射,可以有多个  images:tag
docker exec -it 名字 /bin/bash
docker cp
docker stop/start/restart 容器名字
docker rm 容器名字
docker inspect 容器名字
2 Docker应用部署
# mysql服务 在docker中运行 -e表示环境变量,root密码
docker run -id --name=mysql1 -p 33306:3306 -e MYSQL_ROOT_PASSWORD=123456 mysql:5.7
# redis服务 在docker中运行
docker run -id --name=myredis -p 6379:6379 redis
 
# docker中部署django项目 nginx + django +uwsgi
3 迁移备份
# 把容器打包成镜像
docker run -di --name=mydjango python:3.6
  
# 安装django环境
pip install django==1.11.9
apt-get update
apt-get install vim 

# 把容器打包成镜像
docker commit 容器名字 镜像名字
docker commit mydjango mydjango_i

# 基于镜像再跑起容器
docker run -di --name=mydjango2 mydjango_i

# 把本地的镜像拷贝到其他机器上去,在跑起容器来
# 打成一个tar包,压缩一下(在当前目有个mydjango.tar)
docker  save -o mydjango.tar mydjango_i

# copy这个压缩包到任意的机器上(装了docker)
根据压缩包,恢复成镜像
docker load -i mydjango.tar

你可能感兴趣的:(Docker)