docker建多个mysql_《容器化系列二》利用Docker容器化技术安装多个mysql

前提说明

安装的Linux系统版本为Centos7.x

一、安装docker并测试

1、安装yum相关工具包

///安装yum相关工具包

yum install -y yum-utils device-mapper-persistent-data lvm2

3a3492684a6df6d0126a2a41921b1ead.png

//发些报错,关闭刚刚睡眠中的进程

kill -9 13312

//再次执行

yum install -y yum-utils device-mapper-persistent-data lvm2

1653c535391bb725c8591e4a12f37b54.png

2、添加docker的下载源

建议用下面的阿里源

//添加阿里的安装源

yum-config-manager --add-repo http://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo

915f629c7fc4744aef07aec471c620db.png

//进入yum的仓库配置目录进行查看

[root@Linux-docker1 ~]# cd /etc/yum.repos.d/[root@Linux-docker1 yum.repos.d]# ls

94ac03aed1592dafa086f936dbe3d56d.png

//元数据缓存的建立

yum makecache fast

dbfb22b7f1467fac5de0f739f908830b.png

3、安装docker

//注:安装的是docker社区版本

yum -y install docker-ce

2792286fb72fe6db3f4c1b46b8bc1085.png

//安装完我们验证一下

[root@Linux-docker1 yum.repos.d]# rpm -qa |grep docker

d7be40fd1279b7a951c7c0710680fcc1.png

4、更改镜像源为国内阿里云节点,并指定docker数据存储目录

mkdir -p /data/docker

mkdir-p /etc/docker

vim/etc/docker/daemon.json//注:docker安装好后默认没有此文件,需要手动创建,添加阿里云镜像节点,并指定docker存储目录//按i键进入编辑,按Esc键退出编辑模式,按:wq进行保存

{"registry-mirrors": ["https://ehdjgsyp.mirror.aliyuncs.com"],"graph": "/data/docker"}

5、启动docker,并加入开机启动

//启动docker

systemctl start docker//加入开机自启

systemctl enable docker

63c099cae5397a747d95619f424ec135.png

6、测试验证docker是否启动

//从仓库下载hello-world镜像

docker pull hello-world

4d9c6cc18963a47063c7527a8bd62e55.png

//查看本地镜像

[root@Linux-docker1 yum.repos.d]# docker images

8a1b0c4578b859eb24ba199d956e4632.png

//启动镜像

[root@Linux-docker1 yum.repos.d]# docker run hello-world

2a5ac5e48733fc9862444f3d11b2465d.png

二、下载镜像并启动mysql容器

1、下载mysql镜像

//下载mysql镜像

docker pull mysql

--如果下载失败,请多试几次,如果实在没速度,就需要去看上面添加的阿里镜像源是否有填写正确

2、启动mysql容器

//启动mysql容器

docker run --name docker-mysql -e MYSQL_ROOT_PASSWORD=123456 -p 3333:3306 -d mysql

##参数说明

-name容器的别称。

-p端口映射。格式是主机的端口:容器的端口。

-e设置容器的环境变量。-e MYSQL_ROOT_PASSWORD= 123456就代表mysq的root的密码是123456

-d使用镜像包名称,可以通过docker images查看

3、验证查看容器状态

--查看容器状态

docker ps -a

d200c476722ac53b6bd817856c5960b8.png

4、直接进mysql的容器中的bash

//docker exec -it 容器名 /bin/bash

docker exec-it docker-mysql /bin/bash

//进去以后

mysql -uroot -p

//密码是刚刚设置的123456

5、用本地的Navicate进行连接

①确认环境

首先安装docker的那台Linux宿主机的ip为 192.168.59.132

对应的mysql端口为3333

msyql账号root

mysql密码123456

bcaa8ebf7c51d02c947b3049bc369ed2.png

②发现报错

8d3085c0df8f62b2d5d850d617e6bc21.png

2059-Authentication plugin 'caching.sha2_password' cannot be loaded:..@..gv頗

③解决问题

需要利用上面第4步在docker的mysql容器中执行这条sql语句

alter user 'root'@'%' identified with mysql_native_password by '123456';

上面123456需要改成你自己mysql设置的密码

9a9f836d7b12249450ce57c23f6e5fa6.png

测试连接成功

cbcf74e6358ea74bf6375ebe6e7fdd55.png

到此,我们的一个数据库安装成功

三、安装第2个mysql数据库

1、启动mysql容器,更改端口和容器名称即可

