docker

Docker简介

镜像与容器的关系就像类与实例对象的关系一样

下载镜像
https://www.cnblogs.com/wang-yaz/p/10429899.html

Docker启动与停止命令

启动docker服务: systemctl start docker
停止docker服务: systemctl stop docker
重启docker服务: systemctl restart docker
查看docker服务状态: systemctl status docker
设置开机启动docker服务: systemctl enable docker

查看镜像,搜索镜像,拉取镜像, 删除镜像

# 查看镜像: docker images
#搜索镜像: docker  search  镜像名称
# 拉取镜像就是从Docker仓库下载镜像到本地,镜像名称格式为 名称:版本号,如果版本号不指定则是最新的版本 命令如下:
docker pull 镜像名称,# 如拉取centos 7; docker pull centos:7
# 可以按照镜像id删除镜像,命令如下: docker rmi 镜像id

容器相关命令

  1. 查看容器
查看正在运行的容器使用命令:docker ps
查看所有容器使用命令:docker ps -a

2.创建并启动容器

可以基于已有的镜像来创建和启动容器,创建与启动容器使用命令:docker run

参数说明:
-i:表示运行容器
-t:表示容器启动后会进入其命令行。加入这两个参数后,容器创建就能登录进去。即分配一个伪终端。
--name :为创建的容器命名。
-v:表示目录映射关系(前者是宿主机目录,后者是映射到宿主机上的目录),可以使用多个-v做多个目录或文件
映射。注意:最好做目录映射,在宿主机上做修改,然后共享到容器上。
-d:在run后面加上-d参数,则会创建一个守护式容器在后台运行(这样创建容器后不会自动登录容器,如果只加-i -t
两个参数,创建后就会自动进去容器)。
-p:表示端口映射,前者是宿主机端口,后者是容器内的映射端口。可以使用多个-p做多个端口映射

1)交互式容器
以交互式方式创建并启动容器,启动完成后,直接进入当前容器。使用exit命令退出容器。需要注意的是以此种方式
启动容器,如果退出容器,则容器会进入停止状态。

# 先拉取一个镜像;这一步不是每次启动容器都要做的,而是因为前面我们删除了镜像,无镜像可用所以才再拉取一个 docker pull centos:7 #创建并启动名称为 mycentos7 的交互式容器;下面指令中的镜像名称 centos:7 也可以使用镜像id docker run -it --name=mycentos7 centos:7 /bin/bash 12345

2)守护式容器
创建一个守护式容器;如果对于一个需要长期运行的容器来说,我们可以创建一个守护式容器。命令如下(容器名称
不能重复):

#创建并启动守护式容器 docker run -di --name=mycentos2 centos:7 
#如果容器停止了,启动并进入容器命令为:docker exec -it container_name (或者 container_id) /bin/bash(exit退出 时,容器不会停止) docker exec -it mycentos2 /bin/bash
  1. 停止并启动容器
# 停止正在运行的容器:docker stop 容器名称或者ID docker stop mycentos2 
# 启动已运行过的容器:docker start容器名称或者ID 
docker start mycentos2
重启容器
docker restart  容器名称或者ID

4.文件拷贝

# docker cp 需要拷贝的文件或目录 容器名称:容器目录
 # 创建一个文件abc.txt
 ouch abc.txt
  #复制abc.txt到mycentos2的容器的 / 目录下 
 docker cp abc.txt mycentos2:/ 
   # 进入mycentos2容器 
 docker exec -it mycentos2 /bin/bash
  # 查看容器 / 目录下文件
    ll

5.目录挂载

可以在创建容器的时候,将宿主机的目录与容器内的目录进行映射,这样我们就可以通过修改宿主机某个目录的文件
从而去影响容器。
创建容器时添加-v参数,后边为宿主机目录:容器目录,例如: docker run -di -v /usr/local/test:/usr/local/test –
name=mycentos3 centos:7

# 创建linux宿主机器要挂载的目录 mkdir /usr/local/test # 创建并启动容器mycentos3,并挂载linux中的/usr/local/test目录到容器的/usr/local/test;也就是在 linux中的/usr/local/test中操作相当于对容器相应目录操作 docker run -di -v /usr/local/test:/usr/local/test --name=mycentos3 centos:7 # 在linux下创建文件 touch /usr/local/test/def.txt # 进入容器 docker exec -it mycentos3 /bin/bash
# 在容器中查看目录中是否有对应文件def.txt ll /usr/local/test

注意:如果你共享的是多级的目录,可能会出现权限不足的提示。 这是因为CentOS7中的安全模块selinux把
权限禁掉了,需要添加参数 --privileged=true 来解决挂载的目录没有权限的问题。

查看容器ip

# 在linux宿主机下查看 mycentos3 的ip docker inspect mycentos3

删除容器

# 删除容器 docker rm mycentos7

Docker应用部署

1.MySQL部署
docker run -di --name=mysql5.7 -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root mysql
-p 代表端口映射,格式为 宿主机映射端口:容器运行端口
-e 代表添加环境变量 MYSQL_ROOT_PASSWORD 是root用户的远程登陆密码(如果是在容器中使用root登录的话,
那么其密码为空)

拉取镜像
docker pull  镜像名称
创建容器
docker run -di  --name=取个名字  -p 3306:3306 -e MYSQL_ROOT_PASSWORD=root  下载的mysql版本全称
操作容器MySQL
拉取 镜像
docker exec -it  取得镜像名  /bin/bash

//登录容器里面的mysql
mysql -u  root -p
mysql -uroot -p123456 -h127.0.0.1 -P 3306 -D mysql

//查看数据库
show databases;
//远程登录MySQL
# 查看ip;如果以后要内部连接该mysql,如其他容器中要连接mysql容器的mysql的时候,可以使用如下命令查看Ip docker inspect mysql5.7
用阿里云esc是需要开通端口的安全组权限

2.Tomcat部署

//拉取tomcat镜像
docker  pull  tomcat
//创建容器
# 创建tomcat容器;并挂载了webapps目录
docker  run  -di  -name=mytomcat  -p 9000:8080 -v
/usr/local/tomcat/webapps:/usr/local/tomcat/webapps tomcat
# 如果出现 WARNING: IPv4 forwarding is disabled. Networking will not work. #执行如下操作 # 1、编辑 sysctl.conf vi /etc/sysctl.conf # 2、在上述打开的文件中后面添加 net.ipv4.ip_forward=1 # 3、重启network systemctl restart network

3.Nginx部署

//拉取镜像
docker pull  nginx
//创建容器
docker run  -di --name=mynginx -p 80:80 nginx
启动后再宿主机上访问:http://宿主机IP/
  1. Redis部署
//拉取镜像
docker pull redis
//创建容器
docker  run -di --name=myredis -p 6379:6379 redis
//操作redis容器
//进入redis容器
cd /uer/local/bin
//连接redis
./redis-cli

rabbitmq安装
docker pull rabbitmq:3.7.7-management

docker run -d --hostname my-rabbit --name rabbit -e RABBITMQ_DEFAULT_USER=admin -e RABBITMQ_DEFAULT_PASS=pwd123 -p 15672:15672 -p 5672:5672 -p 25672:25672 -p 61613:61613 -p 1883:1883 rabbitmq:3.7.7-management

admin
pwd123 登录

fastdfs
进入配置
进入容器(id),cd etc/fdfs

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值