使用Docker方式一键部署MySQL和Redis数据库详解

一、前言

数据库是现代应用开发中不可或缺的一部分,MySQL和Redis作为两种广泛使用的数据库系统,分别用于关系型数据库和键值存储。本文旨在通过Docker和Docker Compose的方式,提供一个简洁明了的一键部署方案,确保数据库服务的稳定运行与持久化存储。

二、Docker及Docker Compose安装

2.1 Docker安装

Docker安装过程略有不同,根据您的操作系统选择适合的安装方式。以下以Ubuntu为例,简要说明安装步骤:

  1. 更新包管理器

    sudo apt-get update
    
  2. 安装Docker

    sudo apt-get install -y docker.io
    
  3. 启动Docker服务并设置开机自启

    sudo systemctl start docker
    sudo systemctl enable docker
    
  4. 验证Docker安装

    sudo docker --version
    

2.2 Docker Compose安装

Docker Compose的安装相对简单,同样以Ubuntu为例:

  1. 下载Docker Compose

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

    请根据https://github.com/docker/compose/releases页面上的最新版本调整上述命令中的版本号。

  2. 赋予执行权限

    sudo chmod +x /usr/local/bin/docker-compose
    
  3. 验证Docker Compose安装

    docker-compose --version
    

三、编写Docker Compose文件

接下来,我们将编写一个docker-compose.yml文件来定义MySQL和Redis的服务,以及它们之间的网络配置和持久化存储设置。

version: "3"

# 声明一个名为 'network' 的网络,配置子网和默认网关
networks:
  network:
    ipam:
      driver: default
      config:
        - subnet: '177.7.0.0/16'

# 定义MySQL和Redis的持久化存储卷
volumes:
  mysql:
  redis:

# 定义服务
services:
  mysql:
    image: mysql:8.0.21
    container_name: gva-mysql
    command: mysqld --character-set-server=utf8mb4 --collation-server=utf8mb4_unicode_ci
    restart: always
    ports:
      - "13306:3306"
    environment:
      MYSQL_ROOT_PASSWORD: 'Aa@6447985' # 设置root用户密码
      MYSQL_DATABASE: 'qmPlus'
      MYSQL_USER: 'gva'
      MYSQL_PASSWORD: 'Aa@6447985'
    healthcheck:
      test: ["CMD", "mysqladmin", "ping", "-h", "localhost", "-u", "gva", "-pAa@6447985"]
      interval: 10s
      timeout: 5s
      retries: 3
    volumes:
      - mysql:/var/lib/mysql # 将MySQL的data目录挂载到volume上,实现数据持久化
      - ./init.sql:/docker-entrypoint-initdb.d/init.sql # 初始化脚本
    networks:
      network:
        ipv4_address: 177.7.0.13 # 指定MySQL容器的IP地址

  redis:
    image: redis:6.0.6
    container_name: gva-redis
    restart: always
    ports:
      - '16379:6379'
    healthcheck:
      test: ["CMD-SHELL", "redis-cli ping | grep PONG || exit 1"]
      interval: 10s
      timeout: 5s
      retries: 3
    volumes:
      - redis:/data # 将Redis的数据目录挂载到volume上,实现数据持久化
    networks:
      network:
        ipv4_address: 177.7.0.14 # 指定Redis容器的IP地址

3.1 配置解释

  • networks: 定义了一个名为network的自定义网络,其中设置了子网范围为177.7.0.0/16。这样可以为MySQL和Redis容器分配固定的IP地址,便于管理和维护。

  • volumes: 为MySQL和Redis分别定义了存储卷mysqlredis,用于保存数据库文件,防止数据丢失。

  • services: 这里定义了两个服务,分别是MySQL和Redis。

    • MySQL:

      • 使用指定版本的MySQL镜像。
      • 通过command字段设置了MySQL的启动参数,包括字符集和排序规则。
      • environment字段设置了MySQL的环境变量,包括初始化数据库、用户名、密码等。
      • healthcheck字段定义了健康检查机制,帮助监控MySQL服务的正常运行状态。
      • volumes字段将MySQL的data目录与volume关联起来,同时挂载了初始化脚本。
      • networks字段将MySQL容器加入到自定义网络,并指定了其IP地址。
    • Redis:

      • 使用指定版本的Redis镜像。
      • healthcheck字段定义了健康检查机制,帮助监控Redis服务的正常运行状态。
      • volumes字段将Redis的数据目录与volume关联起来。
      • networks字段将Redis容器加入到自定义网络,并指定了其IP地址。
  • init.sql: 这是一个初始化脚本,用于在MySQL启动时自动创建数据库qmPlus和用户gva,并授予相应的权限。具体内容如下:

    CREATE DATABASE IF NOT EXISTS qmPlus;
    CREATE USER IF NOT EXISTS 'gva'@'177.7.0.1' IDENTIFIED BY 'Aa@6447985';
    GRANT ALL PRIVILEGES ON qmPlus.* TO 'gva'@'177.7.0.1';
    FLUSH PRIVILEGES;
    

