一、Linux:MySQL的源码安装

1、安装前的准备

在安装之前需要安装一下必备的包和工具

  • gcc/g++:MySQL5.6开始,需要使用g++进行编译。
  • cmake:MySQL5.5开始,使用cmake进行工程管理,cmake需要2.8以上版本。
  • bison:MySQL语法解析器需要使用bison进行编译。
  • ncurses-devel:用于终端操作的开发包。
  • zlib:MySQL使用zlib进行压缩

功能需要的包

  • libxml:用于xml输入输出方式的支持。
  • opensll:使用opensll安全套接字通信。
  • dtrace:用于诊断MySQL问题。

有关于MySQL编译参数

  • CMAKE_BUILD_TYPE编译的版本类型:RelWithDebInfo和Debug,不同之处是RelWithDebInfo会进行优化。
  • CMAKE_INSTALL_PREFIX指定make install安装的目标路径。
  • SYSCONFDIR指定配置文件的默认路径。
  • MYSQL_DATADIR指定data目录的默认路径。
  • WITH_DEBUG指定是否有debugging信息,一般用于源码调试时,打开WITH_DEBUG,生产环境关闭。
  • ENABLED_PROFILING指定是否可以使用show profile显示操作执行的详细信息。
  • DEFAULT_CHARSET指定默认字符集,可以在启动的配置文件中指定。
  • DEFAULT_COLLATION指定默认字符比较、排序的规则。
  • WITH_EXTRA_CHARSETS指定其他可能使用的字符集。
  • INSTALL_LAYOUT指定安装的布局类型。
  • WITH_storage_STORAGE_ENGIN指定编译支持的存储引擎,默认支持MyISAM,MERGE,MEMORY,CSV存储引擎。更多详细参数可参考http://dev.mysql.com/doc/refman/5.5/en/source-configuration-options.html

本次安装环境

[root@wulaoer ~]# cat /etc/issue
CentOS release 6.5 (Final)
Kernel \r on an \m
[root@wulaoer ~]# uname -a
Linux wulaoer 2.6.32-431.el6.x86_64 #1 SMP Fri Nov 22 03:15:09 UTC 2013 x86_64 x86_64 x86_64 GNU/Linux
MySQL版本:5.6.12-log Source distribution

安装目录为:/usr/local/mysql/

数据目录为:/data/mysqldata

存储引擎包括:MEMORY,MyISAM,InnoDB等

字符集为:UTF8

2、源码安装MySQL

先安装需要用到的库:

[root@wulaoer ~]# yum -y install gcc-c++ gcc 
[root@wulaoer ~]# yum -y install ncurses-devel

下载所需软件包:

将下载的文件都放到/usr/local/src目录下,如下

[root@wulaoer ~]# cd /usr/local/src/ 
[root@wulaoer src]# wget http://www.cmake.org/files/v2.8/cmake-2.8.11.1.tar.gz --no-check-certificate
[root@wulaoer src]# wget http://ftp.gnu.org/gnu/bison/bison-2.7.tar.gz
[root@wulaoer src]# wget http://ftp.gnu.org/gnu/m4/m4-1.4.16.tar.gz
[root@wulaoer src]#  wget http://www.mysql.com/get/Downloads/MySQL-5.6/mysql-5.6.12.tar.gz/from/http://cdn.mysql.com/ 

安装cmake编译器

[root@wulaoer src]# tar -zxf cmake-2.8.11.1.tar.gz 
[root@wulaoer src]# cd cmake-2.8.11.1
[root@wulaoer cmake-2.8.11.1]# ./bootstrap 
[root@wulaoer cmake-2.8.11.1]# make && make install

检查cmake是否安装成功

[root@wulaoer cmake-2.8.11.1]# which cmake
/usr/local/bin/cmake
 安装m4
[root@wulaoer src]# tar -zxf m4-1.4.16.tar.gz  
[root@wulaoer src]# cd m4-1.4.16
[root@wulaoer m4-1.4.16]# ./configure 
[root@wulaoer m4-1.4.16]# make && make install 

安装bison

[root@wulaoer src]# tar -zxf bison-2.7.tar.gz 
[root@wulaoer src]# cd bison-2.7
[root@wulaoer bison-2.7]# ./configure && make && make install
 创建mysql用户与组,相关目录
[root@wulaoer ~]# /usr/sbin/groupadd mysql
[root@wulaoer ~]# /usr/sbin/useradd -g mysql mysql
[root@wulaoer ~]# mkdir -p /usr/local/mysql/
[root@wulaoer ~]# chown -R mysql:mysql /usr/local/mysql
[root@wulaoer ~]# mkdir -p /data/mysqldata
[root@wulaoer ~]# chown -R mysql:mysql /data/mysqldata

安装mysql

