我是勤劳的搬运工……源码装了好多次Mysql,终于成功了……
1.下载源码安装包
因为安装mysql需要对应的boost文件(必须是相应版本,不能高也不能低),所以,为了不再麻烦的搜索对应的boost文件,下载包含boost的Mysql包
2.查看是否有编译器
# gcc -v
如果没有的话,安装文件时会报错,可以根据提示安装相应文件;
我是通过yum install安装的gcc 、c++、cmake(mysql5.6.*以后需要cmake来编译)
[root@root]# yum install gcc -y
[root@root]# yum install gcc-c++ -y
[root@root]# yum install cmake -y
3.安装关联文件
[root@root]# yum install libaio -y
[root@root]# yum install ncurses-devel -y
4.创建mysql的安装目录及数据库存放目录
[root@root]# mkdir -p /usr/local/mysql //安装mysql
[root@root]# mkdir -p /usr/local/mysql/data //存放数据库(-p自建,如果无上级目录,自建之)
5.创建mysql用户及用户组
[root@root] groupadd mysql
[root@root] useradd -r -g mysql mysql
或[root@root] useradd mysql -g mysql -M -s /sbin/nologin(**这个错误,但设置了mysql无登录权限权限,上边那个怎么加权限呢**)
6.编译安装mysql
[root@root local]# tar -zxvf mysql-5.7.12.tar.gz //解压
[root@root local]# cd mysql-5.7.12
[root@root mysql-5.7.12]#
//配置安装目录、字符集等信息;
//关联Mysql压缩包中的boost
cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DWITH_MEMORY_STORAGE_ENGINE=1 \
-DWITH_READLINE=1 \
-DENABLED_LOCAL_INFILE=1 \
-DMYSQL_DATADIR=/usr/local/mysql/data \
-DMYSQL_USER=mysql \
-DMYSQL_TCP_PORT=3306 \
-DDOWNLOAD_BOOST=1 -DWITH_BOOST=/home/mysql-5.7.12/boost
[root@root mysql-5.7.12]# make
[root@root mysql-5.7.12]# make install
7.检验是否安装成功
[root@root mysql-5.7.12]# cd /usr/local/mysql/
[root@root mysql]# ls
bin data include man mysql.sock.lock README support-files
COPYING docs lib mysql.sock mysql-test share
有bin等以上文件的话,恭喜你已经成功安装了mysql。
8.设置mysql目录权限
[root@localhost mysql]# cd /usr/local/mysql //把当前目录中所有文件的所有者设为root,所属组为mysql
[root@root mysql]# chown -R root:mysql .
[root@root mysql]# chown -R mysql:mysql data
9.将mysql的启动服务添加到系统服务中
[root@root mysql]# cp support-files/my-default.cnf /etc/my.cnf
cp:是否覆盖"/etc/my.cnf"? y
10.初始化数据库并生成初始密码
!!一定要记住初始密码(没记住自行百度怎么改密码吧)
[root@root mysql]# cd /usr/local/mysql
[root@root mysql]# bin/mysqld --initialize --user=mysql
[root@root mysql]# bin/mysql_ssl_rsa_setup
生成如下密码:
A temporary password is generated for root@localhost: =il&jeuyz5aK
=il&jeuyz5aK就是初始密码!!
11.设置环境变量(使得mysql服务可以全局访问)
[root@root ~]# vi /root/.bash_profile
在修改PATH=$PATH:$HOME/bin为:
PATH=$PATH:$HOME/bin:/usr/local/mysql/bin:/usr/local/mysql/lib
[root@root ~]# source /root/.bash_profile //使刚才的修改生效
12.将mysql的启动服务添加到系统服务中
[root@root mysql]# cp support-files/mysql.server /etc/init.d/mysql
13.启动mysql
[root@root mysql]# service mysql start
Starting MySQL... ERROR! The server quit without updating PID file (/usr/local/mysql/data/bogon.pid).
启动失败:
这里是权限问题,先改变权限
[root@root mysql]# chown -R mysql:mysql /usr/local/mysql
重新启动服务器
[root@root mysql]# service mysql start
14.登录并修改初始密码(不修改密码不让你操作,就是这么任性)
[root@root mysql]# mysql -u root -p
Enter password:=il&jeuyz5aK(初始密码)
如果报错:
Can't connect to local MySQL server through socket '/tmp/mysql.sock'
说明Mysql服务没有启动;----请确保服务已经启动
[root@root mysql]# mysql> SET PASSWORD FOR 'root'@'localhost' = PASSWORD('123456');
15.重新登录
[root@root mysql]# mysql> exit
[root@root mysql]# mysql -u root -p
Enter password:123456
16.赋予Mysql远程连接功能
mysql> GRANT ALL PRIVILEGES ON *.* TO root@"%" IDENTIFIED BY "root";
授与root用户从任何其它主机发起的访问(通配符%)--------通过密码root;
注意:在程序里连接数据库,通过以上方法有可能不成功,需要附加当前IP访问数据库的权限;