mysql数据库编译_Mysql数据库源码编译安装

一、下载源码编译工具:

yum -y install \

gcc \

gcc-c++ \

make \

ncurses \

ncurses-devel \

bison \

cmake

二、编译及安装

1、创建运行用户

useradd -s /sbin/nologin mysql //手动建一个账号

2、解包

787273f04a5446eccf12bfcdb4ed7ed8.png

//把压缩包传进Linux里面

tar xf mysql-boost-5.7.20.tar.gz -C /opt/ //解压的目录要足够大,不然会报错

cd /opt/mysql-5.7.20/

3、配置:

cmake \

-DCMAKE_INSTALL_PREFIX=/usr/local/mysql \ //指定将mysql数据库程序安装到某个目录下

-DMYSQL_UNIX_ADDR=/usr/local/mysql/mysql.sock \ //指定sock文件的路劲

-DSYSCONFDIR=/etc \ //指定初始化参数文件目录

-DSYSTEMD_PID_DIR=/usr/local/mysql \

-DDEFAULT_CHARSET=utf8 \ //指定默认使用的字符集编码

-DDEFAULT_COLLATION=utf8_general_ci \ //指定默认使用的字符集校对规则

-DWITH_INNOBASE_STORAGE_ENGINE=1 \

-DWITH_ARCHIVE_STORAGE_ENGINE=1 \

-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \

-DWITH_PERFSCHEMA_STORAGE_ENGINE=1 \

-DMYSQL_DATADIR=/usr/local/mysql/data \

-DWITH_BOOST=boost \

-DWITH_SYSTEMD=1

4、编译及安装

make && make install

三、安装后调整

1、对数据库目录进行权限设置

chown -R mysql:mysql /usr/local/mysql/

2、建立配置文件

vi /etc/my.cnf //原先的删掉插入新的

[client]

port = 3306

default-character-set=utf8

socket = /usr/local/mysql/mysql.sock

[mysql]

port = 3306

default-character-set=utf8

socket = /usr/local/mysql/mysql.sock

[mysqld]

user = mysql

basedir = /usr/local/mysql

datadir = /usr/local/mysql/data

port = 3306

character_set_server=utf8

pid-file = /usr/local/mysql/mysqld.pid

socket = /usr/local/mysql/mysql.sock

server-id = 1

sql_mode=NO_ENGINE_SUBSTITUTION,STRICT_TRANS_TABLES,NO_AUTO_CREATE_USER,NO_AUTO_VALUE_ON_ZERO,NO_ZERO_IN_DATE,NO_ZERO_DATE,ERROR_FOR_DIVISION_BY_ZERO,PIPES_AS_CONCAT,ANSI_QUOTES //固定格式

:x

chown mysql:mysql /etc/my.cnf

3、设置环境变量

echo 'PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH' >> /etc/profile //把这两个路径添加到环境变量中,并放到profile文件中使之开机自运行,否则不生效

echo 'export PATH' >> /etc/profile //也可以软链接

source /etc/profile //立即生效

4、初始化数据库

cd /usr/local/mysql/

bin/mysqld \

--initialize-insecure \

--user=mysql \

--basedir=/usr/local/mysql \

--datadir=/usr/local/mysql/data //mysql初始化

5、添加系统服务

cp usr/lib/systemd/system/mysqld.service /usr/lib/systemd/system/

systemctl daemon-reload

systemctl start mysqld //启动数据库

netstat -anpt | grep 3306

bf563869036d61e580cca7f093f82918.png

systemctl enable mysqld //开机自启

6、设置数据密码

mysqladmin -u root -p password "123" //给root账号设置密码

7、登陆数据库

mysql -u root -p //数据库登陆成功,可以在里面进行操作了

3bf2060b87dc974c91fa87cff5cdfd43.png

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值