使用 Docker 搭建 mysql 数据库

准备

  • 更新 yum 源
    yum update
  • 关闭 SELinux
    sed -i 's/SELINUX=enforcing/SELINUX=disabled/g' /etc/selinux/config
    setenforce 0
  • 关闭防火墙
    systemctl stop firewalld.service
    systemctl disable firewalld.service
  • 安装运维监控系统 Open-Falcon
    yum install git telnet net-tools tree nmap sysstat lrzsz dos2unix tcpdump ntpdate vim -y

配置 Docker

  • 安装 Docker
    yum -y install https://mirrors.aliyun.com/docker-ce/linux/centos/7/x86_64/stable/Packages/docker-ce-18.03.1.ce-1.el7.centos.x86_64.rpm
  • 设置开机自动启动 Docker
    systemctl enable docker
  • 启动 Docker
    systemctl start docker
  • 查看 Docker 状态
    docker ps
  • 安装 docker-compose (容器编排的工具)
    curl -o /usr/local/bin/docker-compose https://dataline-hz-test.oss-cn-hangzhou.aliyuncs.com/docker-compose
  • 添加 docker-compose 执行权限
    chmod +x /usr/local/bin/docker-compose

更新 Docker 业务镜像及容器

  • 在 /opt/mysql/ 文件夹下创建 docker-compose.yml 配置文件
    cd /opt/
    mkdir mysql
    cd mysql/
    vim docker-compose.yml
version: '2'
services:
  mysql_compose:
    image: mysql:5.7
    container_name: mysql-5.7
    ports:
      - 26597:3306
    restart: unless-stopped
    volumes:
      - ./data:/usr/local/mysql
      - ./conf/mysql.cnf:/etc/mysql/mysql.conf.d/mysqld.cnf
      - /etc/localtime:/etc/localtime
    environment:
      MYSQL_ROOT_PASSWORD: "123456"
  • 在 /opt/mysql/conf/ 文件夹下创建 mysql.cnf 文件
    cd /opt/mysql/
    mkdir conf
    cd conf/
    vim mysql.cnf
[mysql]
default-character-set = utf8mb4
prompt = "\U [\d]> "
no-auto-rehash
socket = /tmp/mysql.sock
max_allowed_packet = 32M
[mysqld]
port = 3306
user = mysql
server-id = 100
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
socket = /tmp/mysql.sock
character_set_server = utf8mb4
collation-server = utf8mb4_unicode_ci
default_storage_engine = InnoDB
autocommit = 1
explicit_defaults_for_timestamp = 0
log_timestamps = system
max_allowed_packet = 32M
lower_case_table_names = 0
#sql_mode="STRICT_TRANS_TABLES,ERROR_FOR_DIVISION_BY_ZERO,NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"
sql-mode="NO_AUTO_CREATE_USER,NO_ENGINE_SUBSTITUTION"
open_files_limit = 65000
##connection##
back_log = 600
interactive_timeout = 28800
wait_timeout = 28800
lock_wait_timeout = 1800
skip_name_resolve = 1
max_connections = 1024
max_user_connections = 256
max_connect_errors = 1000000
##table cache performance settings##
table_open_cache = 4096
table_definition_cache = 4096
table_open_cache_instances = 64
##session memory settings##
read_buffer_size = 4M
read_rnd_buffer_size = 8M
sort_buffer_size = 16M
tmp_table_size = 16M
join_buffer_size = 32M
thread_cache_size = 64
##log settings##
log_error = error.log
log_error_verbosity = 2
sync_binlog = 1
log_bin = mysql-bin
binlog_format = ROW
binlog_rows_query_log_events = 1
max_binlog_size = 512M
expire_logs_days = 3
slow_query_log = 1
long_query_time = 1
slow_query_log_file = slow.log
log_queries_not_using_indexes = 1
log_slow_admin_statements = 1
log_slow_slave_statements = 1
# innodb settings #
transaction_isolation = REPEATABLE-READ
innodb_page_size = 16384
innodb_buffer_pool_size = 4G
innodb_buffer_pool_instances = 8
innodb_buffer_pool_load_at_startup = 1
innodb_buffer_pool_dump_at_shutdown = 1
innodb_lru_scan_depth = 4096
innodb_lock_wait_timeout = 15
innodb_io_capacity = 2000
innodb_io_capacity_max = 4000
innodb_max_dirty_pages_pct = 80
innodb_flush_method = O_DIRECT
#innodb_undo_logs = 128
#innodb_undo_tablespaces = 3
#innodb_undo_log_truncate = 1
#innodb_max_undo_log_size = 2G
innodb_flush_neighbors = 0
innodb_log_file_size = 256M
innodb_log_files_in_group = 2
innodb_log_buffer_size = 16M
lower_case_table_names=1
innodb_purge_threads = 2
innodb_large_prefix = 1
innodb_print_all_deadlocks = 1
innodb_strict_mode = 1
innodb_sort_buffer_size = 16M
innodb_write_io_threads = 4
innodb_read_io_threads = 4
innodb_file_per_table = 1
innodb_stats_persistent = 1
innodb_stats_persistent_sample_pages = 32
innodb_autoinc_lock_mode = 2
innodb_online_alter_log_max_size = 1G
innodb_open_files = 4096
innodb_flush_log_at_trx_commit = 2
innodb_buffer_pool_dump_pct = 40
innodb_page_cleaners = 16
innodb_purge_rseg_truncate_frequency = 128
# perforamnce_schema settings
performance-schema-instrument='memory/%=COUNTED'
performance_schema_digests_size = 40000
performance_schema_max_table_instances = 40000
performance_schema_max_sql_text_length = 4096
performance_schema_max_digest_length = 4096
[mysqldump]
single-transaction
socket = /tmp/mysql.sock
max_allowed_packet = 512M
default-character-set = utf8mb4

  • 启动并运行所有的容器
    docker-compose up -d

