Centos7安装Web服务器--Mysql5.7.12安装

649 查看

我是勤劳的搬运工……源码装了好多次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访问数据库的权限;