开发者社区> 科技小能手> 正文

Linux从入门到精通之源码编译安装 MySQL

简介:
+关注继续查看

1.安装cmake
MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具。
因此,我们首先要在系统中源码编译安装cmake工具。

#wgethttp://www.cmake.org/files/v2.8/cmake-2.8.4.tar.gz

#tarzxvfcmake-2.8.4.tar.gz

#cdcmake-2.8.4

#./configure
#make
#makeinstall

2.确保以下所需系统软件包已经被安装
通过rpm-qa|grepname的方式验证以下软件包是否已全部安装。
gcc*gcc-c++*autoconf*automake*zlib*libxml*ncurses-devel*libgcrypt*libtool*

如果缺少相关的软件包,可通过yum-yinstall的方式在线安装,或直接从系统安装光盘中找到并通过rpm-ivh的方式安装。

3.安装前的系统设置
建立mysql安装目录及数据存放目录
#mkdir/opt/mysql
#mkdir/opt/mysql/data

创建用户和用户组
#groupaddmysql
#useradd-gmysqlmysql

赋予数据存放目录权限
#chownmysql:mysql-R/opt/mysql/data

4.从configure更换为cmake
我相信大多数人都已经习惯了之前的configure方式,并且所使用的参数也是比较个性化的,换成cmake之后,这一方面会带来不少的麻烦。
还好,MySQL的官方网站提供了二者的参数对照表,我们可以尽可能的保留之前的参数,来编译配置新的MySQL版本。

configure与cmake参数对照指南:
http://forge.mysql.com/wiki/Autotools_to_CMake_Transition_Guide

以我自己为例,之前我一直使用的参数为:
./configure--prefix=/opt/mysql/\
--sysconfdir=/opt/mysql/etc\
--localstatedir=/opt/mysql/data\
--with-tcp-port=3306\
--with-unix-socket-path=/tmp/mysqld.sock\
--with-mysqld-user=mysql\
--enable-assembler\
--with-extra-charsets=all\
--enable-thread-safe-client\
--with-big-tables\
--with-readline\
--with-ssl\
--with-embedded-server\
--enable-local-infile\
--with-plugins=partition,innobase,myisammrg

经过与cmake的参数对照之后,去除掉已经被取消的参数(大多数是因为新版本已经默认启用),cmake的参数配置如下:
cmake-DCMAKE_INSTALL_PREFIX=/opt/mysql\
-DSYSCONFDIR=/opt/mysql/etc\
-DMYSQL_DATADIR=/opt/mysql/data\
-DMYSQL_TCP_PORT=3306\
-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock\
-DMYSQL_USER=mysql\
-DEXTRA_CHARSETS=all\
-DWITH_READLINE=1\
-DWITH_SSL=system\
-DWITH_EMBEDDED_SERVER=1\
-DENABLED_LOCAL_INFILE=1\
-DWITH_INNOBASE_STORAGE_ENGINE=1

5.编译安装MySQL5.5.x
通过http://www.mysql.com/downloads/mysql官方网址或国内的sohu镜像下载软件包,如目前最新的MySQL5.5.13。
#wgethttp://mirrors.sohu.com/mysql/MySQL-5.5/mysql-5.5.13.tar.gz

#tarzxvfmysql-5.5.13.tar.gz

#cdmysql-5.5.13
#cmake-DCMAKE_INSTALL_PREFIX=/opt/mysql\
-DSYSCONFDIR=/opt/mysql/etc\
-DMYSQL_DATADIR=/opt/mysql/data\
-DMYSQL_TCP_PORT=3306\
-DMYSQL_UNIX_ADDR=/tmp/mysqld.sock\
-DMYSQL_USER=mysql\
-DEXTRA_CHARSETS=all\
-DWITH_READLINE=1\
-DWITH_SSL=system\
-DWITH_EMBEDDED_SERVER=1\
-DENABLED_LOCAL_INFILE=1\
-DWITH_INNOBASE_STORAGE_ENGINE=1

#make
#makeinstall

在make与makeinstall的时候可以看到进度百分比,感觉这一点要比configure方式要好。

6.配置并初始化数据库
创建my.cnf配置文件
#mkdir/opt/mysql/log

#mkdir/opt/mysql/etc
#cpsupport-files/my-medium.cnf/opt/mysql/etc/my.cnf

初始化数据库
执行前需赋给scripts/mysql_install_db文件执行权限
#chmod755scripts/mysql_install_db
#scripts/mysql_install_db--user=mysql--basedir=/opt/mysql/--datadir=/opt/mysql/data/

创建管理MySQL数据库的shell脚本
#mkdir/opt/mysql/init.d
#cpsupport-files/mysql.server/opt/mysql/init.d/mysql

赋予shell脚本可执行权限:
#chmod+x/opt/mysql/init.d/mysql