[root@wulaoer ~]# cd /usr/local/src/
[root@wulaoer src]# tar -zxf mysql-5.6.12.tar.gz 
[root@wulaoer src]# export CFLAGS="-O3 -g -fno-exceptions -static-libgcc -fno-omit-frame-pointer -fno-strict-aliasing"
[root@wulaoer src]# export CXXFLAGS="-O3 -g -fno-exceptions -fno-rtti -static-libgcc -fno-omit-frame-pointer -fno-strict-aliasing"
[root@wulaoer src]# export CXX=g++
[root@wulaoer mysql-5.6.12]# cmake -DCMAKE_INSTALL_PREFIX=/usr/local/mysql/
                            -DMYSQL_UNIX_ADDR=/tmp/mysql.sock
                            -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci
                            -DWITH_EXTRA_CHARSETS=utf8,gbk
                            -DWITH_PERFSCHEMA_STORAGE_ENGINE=1
                            -DWITH_FEDERATED_STORAGE_ENGINE=1
                            -DWITH_PARTITION_STORAGE_ENGINE=1
                            -DWITH_ARCHIVE_STORAGE_ENGINE=1
                            -DMYSQL_DATADIR=/data/mysqldata/
                            -DSYSCONFDIR=/usr/local/mysql/
                            -DWITH_SSL=bundled
                            -DENABLED_LOCAL_INFILE=1
                            -DWITH_INNOBASE_STORAGE_ENGINE=1
                            -DWITH_BLACKHOLE_STORAGE_ENGINE=1
                            -DENABLE_DOWNLOADS=1
[root@wulaoer mysql-5.6.12]# make && make install 

初始化数据库

[root@wulaoer mysql-5.6.12]# cd /usr/local/mysql/
[root@wulaoer mysql]# ./scripts/mysql_install_db --user=mysql --ldata=/data/mysqldata 

3、安装后的收尾工作

配置运行环境

[root@wulaoer ~]# vi /etc/profile 
PATH=/usr/local/mysql/bin:/usr/local/mysql/lib:$PATH
export PATH
[root@wulaoer ~]# source /etc/profile

创建开机启动

[root@wulaoer ~]# cd /usr/local/mysql/
[root@wulaoer mysql]# cp support-files/my-default.cnf /etc/my.cnf
cp:是否覆盖"/etc/my.cnf"? y
[root@wulaoer mysql]# cp support-files/mysql.server /etc/init.d/mysqld
[root@wulaoer mysql]# chkconfig --level 35 mysqld on
[root@wulaoer ~]# /etc/init.d/mysqld start
 
Starting MySQL.. ERROR! The server quit without updating PID file (/usr/local/mysql/data/wulaoer.pid).
 以上错误解决方法进mysql安装目录执行[root@wulaoer mysql]# scripts/mysql_install_db --user=mysql 
[root@wulaoer mysql]# /etc/init.d/mysqld start
 
Starting MySQL. SUCCESS!
 设置数据库密码
[root@wulaoer ~]# mysqladmin -u root password 'root'
[root@wulaoer ~]# mysql -uroot -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 2
Server version: 5.6.12 Source distribution
二、YUM安装

在yum安装之前需要设置以下网络yum源,参考点击这里

在安装之前要看以下系统有没有自带的mysql是否已经安装。

[root@wulaoer ~]# yum list installed | grep mysql
mysql.x86_64            5.1.73-5.el6_6  @base                                   
mysql-libs.x86_64       5.1.73-5.el6_6  @base                                   
mysql-server.x86_64     5.1.73-5.el6_6  @base   
[root@wulaoer ~]# yum -y remove mysql-libs.x86_64
当出现Complete!时候说明已经卸载完成,可以重新查看以下
[root@wulaoer ~]# yum list installed | grep mysql
[root@wulaoer ~]# 

使用yum list | grep mysql 查看yum库上的mysql版本信心

