Linux & Docker常用命令

目录

一、Docker服务相关命令

二、镜像相关命令

-查看镜像:查看本地所有的镜像

-搜索镜像:从网络中查找需要的镜像

-拉取镜像

-删除镜像

三、容器相关命令

-查看容器

-创建容器

-进入容器

-启动容器

-停止容器

-重启应用

-删除容器

-查看容器信息

四、docker 容器的数据卷

数据卷作用

配置数据卷

数据卷容器

数据卷小结

五、docker应用部署

1、mysql部署

补充:

一、docker宿主主机与容器互相传输文件方式

二、本地与远程的文件互相传输

三、linux下文件查找

四、查看进程和端口


一、Docker服务相关命令

-启动docker 服务

systemctl start docker

-停止docker服务

systemctl stop docker

-重启docker服务

systemctl restart docker

-查看docker服务状态

systemctl status docker

二、镜像相关命令

-查看镜像:查看本地所有的镜像

docker images  #查看本地所有的镜像

docker images -q  #查看所有镜像的id

-搜索镜像:从网络中查找需要的镜像

docker search 镜像名称

eg:docker search redis

-拉取镜像

从docker仓库下载镜像到本地,镜像名称格式为【名称:版本号】,如果版本号不指定则是最新的版本,如果不指定镜像版本,可以去docker hub搜索。

docker pull 镜像名称[:版本号]

-删除镜像

删除本地镜像

docker rmi 镜像id   #删除指定本地镜像

docker rmi `docker images -q`  #删除本地所有镜像

三、容器相关命令

-查看容器

docker ps     #查看正在运行的容器

docker ps -a   #查看所有的容器

-创建容器

docker run 参数

eg:  docker run -it --name=r1 redis:6.2

  1. -i:保持容器运行。通常与-t同时使用,加入it这两个参数后,容器创建后自动进入容器中,退出容器后,容器自动关闭。
  2. -t:为容器重新分配一个伪输入终端,通常与-i同时使用。
  3. -d:以守护(后台)模式运行容器。创建一个容器在后台运行,需要使用docker exec进入容器,退出后,容器不会关闭。
  4. -it创建的容器一般称为交互式容器,-id创建的容器一般称为守护式容器。
  5. --name:为创建的容器命名。

-进入容器

  1. docker exec -it 容器id /bin/bash
  2. docker exec -it 容器id /bin/sh

-启动容器

docker start 容器id

-停止容器

docker stop 容器id

-重启应用

docker-compose down && docker-compose up -d

-删除容器

docker rm 容器id   :删除已经停止的容器

docker rm -f 容器id  :强行删除容器

-查看容器信息

分别执行 hostname、ip addr、env 这三个命令可以获取相关信息

  1. 进入容器内部获取信息
    (2)执行docker exec命令
    (3)执行docker inspect命令(推荐)

第1种:进入容器内部获取信息

docker exec -it 容器id  /bin/bash

第2种:执行docker exec命令

docker exec 容器id  hostname

docker exec 容器id  ip addr

docker exec 容器id  env

第3种:使用docker inspect命令(推荐)

docker  inspect 容器名

四、docker 容器的数据卷

思考:

  1. Docker容器删除后,在容器中产生的数据还存在吗?
  2. Docker容器和外部机器可以直接交换文件吗?-不可以
  3. 容器之间想要进行数据交互?

数据卷******

  1. 数据卷是宿主机中的一个目录或文件
  2. 当容器目录和数据卷目录绑定后,对方的修改会立即同步
  3. 一个数据卷可以被多个容器同时挂载
  4. 一个容器也可以挂载多个数据卷

数据卷作用

  1. 容器数据持久化
  2. 外部机器和容器间接通信
  3. 容器之间数据交换

配置数据卷

创建启动容器时,使用-v参数设置数据卷

docker run ... -v 宿主机目录(文件): 容器内目录(文件)

eg:  docker run -it --name=mysql -v /root/data/jcx:/root/container 96d0eae5ed60 /bin/bash

