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,centeros7的更多相关文章

  1. linux下源码编译安装mysql

    1.安装依赖的包: yum install -y gdb cmake ncurses-devel bison bison-devel 2.创建mysql安装目录和数据文件目录 mkdir -p /us ...

  2. Linux下源码编译安装MySQL 5.5.8

    准备工作: 新建用户和用户组 groupadd mysql useradd -g mysql mysql 1:下载: bison-2.4.2.tar.bz2 cmake-2.8.3.tar.gz ma ...

  3. CentOS 6.6 下源码编译安装MySQL 5.7.5

    版权声明:转自:http://www.linuxidc.com/Linux/2015-08/121667.htm 说明:CentOS 6.6 下源码编译安装MySQL 5.7.5 1. 安装相关工具# ...

  4. Linux下源码编译安装rpy2

    R(又称R语言)是一款开源的跨平台的数值统计和数值图形化展现工具.rpy2是Python直接调用R的第三方库,它可以实现使用python读取R的对象.调用R的方法以及Python与R数据结构转换等.这 ...

  5. Linux 下源码编译安装 vim 8.1

    前言 目前 linux 的各个发行版基本上都是带了一个 vi 编辑器的,而本文要说的 vim 编辑器对 vi 做了一些优化升级,更好用.当我们需要远程操作一台 linux 服务器的时候,只能使用命令行 ...

  6. 在Linux下源码编译安装GreatSQL/MySQL

    欢迎来到 GreatSQL社区分享的MySQL技术文章,如有疑问或想学习的内容,可以在下方评论区留言,看到后会进行解答 GreatSQL社区原创内容未经授权不得随意使用,转载请联系小编并注明来源. 本 ...

  7. 1、Linux下源码编译安装PostgreSQL

    操作系统:Centos7 说明:postgresql必须在postgres用户下初始化数据库和启动,否则报错. PostgreSQL的特性 PostgreSQL是一种几乎可以运行在各种平台上的免费的开 ...

  8. Linux下源码编译安装PostgreSQL数据库

    我使用的Postgres的源码版本为 postgresql-9.3.5.系统为 CentOS6.5 ,是64位. 下载以后直接阅读其中的 README然后阅读其中的INSTALL,按照其中将的步骤做就 ...

  9. centos下源码编译安装MySQL

    解压下载的软件压缩包  tar xzvf mysql-5.1.63.tar.gz 进入解压的目录  cd mysql-5.1.63/ 安装需要的依赖包  yum install gcc gcc-c++ ...

随机推荐

  1. 安装k8s-1master多node节点

    卸载比较新的18.3版本,安装17.03版本 删除旧版本 sudo yum remove docker \ docker-client \ docker-client-latest \ docker- ...

  2. JAVA 基础编程练习题7 【程序 7 处理字符串】

    7 [程序 7 处理字符串] 题目:输入一行字符,分别统计出其中英文字母.空格.数字和其它字符的个数. 程序分析:利用 while 语句,条件为输入的字符不为'\n'. package cskaoya ...

  3. SpringBoot之解决一对一、多对一、多对多等关联实体在JSON序列化/输出时产生的无限递归死循环问题(infinite recursion)

    前言 这问题着实让人苦不堪言,有必要把它记下了. @JsonBackReference [亲测有效] 1.使用注解@JsonBackReference标记在有关联关系的实体属性上 2.仅导入此注解类有 ...

  4. Python C/S架构,网络通信相关名词,socket编程

    主要内容: 一.  C/S架构 二. 网络通信的相关名词 三. socket编程 一. C/S架构和B\S架构概述 1. C/S架构: Client/Server(客户端/服务端)架构 描述: C/S ...

  5. Summary of OAuth 2.0

    Summary of OAuth 2.0 1 Problems: This pattern of applications obtaining user passwords obviously has ...

  6. USACO 1.1 Your Ride Is Here

    直接模拟 #include<cstdio> #include<cstring> using namespace std; #define MAXN 10 #define MOD ...

  7. PHP学习(8)——面向对象(下)

    8.编写代码类 每个分离的函数可以执行一个明确的任务.任务越简单,编写与测试这个函数就越简单,当然也不要将这个函数分得太小——若将程序分成太多的小个体,读起来就会很困难. 使用继承可以重载操作.我们可 ...

  8. Javadoc文档生成工具-自定义版

    先上图来一波 本身JDK自带了doc文档生成工具,但是不支持排除类,方法,属性,虽然有个@deprecated可以使用,但是达不到我想要的结果(类会被标记为废弃类,编译使用时会提示), 而且类说明示例 ...

  9. 修改Jupyter Notebook默认目录

    Jupyter Notebook每次打开都需要先进到相应的文件夹再打开 很不方便 首先进入到Jupyter的安装目录,我的是 D:\Anaconda3\Scripts 然后,输入命令: jupyter ...

  10. 对pdf 表单域 或文本框的操作---动态填充PDF 文件内容

    前提:需要pdf模板:并且模板内容以pdf 文本框的形式填写 package com.test;import java.io.File;import java.io.FileOutputStream; ...