Chinaunix首页 | 论坛 | 博客
  • 博客访问: 581071
  • 博文数量: 104
  • 博客积分: 0
  • 博客等级: 民兵
  • 技术积分: 1559
  • 用 户 组: 普通用户
  • 注册时间: 2014-08-21 00:58
个人简介

锻炼精神,首先要锻炼肉体

文章分类

全部博文(104)

文章存档

2018年(1)

2016年(1)

2015年(101)

2014年(1)

我的朋友

分类: Mysql/postgreSQL

2015-07-19 09:11:18

首先,找到 mysql 官网, 找到对应的版本, 将下拉列表项选择 source code 选项。
然后,选择和操作系统匹配的版本, 我的是 red hat enterprise 7
下载 *.src.rpm 文件包到本地

命令 1 rpm2cpio MySQL-5.6.25.1.el7.src.rpm | cpio -div
        解压得到 mysql-*.tar.gz 源码压缩包

命令 2 tar -xzf mysql-5.6.25.tar.gz 
       解压得到文件源码目录, 按照源码步骤安装即可
-----------------------------------------------------
mysql 源码安装
1. 使用 yum install 先来安装 mysql 编译的时候需要依赖的工具
    # yum install cmake 
    # yum install bison
2. 创建 mysql 用户和用户组
  # groupadd  mysql
    # useradd -g mysql mysql 
3. 切换路径至 mysql 解压之后的源码文件夹
   创建 cmakeFolder , 目的是缓存编译生成的文件, 如果安装出错可以直接清空该文件夹,不会‘污染’ 源码文件夹
4. 切换路径至 cmakeFolder 
    # cmake ../ 
5. 出现系统找不到依赖库 , 报错 ----> 清空 makeFolder 中的文件
   # yum install ncurses-devel / 如果 os 是 ubuntu 的话, 使用命令 #apt-get install libncurses5-dev
6. 重新切入路径至 cmakeFolder 
    #cmake ../     \
    -DCMAKE_INSTALL_PREFIX=/usr/local/mysql \
    -DMYSQL_DATADIR=/usr/local/mysql/data  \
    -DDEFAULT_CHARSET=utf8                \
    -DDEFAULT_COLLATION=utf8_general_ci     \
    -DEXTRA_CHARSETS=all                 \
    -DENABLED_LOCAL_INFILE=1

    正确编译显示如下信息
  
    
7. 执行命令 make && make install
    安装开始
  


如果计算机配置比较好,可以 make -j 8-128 来启动多线程进行编译,配置较差的话就不行了,虚拟机会卡。
遇到编译中断,很大可能都是出现不可再现的系统错误,只需要重新输入 make && make install 即可继续安装。

8. 成功安装之后,来试着启动 mysql
   将路径切换至, /usr/local/mysql/scripts/
    # ./mysql_install_db --user=root --basedir=/usr/local/mysql --datadir=/usr/local/mysql/data --defaults-file=/etc/my.cnf
  8.1 修改 /etc/my.cnf 文件,如下所示

        
    
  8.2 根据文件来在系统中创建对应的文件夹
  8.3 启动 mysql 服务器
        路径切换至 /usr/local/mysql/bin
       # ./mysql_safe --defaults-file=/etc/my.cnf --user=root & 
   8.4 启动 mysql 命令行客户端
       # ./mysql 
       # show databases ;       




7.25 
今天启动 mysql 的时候报错, 启动 mysql 服务器总是失败,当然,登陆 mysql 客户端也不成功。
具体的原因是没有在mysq 的主目录下面为 mysql 用户分配相关的权限,
解决方法是, 首先切换到 mysql 安装的路径下面,
# cd /usr/local/mysql 
# chown -R  mysql.mysql .

然后重新启动 
# /etc/init.d/mysql start 
# ./mysql 
启动成功

在这里,再记录一下,
将 linux 系统中安装的
 mysql 设置为大小写不敏感的方法
在 windows 系统中, mysql 默认的是大小写不敏感,就是两张表 TEST, test , 
在 windows 下面无法存在于同一个数据库中,
因为表名称一样/大小写不敏感,对于 windows 来说, TEST=test .
但是在 linux 下面默认的是 TEST != test , 这样会在数据库中间件通过配置文档查找数据表的时候,
会找不到名称为 test , 实际上在数据库中以 TEST 名称存放, 的数据表。


在 linux 下设置大小写不敏感的方法, 打开 /etc/my.cnf 文件
在 [mysqld] 下面添加

lower_case_table_names=1 

在重新启动数据库服务即可, 但是这次重启再次失败,
将存放数据文件信息全部删除/注意是删除配置信息, 而非删除数据库相关文件

将作为 mysql data dir 下面的配置文件全部删除,
在我的linux 上面就是,删除了 /usr/local/mysql/data/  下面除了文件夹之外的所有文件
这些文件都是 mysql 数据库启动的时候写入到该路径下面的,

下次启动还会生成,所以无需担心删除之后对数据库造成无法启动的后果。
再次启动数据库即可

  
 

end
阅读(1768) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~