Linux上docker安装mysql

博客介绍了使用Docker拉取MySQL官方镜像(以5.7版本为例),检查拉取是否成功,配置容器运行参数,如容器名、登陆密码、端口映射等,还提及是否建立目录映射的操作。之后说明了检查容器运行情况、设置自启动,以及进入本地连接客户端、远程连接注意事项和无法访问的可能原因。
  1. 拉取官方镜像(我们这里选择5.7,如果不写后面的版本号则会自动拉取最新版)

    docker pull mysql:5.7   # 拉取 mysql 5.7
    docker pull mysql       # 拉取最新版mysql镜像
    

     

  2. 检查是否拉取成功

    $ sudo docker images
    
  3. 一般来说数据库容器不需要建立目录映射

    sudo docker run -p 3306:3306 --name mysql -e MYSQL_ROOT_PASSWORD=123456 -d mysql:5.7
    
    • –name:容器名,此处命名为mysql
    • -e:配置信息,此处配置mysql的root用户的登陆密码
    • -p:端口映射,此处映射 主机3306端口 到 容器的3306端口
    • -d:后台运行容器,保证在退出终端后容器继续运行
  4. 如果要建立目录映射

    duso docker run -p 3306:3306 --name mysql \
    -v /usr/local/docker/mysql/conf:/etc/mysql \
    -v /usr/local/docker/mysql/logs:/var/log/mysql \
    -v /usr/local/docker/mysql/data:/var/lib/mysql \
    -e MYSQL_ROOT_PASSWORD=123456 \
    -d mysql:5.7
    
    • -v:主机和容器的目录映射关系,":"前为主机目录,之后为容器目录
  5. 检查容器是否正确运行

    docker container ls
    
    • 可以看到容器ID,容器的源镜像,启动命令,创建时间,状态,端口映射信息,容器名字
  6. 设置容器自启动:docker update 容器名/容器ID --restart=always

三、连接mysql

  1. 进入docker本地连接mysql客户端

    sudo docker exec -it mysql bash
    mysql -uroot -p123456
    
  2. 使用远程连接软件时要注意一个问题

    我们在创建容器的时候已经将容器的3306端口和主机的3306端口映射到一起,所以我们应该访问:

    host: 127.0.0.1
    port: 3306
    user: root
    password: 123456
    
  3. 如果你的容器运行正常,但是无法访问到MySQL,一般有以下几个可能的原因:

    • 防火墙阻拦

      # 开放端口:
      $ systemctl status firewalld
      $ firewall-cmd  --zone=public --add-port=3306/tcp -permanent
      $ firewall-cmd  --reload
      # 关闭防火墙:
      $ sudo systemctl stop firewalld
      
    • 开放权限:

      • 进入容器:docker exec -it tensquare_mysql bash
        
        登录mysql: mysql -uroot -proot(u,p后面跟的是用户名和密码)
        
        授权:ALTER user 'root'@'%' IDENTIFIED WITH mysql_native_password BY 'root';
        
        刷新:FLUSH PRIVILEGES;

         

 

Linux系统中使用Docker安装MySQL 8.0,可按以下步骤操作: ### 安装Docker 从阿里下载repo镜像,然后安装Docker并启动,查看其版本: ```bash # 从阿里下载repo镜像 wget -O /etc/yum.repos.d/docker-ce.repo https://mirrors.aliyun.com/docker-ce/linux/centos/docker-ce.repo # 安装docker yum install docker-ce docker-ce-cli containerd.io # 启动docker systemctl start docker # 查看docker版本 docker -v ``` ### 拉取MySQL镜像 使用以下命令拉取MySQL 8.0镜像: ```bash docker pull mysql:8.0 ``` ### 创建并运行MySQL容器 有不同的创建容器的方式,以下是两种示例: #### 示例一 ```bash docker run --name my-mysql -e MYSQL_ROOT_PASSWORD=123456 -v /tmp/mysql8:/var/lib/mysql -p 3307:3306 -d mysql:8.0 ``` 这个命令创建了一个名为 `my-mysql` 的容器,设置了root用户密码为 `123456`,将宿主机的 `/tmp/mysql8` 目录挂载到容器的 `/var/lib/mysql` 目录,将容器的3306端口映射到宿主机的3307端口,并在后台运行容器[^2]。 #### 示例二 在 `conf` 文件下创建 `my.cnf` 文件,内容如下: ```ini [client] port = 3306 default-character-set = utf8mb4 [mysql] port = 3306 default-character-set = utf8mb4 [mysqld] # bind-address = 0.0.0.0 # port = 3306 max_connections=10000 character-set-server = utf8mb4 collation-server = utf8mb4_unicode_ci # 设置时区和字符集 # default-time-zone='+8:00' character-set-client-handshake=FALSE init_connect='SET NAMES utf8mb4 COLLATE utf8mb4_unicode_ci' gtid-mode=ON enforce-gtid-consistency = ON ``` 然后运行以下命令创建容器: ```bash docker run -p 3306:3306 --privileged=true --name mysql --restart=always -e MYSQL_ROOT_PASSWORD=root -v /docker/mysql/conf/my.cnf:/etc/mysql/my.cnf -v /docker/mysql/data:/var/lib/mysql -v /docker/mysql/logs:/var/log/mysql -d mysql:8.0 --lower_case_table_names=1 ``` 此命令创建了一个名为 `mysql` 的容器,设置了root用户密码为 `root`,进行了多个目录的挂载,开启了容器自启动,并且设置了mysql字母大小写忽略等参数[^3]。 ### 远程登录测试 可以使用MySQL客户端工具,如 `mysql -h 宿主机IP -P 映射端口 -u root -p` 进行远程登录测试,输入之前设置的root密码,若能成功登录,则表示安装成功。
评论
成就一亿技术人!
拼手气红包6.0元
还能输入1000个字符
 
红包 添加红包
表情包 插入表情
 条评论被折叠 查看
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值