//启动mysql容器,更改端口3333改成3334,防止端口冲突,还需要更改容器名称把之前的docker-mysql随便改成不同的即可,这里改成了docker-mysql-2

docker run --name docker-mysql-2 -e MYSQL_ROOT_PASSWORD=123456 -p 3334:3306 -d mysql

这样新的mysql容器又起来了

2、用Navicate进行连接

首先安装docker的那台Linux宿主机的ip为 192.168.59.132

对应的mysql端口为3334(上面那个是3333)

msyql账号root

mysql密码123456

后续步骤应该不用多说了吧

ffbe4a26430e750d7fc8055af03b5cbd.png

3bbbb4154d7a6a7193161d61ed08c3fc.png

3、以此类推可以安装其他的mysql,只需要映射的端口号和容器名不同即可

四、其他说明

1、doker关闭容器

//docker stop +容器名或者+容器的id

docker stop $CONTAINER_ID

2、容器的id在哪找

//直接docker ps -a 一下

docker ps -a

3、手动关闭后的容器怎么启动

//直接start一下即可+容器名或者+容器id

docker start docker-mysql

4、怎样关闭docker的服务

//直接用系统服务进行关闭,关闭以后,里面的容器也会相应关闭!所以请先关停里面的容器,再关闭docker服务!

systemctl stop docker

5、启动docker的服务

//直接利用系统服务去启动

systemctl start docker

2020.07.23

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.mzph.cn/news/508309.shtml

如若内容造成侵权/违法违规/事实不符,请联系多彩编程网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

mysql 元数据获取_[MySQL] 获取元数据的步骤

[MySQL] 获取元数据的方法 MySQL提供了以下三种方法用于获取数据库对象的元数据: 1)show语句 2)从INFORMATION_SCHEMA数据库里查询相关表 3)命令行程序,如mysqlshow, mysqldump 用SHOW语句获取元数据 MySQL用show语句获取元数据是最常用的方法&#xff0…

ai如何置入_ai图片(ai怎么把图片嵌入到图形里)

怎样将Ai格式的图片转换成常用的jpg,用什么软件转换?ai后缀的图片是指通过Illustrator(简称ai )软件储存得到的图片格式 这种格式的图片是矢量的,也就是说像freehand,Coredraw那样子的图片可以随意放大但不失真的那种 .在AI中,插入…

在模糊查询中怎样事先加载页面_8种信息类型,中后台产品功能自查清单

产品经理在梳理产品需求文档时需要把每一个功能的逻辑关系、交互方式都整理全面,为了避免疏漏,与开发评审前,建议每位产品都 Check 几遍文档。本文整理了一份中后台产品功能自查清单,供大家参考,如有不全欢迎提建议~中…

mysql 8.0 手动安装教程_mysql 8.0.13手动安装教程

本文为大家分享了mysql 8.0.13手动安装教程,供大家参考,具体内容如下一、步骤解读1.下载MySQL下载地址选择 Downloads-->Community-->MySQL Community Server,然后拉到页面的最低端,点击“下载”。此时一般会提示登陆&#…

gff3转mysql_科学网-把GFF3文件导入MySQL数据库-闫双勇的博文

什么是GFF3?这个一种序列注释文件的格式,基因组注释数据常常会用这种格式来记录序列注释信息,关于这种格式的更多信息,可以在这里学习:http://www.sequenceontology.org/gff3.shtml这里简单说下,怎样把GFF3文件导入My…

mysql时间字段不走索引_MySQL使用=或=范围查询时不走索引

2020-02-27最近一个日志页面查询很慢,然后去跟踪了查询sql,发现日期字段上即使建了索引,查询还是很慢,执行语句还是使用了全表扫描,于是继续分析下去。查询语句类似:select * from logs where createtime > 2020-01…

php mysql关键技术_中高级PHP开发者应该掌握哪些技术?

