centos7 编译安装mysql5.7
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的更多相关文章
- centos7编译安装MySQL5.7.9
title: centos7编译安装MySQL5.7.9 date: 2016-05-12 16:20:17 tags: --- Centos7编译安装mysql5.7.9 mysql5.7有更好的性 ...
- CentOS7 编译安装MySQL5.6.38(一)
一.下载MySQL5.6.38安装包 下载地址:https://www.mysql.com/downloads/ 打开网站之后选择Archives 然后再选择开源版本 选择我们要下载的版本: htt ...
- CentOS7编译安装MySQL5.7.24
目录 安装依赖 安装boost 编译安装MySQL 配置 登录MySQL,修改密码 安装依赖 (1)cmake是新版MySQL的编译工具 sudo yum install gcc gcc-c++ pc ...
- CentOS7编译安装mysql-5.6.43
Step 1:安装编译需要的软件和工具 [root@node-1 ~]# yum install gcc gcc-c++ cmake ncurses-devel bison Step 2:创建mysq ...
- centos7编译安装mysql5.6
先安装如下依赖包: $ yum -y install make gcc-c++ cmake bison-devel ncurses-devel 下载MySQL5.6.14安装包,https://pa ...
- centos7.2环境编译安装mysql5.5.48
一.安装cmake编译工具 跨平台编译器 查看是否已经安装了gcc # rpm -qa | grep gcc # yum install -y gcc-c++ # yum install -y cma ...
- Centos7编译安装lnmp(nginx1.10 php7.0.2)
我使用的是阿里云的服务器 Centos7 64位的版本 1. 连接服务器 这个是Xshell5的版本 安装好之后我们开始连接服务器 2. 安装nginx 首先安装nginx的依赖 yum instal ...
- 编译安装MySQL-5.7.13
编译安装MySQL-5.7 cmake的重要特性之一是其独立于源码(out-of-source)的编译功能,即编译工作可以在另一个指定的目录中而非源码目录中进行,这可以保证源码目录不受任何一次编译的影 ...
- 转:Linux 编译安装 Mysql5.7
http://broqiang.com/2017/04/18/Mysql-Install-5.7.18-Linux-Compile/ 原文 Linux 编译安装 Mysql5.7 Ubuntu 下快速 ...
随机推荐
- canvas初尝试
最近学习了canvas,就拿它做了这么个小东西,感觉已经爱上canvas了.上代码 /* * @auhor : 开发部-前端组-李鑫超 * @property { tableData : {Array ...
- 《即时消息技术剖析与实战》学习笔记11——IM系统如何保证服务高可用:流量控制和熔断机制
IM 系统的不可用主要有以下两个原因: 一是无法预测突发流量,即使进行了服务拆分.自动扩容,但流量增长过快时,服务已经不可用了: 二是业务中依赖的这些接口.资源不可用或变慢时,比如发消息可能需要依赖& ...
- nginx前端服务部署
一.登录服务器 登录跳板机 执行list,列出所有机器 执行dssh 机器序号,如dssh 1,选择机器 二. 创建nginx配置文件 进入nginx配置目录:cd usr/local/nginx/c ...
- eetcode必要技巧--动态规划(一)
首先我们要搞清楚什么是动态规划 动态规划是运筹学中用于求解决策过程中的最优化数学方法.当然,我们在这里关注的是作为一种算法设计技术,作为一种使用多阶段决策过程最优的通用方法. 当然这个很难理解,但是按 ...
- si4745 FM-AM-SW 音量控制芯片 驱动详解
在论坛上看到有人发这个dsp 芯片,仔细看了下,发现功能正合我意,网上能找到的资料(源码)不多 软件环境:linux4.1.36 arm-linux-gcc 4.3.2 实现功能:自动搜台,上一台, ...
- Java自学路线图之Java基础自学
自学Java要从Java基础语法开始自学,自学Java的过程中打好基础是很重要的!首先自学:面向对象基础,API基础,集合基础.这些对Java小白的数学和英语能力的要求门槛不高,在学习的过程中积累相应 ...
- MATLAB神经网络(3) 遗传算法优化BP神经网络——非线性函数拟合
3.1 案例背景 遗传算法(Genetic Algorithms)是一种模拟自然界遗传机制和生物进化论而形成的一种并行随机搜索最优化方法. 其基本要素包括:染色体编码方法.适应度函数.遗传操作和运行参 ...
- Core + Vue 后台管理基础框架7——APM
1.前言 APM,又称应用性能统计,主要用来跟踪请求调用链,每个环节调用耗时,为我们诊断系统性能.定位系统问题提供了极大便利.本系统采用的是Elastic Stack体系中的APM,主要是之前部门搞P ...
- 创建 VuePress + GithubPages + TravisCI 在线文档
目录 最终效果 思路 总体 过程 用到的东西 相关 创建Github仓库 创建Github仓库 SSH密钥链接Github 生成SSH密钥 Github添加SSH密钥 测试SSH密钥 配置VuePre ...
- 在vscode中怎样debug调试go程序
随着互联网时代的飞速发展,我们编码使用的开发利器也在不断更新换代,古话说工欲善其事必先利其器,对于Java开发者而言,eclipse和idea这两款神器各有千秋,因自己的爱好可以选取不同的IDE,但是 ...