Docker安裝MySql遇到的問題解決
一、mysql查詢中文亂碼問題
由于字符集設置不正確導致。
解決方案:
1. 進入mysql中進行查看數(shù)據(jù)庫字符集
show variables like 'character%';
character_set_client character_set_connection | 連接到 MySQL 服務器的客戶端使用的字符集 |
character_set_database | 當前數(shù)據(jù)庫的默認字符集 |
character_set_results | 查詢結果返回給客戶端時使用的字符集 |
character_set_server | MySQL 服務器使用的默認字符集 |
返回的字符集中,character_set_database
、character_set_server
等都為latin1
字符集,所以會出現(xiàn)亂碼。
2. 修改 my.cnf 中的配置
我的mysql是掛載在下 /app/mysql-master/conf, 所以我只需要到該路徑下修改。
vim /app/mysql-master/conf/my.cnf
[client] # 設置客戶端的默認字符集為 utf8 default-character-set = utf8 [mysqld] # 設置服務器的排序規(guī)則為 utf8_general_ci collation-server = utf8_general_ci # 設置服務器的默認字符集為 utf8 character-set-server = utf8
3. 重啟mysql容器,使得容器重新加載配置文件
docker restart mysql-master
4. 測試結果
二、主從同步中遇到的問題
在同步測試過程中發(fā)現(xiàn)從機并沒有同步主機的數(shù)據(jù),并且查看從機的狀態(tài)
# \G 可以將橫向的結果集表格轉換成縱向展示。 # slave status的字段比較多,縱向展示比友好 show slave status \G;
如果 Slave_IO_Running 和 Slave_SQL_Running 不為 Yes。
2.1 Slave_IO_Running:Connecting 的解決方案
1. 確定宿主機防火墻開放mysql的映射端口
如果不是生產環(huán)境,可以直接簡單粗暴先暫時關閉防火墻進行排錯。
# 查看防火墻狀態(tài) systemctl status firewalld # 暫時關閉防火墻 systemctl stop firewalld # 永久關閉防火墻 systemctl disable firewalld
2. 檢查配置文件中 server_id 是否唯一
如果修改了配置文件需要重啟容器使得生效,
docker restart mysql-master
ps:主機和從機都查看一遍
3. 檢查的同步狀態(tài)
3.1 查看主服務器當前的二進制日志狀態(tài)
show master status;
3.2 進入從機中設置同步配置
如果已經(jīng)啟動和同步,需要先關閉同步
stop slave;
-- 格式: -- change master to master_host='宿主機ip',master_user='主數(shù)據(jù)庫配置的主從復制用戶名',master_password='主數(shù)據(jù)庫配置的主從復制用戶密碼',master_port=宿主機主數(shù)據(jù)庫端口,master_log_file='主數(shù)據(jù)庫主從同步狀態(tài)的文件名File',master_log_pos=主數(shù)據(jù)庫主從同步狀態(tài)的Position,master_connect_retry=連接失敗重試時間間隔(秒); change master to master_host='192.168.xxx.xxx',master_user='slave',master_password='123456',master_port=3307,master_log_file='mall-mysql-bin.000001',master_log_pos=769,master_connect_retry=30;
-- 配置完成后在進行啟動同步 start slave;
ps:根據(jù)主機配置進行設置。
最后查看主機中的主從復制的狀態(tài)
# \G 可以將橫向的結果集表格轉換成縱向展示。 # slave status的字段比較多,縱向展示比友好 show slave status \G;
ps:如果同步不成功,可以在這里查看日志。
2.2 authentication plugin 'caching_sha2_password' cannot be loaded
原因主要是由于MySQL 8.0版本引入了新的默認身份驗證插件 caching_sha2_password
,而一些舊的MySQL客戶端或庫可能不支持這個插件,導致連接問題。解決方案 ↓↓↓ ↓↓↓
1. 可以查看 user 中的用戶數(shù)據(jù)
use mysql; select host,user,plugin from user;
2. 所以需要修改認證插件統(tǒng)一為 mysql_native_password
ALTER USER 'root'@'%' IDENTIFIED WITH mysql_native_password BY '123456'; ALTER USER 'slave'@'%' IDENTIFIED WITH mysql_native_password BY '123456';
3. 查看是否修改成功
到此這篇關于Docker安裝MySql遇到的問題解決的文章就介紹到這了,更多相關Docker安裝MySql內容請搜索腳本之家以前的文章或繼續(xù)瀏覽下面的相關文章希望大家以后多多支持腳本之家!
相關文章
Docker創(chuàng)建MongoDB容器并添加root密碼驗證與更多用戶詳細步驟
MongoDB是一個著名的面向文檔的數(shù)據(jù)庫,被許多現(xiàn)代Web應用程序使用,下面這篇文章主要給大家介紹了關于Docker創(chuàng)建MongoDB容器并添加root密碼驗證與更多用戶的相關資料,需要的朋友可以參考下2023-01-01修改Docker鏡像倉庫為阿里云鏡像或163鏡像的實現(xiàn)
docker本身的倉庫非常慢,但是國內有阿里云的鏡像倉庫非常快,本文主要介紹了修改Docker鏡像倉庫為阿里云鏡像或163鏡像的實現(xiàn),具有一定的參考價值,感興趣的可以了解一下2023-11-11docker搭建redis三主三從集群的實現(xiàn)步驟
本文主要介紹了docker搭建redis三主三從集群,文中通過示例代碼介紹的非常詳細,對大家的學習或者工作具有一定的參考學習價值,需要的朋友們下面隨著小編來一起學習學習吧2022-08-08Linux搭建Docker環(huán)境的詳細過程(最新推薦)
Docker從17.03版本之后分為CE(Community Edition: 社區(qū)版)和EE(Enterprise Edition: 企業(yè)版),相對于社區(qū)版本,企業(yè)版本強調安全性,但需付費使用,這里我們使用社區(qū)版本即可,這篇文章給大家介紹Linux搭建Docker環(huán)境的詳細過程,感興趣的朋友一起看看吧2025-04-04Docker網(wǎng)絡配置及部署SpringCloud項目詳解
bridge模式是Docker默認的網(wǎng)絡設置,此模式會為每一個容器分配Network Namespace、設置IP等,并將一個主機上的Docker容器連接到一個虛擬網(wǎng)橋上,下面這篇文章主要給大家介紹了關于Docker網(wǎng)絡配置及部署SpringCloud項目的相關資料,需要的朋友可以參考下2023-01-01