程序師世界是廣大編程愛好者互助、分享、學習的平台,程序師世界有你更精彩!
首頁
編程語言
C語言|JAVA編程
Python編程
網頁編程
ASP編程|PHP編程
JSP編程
數據庫知識
MYSQL數據庫|SqlServer數據庫
Oracle數據庫|DB2數據庫
 程式師世界 >> 數據庫知識 >> MYSQL數據庫 >> MySQL綜合教程 >> MySQL 源碼安裝,mysql源碼安裝

MySQL 源碼安裝,mysql源碼安裝

編輯:MySQL綜合教程

MySQL 源碼安裝,mysql源碼安裝


安裝mysql  

創建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

本站點所有隨筆都是原創,歡迎大家轉載;但轉載時必須注明文章來源,且在文章開頭明顯處給明鏈接。

《歡迎交流討論》

  1. 上一頁:
  2. 下一頁:
Copyright © 程式師世界 All Rights Reserved