当前位置: 首页 > news >正文

Docker使用的常见问题

1. docker-compose文件中文乱码

在 Docker Compose 的 YAML 文件中,中文注释出现乱码通常是因为文件编码不是 UTF-8,导致 Docker 或编辑器无法正确解析中文字符。

推荐使用:VS Code:右下角点击编码(如 UTF-8 或 GBK),选择 另存为 UTF-8。

Notepad++:顶部菜单 编码 → 选择 UTF-8 无 BOM。

可以使用 docker-compose config 命令来检查读取是否正常。

2. Docker容器的名称,如何避免重复

在 Docker 里,容器名称(--name 或 container_name)必须是唯一的。如果尝试启动一个名为 nginx 的容器,而已经存在一个同名容器(哪怕是已退出的),就会报错。

避免方案:

1)一次性运行容器(临时)

不要手动指定名称,让 Docker 自动生成唯一名称。比如:nginx_quirky_leakey

2)长期运行的服务(如用 Docker Compose)

在 docker-compose.yml 中:不要写 container_name,让 Compose 自动生成唯一名称(基于项目名 + 服务名 + 序号)。

如果非要固定名称,可以加一个唯一前缀或动态后缀。

3)使用 Docker Compose 时避免项目名冲突

Docker Compose 默认用目录名作为项目名,可能导致多个项目容器名冲突。有的项目的docker compose文件放在工程下的docker目录中,这样导致前缀是docker-xxxx。而且很难辨识。这个时候最好在启动的时候手动指定项目名:

docker-compose -p mysite up -d
# 容器名会是:mysite_nginx_1

3. Docker容器之间的访问

在 Docker 容器中,使用 localhost 或 127.0.0.1 访问 类似 MySQL 容器是行不通的,因为每个容器都有自己的网络命名空间,localhost 指的是当前容器自身,而不是 MySQL 容器。

在 Docker 中连接另一个容器,要使用容器名或 Compose 服务名作为主机名,而不是 localhost。

推荐使用 Docker Compose,Docker Compose 会自动为服务创建一个网络,服务名就是主机名。

version: '3.8'
services:db:image: mysql:8environment:MYSQL_ROOT_PASSWORD: rootMYSQL_DATABASE: testdbports:- "3306:3306"app:build: .depends_on:- dbenvironment:DB_HOST: dbDB_USER: rootDB_PASS: rootDB_NAME: testdb

4. Docker compose文件的环境变量

1)env_file:  - .env.api  配置

不会复制文件到容器内,但会把变量注入容器环境,编译期拿不到,运行期可以。除非在 dockerfile 里显示处理。

services:api:image: my-api:latestenv_file:- .env.api
  • 不会把 .env.api 文件本身复制到镜像或容器文件系统里;
  • 会在启动容器时,把 .env.api 里定义的 KEY=value 逐条注入为容器的环境变量;
  • 这些变量对容器内运行的进程可见,就像 export KEY=value 一样。

对源码编译的影响

镜像构建阶段(docker build):如果 .env.api 不在 Dockerfile 里显式 COPY,编译时拿不到这些变量。构建阶段的环境变量需要通过 ARG 或 ENV 显式传入。

容器运行阶段(docker run/docker compose up):容器启动后,.env.api 中的变量会成为运行环境的一部分,应用进程可以通过 os.Getenv()、process.env 等方式读取。

2)根目录的 .env文件配置

.env 是 Docker Compose 的“默认环境变量文件”。只要它放在 docker-compose.yml 同目录,不需要任何额外声明,Docker Compose 会自动把它加载进来,里面的 KEY=value 可以在 compose 文件中用 ${KEY} 或 ${KEY:-默认值} 直接使用。

.env 里的变量只用于解析 compose 文件本身(如 ${VAR} 占位符),不会自动变成容器里的环境变量,除非在 environment: 里显式引用;或者在 env_file: 里再次把 .env 列进去。

3)根目录的 .env.api 文件配置

放在项目根目录时,Docker Compose 会自动加载它,把里面的变量注入到 所有服务的运行环境。

不需要在 docker-compose.yml 里写 env_file。适合放所有服务共用的变量。

还可以使用 .env.api.vars(自定义命名)

Docker Compose 不会自动加载,必须在 docker-compose.yml 里手动声明:

services:api:image: my-api:latestenv_file:- .env.api.vars

适合按服务拆分配置,例如:

# .env.api.vars
DB_HOST=db
DB_USER=api_user
DB_PASS=api_pass

两者可以共存:

  • .env.api 放通用变量(自动加载);
  • .env.api.vars 放某个服务专用变量(手动加载)。

http://www.dtcms.com/a/315551.html

相关文章:

  • 《BFC的深层逻辑与全域应用》
  • 目标检测、分割的数据增强策略
  • 前端安全攻防
  • CVE-2017-8291源码分析与漏洞复现(PIL远程命令执行漏洞)
  • Kafka-Eagle 安装
  • LeetCode——2411. 按位或最大的最小子数组长度
  • 工业级 CAN 与以太网桥梁:串口服务器CAN通讯转换器深度解析(上)
  • 【Git】git提交代码报错Git: husky > pre-commit
  • 【java】大数据insert的几种技术方案和优缺点
  • 机器学习——集成学习(Ensemble Learning)详解:原理、方法与实战应用
  • 机遇识别与商业变革:基于开源AI大模型、AI智能名片与S2B2C商城小程序的协同创新研究
  • 【Day 16】Linux-性能查看
  • SpringBoot3.x入门到精通系列:4.3 性能优化技巧
  • 飞算JavaAI需求转SpringBoot项目:从零到一的沉浸式开发之旅
  • Angular进阶之十三:Angular全新控制流:革命性的模板语法升级
  • Solidity智能合约基础
  • Python 函数详解
  • 精华贴分享|指数,衍生品,与交易时间之间的逻辑关系
  • Apache OFBiz Scrum 组件命令注入漏洞
  • MySQL 查询性能优化与索引失效问题全解析
  • 视频水印技术中的变换域嵌入方法对比分析
  • K8s Master状态NotReady
  • Linux内核参数调优:为K8s节点优化网络性能
  • Datart:开源数据可视化的新星,赋能企业数据分析
  • K8S的NetworkPolicy使用教程
  • ubuntu24中部署k8s 1.30.x-底层用docker
  • 本机部署K8S集群
  • 基于k8s环境下的pulsar常用命令(下)
  • 查看部署在K8S服务的资源使用情况
  • docker构建镜像并运行容器详细过程