linux
通过dig @114.114.114.114 registry-1.docker.io
找到可用IP地址
docker
镜像运行在容器内部,通过docker compose可以更好地管理镜像的启动以及结束
#列出compose当前的所有容器
docker-compose ps
#以下命令使用 ubuntu 镜像启动一个容器,参数为以命令行模式进入该容器
#/bin/bash:放在镜像名后的是命令,这里我们希望有个交互式 Shell,因此用的是 /bin/bash
#在大部分的场景下,我们希望 docker 的服务是在后台运行的,我们可以过 -d 指定容器的运行模式
docker run -itd ubuntu /bin/bash
#删除容器
docker rm -f ad40b1d70c2f
#与容器交互
docker exec -it 243c32535da7 /bin/bash
docker-compose
Compose 是用于定义和运行多容器 Docker 应用程序的工具。通过 Compose,可以使用 YML 文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从 YML 文件配置中创建并启动所有服务。
- 使用 Dockerfile 定义应用程序的环境。(非必须)
- 使用 docker-compose.yml 定义构成应用程序的服务,这样它们可以在隔离环境中一起运行
- 最后,执行 docker-compose up 命令来启动并运行整个应用程序
docker-compose.yaml
volumes:
/opt/data:/var/lib/mysql
[SOURCE:]TARGET[:MODE]格式
type:挂载类型,可以为volume、bind、tmpfs或npipe。
source:挂载源,在主机上用于绑定挂载的路径或定义在顶层volumes配置项中的数据卷名称。不适用于tmpfs挂载类型。
target:数据卷挂载在容器中的路径。
Illegal mix of collations (utf8mb4_unicode_ci,IMPLICIT) and (utf8mb4_general_ci)
原因:两张表的编码方式不同,在DataGrip中无法直接使用ui进行修改,需要使用以下sql语句
ALTER TABLE issue_scan CHARACTER SET utf8mb4 COLLATE utf8mb4_unicode_ci;
不过以上解决方法在我这里并没有用,所以采用以下方法:
在join时,添加COLLATE
属性,比如a表关联b表,a表的排序规则为utf8mb4_unicode_ci,b表排序规则为utf8mb4_general_ci,直接使用a.xxx_id = b.xxx_id
就会报类似这种错误,我们将两张表的排序规则进行统一。
a.xxx_id = b.xxx_id COLLATE utf8mb4_unicode_ci