在linux系統中mysql區分大小寫寫的,如果你想讓mysql不區分大小寫的話我們可以在my.ini中修改lower_case_table_names即可
今天公司服務器上,tomcat去讀取mysql裡的數據,居然無法讀取成功,查看了下tomcat的日志,發現數據裡有一句包含得有大小寫的字母,為了解決這個問題,網上搜了一下,居然是要讓mysql忽略大小寫,但我們公司的mysql是做了主從的,為了不影響主從環境和mysql裡的數據,我們提前給老大打了招呼,說要停web服務、tomcat服務和mysql服務2個小時,在緊張的氣氛下我們終於搞定了,下面就是介紹怎麼修改mysql忽略大小寫的操作.
系統:centos 6.x
軟件版本:mysql 5.5.x tomcat-6.x
1.先停止web服務和tomcat
這裡就不說怎麼停止,是個搞運維的都應該知道.
2.停止mysql主從同步
先在從服務器上停止slave,然後再對主數據庫進行鎖定,不讓數據再寫進去了,再對主數據庫裡的數據進行備份.
flush tables with read lock; 主數據庫進行鎖表操作,不讓數據再進行寫入動作.
show master status; 查看主數據庫狀態,並記錄下 FILE 及 Position 的值.
mysqldump -u root -p db|gzip>/root/sqlbak/db.sql.gz 備份主數據庫裡的sql數據.
slave stop; 在從數據庫裡停止slave
3.修改mysql主從配置文件,讓其忽略大小寫
vi /etc/my.cnf
# The MySQL server
[mysqld]
set-variable=lower_case_table_names=1
要添加在mysqld下面,不要添加錯了地方,保存後重啟mysql.
ps:這裡我要說句,lower_case_table_names這個參數是無法在mysql命令行裡進行修改的,如果你在mysql命令行裡修改,如下:
set GLOBAL lower_case_table_names =1;
set session;
執行這兩條命令的話,mysql會報下面的錯誤:
Error : Variable 'lower_case_table_names' is a read only variable
說明lower_case_table_names這個參數,只能在my.cnf配置裡添加,是無法在mysql命令行裡修改的.
4.恢復主從同步
先在主裡,看主數據庫的狀態,再根據主的狀態在從數據庫裡執行:
change master to master_host='192.168.10.151',master_user='dbmysql',master_password='123456',master_log_file='master-bin.000001',master_log_pos=107;
start slave;
show slave statusG;
如果同步上了,再取消主數據庫的鎖定狀態,命令如下:
unlock tables;
5.進行驗證
隨便在主裡插入條數據或者修改點數據,如果有同步起,那就說明主從正常了,如果沒有同步起,檢查從數據庫是否有報錯.