在安全组放开 26597 端口

修改密码

  • 查看容器列表
    docker container ls
  • 进入容器内部
    docker exec -it [CONTAINER ID] bash
  • 连接 mysql 数据库
    mysql -u root -p
  • 切换数据库
    use mysql
  • 修改密码
    update user set authentication_string=PASSWORD("123456") where User='root';
  • 重新启动容器
    docker-compose up -d

Docker 常用命令

  • 启动 systemctl start docker
  • 重启 systemctl restart docker
  • 关闭 systemctl stop docker
  • 查看容器列表 docker container ls
  • 重新启动容器 docker-compose up
  • 启动并运行所有的容器 docker-compose up -d
    注: 默认情况下, docker-compose up 启动的容器都在前台, 控制台将会同时打印所有容器的输出信息, 可以很方便进行调试. 当通过 Ctrl+C 停止命令时, 所有容器将会停止. 如果希望在后台启动并运行所有的容器, 使用 docker-compose up -d
最后编辑于
©著作权归作者所有,转载或内容合作请联系作者
  • 序言:七十年代末,一起剥皮案震惊了整个滨河市,随后出现的几起案子,更是在滨河造成了极大的恐慌,老刑警刘岩,带你破解...
    沈念sama阅读 158,736评论 4 362
  • 序言:滨河连续发生了三起死亡事件,死亡现场离奇诡异,居然都是意外死亡,警方通过查阅死者的电脑和手机,发现死者居然都...
    沈念sama阅读 67,167评论 1 291
  • 文/潘晓璐 我一进店门,熙熙楼的掌柜王于贵愁眉苦脸地迎上来,“玉大人,你说我怎么就摊上这事。” “怎么了?”我有些...
    开封第一讲书人阅读 108,442评论 0 243
  • 文/不坏的土叔 我叫张陵,是天一观的道长。 经常有香客问我,道长,这世上最难降的妖魔是什么? 我笑而不...
    开封第一讲书人阅读 43,902评论 0 204
  • 正文 为了忘掉前任,我火速办了婚礼,结果婚礼上,老公的妹妹穿的比我还像新娘。我一直安慰自己,他们只是感情好,可当我...
    茶点故事阅读 52,302评论 3 287
  • 文/花漫 我一把揭开白布。 她就那样静静地躺着,像睡着了一般。 火红的嫁衣衬着肌肤如雪。 梳的纹丝不乱的头发上,一...
    开封第一讲书人阅读 40,573评论 1 216
  • 那天,我揣着相机与录音,去河边找鬼。 笑死,一个胖子当着我的面吹牛,可吹牛的内容都是我干的。 我是一名探鬼主播,决...
    沈念sama阅读 31,847评论 2 312
  • 文/苍兰香墨 我猛地睁开眼,长吁一口气:“原来是场噩梦啊……” “哼!你这毒妇竟也来了?” 一声冷哼从身侧响起,我...
    开封第一讲书人阅读 30,562评论 0 197
  • 序言:老挝万荣一对情侣失踪,失踪者是张志新(化名)和其女友刘颖,没想到半个月后,有当地人在树林里发现了一具尸体,经...
    沈念sama阅读 34,260评论 1 241
  • 正文 独居荒郊野岭守林人离奇死亡,尸身上长有42处带血的脓包…… 初始之章·张勋 以下内容为张勋视角 年9月15日...
    茶点故事阅读 30,531评论 2 245
  • 正文 我和宋清朗相恋三年,在试婚纱的时候发现自己被绿了。 大学时的朋友给我发了我未婚夫和他白月光在一起吃饭的照片。...
    茶点故事阅读 32,021评论 1 258
  • 序言:一个原本活蹦乱跳的男人离奇死亡,死状恐怖,灵堂内的尸体忽然破棺而出,到底是诈尸还是另有隐情,我是刑警宁泽,带...
    沈念sama阅读 28,367评论 2 253
  • 正文 年R本政府宣布,位于F岛的核电站,受9级特大地震影响,放射性物质发生泄漏。R本人自食恶果不足惜,却给世界环境...
    茶点故事阅读 33,016评论 3 235
  • 文/蒙蒙 一、第九天 我趴在偏房一处隐蔽的房顶上张望。 院中可真热闹,春花似锦、人声如沸。这庄子的主人今日做“春日...
    开封第一讲书人阅读 26,068评论 0 8
  • 文/苍兰香墨 我抬头看了看天上的太阳。三九已至,却和暖如春,着一层夹袄步出监牢的瞬间,已是汗流浃背。 一阵脚步声响...
    开封第一讲书人阅读 26,827评论 0 194
  • 我被黑心中介骗来泰国打工, 没想到刚下飞机就差点儿被人妖公主榨干…… 1. 我叫王不留,地道东北人。 一个月前我还...
    沈念sama阅读 35,610评论 2 274
  • 正文 我出身青楼,却偏偏与公主长得像,于是被迫代替她去往敌国和亲。 传闻我的和亲对象是个残疾皇子,可洞房花烛夜当晚...
    茶点故事阅读 35,514评论 2 269

推荐阅读更多精彩内容