標籤:style http io os 使用 ar for 檔案 sp
背景說明
mysql的安裝方法有多種,如二進位安裝、源碼編譯安裝、yum安裝等。yum安裝只能安裝mysql 5.1 版本;源碼安裝編譯的過程比較長,若沒有對源碼進行修改且要求使用mysql較高版本,建議使用二進位安裝。本文以二進位安裝mysql,且使用mysqld_mutil進行mysql多執行個體管理。
是否安裝了mysql
首先查看下伺服器中是否有安裝mysql,若連接埠被佔用,則需要選擇其他連接埠。
下載mysql
cd /usr/srcwget http://cdn.mysql.com/Downloads/MySQL-5.6/mysql-5.6.21-linux-glibc2.5-x86_64.tar.gz
解壓及遷移
tar -zxvf mysql-5.6.21-linux-glibc2.5-x86_64.tar.gzmv mysql-5.6.21-linux-glibc2.5-x86_64 /usr/local/mysql
關閉防火牆
臨時關閉:service iptables stop永久關閉:chkconfig iptables off
關閉selinux
vim /etc/sysconfig/selinux 將SELINUX修改為DISABLED,即SELINUX=DISABLED
初始化使用者組及使用者
建立一個mysql使用者組及使用者,且這個使用者是不可登入的建立使用者組:groupadd mysql建立不可登入使用者:useradd -g mysql -s /sbin/nologin -d /opt/mysql mysql查看下建立後的使用者資訊:id msyql# id mysqluid=500(mysql) gid=500(mysql) groups=500(mysql)
建立相關目錄
cd /mkdir /datacd /datamkdir mysqlcd mysql mkdir {mysql_3306,mysql_3307}cd /data/mysql/mysql_3306mkdir {data,log,tmp}cd /data/mysql/mysql_3307mkdir {data,log,tmp} 更改目錄許可權
chown -R mysql:mysql /data/mysql/chown -R mysql:mysql /usr/local/mysql/
添加環境變數
echo 'export PATH=$PATH:/usr/local/mysql/bin' >> /etc/profilesource /etc/profile
複製my.cnf檔案到etc目錄
cd /usr/local/mysql/support-filescp my-default.cnf /etc/my.cnf
修改my.cnf將以下內容,全部替換 /etc/my.cnf中的內容:
[client] port=3306 socket=/tmp/mysql.sock [mysqld_multi] mysqld = /usr/local/mysql /bin/mysqld_safe mysqladmin = /usr/local/mysql /bin/mysqladmin log = /data/mysql/mysqld_multi.log [mysqld] user=mysql basedir = /usr/local/mysql sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES [mysqld3306] mysqld=mysqld mysqladmin=mysqladmin datadir=/data/mysql/mysql_3306/data port=3306 server_id=3306 socket=/tmp/mysql_3306.sock log-output=file slow_query_log = 1 long_query_time = 1 slow_query_log_file = /data/mysql/mysql_3306/log/slow.log log-error = /data/mysql/mysql_3306/log/error.log binlog_format = mixed log-bin = /data/mysql/mysql_3306/log/mysql3306_bin [mysqld3307] mysqld=mysqld mysqladmin=mysqladmin datadir=/data/mysql/mysql_3307/data port=3307 server_id=3307 socket=/tmp/mysql_3307.sock log-output=file slow_query_log = 1 long_query_time = 1 slow_query_log_file = /data/mysql/mysql_3307/log/slow.log log-error = /data/mysql/mysql_3307/log/error.log binlog_format = mixed log-bin = /data/mysql/mysql_3307/log/mysql3307_bin
初始化資料庫
初始化3306資料庫/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql/ --datadir=/data/mysql/mysql_3306/data --defaults-file=/etc/my.cnf 初始化3307資料庫/usr/local/mysql/scripts/mysql_install_db --basedir=/usr/local/mysql/ --datadir=/data/mysql/mysql_3307/data --defaults-file=/etc/my.cnf
說明:--basedir:mysql的安裝目錄--datadir:資料庫的資料檔案目錄--defaults-file:mysql設定檔目錄
需要看兩個Ok,才說明成功,如:
查看資料庫是否初始化成功cd /data/mysql/mysql_3306/data設定開機檔案
cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysql
mysqld_multi進行多執行個體管理
啟動全部執行個體:/usr/local/mysql/bin/mysqld_multi start查看全部執行個體狀態:/usr/local/mysql/bin/mysqld_multi report啟動單個執行個體:/usr/local/mysql/bin/mysqld_multi start 3306停止單個執行個體:/usr/local/mysql/bin/mysqld_multi stop 3306查看單個執行個體狀態:/usr/local/mysql/bin/mysqld_multi report 3306
修改密碼
由於mysql的root使用者初始密碼是空,所以需要登入mysql進行修改密碼,下面以3306為例:mysql -S /tmp/mysql_3306.sock set password for [email protected]'localhost'=password('123456');flush privileges;建立使用者及授權
一般建立資料庫都需要新增一個使用者,用於程式串連,這類使用者只需要insert、update、delete、select許可權。新增一個使用者,並授權如下:grant select,delete,update,insert on *.* to [email protected]'192.168.1.%' identified by '123456';flush privileges;
centos下mysql多執行個體安裝3306、3307執行個體(2014-10-15)