Docker日常使用方式
前提
在安装docker之前,建议你设置系统的国内镜像源先哦,很快~嗯,快。
阿里云镜像源:https://developer.aliyun.com/mirror/
安装
安装docker
下面都是官网地址:
ubuntu: https://docs.docker.com/engine/install/ubuntu/
centos:https://docs.docker.com/engine/install/centos/
其他版本就是url后面的几个英文不同。
开机启动
sudo systemctl enable docker.service
设置国内镜像
docker中国区的镜像:https://registry.docker-cn.com
网易:http://hub-mirror.c.163.com
中国科技大学:https://docker.mirrors.ustc.edu.cn
阿里云:https://cr.console.aliyun.com/ 点击左侧栏有个镜像加速地址,就可以看到你的加速镜像地址
sudo mkdir -p /etc/docker
sudo tee /etc/docker/daemon.json <<-'EOF'
{
"registry-mirrors": ["加速镜像地址"]
}
EOF
sudo systemctl daemon-reload
sudo systemctl restart docker
安装docker-compose(用到才装)
官网地址:https://docs.docker.com/compose/install/
设置.docker文件权限
docker安装好后,会在当前用户的家目录下生成.docker
文件,该文件不出意外的话是属于root用户和root组,毕竟要sudo下载,使用ll
命令查看一下。
drwx------ 2 root root 4096 Jun 5 11:26 .docker/
假设我的用户和组都为vagrant
,那么命令如下:
sudo chown -R vagrant:vagrant 当前用户的家目录/.docker
上面的vagrant:vagrant
对应的是用户名:用户组
,一般情况下现在使用docker指令则不需要在前面加sudo
了(去你丫的sudo)
安装步骤已完成
镜像?容器?
什么是镜像?什么是容器呐?可以这么类比:镜像就是一个模板;容器则是根据模板的实现。在代码中,你也可以想成接口(镜像)与实现类(容器)。
docker镜像中心
地址:https://hub.docker.com/,在这里你可以找到你所需要的镜像,你可以搜mysql、redis、nginx等等,可以查到有什么版本、怎么运行、有什么配置,有什么环境变量可以设置(比如在mysql你需要设置他的root密码)等等信息。
指令集
以mysql为例
下载镜像
使用docker pull
命令
docker pull mysql:8.0.20
查看所有镜像,可以看到你刚下载的mysql镜像
docker images
创建并运行容器
创建并运行你的mysql容器,我使用一条比较长的命令来讲解:
sudo docker run --name mysql_1 -p 3306:3306 --restart=always -v /var/mapping/mysql/conf.d:/etc/mysql/conf.d -v /var/mapping/mysql_1/lib:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=root -d mysql:8.0.20 --default-authentication-plugin=mysql_native_password --character-set-server=utf8mb4
指令格式 docker run [OPTIONS] IMAGE [COMMAND]
docker run:会创建并运行容器
-p:映射端口 3306:3306 就是把容器的3306端口映射到宿主机的3306端口, 格式(宿主机端口:容器端口)
-v:映射数据卷,即映射文件,格式(宿主机数据卷:容器数据卷)
-e:设置环境变量,如设置root的初始密码 MYSQL_ROOT_PASSWORD,可以在docker的镜像中心查看有哪些环境变量
-d:指定镜像
--default-authentication-plugin=mysql_native_password
和--character-set-server=utf8mb4
属于command参数,需要设置在镜像后面。
--default-authentication-plugin=mysql_native_password
指的是修改认证的加密方式,mysql8.0后的加密方式改了,导致navicat那些数据库管理工具连不上。所以这里修改加密方式为mysql_native_password
--character-set-server=utf8mb4
则是设置数据库的编码方式为utf8mb4。
当然还有很多的command指定都可以在docker hub镜像中心查看。
自动运行
当docker启动的时候,容器也自动启动,有两种方式
1.创建容器时指定 --restart=always
docker run --restart=always -d mysql:8.0.20
2.容器已经创建好了,使用docker update
修改容器,CONTAINER
可以是容器id,也可以是容器名,docker ps
可以命令查看
docker update --restart=always [CONTAINER]
常用指令
首先说明一下:CONTAINER
可以是容器ID,也可以是容器名,IMAGE
可以是镜像ID,也可以是 镜像名:tag
查看所有镜像
docker images
查看所有容器,包括没启动的(加 -a 选项)
docker ps -a
启动容器,停止容器
docker start [CONTAINER]
docker start CONTAINER1 CONTAINER2 # 启动多个容器
docker stop [CONTAINER]
docker stop CONTAINER1 CONTAINER2 # 停止多个容器
进入容器
docker exec -it [CONTAINER] bash
在宿主机执行容器内的命令,mysqldump是mysql_1容器内的指令
docker exec -it mysql_1 mysqldump ...
删除容器
docker rm [CONTAINER]
docker rm CONTAINER1 CONTAINER2 # 删除多个容器
删除镜像
docker rmi [IMAGE]
docker rmi IMAGE1 IMAGE2 # 删除多个镜像
docker镜像仓库
当你在公司修改了某个容器之后,想在家也使用这个容器。那么可以把容器打包成镜像,提交到docker仓库当中。
我是在aliyun上创建了docker镜像仓库:https://cr.console.aliyun.com/
首先把你的容器打包成镜像,这个是把我的mysql_1
容器打包成镜像my_mysql_1
,tag
为latet
。
docker commit mysql_1 my_mysql_1:latest
打包完后执行指令docker images
,查看镜像是否存在。
提交到镜像仓库
1.首先需要创建命名空间
2.创建你的镜像仓库
3.登录并提交到仓库
点击所需提交到镜像仓库的管理按钮,可以查看到以下界面
跟着这里面的步骤执行就可以提交到docker镜像仓库了。就介么简单。
总结
以上便是docker比较常用的操作。ok,拜拜你了~。
个人博客网址: https://colablog.cn/
如果我的文章帮助到您,可以关注我的微信公众号,第一时间分享文章给您