赞
踩
1、下载boost_1_59_0.tar.gz、mysql-5.7.20.tar.gz源码包
wget https://nchc.dl.sourceforge.net/project/boost/boost/1.59.0/boost_1_59_0.tar.gz;wget https://dev.mysql.com/get/Downloads/MySQL-5.7/mysql-5.7.20.tar.gz
***注:***Boost库是为C++语言标准库提供扩展的一些C++程序库的总称,由Boost社区组织开发、维护
2、yum安装必要的软件
yum -y install gcc-c++ ncurses-devel cmake make perl gcc autoconf automake zlib libxml libgcrypt libtool bison
3、将刚刚下载的两个源码包移到/usr/local/下
[root@proxy-server ~]# mv mysql-5.7.20.tar.gz /usr/local/
[root@proxy-server ~]# mv boost_1_59_0.tar.gz /usr/local/
4、解压boost_1_59_0.tar.gz、mysql-5.6.35.tar.gz
[root@proxy-server local]# tar -xvf mysql-5.7.20.tar.gz
[root@proxy-server local]# tar -xvf boost_1_59_0.tar.gz
5、把解压得到的boost_1_59_0这个目录移到/usr/local/boost
[root@proxy-server local]# mv boost_1_59_0 /usr/local/boost
6、cmake预编译
[root@proxy-server local]# cd mysql-5.7.20/ [root@proxy-server local]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ -DMYSQL_UNIX_ADDR=/tmp/mysql.sock \ -DMYSQL_DATADIR=/data/mysql \ -DSYSCONFDIR=/etc \ -DMYSQL_USER=mysql \ -DMYSQL_TCP_PORT=3306 \ -DWITH_XTRADB_STORAGE_ENGINE=1 \ -DWITH_INNOBASE_STORAGE_ENGINE=1 \ -DWITH_PARTITION_STORAGE_ENGINE=1 \ -DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ -DWITH_MYISAM_STORAGE_ENGINE=1 \ -DWITH_READLINE=1 \ -DENABLED_LOCAL_INFILE=1 \ -DWITH_EXTRA_CHARSETS=1 \ -DDEFAULT_CHARSET=utf8 \ -DDEFAULT_COLLATION=utf8_general_ci \ -DEXTRA_CHARSETS=all \ -DWITH_BIG_TABLES=1 \ -DWITH_DEBUG=0 \ -DENABLE_DTRACE=0 \ -DDOWNLOAD_BOOST=1 \ -DWITH_BOOST=/usr/local/boost *** #注意上面这个就是指定的那个boost库的位置,所以必须要进行第五步***
6、编译安装
[root@proxy-server mysql-5.6.35]# make&&make install
#不建议使用make -j4这个参数,因为非常容易出现错误,比如
c++: 编译器内部错误:已杀死(程序 cc1plus) Please submit a full bug report
#根据网上的说法是出现了内存不足,用如下命令添加交换内存:
dd if=/dev/zero of=/home/swap bs=64M count=16
mkswap /home/swap
swapon /home/swap
关闭并删除交换内存/home/swap:
swapoff /home/swap
rm /home/swap
但是我无论添加多少的交换内存都无法解决这个报错。后面不使用-j这个参数才成功了。
cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql Cmake预编译; -DMYSQL_UNIX_ADDR=/tmp/mysql.sock MYSQL Socket通信文件位置; -DMYSQL_DATADIR=/data/mysql MYSQL数据存放路径; -DSYSCONFDIR=/etc 配置文件路径; -DMYSQL_USER=mysql MYSQL运行用户; -DMYSQL_TCP_PORT=3306 MYSQL监听端口; -DWITH_XTRADB_STORAGE_ENGINE=1 开启xtradb引擎支持; -DWITH_INNOBASE_STORAGE_ENGINE=1 开启innodb引擎支持; -DWITH_PARTITION_STORAGE_ENGINE=1 开启partition引擎支持; -DWITH_BLACKHOLE_STORAGE_ENGINE=1 开启blackhole引擎支持; -DWITH_MYISAM_STORAGE_ENGINE=1 开启MyISAM引擎支持; -DWITH_READLINE=1 启用快捷键功能; -DENABLED_LOCAL_INFILE=1 允许从本地导入数据; -DWITH_EXTRA_CHARSETS=1 支持额外的字符集; -DDEFAULT_CHARSET=utf8 默认字符集UTF-8; -DDEFAULT_COLLATION=utf8_general_ci 检验字符; -DEXTRA_CHARSETS=all 安装所有扩展字符集; -DWITH_BIG_TABLES=1 将临时表存储在磁盘上; -DWITH_DEBUG=0 禁止调试模式支持;
1、创建mysql用户的账号
[root@proxy-server ~]# groupadd mysql
[root@proxy-server ~]# useradd -s /sbin/nologin -g mysql -M mysql
useradd 命令的参数参数简要说明:
-s /sbin/nologin 表示禁止该用户登录,只需要用户存在即可,加强安全
-g mysql 指定mysql用户属于mysql组
-M 表示不创建用户家目录,因为没有需要
检查创建的mysql用户及组:
tail -l /etc/passwd
id mysql
2、将安装目录所有者及所属组改为mysql,创建/data/mysql/
chown -R mysql.mysql /usr/local/mysql
mkdir -p /data/mysql && chown mysql:mysql -R /data/mysql/
3、配置my.cnf文件
[client]
port=3306
socket=/tmp/mysql.sock
[mysqld]
basedir=/usr/local/mysql
datadir=/data/mysql
socket=/tmp/mysql.sock
symbolic-links=0
[mysqld_safe]
log-error=/data/mysql/mysql-error.log
pid-file=/data/mysql/mysql.pid
!includedir /etc/my.cnf.d
4、初始化
[root@localhost mysql]# /usr/local/mysql/bin/mysqld --initialize --user=mysql --datadir=/data/mysql --basedir=/usr/local/mysql
注:mysql 程序初始化的内容,mysql的默认程序表,系统表,用户表,都是在初始化的时进行创建的。
6、将启动文件copy到/etc/init.d/mysqld
[root@localhost mysql]# \cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
//mysql.server这个是mysql的启动文件。
目录/etc/init.d/的作用:init.d目录包含许多系统各种服务的启动和停止脚本
要想加入系统服务必须把启动文件copy到这个目录下
7、加入系统服务,开机自启动
chkconfig --add mysqld
chkconfig mysqld on
8、启动mysqld服务
[root@localhost mysql]# systemctl restart mysqld
9、加入到环境变量,方便使用mysql命令登录
[root@localhost mysql]# vim /etc/profile
编辑内容如下:
[root@localhost mysql]# source /etc/profile //使文件配置生效
使用下面命令进入到mysql
[root@localhost mysql]# mysql -uroot -p
//注意要想登录,先要启动mysql
//这里会提示输入密码,输入之前第四步的密码即可
//也可以在my.cnf中的[mysqld]下加入--skip-grant-tables这个参数即可跳过密码登录
10、启动mysql,修改root用户密码
service mysqld start
mysql -uroot -p
alter user 'root'@'localhost' identified by 'mysql';
***注:***第一次进数据库,第一个操作就是采用上面指令修改密码,不然会报错:
ERROR 1820 (HY000): You must reset your password using ALTER USER statement before executing this statement.
Copyright © 2003-2013 www.wpsshop.cn 版权所有,并保留所有权利。