[root@wulaoer ~]# yum list | grep mysql 
apr-util-mysql.x86_64                    1.3.9-3.el6_0.1                base    
bacula-director-mysql.x86_64             5.0.0-13.el6                   base    
bacula-storage-mysql.x86_64              5.0.0-13.el6                   base    
dovecot-mysql.x86_64                     1:2.0.9-19.el6_7.2             updates 
freeradius-mysql.x86_64                  2.2.6-6.el6_7                  updates 
libdbi-dbd-mysql.x86_64                  0.8.3-5.1.el6                  base    
mod_auth_mysql.x86_64                    1:3.0.0-11.el6_0.1             base    
mysql.x86_64                             5.1.73-5.el6_6                 base    
mysql-bench.x86_64                       5.1.73-5.el6_6                 base    
mysql-connector-java.noarch              1:5.1.17-6.el6                 base    
mysql-connector-odbc.x86_64              5.1.5r1144-7.el6               base    
mysql-devel.i686                         5.1.73-5.el6_6                 base    
mysql-devel.x86_64                       5.1.73-5.el6_6                 base    
mysql-embedded.i686                      5.1.73-5.el6_6                 base    
mysql-embedded.x86_64                    5.1.73-5.el6_6                 base    
mysql-embedded-devel.i686                5.1.73-5.el6_6                 base    
mysql-embedded-devel.x86_64              5.1.73-5.el6_6                 base    
mysql-libs.i686                          5.1.73-5.el6_6                 base    
mysql-libs.x86_64                        5.1.73-5.el6_6                 base    
mysql-server.x86_64                      5.1.73-5.el6_6                 base    
mysql-test.x86_64                        5.1.73-5.el6_6                 base    
php-mysql.x86_64                         5.3.3-46.el6_6                 updates 
qt-mysql.i686                            1:4.6.2-28.el6_5               base    
qt-mysql.x86_64                          1:4.6.2-28.el6_5               base    
rsyslog-mysql.x86_64                     5.8.10-10.el6_6                base    
rsyslog7-mysql.x86_64                    7.4.10-3.el6_7.1               updates 

也可以使用yum -y list mysql*

[root@wulaoer ~]# yum -y list mysql*
Loaded plugins: fastestmirror, security
Loading mirror speeds from cached hostfile
 * c6-media: 
Available Packages
MySQL-python.x86_64                              1.2.3-0.3.c1.1.el6                      base
mysql.x86_64                                     5.1.73-5.el6_6                          base
mysql-bench.x86_64                               5.1.73-5.el6_6                          base
mysql-connector-java.noarch                      1:5.1.17-6.el6                          base
mysql-connector-odbc.x86_64                      5.1.5r1144-7.el6                        base
mysql-devel.i686                                 5.1.73-5.el6_6                          base
mysql-devel.x86_64                               5.1.73-5.el6_6                          base
mysql-embedded.i686                              5.1.73-5.el6_6                          base
mysql-embedded.x86_64                            5.1.73-5.el6_6                          base
mysql-embedded-devel.i686                        5.1.73-5.el6_6                          base
mysql-embedded-devel.x86_64                      5.1.73-5.el6_6                          base
mysql-libs.i686                                  5.1.73-5.el6_6                          base
mysql-libs.x86_64                                5.1.73-5.el6_6                          base
mysql-server.x86_64                              5.1.73-5.el6_6                          base
mysql-test.x86_64                                5.1.73-5.el6_6                          base

使用yum安装mysql数据库。

[root@wulaoer ~]# yum -y install mysql-server mysql mysql-devel 

注:安装mysql只是安装了数据库,只有安装了mysql-server才相当于安装了客户端。

当出现Complete!的时候说明数据库安装成功了,

设置数据库密码

[root@wulaoer ~]# mysqladmin -uroot password 'wulaoer'
mysqladmin: connect to server at 'localhost' failed
error: 'Access denied for user 'root'@'localhost' (using password: NO)'

注:如果没有报错,说明数据库密码修改成功了,如果有以上错误,请继续。

[root@wulaoer ~]# service mysqld stop #停止数据库
停止 mysqld:                                              [确定]
[root@wulaoer ~]# mysqld_safe --skip-grant-tables & #初始化数据库
[1] 25576
[root@wulaoer ~]# 160120 21:07:11 mysqld_safe Logging to '/var/log/mysqld.log'.
160120 21:07:11 mysqld_safe Starting mysqld daemon with databases from /var/lib/mysql [root@wulaoer ~]# mysql -uroot -p #直接进数据库不用密码
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.1.73 Source distribution Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement. mysql> use mysql; #切换到数据库
Reading table information for completion of table and column names
You can turn off this feature to get a quicker startup with -A Database changed
mysql> update user set password=PASSWORD("wulaoer")where user="root";#修改数据库的密码
Query OK, 3 rows affected (0.01 sec)
Rows matched: 3  Changed: 3  Warnings: 0
mysql> flush privileges;#更新权限
Query OK, 0 rows affected (0.00 sec) mysql> quit #退出
Bye
[root@wulaoer ~]# service mysqld start
正在启动 mysqld:                                          [确定]
[root@wulaoer ~]# mysql -uroot -p
Enter password: 
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 6
Server version: 5.1.73 Source distribution Copyright (c) 2000, 2013, Oracle and/or its affiliates. All rights reserved. Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners. Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

本文参考http://www.linuxidc.com/Linux/2014-10/108044.htm,请尊重别人的劳动成功。

