源码安装MYSQL

源码安装mysql 5.7
1、安装依赖

yum -y install gcc-c++ ncurses-devel cmake make perl gcc autoconf automake zlib libxml libgcrypt libtool bison openssl-devel

下载Boost库
Boost库是为C++语言标准库提供扩展的一些C++程序库的总称,由Boost社区组织开发、维护

wget http://nchc.dl.sourceforge.net/project/boost/boost/1.59.0/
boost_1_59_0.tar.gz
tar –xzvf boost_1_59_0.tar.gz
# 移动目录并改名,为下面将要编译mysql时做准备,编译时指定到这个目录
mv boost_1_59_0  /usr/local/boost

下载,解压,编译,安装

#下载5.7.33
cd /usr/src
wget http://mirrors.163.com/mysql/Downloads/MySQL-5.7/mysql-5.7.33.tar.gz 

使用cmake编译
make与cmake :mysql自从5.5之后,编译安装项目代码管理不在使用make,而是用的是cmake。cmake的重要特性之一是其独立于源码(out-of-source)的编译功能,即编译工作可以在另一个指定的目录中而非源码目录中进行,这可以保证源码目录不受任何一次编译的影响,因此在同一个源码树上可以进行多次不同的编译,如针对于不同平台编译,并且编译安装需要准备开发环境,cmake默认也是不安装

#指定安装、数据存放目录,端口等等
[root@node02 src]# cd mysql-5.7.33
[root@node02 mysql-5.7.33]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql57 \
> -DMYSQL_DATADIR=/data/mysql57 \
> -DSYSCONFDIR=/usr/local/mysql57 \
> -DMYSQL_UNIX_ADDR=/data/mysql57/mysql.sock \
> -DMYSQL_USER=mysql \
> -DMYSQL_TCP_PORT=3307 \
> -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

[root@node02 mysql-5.7.33]# make && make install

添加存储数据库据目录以及访问用数据用户并设定访问权限

[root@node02 mysql-5.7.33]# mkdir -p /data/mysql57
[root@node02 mysql-5.7.33]# useradd -s /sbin/nologin  mysql
[root@node02 mysql-5.7.33]# chown -R mysql. /data/mysql57/
[root@node02 mysql-5.7.33]#

添加系统启动文件和可执行权限

[root@node02 mysql-5.7.33]# cp support-files/mysql.server /etc/init.d/mysqld57
[root@node02 mysql-5.7.33]# chmod +x /etc/init.d/mysqld57 
[root@node02 mysql-5.7.33]# 

新增配置文件my.cnf

[root@node02 mysql-5.7.33]# vim /usr/local/mysql57/my.cnf
[mysqld]
basedir=/usr/local/mysql57/
datadir=/data/mysql57/
port=3306
pid-file=/data/mysql57/mysql.pid
socket=/data/mysql57/mysql.sock
[mysqld_safe]
log-error=/data/mysql57/mysql.log

数据库初始化

/usr/local/mysql57/bin/mysqld --initialize --user=mysql --basedir=/usr/local/mysql57 --datadir=/data/mysql57

启动msyql服务

[root@node02 mysql-5.7.33]# /etc/init.d/mysqld57 start
Starting MySQL.Logging to '/data/mysql57/mysql.log'.
. SUCCESS! 
[root@node02 mysql-5.7.33]# netstat -ntlp
Active Internet connections (only servers)
Proto Recv-Q Send-Q Local Address           Foreign Address         State       PID/Program name    
tcp        0      0 127.0.0.1:9000          0.0.0.0:*               LISTEN      123837/php-fpm: mas 
tcp        0      0 0.0.0.0:22              0.0.0.0:*               LISTEN      6998/sshd           
tcp6       0      0 :::3306                 :::*                    LISTEN      50829/mysqld        
tcp6       0      0 :::80                   :::*                    LISTEN      1430/httpd          
tcp6       0      0 :::22                   :::*                    LISTEN      6998/sshd           
[root@node02 mysql-5.7.33]#
  • 0
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

阿蔡BLOG

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值