二、MySQL系列 - MySQL源码安装配置(附5.7等最新版本)
1、依赖环境准备
2、开始安装
2.1、下载MySQL
2.2、解压
2.3、赋权限
2.4、修改配置文件
2.5、启动MySQL
3、MySQL 5.7源码安装不同之处
二、MySQL系列 - MySQL源码安装配置(附5.7等最新版本)
1、依赖环境准备
- make安装
make编译器下载地址:http://www.gnu.org/software/make/
# tar zxvf make-3.82.tar.gz
# cd make-3.82
# ./configure
# make
# make install
- bison安装
bison下载地址:http://www.gnu.org/software/bison/
# tar zxvf bison-2.5.tar.gz
# cd bison-2.5
# ./configure
# make
# make install
- gcc-c++安装
gcc-c++下载地址:http://www.gnu.org/software/gcc/
# tar zxvf gcc-c++-4.4.4.tar.gz
# cd gcc-c++-4.4.4
#./configure
# make
# make install
- cmake安装
cmake下载地址:http://www.cmake.org/
# tar zxvf cmake-2.8.4.tar.gz
# cd cmake-2.8.4
#./configure
# make
# make install
- ncurses安装
ncurses下载地址:http://www.gnu.org/software/ncurses/
# tar zxvf ncurses-5.8.tar.gz
# cd ncurses-5.8
#./configure
# make
# make install
2、开始安装
2.1、下载MySQL
MySQL5.6下载地址:http://dev.mysql.com/
这里我在这里下载的mysql-5.6.12.tar.gz
ftp://mirror.switch.ch/mirror/mysql/Downloads/MySQL-5.6/
# groupadd mysql
# useradd mysql -g mysql -M -s /sbin/nologin
#增加一个名为 mysql的用户。
-g:指定新用户所属的用户组(group)
-M:不建立根目录
-s:定义其使用的shell,/sbin/nologin代表用户不能登录系统。
2.2、解压
解压并安装MySQL
# tar zxvf mysql-5.6.12.tar.gz
# cd mysql-5.6.12
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_READLINE=1 -DMYSQL_UNIX_ADDR=/tmp/mysqld.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
2.3、赋权限
# cd /usr/local/mysql
# chown -R mysql:mysql . (#这里最后是有个.的大家要注意# 为了安全安装完成后请修改权限给root用户)
# scripts/mysql_install_db --user=mysql (先进行这一步再做如下权限的修改)
# chown -R root:mysql . (将权限设置给root用户,并设置给mysql组, 取消其他用户的读写执行权限,仅留给mysql "rx"读执行权限,其他用户无任何权限)
# chown -R mysql:mysql ./data (数据库存放目录设置成mysql用户mysql组)
# chmod -R ug+rwx . (赋予读写执行权限,其他用户权限一律删除仅给mysql用户权限)
2.4、修改配置文件
下面的命令是将mysql的配置文件拷贝到/etc
# cp support-files/my-default.cnf /etc/my.cnf
(5.6之前的版本用如下命令)
# cp support-files/my-medium.cnf /etc/my.cnf (5.6之前的版本是此操作,读者也可在此时自己进入support-files文件夹下面,看是配置文件的真正名称,那个存在,就拷贝那个。。)
修改my.cnf配置
# vi /etc/my.cnf
#[mysqld] 下面添加:
user=mysql
datadir=/data/mysql
default-storage-engine=MyISAM
2.5、启动MySQL
# bin/mysqld_safe --user=mysql & 或者直接进入bin文件夹下面
# cd bin
#./mysqld \ 这里说明,mysqld_safe或者mysqld都可以启动的
启动mysql,看是否成功
# ps –ef|grep mysql
上面是一种启动mysql的方法,还有一种简单的方便,如下:
将mysql的启动服务添加到系统服务中
# cp support-files/mysql.server /etc/init.d/mysql
现在可以使用下面的命令启动mysql
# service mysql start
停止mysql服务
# service mysql stop
重启mysql服务
# service mysql restart
3、MySQL 5.7源码安装不同之处
- cmake版本必须在2.8以上
- 依赖boost库,需要在cmake时新增如下选项
-DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local/boost
- 初始化以及启动
在5.7.6之前初始化的方法是:bin/mysql_install_db --user=mysql 5.7.6之后的版本初始化数据库不再使用mysql_install_db
bin/mysqld --initialize --user=mysql --basedir=/package/mysql --datadir=/package/mysql/data --innodb_undo_tablespaces=3
bin/mysql_ssl_rsa_setup
cp support-files/mysql.server /etc/init.d/mysql
bin/./mysqld_safe --skip-grant-tables --skip-networking &
在5.7中存储密码的字段不再是password了,变成了authentication_string
update mysql.user set authentication_string=password(‘root‘) where user=‘root‘
SET PASSWORD=PASSWORD(‘root‘);
时间: 2024-10-02 17:08:54