|
在linux系統(tǒng)中mysql區(qū)分大小寫寫的,如果你想讓mysql不區(qū)分大小寫的話我們可以在my.ini中修改lower_case_table_names即可
今天公司服務器上,tomcat去讀取mysql里的數(shù)據(jù),居然無法讀取成功,查看了下tomcat的日志,發(fā)現(xiàn)數(shù)據(jù)里有一句包含得有大小寫的字母,為了
解決這個問題,網(wǎng)上搜了一下,居然是要讓mysql忽略大小寫,但我們公司的mysql是做了主從的,為了不影響主從環(huán)境和mysql里的數(shù)據(jù),我們提前
給老大打了招呼,說要停web服務、tomcat服務和mysql服務2個小時,在緊張的氣氛下我們終于搞定了,下面就是介紹怎么修改mysql忽略大小
寫的操作.
系統(tǒng):centos 6.x
軟件版本:mysql 5.5.x tomcat-6.x
1.先停止web服務和tomcat
這里就不說怎么停止,是個搞運維的都應該知道.
2.停止mysql主從同步
先在從服務器上停止slave,然后再對主數(shù)據(jù)庫進行鎖定,不讓數(shù)據(jù)再寫進去了,再對主數(shù)據(jù)庫里的數(shù)據(jù)進行備份.
flush tables with read lock; 主數(shù)據(jù)庫進行鎖表操作,不讓數(shù)據(jù)再進行寫入動作.
show master status; 查看主數(shù)據(jù)庫狀態(tài),并記錄下 FILE 及 Position 的值.
mysqldump -u root -p db|gzip>/root/sqlbak/db.sql.gz 備份主數(shù)據(jù)庫里的sql數(shù)據(jù).
slave stop; 在從數(shù)據(jù)庫里停止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這個參數(shù)是無法在mysql命令行里進行修改的,如果你在mysql命令行里修改,如下:
set GLOBAL lower_case_table_names =1;
set session;
執(zhí)行這兩條命令的話,mysql會報下面的錯誤:
Error : Variable 'lower_case_table_names' is a read only variable
說明lower_case_table_names這個參數(shù),只能在my.cnf配置里添加,是無法在mysql命令行里修改的.
4.恢復主從同步
先在主里,看主數(shù)據(jù)庫的狀態(tài),再根據(jù)主的狀態(tài)在從數(shù)據(jù)庫里執(zhí)行:
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;
如果同步上了,再取消主數(shù)據(jù)庫的鎖定狀態(tài),命令如下:
unlock tables;
5.進行驗證
隨便在主里插入條數(shù)據(jù)或者修改點數(shù)據(jù),如果有同步起,那就說明主從正常了,如果沒有同步起,檢查從數(shù)據(jù)庫是否有報錯.
http://www./1413464642.html
|