启动MySQL:
#/opt/mysql/init.d/mysqlstart

通过命令行登录管理MySQL服务器(提示输入密码时直接回车):
#/opt/mysql/bin/mysql-uroot-p-S/tmp/mysql.sock

输入以下SQL语句,创建一个具有root权限的用户(admin)和密码(12345678):
GRANTALLPRIVILEGESON*.*TO'admin'@'localhost'IDENTIFIEDBY'12345678';
GRANTALLPRIVILEGESON*.*TO'admin'@'127.0.0.1'IDENTIFIEDBY'12345678';

为root帐户设置初始密码
#/opt/mysql/bin/mysqladmin-urootpassword'new-password'

删除本机匿名连接的空密码帐号
/opt/mysql/bin/mysql-uroot-p'new-password'
mysql>usemysql;//选择系统数据库mysql
mysql>selectHost,User,Passwordfromuser;//查看所有用户
mysql>deletefromuserwherepassword="";
mysql>flushprivileges;
mysql>selectHost,User,Passwordfromuser;//确认密码为空的用户是否已全部删除
mysql>exit;



本文转自Devin 51CTO博客,原文链接:http://blog.51cto.com/devingeng/1300895

版权声明:本文内容由阿里云实名注册用户自发贡献,版权归原作者所有,阿里云开发者社区不拥有其著作权,亦不承担相应法律责任。具体规则请查看《阿里云开发者社区用户服务协议》和《阿里云开发者社区知识产权保护指引》。如果您发现本社区中有涉嫌抄袭的内容,填写侵权投诉表单进行举报,一经查实,本社区将立刻删除涉嫌侵权内容。

相关文章
终结初学者对ElasticSearch、Kibana、Logstash安装的种种困难《玩转ElasticSearch 1》-1
终结初学者对ElasticSearch、Kibana、Logstash安装的种种困难《玩转ElasticSearch 1》
7 0
如何让脚本在任意地方可执行
如何让脚本在任意地方可执行
5 0
为什么不让用join?《死磕MySQL系列 十六》
为什么不让用join?《死磕MySQL系列 十六》
9 0
Win 终端 putty & pscp & kitty 使用
前言 受制于 Xshell 的收费,寻思构建一套免费的 ssh 方案。 putty 双击即可直接使用 用它来远程管理 Linux 十分好用,其主要优点如下: ◆ 完全免费; ◆ 在 Windows 9x/NT/2000 下都能运行的都非常好; ◆ 支持协议广 用快捷方式实现自动登陆 首先创建 putty.exe 的快捷方式到桌面;然后运行 putty,输入 host name、port、saved session’s name,点击保存,假设 session 名为“qa server”,随后关闭窗口;最后右击 putty 快捷方式,属性,目标,加上如下参数 -load "qa server"
9 0
SpringBoot入门整合 上手 简单易解
SpringBoot入门整合 上手 简单易解
11 0
Win 独享 WSL 并搭配 Oh My Zsh
Windows Subsystem for Linux(简称 WSL)是一个在 Windows 10/11 上能够运行原生 Linux 二进制可执行文件(ELF 格式)的兼容层。
8 0
lagou 爪哇 1-2 spring 笔记
任务一 自定义IoC&AOP框架 1.1 IoC IoC 全称为 Inversion of Control,翻译为 “控制反转”,它还有一个别名为 DI(Dependency Injection),即依赖注入。 1. 谁控制谁 (由 Spring IoC 容器来负责对象的生命周期和对象之间的关系) 2. 控制什么 (bean对象创建,属性注入) 3. 为何是反转 (依赖的对象由原来的主动获取变成被动接受,所以是反转) 4. 哪些方面反转了(所依赖对象的获取被反转了) hibernate中的inverse也是一种IoC
7 0
Google应该这样玩,你知道这些技巧吗?
网络让世界变成了“地球村”,拉近了世界各地人与人之间的距离;搜索引擎更是让我们在互联网上没有秘密可言,查找网页,查找信息,查找人,我们都离不开它。
11 0
终结初学者对ElasticSearch、Kibana、Logstash安装的种种困难《玩转ElasticSearch 1》-2
终结初学者对ElasticSearch、Kibana、Logstash安装的种种困难《玩转ElasticSearch 1》
7 0
终结初学者对ElasticSearch、Kibana、Logstash安装的种种困难《玩转ElasticSearch 1》-3
终结初学者对ElasticSearch、Kibana、Logstash安装的种种困难《玩转ElasticSearch 1》
7 0
23705
文章
0
问答
文章排行榜
最热
最新
相关电子书
更多
OceanBase 入门到实战教程
立即下载
阿里云图数据库GDB,加速开启“图智”未来.ppt
立即下载
实时数仓Hologres技术实战一本通2.0版(下)
立即下载