mysql源码可以到官网下载

安装依赖包

yum -y install gcc gcc-c++ ncurses ncurses-devel bison libgcrypt perl make cmake

创建组mysql

groupadd mysql

创建用户mysql

useradd -r -g mysql -s /bin/false -M mysql

创建mysql 的安装目录

mkdir -p /usr/local/mysql

创建mysql数据存储目录

mkdir -p /data/mysql

修改目录的用户所属

chown mysql:mysql -R /data

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

下载mysql源文件

tar -zxvf mysql-boost-5.7.25.tar.gz

解压到当前目录,然后进入mysql源文件目录

cd mysql-boost-5.7.25

mv boots /usr/local/mysql/boost

cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/data/mysql -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DMYSQL_TCP_PORT=3306 -DMYSQL_USER=mysql -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DENABLE_DOWNLOADS=1 -DDOWNLOAD_BOOST=1 -DWITH_BOOST=/usr/local/mysql/boost

在这里出现了一个警告

重新执行一下上面的cmake命令,警告就没了

make

可能会出现错误,可能是因为内存不足导致

我这里是内存不足的原因

然后添加了虚拟内存,就可以继续编译了

dd if=/dev/zero of=/swapfile bs=1k count=2048000      注:(count表示虚拟内存大小,我这里用了2G,一般跟物理内存一样或者大虚拟内存一倍)

mkswap /swapfile

swapon /swapfile

然继续编译就OK

make

make install

我重新的执行了一次修改了文件所属用户,因为安装后有新的目录

chown mysql:mysql -R /data

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

添加环境变量

echo "export PATH=$PATH:/home/mysql/bin" >> /etc/profile

source /etc/profile

初始化数据库  –initialize 表示默认生成一个安全的密码,–initialize-insecure 表示不生成密码

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

出现了一个警告和错误

警告:[Warning] TIMESTAMP with implicit DEFAULT value is deprecated. Please use --explicit server option (see documentation for more details)

错误:--initialize specified but the data directory has files in it

警告的解决方法是

vim /etc/my.cnf

在[mysqld]写入  explicit_defaults_for_timestamp=1

报错误的原因是因为存放数据的目录下有文件

