日日操夜夜添-日日操影院-日日草夜夜操-日日干干-精品一区二区三区波多野结衣-精品一区二区三区高清免费不卡

公告:魔扣目錄網為廣大站長提供免費收錄網站服務,提交前請做好本站友鏈:【 網站目錄:http://www.ylptlb.cn 】, 免友鏈快審服務(50元/站),

點擊這里在線咨詢客服
新站提交
  • 網站:51998
  • 待審:31
  • 小程序:12
  • 文章:1030137
  • 會員:747

目錄
  • 前言
  • 1. 編寫 docker-compose.yml 文件
  • 2. 定義測試數據
  • 3. 定義啟動文件
  • 4. 啟停 mysql

前言

在日常開發中,數據庫 mysql 是必不可少的,但是由于其繁瑣的配置,安裝 mysql 時總是不太順利,還可能會踩坑。所以本文的目的,可以讓你快速搭建一個 mysql 服務。

下面跟著以下教程,可以讓你快速、流暢的安裝 mysql 數據庫,流程可分成 4 步。

如何使用?docker?搭建一個?mysql?服務

1. 編寫 docker-compose.yml 文件

創建 docker-compose.yml 文件,文件內容如下:

version: '3.1'

services:
    mysql:
        image: mysql:8
        restart: always
        # https://stackoverflow.com/a/49021165/7756877,使用默認的授權插件,
        # mysql 8 默認使用 caching_sha2_password 作為授權插件,并非 mysql_native_password,
        # 然而 mysql 驅動還不支持 caching_sha2_password,為了往后兼容所以要加這一行。
        command: --default-authentication-plugin=mysql_native_password
        ports:
            - "7306:3306"
        volumes:
            - "./table.sql:/docker-entrypoint-initdb.d/01-init-table.sql"
        environment:
            MYSQL_ROOT_PASSWORD: mysql # root 用戶的密碼
            MYSQL_DATABASE: lingmo   # 默認創建 lingmo 數據庫
            MYSQL_USER: kele         # 新建一個用戶
            MYSQL_PASSWORD: baishi2020 # 新建用戶的密碼

Compose 是用于定義和運行多容器 Docker 應用程序的工具。通過 Compose,您可以使用 YML 文件來配置應用程序需要的所有服務。然后,使用一個命令,就可以從 YML 文件配置中創建并啟動所有服務。

docker-compose 的 services 屬性中定義的一個 mysql

  • image 表明鏡像版本是 mysql:8
  • command 通過參數 --default-authentication-plugin 定義了一個默認插件 mysql_native_password, 原因是: mysql 8 默認使用 caching_sha2_password 作為授權插件,并非 mysql_native_password,然而 mysql 驅動還不支持 caching_sha2_password,為了往后兼容所以要加這一行。
  • port 表明使用本地的 7306 端口映射容器中 mysql 的 3306 端口。
  • volumes 表明將 ./table.sql 文件掛載到容器的 docker-entrypoint-initdb.d/01-init-table.sql 文件中,而存在容器中 docker-entrypoint-initdb.d/ 目錄中的文件,在 mysql 第一次啟動時會執行,之后重啟容器不會重復執行。
  • environment
    • MYSQL_ROOT_PASSWORD: 創建 mysql 服務時會新建一個 root 用戶,這個屬性定義的是 root 用戶密碼。
    • MYSQL_DATABASE: 默認創建一個 lingmo 的數據庫。
    • MYSQL_USER: 再次創建一個用戶,用戶名是 kele。
    • MYSQL_PASSWORD: 表明 kele 用戶的密碼,這里是 baishi2020

2. 定義測試數據

新建測試數據表 table.sql ,目的是在 mysql 啟動時初始化數據。

DROP TABLE IF EXISTS `students`;
CREATE TABLE `students` (
    `student_id` varchar(255) NOT NULL,
    `student_name` varchar(255),
    `sex` tinyint(1) DEFAULT NULL,
    PRIMARY KEY (`student_id`)
) ENGINE=InnoDB AUTO_INCREMENT=100 DEFAULT CHARSET=utf8mb4;

INSERT INTO `students`(`student_id`, `student_name`, `sex`) VALUES(1, 'jake', 0), (2, 'jenery', 1);

以上表示新建一張 students 表,然后插入兩條數據。

3. 定義啟動文件

新建啟動文件 set-env.sh, 通過 docker-compose 啟動 mysql 容器服務;然后通過 souce set-env.sh 把 mysql-local-dev 設置到環境變量中去。

#!/bin/bash

MYSQL_LOCAL_ENV_DIR="$( cd "$(dirname "$0")"; pwd -P )"

function mysql-local-dev() {
    case $1 in
        "up")
            docker-compose -p lingmo -f "$MYSQL_LOCAL_ENV_DIR"/docker-compose.yml up -d
            ;;
        "down")
            docker-compose -p lingmo -f "$MYSQL_LOCAL_ENV_DIR"/docker-compose.yml down
            ;;
        *)
            echo 'mysql-local-dev [up | down]'
    esac
}

啟動 mysql 的三個文件已定義完成,目錄結構為以下:

?  local-mysql git:(main) ? tree . 
.
├── docker-compose.yml
├── set-env.sh
└── table.sql

0 directories, 3 files

最后,我們測試下是否可啟動 mysql。

4. 啟停 mysql

  • 啟動 mysql
mysql-local-dev up

說明 mysql 啟動成功。

如何使用?docker?搭建一個?mysql?服務

 通過相應的賬號、密碼登錄 mysql 即可。

  • 停止 mysql
mysql-local-dev down 

分享到:
標簽:Docker 如何使用 搭建 服務 服務器
用戶無頭像

網友整理

注冊時間:

網站:5 個   小程序:0 個  文章:12 篇

  • 51998

    網站

  • 12

    小程序

  • 1030137

    文章

  • 747

    會員

趕快注冊賬號,推廣您的網站吧!
最新入駐小程序

數獨大挑戰2018-06-03

數獨一種數學游戲,玩家需要根據9

答題星2018-06-03

您可以通過答題星輕松地創建試卷

全階人生考試2018-06-03

各種考試題,題庫,初中,高中,大學四六

運動步數有氧達人2018-06-03

記錄運動步數,積累氧氣值。還可偷

每日養生app2018-06-03

每日養生,天天健康

體育訓練成績評定2018-06-03

通用課目體育訓練成績評定