docker-conpose 入门

本文介绍了如何使用Docker Compose在Linux环境下安装,并通过编写Dockerfile和docker-compose.yml文件来编排Java应用和Nginx服务。通过Nginx代理,实现了对外提供服务,详细步骤包括Dockerfile配置、docker-compose.yml文件设置以及容器的启动和日志查看。

docker-compose 安装

官方地址github

Linux 下安装

sudo curl -L "https://github.com/docker/compose/releases/download/1.24.1/docker-compose-$(uname -s)-$(uname -m)" -o /usr/local/bin/docker-compose

要安装其他版本的 Compose,请替换 1.29.1

将可执行权限应用给docker-compose

sudo chmod +x /usr/local/bin/docker-compose

创建软连接,在/usr/bin 下,这样可以直接访问到命令

sudo ln -s /usr/local/bin/docker-compose /usr/bin/docker-compose

查看版本,确定是否成功安装配置。

image

docker-compose 简介

Compose 是用于定义和运行多容器 Docker 应用程序的工具。通过 Compose,您可以使用 YML 文件来配置应用程序需要的所有服务。然后,使用一个命令,就可以从 YML 文件配置中创建并启动所有服务。

也就是可以编排容器。

docker-compose 编排容器

首先我们准备了一个java程序,简单的helloworld

将其放在目录下,该目录还有docker-compose.yml 的配置文件,以及将jar包打包成镜像的Dockerfile,还有我们即将用到的nginx配置,这个配置是从另外一个nginx容器中导出的

# 将运行中的ng容器中的/etc/nginx/ 文件夹 拷贝至当前文件夹下的nginx/conf
docker cp ng:/etc/nginx/ ./nginx/conf 

image

我们先配置Dockerfile,比较简单

FROM java:8
VOLUME /tmp

WORKDIR /project/demo

ADD ./demo-0.0.1-SNAPSHOT.jar ./app.jar

ENTRYPOINT ["java","-jar" ,"./app.jar"]

接着配置docker-compose.yml

version: '3'
# 服务---需要构建的容器
services:
  docker-demo:
  # 表示使用当前目录下的Dockerfile 进行构建镜像
    build: ./
    # 映射端口
    ports:
      - "9090:8080"
  nginx:
  # 使用nginx镜像
    image: nginx
    # 挂载 将我们当前目录的 ./nginx/conf/nginx 挂载到 容器中的 /etc/nginx
    volumes:
      - ./nginx/conf/nginx:/etc/nginx
     # 链接  这样 在容器中就可以使用app进行于docker-demo这个容器通信 相当于ip映射
    links:
      - "docker-demo:app"
      # 映射端口
    ports:
      - "80:80"

然后我们使用下面命令构建镜像并启动容器

# 构建镜像并启动容器   -d 后台启动
docker-compose up -d

# 查看日志
docker-compse logs 

nginx.conf

location /hello {
		# 需要使用app的内部端口
        proxy_pass http://app:8080;
    }

image

image

image

nginx 代理成功

image

image

### 正确配置并启动 MongoDB 服务 为了通过 `docker-compose` 文件正确配置并启动 MongoDB 服务,可以按照以下方法操作: #### 1. 创建目录结构 首先需要创建一个用于存储配置文件和数据的目录。例如,在 `/web/mongo/` 下建立如下目录结构[^2]: ``` /web/ ├─ mongo/ │ ├─ conf/ │ │ └─ mongod.conf # 配置文件 (可选) │ ├─ db/ # 数据存储目录 │ └─ docker-compose.yaml # Docker Compose 配置文件 ``` #### 2. 编写 `docker-compose.yaml` 文件 以下是适用于 MongoDB 的 `docker-compose.yaml` 文件内容示例[^3]: ```yaml version: '3' services: mongodb: image: mongo:7.0.12 # 使用官方 MongoDB 镜像版本 7.0.12 container_name: mongodb restart: always # 容器崩溃自动重启 environment: MONGO_INITDB_ROOT_USERNAME: root # 设置管理员用户名 MONGO_INITDB_ROOT_PASSWORD: example # 设置管理员密码 ports: - "27017:27017" # 映射主机端口到容器内部端口 volumes: - ./db:/data/db # 将本地的数据目录挂载至容器内的 /data/db 路径 networks: - mongo-network networks: mongo-network: driver: bridge # 使用桥接网络模式 ``` > **注意**: 如果计划使用副本集 (`replSet`) 功能,则需移除环境变量中的用户信息部分,因为初始化副本集时会引发冲突。 #### 3. 启动 MongoDB 服务 完成上述配置后,可以通过以下命令启动 MongoDB 服务[^4]: ```bash docker-compose -f /path/to/docker-compose.yaml up -d ``` 此命令将以分离模式运行容器,并在后台启动 MongoDB 实例。 #### 4. 停止或卸载 MongoDB 服务 当不再需要该服务时,可通过以下命令停止或删除容器及其关联资源: ```bash # 停止服务 docker-compose -f /path/to/docker-compose.yaml down # 清理残留数据(谨慎执行) rm -rf /path/to/db/* ``` --- ###
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值