注意:这里创建的用户gva配置允许从177.7.0.1进行连接,这个是容器网络的网关地址。为什么要配置为它?是为了让容器外的宿主机能够通过13306端口连接。

四、启动服务

在编写好docker-compose.yml文件后,即可通过Docker Compose命令来启动服务。

  1. 创建并启动容器

    sudo docker-compose -f deploy/docker-compose/docker-compose.yaml up -d
    
    • -d表示以后台模式(detached)运行容器。
  2. 检查容器状态

    docker-compose ps
    #进入某个容器
    sudo docker exec -it gva-mysql bash
    #查看容器挂载的卷
     sudo docker volume ls
     #进入容器的卷
     sudo docker run -it --rm -v docker-compose_server:/volume-data --name temp-container busybox
     #查看端口占用情况
     sudo netstat -tulpn | grep :13306
    

    该命令将列出所有由docker-compose.yml文件定义的服务及其状态。

五、停止服务

若需要停止并移除所有由docker-compose.yml文件定义的容器,可以使用以下命令:

docker-compose down
  • 该命令会停止并移除所有服务对应的容器,同时保留volume中的数据,从而达到持久化存储的目的。

六、总结

通过本文,您已经了解了如何利用Docker Compose实现MySQL和Redis的一键部署,包括Docker和Docker Compose的安装、docker-compose.yml文件的编写以及服务的启动与停止。

这种方法不仅简化了数据库服务的配置和管理,还确保了数据的安全性。希望对您有所帮助!

使用Python实现UDP通信,可以使用socket模块提供的函数。以下是使用Python实现UDP通信的一般步骤: 1. 导入socket模块:`from socket import *` 2. 创建UDP套接字:`udp_socket = socket(AF_INET, SOCK_DGRAM)` 3. 设置服务器地址监听端口:`server_host_port = ('服务器IP地址', 端口号)` 4. 准备要发送的数据:`data = '要发送的数据'.encode('utf-8')` 5. 发送数据:`udp_socket.sendto(data, server_host_port)` 6. 接收服务器返回的数据:`response, server_address = udp_socket.recvfrom(1024)` 7. 关闭套接字:`udp_socket.close()` 需要注意的是,UDP是面向无连接的协议,通信时不需要建立连接。它适用于多点通信实时的数据业务,如语音广播、视频、文件传输大型网络游戏。由于UDP是不可靠的协议,发送的数据报并不一定按相同的顺序到达接收方。同时,UDP传输数据时有大小限制,每个数据报的大小必须限定在64KB以内。 以上是用Python实现UDP通信的一般步骤一些注意事项。根据实际需求,你可以根据这些步骤来编写你的UDP通信程序。<span class="em">1</span><span class="em">2</span><span class="em">3</span> #### 引用[.reference_title] - *1* *2* *3* [python网络编程—UDP协议](https://blog.youkuaiyun.com/YZL40514131/article/details/120808489)[target="_blank" data-report-click={"spm":"1018.2226.3001.9630","extra":{"utm_source":"vip_chatgpt_common_search_pc_result","utm_medium":"distribute.pc_search_result.none-task-cask-2~all~insert_cask~default-1-null.142^v93^chatsearchT3_1"}}] [.reference_item style="max-width: 100%"] [ .reference_list ]
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

特立独行的猫a

您的鼓励是我的创作动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值