mv /data/mysql/* /tmp 移动走就好了

重新执行一遍初始化数据库

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

初始化成功

拷贝mysql启动文件到/etc/init.d/ ,并赋予执行权限

注:support-files/mysql.server这个文件在mysql刚编译的目录下(即是解压的目录下)

cp support-files/mysql.server /etc/init.d/mysqld

chmod +x /etc/init.d/mysqld

设置mysql开机启动

chkconfig --add mysqld

chkconfig mysqld on

这是我的etc.cnf配置文件

启动数据库

service mysqld start(或者/etc/init.d/mysqld start)

进入数据库

这里出现了一个错误

解决方法是修改/etc/my.cnf

添加这两个路径

接着又一个错误,可能是因为我初始化数据库太久了,所有密码过期了 Your password has expired. To log in you must change it using a client that supports expired passwords.

修改my.cnf 加入无密登陆数据库

skip-grant-tables

重启mysql即可

重新设置mysql密码

use mysql;  切换到user库

grant all on * to 'root'@'localhost' identified by '123456';  一次执行会报错

FLUSH PRIVILEGES;  刷新权限

grant all on * to 'root'@'localhost' identified by '123456';  再次执行即可

%表示允许远程登陆

localhost表示本地登陆

记得把my.cnf里的 skip-grant-tables 注释掉或者删除 然后再重启服务器

重新输入密码进入即可

٩(๑>◡<๑)۶

centos7 编译安装mysql5.7的更多相关文章

  1. centos7编译安装MySQL5.7.9

    title: centos7编译安装MySQL5.7.9 date: 2016-05-12 16:20:17 tags: --- Centos7编译安装mysql5.7.9 mysql5.7有更好的性 ...

  2. CentOS7 编译安装MySQL5.6.38(一)

    一.下载MySQL5.6.38安装包 下载地址:https://www.mysql.com/downloads/  打开网站之后选择Archives 然后再选择开源版本 选择我们要下载的版本: htt ...

  3. CentOS7编译安装MySQL5.7.24

    目录 安装依赖 安装boost 编译安装MySQL 配置 登录MySQL,修改密码 安装依赖 (1)cmake是新版MySQL的编译工具 sudo yum install gcc gcc-c++ pc ...

  4. CentOS7编译安装mysql-5.6.43

    Step 1:安装编译需要的软件和工具 [root@node-1 ~]# yum install gcc gcc-c++ cmake ncurses-devel bison Step 2:创建mysq ...

  5. centos7编译安装mysql5.6

    先安装如下依赖包: $ yum -y install make gcc-c++ cmake bison-devel  ncurses-devel 下载MySQL5.6.14安装包,https://pa ...

  6. centos7.2环境编译安装mysql5.5.48

    一.安装cmake编译工具 跨平台编译器 查看是否已经安装了gcc # rpm -qa | grep gcc # yum install -y gcc-c++ # yum install -y cma ...

  7. Centos7编译安装lnmp(nginx1.10 php7.0.2)

    我使用的是阿里云的服务器 Centos7 64位的版本 1. 连接服务器 这个是Xshell5的版本 安装好之后我们开始连接服务器 2. 安装nginx 首先安装nginx的依赖 yum instal ...

  8. 编译安装MySQL-5.7.13

    编译安装MySQL-5.7 cmake的重要特性之一是其独立于源码(out-of-source)的编译功能,即编译工作可以在另一个指定的目录中而非源码目录中进行,这可以保证源码目录不受任何一次编译的影 ...

  9. 转:Linux 编译安装 Mysql5.7

    http://broqiang.com/2017/04/18/Mysql-Install-5.7.18-Linux-Compile/ 原文 Linux 编译安装 Mysql5.7 Ubuntu 下快速 ...

随机推荐

  1. js判断PC端还是移动端的代码小坑

    我在写官网的时候做了pc和移动端两个,在通过网上查找了这样的代码,看着完全没问题,等放进去页面中后,PC端页面一直刷新,根本停不下来,找了类似js还是同样的问题.通过不断尝试后才发现,问题就是多了一行 ...

  2. 前端每日实战:4# 视频演示如何用纯 CSS 创作一个金属光泽 3D 按钮特效

    效果预览 按下右侧的"点击预览"按钮在当前页面预览,点击链接全屏预览. https://codepen.io/zhang-ou/full/MGeRRO 可交互视频教程 此视频是可以 ...

  3. 前端每日实战:8# 视频演示如何用纯 CSS 创作一个充电 loader 特效

    效果预览 按下右侧的"点击预览"按钮在当前页面预览,点击链接全屏预览. https://codepen.io/zhang-ou/pen/deNqdV 可交互视频教程 此视频是可以交 ...

  4. 适合MCU用的C语言快速互转HEX(16进制)和原始字符串/数组方法

    缘由 这个起因是昨晚群里有人在讨论怎么把字符串转成HEX方法最佳,讨论到最后变成哪种方法效率最优了.毕竟这代码是要在MCU上面跑的,要同时考虑到时间和空间的最优解. 当然讨论的是有结果的,具体实现的方 ...

  5. MacOS麦克风输入监听的方法

    Windows上很多人都知道,然而实际上并没什么用——延迟太大,根本没法用. MacOS上有两种方法: QuickTime Player新建音频录制(不需要真的录音),如下图: 这个方法和Window ...

  6. Kubernetes Jenkins动态创建Slave

    目录 0.前言 1.Jenkins部署 2.配置jenkins动态slave 3.dubbo服务构建 3.1.制作dubbo镜像底包 3.2.制作slave基础镜像 3.2.1.Maven镜像 3.2 ...

  7. call 和 apply 和 bind的区别

    有些东西说忘就往,每天记录自己忘记的东西重新学习一遍,挺好 作用:call()和apply()用法都是一样的,改变this的指向问题 区别:接收参数的方式不同, (bind 方法是附加在函数调用后面使 ...

  8. ajax参数contentType与数据提交方式

    使用bootstrapTable时,服务器端无法获取参数(flask,request.form.get方法),检查发现是因为ajax提交的时候,方式是payload,要想用form提交,需要设置con ...

  9. Python基础篇_实例练习1

    1.逢7跳过小游戏:从1-100之间,遇到带7的数字或者7的倍数跳过. for i in range(1,101): if i == 7 or i % 10 == 7 or i // 10 == 7: ...

  10. Python生态_turtle库

    Python生态_turtle库: 绘制状态函数: pendown():别名pd(),落下画笔,之后,移动画笔将绘制形状 penup():抬起画笔 pensize():画笔粗细大小 颜色控制函数: p ...