===============================================

2018/7/1_第1次修改                       ccb_warlock

===============================================

mysql作为常用的关系型数据库和项目的关系非常紧密。由于经常需要搭建临时的mysql服务,而临时搭建时大多只是为了临时查点数据,而正常yum或apt-get的方式安装需要下载大量的时间,且还需要从虚拟机快照的角度进行回滚清理环境。故最近尝试了使用docker快速部署,感觉对于非压力负载环境通过docker方式非常轻便,且清理干净。

由于技术能力和公司业务所限,没有尝试过容器mysql的负载能力,按照一些反馈的说法自己搭建mysql容器的性能远远不如云服务器厂商提供的mysql服务(这里我的理解是个人仅仅是搭了mysql容器但是没有做各方面的优化,性能远远无法满足生产环境的要求),所以容器部署mysql仅仅只是研发内部使用,没有足够的能力做优化还是不要急着上生产环境。

mysql默认是关闭远程访问,最近没时间试验部署直接开机远程访问,目前的教程还需要连到mysql容器内部去进行配置,后期有空我会将缺失的内容补上。


 一、前提条件


 二、部署mysql容器(5.6)

 2.1 创建映射目录 

mkdir -p /usr/docker-vol/mysql/data

 2.2 配置mysql-stack.yml

# 编辑mysql-stack.yml

vi /root/mysql-stack.yml

# 添加下面的内容到mysq-stack.yml中,wq保存

version: '3.6'
services: mysql:
image: mysql:5.6.40
environment:
# 设置时区为Asia/Shanghai
- TZ=Asia/Shanghai
- MYSQL_ROOT_PASSWORD=123456
volumes:
- /usr/docker-vol/mysql/data:/var/lib/mysql
deploy:
replicas: 1
restart_policy:
condition: any
resources:
limits:
cpus: "0.2"
memory: 512M
update_config:
parallelism: 1 # 每次更新1个副本
delay: 5s # 每次更新间隔
monitor: 10s # 单次更新多长时间后没有结束则判定更新失败
max_failure_ratio: 0.1 # 更新时能容忍的最大失败率
order: start-first # 更新顺序为新任务启动优先
ports:
- 3306:3306
networks:
- myswarm-net networks:
myswarm-net:
external: true

 2.3 部署服务栈

1)命令方式

cd
docker stack deploy -c mysql-stack.yml mysql-stack

2)portainer界面方式(推荐)