示例:多个容器挂载同一个数据卷,实现不同容器之间的数据交换

容器1: docker run -it --name=A -v /root/jcx:/root/container/data1 mysql /bin/bash

容器2: docker run -it --name=B -v /root/jcx:/root/container/data2 mysql /bin/bash

说明:将容器A和容器B都挂载到数据卷/root/jcx下,实现A、B数据之间同步。

数据卷容器

多容器进行数据交换

  1. 多个容器挂载同一个数据卷
  2. 数据卷容器 (上图中的container c3)

数据卷小结

五、docker应用部署

1、mysql部署

目标:在docker容器中部署mysql,并通过外部mysql客户端操作mysql server.

实现步骤

  1. 搜索mysql镜像
  2. 拉取mysql镜像
  3. 创建容器
  4. 操作容器中的mysql

操作步骤:

在/root 目录下创建mysql目录用于存储mysql数据信息

mkdir /root/mysql

cd  /root/mysql

docker run -id \

-p 3307:3306 \

--name=c_mysql \

-v $PWD/conf:/etc/mysql/conf.d \

-v $PWD/logs:/logs \

-v $PWD/data:/var/lib/mysql \

-e MYSQL_ROOT_PASSWORD=123456 \

mysql

  1. 进入mysql容器

docker exec -it c_mysql /bin/bash

  1. 登陆mysql

mysql -uroot -p123456

Windows上用navicat连接docker上部署的mysql 服务

用宿主机的ip  + 宿主机上数据卷的端口

eg: 192.168.10.7:3307  用户名密码:root/123456

补充:

一、docker宿主主机与容器互相传输文件方式

1、从宿主机器copy文件到容器里

docker cp 要拷贝的文件路径 容器名:容器里的路径

docker cp /jcx/arthas-boot.jar 容器id:/jcx/

2、从容器copy文件到宿主机

docker cp 容器id:/容器里文件路径 宿主机路径

docker cp 容器id:/jcx/a.txt  /jcx/

说明:不管容器有没有启动,拷贝命令都会生效。

二、本地与远程的文件互相传输

scp命令:scp是secure copy的简写,用于在Linux下进行远程拷贝文件的命令,和它类似的命令有cp,不过cp只是在本机进行拷贝不能跨服务器,而且scp传输是加密的

1、从本地复制到远程

在本地服务器上将/root/lk目录下所有的文件传输到服务器43.224.34.73的/home/lk/cpfile目录下,命令为:

scp -r /root/lk root@43.224.34.73:/home/lk/cpfile

2、从远程复制到本地

在本地服务器上操作,将服务器43.224.34.73上/home/lk/目录下所有的文件全部复制到本地的/root目录下,命令为:

scp -r root@43.224.34.73:/home/lk /root

三、linux下文件查找

1、find  ***********

在指定目录下查找(常用)

【语法】find path -name filename

find / -name redis

find / -name redis* #模糊匹配

find / -mmin -20 #最近20分钟内修改的文件

find / -mtime -1 #最近一天内修改的文件

2、which

which 从环境变量文件(/etc/profile)中的path目录中查找,且witch找的都是可执行文件

which redis

3、locate

linux系统每天至少自动扫描一次文件,将结果保存到数据库,locate查的是数据库记录。locate查询比find要快,但最新文件如果在数据库中没有记录,是需要手动更新(updatedb)

locate redis

4、whereis

与which类似查询【可执行文件】,whereis查询更多,会查找出相关的man文件

whereis redis

四、查看进程和端口

1、linux查询端口

netstat -anp  #显示所有已开放端口

netstat -anp | grep 80  #查询指定端口通过grep过滤

netstat -tnlp  #显示tcp的端口和进程等相关情况

说明:

2、杀掉占用端口的进程

kill -9  pid

3、Linux查看某个服务是否启动

ps -ef | grep redis

  • 0
    点赞
  • 10
    收藏
    觉得还不错? 一键收藏
  • 2
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 2
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值