Linux下二进制编译安装MySql centos7的教程
// 当时我装这个也是折腾了一下午 , 所以写一个笔记记录一下;
//如果哪里有问题的话我们可以一起讨论( qq: 2970911340,邮箱+@qq.com),这也是我第一次写博客 练练手
1. 安cmake工具
# yum install -y cmake
2. 创建mysql用户
#useradd -s /sbin/nologin mysql //设置为非登陆用户(安全)
3. 创建数据目录,该目录是用于数据库初始化时生成的库、表、日志等,不要直接在该目录下存放东西
# mkdir -p /mysql/data //目录名随意(后面设置时要对应),但目录所在分区剩余空间不能小于1g(不是很清楚)
# chown mysql.mysql /mysql/ -R // 将该目录的属主属组设置为mysql
4.安装编译时所需要的开发包等
# yum install ncurses-devel openssl-devel gcc* -y
5.解压mysql二进制包,并编译
# cd /packet //cd 到 存放包的目录下
# tar xvf mysql-5.6.22.tar.gz
# cd mysql-5.6.22
//直接开始编译,注意:一定要进入解压后的mysql包里在编辑 然后 cmake 接一大堆参数 有一些可以省略的
#cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/mysql/data -DDEFAULT_CHARSET=utf8 -DEXTRA_CHARSETS=all -DDEFAULT_COLLATION=utf8_general_ci -DWITH_SSL=system -DWITH_EMBEDDED_SERVER=1 -DENABLED_LOCAL_INFILE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_SSL=bundled
// -DCMAKE_INSTALL_PREFIX=/usr/local/mysql //指定安装目录
//-DMYSQL_DATADIR=/mysql/data //指定数据目录,上面创建的那个
//其它的略。。。
6.错误解决(一般来说按照上面来是不会出错的)
# rm -rf CMakeCache.txt
//当编译出现错误后 一定要先删除 CMakeCache.txt 再重新编译,该文件编译时会自动生成有点像 “记账本 ”记录编译时的一些信息。。。
//错误大全暂时先放一放后面更新。。。
7.安装
# make -j 4 // -j 4 使用4核编译,因为编译很要好久所以多给它几个u
# make install
8.初始化
# yum install -y perl-Data-Dumper //会提示安装这个
# /usr/local/mysql/scripts/mysql_install_db --user=mysql --datadir=/mysql/data/ --basedir=/usr/local/mysql
//初始化完毕后可以在 /mysql/data/ 目录下看到生成的基本库和日志等
// 里面 client21.err (主机名.err)会记录 mysql服务启动 重启 关闭时的日志,如果启动有问题时可以看该日志
# tail -50 /mysql/data/client21.err
9. 启动配置,启动
# cp /usr/local/mysql/mysql-test/include/default_my.cnf /etc/my.cnf //该文件是mysql服务的配置文件
# cat > /etc/my.cnf //将里面的内容都删除掉否则后面会有问题,也可以自己添加一些选项进去
# /usr/local/mysql/bin/mysqld_safe --user=mysql & //放入后台启动,不加 '&'当前终端就会废掉,可以试试看
//当然中间也可能会有一些令人头疼的错误,后面有时间会跟新…
eg:排查思路看提示信息,错误日志的地址 , 从哪启动
1. selinux 是否关闭 //setenforce 0 临时关闭
2. 是否正常初始化
3. cp的/etc/my.cf 配置文件里的数据路径 ‘datadir ‘是否正确
10.将命令定义成系统命令(可以忽略这一步)
# vim /etc/profile.d/mysql.sh
export PATH=/usr/local/mysql/bin:$PATH //只需要添加这一行就行
# source /etc/profile.d/mysql.sh
11.设置开机启动
# cp /usr/local/mysql/support-files/mysql.server /etc/init.d/mysqld
# chkconfig --add mysqld //将mysqld添加到chkconfig管理的开机启动中
# chkconfig --list | grep mysqld //查看mysqld在各运行级别中是否开机启动
mysqld 0:off 1:off 2:on 3:on 4:on 5:on 6:off
而且设置完后 可以直接 用 systemctl restart | start mysqld 控制了,( stop 用不了,暂时不知道为啥 可以先用 ‘ pkill mysqld ‘ 代替)
12. 本机测试访问 , 在本机上下载mysql客户端(不是服务哦)
# yum install -y mysql //这样装的是mariadb客户端,体验会比我的mysql好一点 其实都是一样的
# mysql //直接进入 ,测试一下有没有问题
//如果能正常读写说明没有问题, very good !
总结
以上所述是小编给大家介绍的Linux下二进制编译安装MySql centos7的教程,希望对大家有所帮助,如果大家有任何疑问请给我留言,小编会及时回复大家的。在此也非常感谢大家对ZaLou.Cn网站的支持! 如果你觉得本文对你有帮助,欢迎转载,烦请注明出处,谢谢!
- DNS Tunneling及相关实现
- 创建代码生成器可以很简单:如何通过T4模板生成代码?[下篇]
- 创建代码生成器可以很简单:如何通过T4模板生成代码?[上篇]
- 从Trace和Debug来看条件编译(Conditional Compilation)
- 解码针对工业工程领域的网络攻击 Operation Ghoul「食尸鬼行动」
- EndpointAddress——不只是一个Uri[上篇]
- EndpointAddress——不只是一个Uri[下篇]
- ASP.NET Core中如影随形的”依赖注入”[上]: 从两个不同的ServiceProvider说起
- ASP.NET Core中如影随形的”依赖注入”[下]: 历数依赖注入的N种玩法
- ASP.NET Core中的缓存[1]:如何在一个ASP.NET Core应用中使用缓存
- ASP.NET Core的路由[5]:内联路由约束的检验
- .NET Core跨平台的奥秘[下篇]:全新的布局
- Equation Group泄露文件分析
- ModelBinder——ASP.NET MVC Model绑定的核心
- JavaScript 教程
- JavaScript 编辑工具
- JavaScript 与HTML
- JavaScript 与Java
- JavaScript 数据结构
- JavaScript 基本数据类型
- JavaScript 特殊数据类型
- JavaScript 运算符
- JavaScript typeof 运算符
- JavaScript 表达式
- JavaScript 类型转换
- JavaScript 基本语法
- JavaScript 注释
- Javascript 基本处理流程
- Javascript 选择结构
- Javascript if 语句
- Javascript if 语句的嵌套
- Javascript switch 语句
- Javascript 循环结构
- Javascript 循环结构实例
- Javascript 跳转语句
- Javascript 控制语句总结
- Javascript 函数介绍
- Javascript 函数的定义
- Javascript 函数调用
- Javascript 几种特殊的函数
- JavaScript 内置函数简介
- Javascript eval() 函数
- Javascript isFinite() 函数
- Javascript isNaN() 函数
- parseInt() 与 parseFloat()
- escape() 与 unescape()
- Javascript 字符串介绍
- Javascript length属性
- javascript 字符串函数
- Javascript 日期对象简介
- Javascript 日期对象用途
- Date 对象属性和方法
- Javascript 数组是什么
- Javascript 创建数组
- Javascript 数组赋值与取值
- Javascript 数组属性和方法
- 最通俗易懂的一篇文章了解JVM、JRE、JDK的关系是什么?
- 六. CSS 样式补充之 font & background
- 七 .Html的表格
- rollup + typescript 构建 ts 包
- node 写爬虫,原来这么简单
- 计时器 hook
- 自定义eslint 配置包
- 【61期】MySQL行锁和表锁的含义及区别(MySQL面试第四弹)
- 关于死锁你了解多少,通过“让APP随手机壳改变颜色,程序员和产品经理大家”这一事,了解下死锁可好?
- 三阴性乳腺癌表达矩阵探索笔记之GSEA
- 关于Python异常处理,你需要了解的知识点
- 三阴性乳腺癌表达数据探索笔记之GSVA分析
- 无敌解决GitHub无法ping通也无法登录的问题无敌解决idea连接GitHub提示Invalid authentication data. Connection reset
- 文献笔记七十一:REDO根据vcf文件检测植物细胞器基因组RNA编辑位点
- 如如何基于Docker快速搭建Elasticsearch集群?