登录portainer(如果是根据上面的教程部署的portainer,浏览器访问http://宿主机IP:9000,在stack中增加mysql-stack.yml文件中的内容)


 三、配置mysql允许远程IP访问

官方提供的镜像和安装在linux的配置一样,初始只允许本地服务访问mysql,需要调整mysql的配置之后才能达到远程连接的目的。(正如前面讲的,目前的方案并不是很合理,将来需要优化这个方式)

# 获取容器id

docker ps

找到mysql-stack_mysql.*******************的CONTAINER ID(我这里的是0d66abc8ce32)

# 进入容器

docker exec -it 0d66abc8ce32 /bin/bash

# 登录mysql

mysql -uroot -p

输入初始化的root密码123456登录。

# 进入mysql库

mysql> use mysql;

# 设置允许root用户用于通过任意IP访问mysql

mysql> grant all privileges  on *.* to root@'%' identified by "";

# 使配置立即生效

mysql> flush privileges;

# 退出mysql

mysql> exit

# 退出容器

exit

接着用navicat连接192.168.12.11:3306,用户名/密码:root/123456,提示连接成功,说明mysql容器已经可以使用了。

docker stack 部署 mysql 5.6的更多相关文章

  1. 在Centos上安装docker,部署mysql数据库

    何为docker? Docker 可以让开发者打包他们的应用以及依赖包到一个轻量级.可移植的容器中,然后发布到任何流行的 Linux 机器上,也可以实现虚拟化. 本机环境 24小时不关机的Centos ...

  2. 利用Docker快速部署Mysql

    写在前面 我又来更新了~~~,今天内容较少,主要是利用Docker快速部署Mysql和初始化数据 利用Docker下载Mysql 简洁明了,在命令提示符中输入 docker pull mysql:8. ...

  3. docker stack 部署 mssql

    =============================================== 2019/12/8_第1次修改                       ccb_warlock == ...

  4. docker stack 部署容器监控方案(cAdvisor、Prometheus、Grafana)

    =============================================== 2018/7/8_第1次修改                       ccb_warlock === ...

  5. docker stack 部署 filebeat

    =============================================== 2018/7/21_第3次修改                       ccb_warlock 更新 ...

  6. docker stack 部署 redis

    =============================================== 2019/4/16_第2次修改                       ccb_warlock 更新 ...

  7. docker stack 部署 seafile(http)

    =============================================== 2018/5/13_第1次修改                       ccb_warlock == ...

  8. docker stack 部署 rabbitmq 容器

    =============================================== 2018/5/13_第1次修改                       ccb_warlock == ...

  9. docker环境部署mysql

    参考文档 docker官方:https://hub.docker.com/_/mysql/?tab=description 部署步骤 1. 拉取镜像 这里我拉取了tag为5.7的镜像 docker p ...

随机推荐

  1. [洛谷P3829][SHOI2012]信用卡凸包

    题目大意:有$n$张一模一样的信用卡,每个角进行了圆滑处理,问这些卡组成的“凸包”的周长 题解:发现是圆滑处理的圆心围成的凸包加上一个圆周即可 卡点:输入长宽弄反,然后以为是卡精 C++ Code: ...

  2. java10 新特性 详解

    引言: 点击-->java9 新特性 详解 点击-->java8 新特性 详解 正题: 1.局部变量var 将前端思想var关键字引入java后段,自动检测所属于类型,一种情况除外,不能为 ...

  3. 洛谷 P3171 [CQOI2015]网络吞吐量 解题报告

    P3171 [CQOI2015]网络吞吐量 题目描述 路由是指通过计算机网络把信息从源地址传输到目的地址的活动,也是计算机网络设计中的重点和难点.网络中实现路由转发的硬件设备称为路由器.为了使数据包最 ...

  4. Android 图片加载框架 Glide 的用法

    https://github.com/bumptech/glide Android图片加载框架最全解析(一),Glide的基本用法http://blog.csdn.net/guolin_blog/ar ...

  5. Android Studio自动生成UML关系类图

    android studio 根据源码自动生成UML的插件介绍http://www.jianshu.com/p/cbccd831cf01 simpleumlhttps://plugins.jetbra ...

  6. 使用JS在textarea在光标处插入内容

    // 在光标处插入字符串 // myField 文本框对象 // myValue 要插入的值 function insertAtCursor(myField, myValue) { //IE supp ...

  7. Chapter11(关联容器)--C++Prime笔记

    1.关联容器: map关键字-值对,经常被称为关联数组 set中每个元素只有一个关键字,即只保存关键字的容器 ①允许重复的关键字的容器名字都包含multi. ②不保持关键字顺序存储的容器的名字都以但粗 ...

  8. Nginx Configuration 免费HTTPS加密证书

    Linux就该这么学 2018-05-11 实验环境:CentOS Linux release 7.3.1611 (Core) 内核版本:Linux version 3.10.0-514.el7.x8 ...

  9. P1792 [国家集训队]种树

    P1792 [国家集训队]种树 题目描述 A城市有一个巨大的圆形广场,为了绿化环境和净化空气,市政府决定沿圆形广场外圈种一圈树. 园林部门得到指令后,初步规划出n个种树的位置,顺时针编号1到n.并且每 ...

  10. python---django中权限框架设计

    一:admin下的权限了解 推文:如何正确使用 Django的User Model (一)默认权限表是在自带auth模块,中permission表中 可以使用has_perm方法获取用户是否有这个权限 ...