創建mysql數據目錄
mkdir -p /usr/local/mysql --安裝目錄 mkdir -p /usr/local/mysql/data ---數據目錄
創建mysql用戶和組
groupadd mysql useradd -r -g mysql mysql
安裝插件
yum -y install gcc gcc-c++ autoconf bison cmake automake zlib* fiex* libxml* ncurses-devel libmcrypt* libtool-ltdl-devel*
編譯安裝
wget http://dev.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.15.tar.gz
cmake \ -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_DATADIR=/usr/local/mysql/data \ -DSYSCONFDIR=/etc \ -DWITH_MYISAM_STORAGE_ENGINE=1 \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_MEMORY_STORAGE_ENGINE=1 \ -DWITH_FEDERATED_STORAGE_ENGINE=1 \ -DWITH_READLINE=1 \ -DMYSQL_UNIX_ADDR=/usr/local/mysql/data/mysql.sock \ -DMYSQL_TCP_PORT=3306 \ -DENABLED_LOCAL_INFILE=1 \ -DWITH_PARTITION_STORAGE_ENGINE=1 \ -DEXTRA_CHARSETS=all \ -DDEFAULT_CHARSET=utf8 \ -DDEFAULT_COLLATION=utf8_general_ci
make make install
具體選項可參考mysql官方:http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html。
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql //安裝目錄
-DINSTALL_DATADIR=/usr/local/mysql/data //數據庫存放目錄
-DDEFAULT_CHARSET=utf8 //使用utf8字符
-DDEFAULT_COLLATION=utf8_general_ci //校驗字符
-DEXTRA_CHARSETS=all //安裝所有擴展字符集
-DENABLED_LOCAL_INFILE=1 //允許從本地導入數據
-DINSTALL_SBINDIR= mysqlid目錄
-DSYSCONFDIR= my.cnf配置文件目錄
-DINSTALL_PLUGINDIR= 插件目錄
-DINSTALL_MANDIR= 手冊文件目錄
-DINSTALL_SHAREDIR= 共享數據目錄
-DINSTALL_LIBDIR= library庫目錄
-DINSTALL_INCLUDEDIR= header安裝目錄
-DINSTALL_INFODIR= 信息文檔目錄
存儲引擎相關參數(- DWITH代表啟用,-DWITHOUT代表不啟用,mysql默認支持的數據庫引擎有MyISAM, MERGE, MEMORY, CSV,無需在編譯時再聲明):
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_FEDERATED_STORAGE_ENGINE=1 \
-DWITH_PARTITION_STORAGE_ENGINE=1 \
-DWITH_ARCHIVE_STORAGE_ENGINE=1
授予mysql用戶權限
chown -R mysql:mysql /usr/local/mysql
創建系統自帶的數據庫和表
cd /usr/local/mysql scripts/mysql_install_db --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --user=mysql mysql_install_db 腳本的目的是生成新的MySQL授權表。它不覆蓋已有的MySQL授權表,並且它不影響任何其它數據。所有的數據庫相關文件都會默認生產在/usr/local/mysql/data路徑下 mv /usr/local/mysql/my.cnf /etc/my.cnf chown -R mysql:mysql /usr/local/mysql
配置mysql啟動服務
進入源碼包文件 cp support-files/mysql.server /etc/init.d/mysql chmod +x /etc/init.d/mysql --授予文件可執行權限 chkconfig mysql on --配置mysql開機自動啟動 service mysql start --啟動MySQL
配置環境變量
為了能直接調用mysql命令,需要配置環境變量 vim /etc/profile 在/etc/profile文件末尾添加 export PATH=/usr/local/mysql/bin:$PATH 使環境變量立即生效 source /etc/profile
設置mysql root用戶密碼
默認mysql root用戶安裝完密碼為空 mysql -uroot ---登入 SET PASSWORD = PASSWORD('root'); --設置root密碼 默認root只運行本地訪問 use mysql select user,host from user where user='root'; 授予root遠程連接權限,生產環境慎用 GRANT ALL PRIVILEGES ON *.* TO 'root'@'%' IDENTIFIED BY 'root' WITH GRANT OPTION;
創建備份用戶
grant reload,lock tables,replication client,create tablespace,super on *.* to 'backup'@'%' identified by 'backup';
防火牆配置
默認3306端口是未啟用,啟用3306端口 vim /etc/sysconfig/iptables 在-A INPUT -m state --state NEW -m tcp -p tcp --dport 22 -j ACCEPT後面加入以下內容 -A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT 重新啟動防火牆 service iptables restart
centos7操作系統防火牆還需要修改的地方有:
Firewalld中添加端口方法如下:
firewall-cmd --zone=public --add-port=3306/tcp --permanent
firewall-cmd --reload
如果更改.sock的默認路徑,需要在本機登入那麼[client]中也要配置socket,實際的業務系統需要將日志文件和數據文件分開磁盤存放,可以在my.cnf文件中配置。
備注:
作者:pursuer.chen
博客:http://www.cnblogs.com/chenmh
本站點所有隨筆都是原創,歡迎大家轉載;但轉載時必須注明文章來源,且在文章開頭明顯處給明鏈接。
《歡迎交流討論》