1.Linux能够流畅的使用Shell脚本来完成很多自动化的工作;awk/sed/perl 也操作的不错,能够完成很多文本处理和数据统计等工作;基本能够安装大 部分非特殊的Linux程序(包括各种库、包、第三方依赖等等,比如MongoDB/Redis/Sphinx/Lun…

python 简单socket_Python 简单socket

OSI七层模型(Open System Interconnection,开放式系统互联)应用层表示层回话层传输层 tcp,udp网络层 ip,icmp数据链路层 mac地址物理层 物理网卡服务端:import socket#实例化,绑定,监听,等待,解构(标识,ip-…

wxpython有哪些基本功能_用Python中的wxPython实现最基本的浏览器功能

通常,大多数应用程序通过保持 HTML 简单来解决大多数浏览器问题 ― 或者说,根据最低共同特性来编写。然而,即便如此,也仍然存在字体和布局的问题,发行新浏览器和升级现有浏览器时,也免不了测试应用程序的痛…

python增删改查mysql_python对数据库mysql的操作(增删改查)

#codingutf-8import pymysql# #查询# def connMySQL():# try:# connpymysql.connect(‘localhost‘,‘root‘,‘admin‘)# conn.select_db(‘five‘)# except Exception as e:# return e.args# else:# curconn.cursor()# cur.execute("select * from users")# datacu…

指数函数中x的取值范围_指数函数x的取值范围是

1、指数函数x的取值范围是a>0且a不1;2、指数函数是重要的基本初等函数之一。一般地,yax函数(a为常数且以a>0,a≠1)叫做指数函数,函数的定义域是 R ;3、,在指数函数的定义表达式中,在ax前的…

java创建response对象_创建一个HttpResponse对象

创建一个HttpResponse对象HttpResponse类实现了javax.servlet.http.HttpServletResponse。跟随它的是一个叫做 HttpResponseFacade的faade类。Figure 3.3显示了HttpResponse类和它的相关类的UML图。在第2章中,你使用的是一个部分实现的HttpResponse类。例如&#xf…

java编译机制_java的编译机制

我们通常写的文件都是java文件,最后要在JVM上运行则需要将java文件编译成class(二进制文件).各厂商在实现JDK时通常会符合java语言规范的源码编译为class文件的编译器.编译器的好坏很大程度上决定了最后程序在机器上执行效率.通常使用Sun JDK(javac).javac将java源码编译成clas…

java excutorthread_JAVA 线程池ThreadPoolExcutor原理探究

概论线程池(英语:thread pool):一种线程使用模式。线程过多会带来调度开销,进而影响缓存局部性和整体性能。而线程池维护着多个线程,等待着监督管理者分配可并发执行的任务。这避免了在处理短时间任务时创建与销毁线程的代价。线程…

java 继承作用_java三大特性之继承

继承(extends):让类与类之间产生关系,子父类的关系继承的好处与弊端:好处:提高代码的复用性提高了代码的维护性让类与类之间产生关系,是多态的前提弊端:类的耦合性增加开发的原则是:1、高内聚&a…

java gui 单选_java GUI编程(swing)之三swing单选框复选框组件

swing复选框(JCheckBox) 单选框(JRadioButton)特别说明:同一组单选按钮,必须先创建一个ButtonGroup,然后把单选按钮放到ButtonGroup中package gui;import javax.swing.JButton;import javax.swing.JFrame;import javax.swing.JPanel;import j…

websocket连接mysql_websocket 使用 spring 的service层 ,进而调用里面的 dao层 来操作数据库 ,包括redis、mysql等通用...

1.前言描述一下今天用websocket踩得坑 ---》空指针异常!我想在websocket里面使用service 层的接口,从中获取数据库的一些信息 ,使用 Autowired 注解 接口 ,报错 空指针异常 !!!查过资料才发…

世上最简单的mysql_最简单易懂的mysql安装教程

今天安装MySQL花了蛮长时间的,感觉坑还是挺多的,写遍文章总结一下。一、安装1.解压zip包到安装目录先从MySQL官网 下载mysql最新的免安装版压缩包解压之后变成这个样子:里面的文件是这个样子下面开始了,请注意2.配置文件在安装目录…

java if hasvalue_首选:可为空 .HasValue或Nullable !=空吗?

我一直使用Nullable<>.HasValue因为我喜欢这种语义。 但是&#xff0c;最近我正在开发其他人的现有代码库&#xff0c;其中他们专门使用Nullable<> ! null 。是否有理由优先使用一个&#xff0c;还是纯粹是偏爱&#xff1f;int? a; if (a.HasValue) // ...与int?…

Java 源程序的良好书写规范有哪些_使用Java作为程序语言时,好的命名规范有哪些...

变量名普通变量命名应该采用首字母小写&#xff0c;其他字母首字母大写的方式。final static变量的名字应该都大写&#xff0c;并且指出完整含义。如果一个常量名称由多个单词组成&#xff0c;则应该用下划线来分割这些单词如。NUM_DAYS_IN_WEEK MAX_VALU如果需要对变量名进行缩…