MySQL:MySQL的安装的更多相关文章

  1. mysql 7下载安装及问题解决

    mysql 7安装及问题解决 一.mysql下载 下载地址:https://www.mysql.com/downloads/ Community (GPL) Downloads MySQL Commu ...

  2. MySQL多实例安装

    1.安装MySQL需要的依赖的包和编译软件   (1)安装MySQL需要的依赖包 安装MySQL之前,最好先安装MySQL需要的依赖包,不然后面会出现报错,还得回来安装MySQL的依赖包. [root ...

  3. mysql介绍及安装

    一.MySQL介绍 1.标志 MySQL的海豚标志的名字叫"sakila",它是由MySQL AB的创始人从用户在"海豚命名"的竞赛中建议的大量的名字表中选出的 ...

  4. MySQL数据库的安装与密码配置

                      MySQL是由MySQL AB公司开发,后由Oracle公司收购     MySQL是一个关系型数据库管理系统       分为社区版和企业版            ...

  5. my SQL下载安装,环境配置,以及密码忘记的解决,以及navicat for mysql下载,安装,测试连接

    一.下载 在百度上搜索"mysql-5.6.24-winx64下载" 二.安装 选择安装路径,我的路径“C:\Soft\mysql-5.6.24-winx64” 三.环境配置 计算 ...

  6. MySQL 5.5安装记录

    安装gnake ./configure && gmake && gmake install 安装ncurses-devel yum install -y ncurses ...

  7. Python之路-python(mysql介绍和安装、pymysql、ORM sqlachemy)

    本节内容 1.数据库介绍 2.mysql管理 3.mysql数据类型 4.常用mysql命令 创建数据库 外键 增删改查表 5.事务 6.索引 7.python 操作mysql 8.ORM sqlac ...

  8. mysql安装和mysql图形界面安装以及文本文件导入mysql

    本人大一大二一直使用windows系统,被微软爸爸给惯坏了,一看到cmd命令行就吓尿.现在用ubuntu,每一个操作都是语句,也是得到锻炼(个jb). ubuntu安装mysql和python代码 s ...

  9. MySQL下载、安装及启动

    介绍 Mysql是最流行的关系型数据库管理系统,在WEB应用方面MySQL是最好的RDBMS(Relational Database Management System:关系数据库管理系统)应用软件之 ...

  10. Debian MySQL 卸载和安装 PHP安装

    如果是apt-get安装的 sudo apt-get --purge remove mysql-serversudo apt-get --purge remove mysql-clientsudo a ...

随机推荐

  1. IoC容器Autofac正篇之依赖注入(七)

    依赖注入,这个专业词我们可以分为两个部分来理解: 依赖,也就是UML中描述事物之间关系的依赖关系,依赖关系描述了事物A在某些情况下会使用到事物B,事物B的变化会影响到事物A: 注入,医生通过针头将药物 ...

  2. Ansible4:Ad-hoc与命令执行模块【转】

    Ad-Hoc 是指ansible下临时执行的一条命令,并且不需要保存的命令,对于复杂的命令会使用playbook.Ad-hoc的执行依赖于模块,ansible官方提供了大量的模块. 如:command ...

  3. Bookmark

    http://stackoverflow.com/https://www.baidu.com/?tn=06074089_27_pghttp://apistore.baidu.com/http://to ...

  4. 【匈牙利算法】 二分图模板 poj 1274

    #include <iostream> #include <cstdio> #include <memory.h> using namespace std; int ...

  5. vi编辑器常见命令的使用

    Linux下的文本编辑器有很多种,vi 是最常用的,也是各版本Linux的标配.注意,vi 仅仅是一个文本编辑器,可以给字符着色,可以自动补全,但是不像 Windows 下的 word 有排版功能. ...

  6. HDU 2579/BFS/ Dating with girls(2)

    题目链接 /* 题意是是传统的迷宫加上一个条件,墙壁在k的整倍数时刻会消失,那么求到达出口的最短时间. 关键点在于某个点最多被走k次,标记vis[x][y][time%k]即可. */ #includ ...

  7. JS-DOM操作应用高级(二)

    搜索 字符串比较.忽略大小写----大小写转换.模糊搜索----search的使用.split.高亮显示及筛选 toLowerCase() 方法用于把字符串转换为小写 str.search('')   ...

  8. RMQ 详解

    RMQ(Range Minimum/Maximum Query)问题:RMQ问题是给定一个区间,求这个区间中的最大或最小值的问题 RMQ采用动态规划的思想来求解:(st算法:Square Table) ...

  9. jz2440 环境搭建遇到的问题

    已解决:

  10. C语言中的几种常见排序算法

    1.冒泡排序法:如果有N个数,两两相邻进行比较,将最值沉入最后一位置,要进行N-1轮比较, 第一轮要比较N-1次,第2轮只要比较N-1-1次,因为第一次已经把最值沉入最后一位置,故 不需在进行比较一次 ...