docker小试牛刀之mysql

mysql作为经典的开源数据库,docker安装mysql过程还是遇到了几个坑,今天想来总结下,分享给需要的朋友。

docker安装mysql(注:系统需预装docker-ce)

  1. linux系统下安装docker-ce 官方链接
  2. docker安装mysql
  3. 阿里云ECS iptables配置
  4. mysql字符集配置

1.docker安装mysql

  1. 一开始试了官方的mysql安装命令,结果试了好多次还是无法连接,于是只能找更详细的配置命令进行安装
  2. 废话少说,上最终的安装命令
$ docker run -p 3306:3306 --name mysql-01 -v $PWD/conf:/etc/mysql/conf.d -v $PWD/logs:/logs -v $PWD/data:/var/lib/mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7.24

2.阿里云ECS iptables配置

  1. mysql默认为3306端口,但是阿里云没有暴露相应的端口,因此在公网环境下navicat等mysql客户端工具并不能正常访问。当然对于其他的可直接访问的一些服务器,此配置应当可忽略
  2. 登录阿里云,配置ecs的安全组策略,点击实例列表对应的更多->网络与安全->安全组->配置规则,规则选入方向,端口范围为3306/3306,授权对象为0.0.0.0/0(暴露给所有机器,不太安全)或本机公网ip,其他配置项可选默认值
  3. 远程22端口登录ecs,进行相应配置
//查看防火墙状态
$ systemctl status firewalld
//关闭防火墙
$ systemctl stop firewalld
//配置iptables,让防火墙应用更广
$ systemctil disable firewalld
$ yum install -y iptables-services
//启动iptables
$ systemctl start iptables
//更改iptables规则
$ cp -a /etc/sysconfig/iptables /etc/sysconfig/iptables.bak
//设置 INPUT 方向所有的请求都拒绝
$ iptables -P INPUT DROP
//放开3306端口
$ iptables -I INPUT -p tcp --dport 3306 -m state --state NEW -j ACCEPT
//保存配置
$ iptables-save > /etc/sysconfig/iptables
//设置开机启动
$ systemctl enable iptables.service
  1. 阿里云控制台将ECS重启
  2. docker重启及mysql容器重启
$ systemctl restart docker 
$ docker container ls
$ docker container restart mysql-01
  1. mysql客户端连接测试…

3.mysql字符集等配置

  1. 使用mysql的时候遇到一些奇怪的字符问题,写入的中文数据全变成了?号,开发测试起来也是满满的坑,必须把它解决掉,百度了一番,总算搞定了
  2. 由于1.1已经进行了docker volumn 的配置,因此只需要在宿主机进行自定义的mysql配置即可,不用再进入容器内部单独配置,再次远程登录ecs
//进入conf目录
$ cd conf
//创建自定义的mysql配置文件
$ touch my.cnf
$ vim my.cnf
  1. my.cnf配置
[mysql.server]
default-character-set-=utf8
[mysqld_safe]
default-character-set-=utf8
[client]
default-character-set-=utf8
[mysql]
default-character-set-=utf8
[mysqld]
character-set-server-=utf8
  1. 保存my.cnf后重启mysql实例,进行连接测试
//进入conf目录
$ docker container restart mysql-01
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值