源代码编译安装MySQL5.5.25a

本文涉及的产品
云数据库 RDS MySQL,集群系列 2核4GB
推荐场景:
搭建个人博客
RDS MySQL Serverless 基础系列,0.5-2RCU 50GB
云数据库 RDS MySQL,高可用系列 2核4GB
简介:

 

源码编译安装MySQL-5.5

       需要事先准备cmake-2.8.8.tar.gz与mysql-5.5.25a.tar.gz两个包放入linux /usr/local/src中
 
    cmake的重要特性之一是其独立于源码(out-of-source)的编译功能,即编译工作可以在另一个指定的目录中而非源码目录中进行,这可以保证源码目录不受任何一次编译的影响,因此在同一个源码树上可以进行多次不同的编译,如针对于不同平台编译。
 
 

一、安装cmake

 
跨平台编译器
 

  
  
  1. [root@localhost src]# tar xf cmake-2.8.8.tar.gz   
  2. [root@localhost src]# cd cmake-2.8.8  
  3. [root@localhost cmake-2.8.8]# ./bootstrap   
  4. [root@localhost cmake-2.8.8]# make && make install  
 
 

二、编译安装mysql-5.5.25a

 

1、使用cmake编译mysql-5.5

cmake指定编译选项的方式不同于make,其实现方式对比如下:
./configure            cmake .
./configure --help     cmake . -LH or ccmake .
 
 
 
指定安装文件的安装路径时常用的选项:
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql
-DMYSQL_DATADIR=/data/mysql
-DSYSCONFDIR=/etc
 
 
默认编译的存储引擎包括:csv、myisam、myisammrg和heap。若要安装其它存储引擎,可以使用类似如下编译选项:
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
-DWITH_FEDERATED_STORAGE_ENGINE=1
 
若要明确指定不编译某存储引擎,可以使用类似如下的选项:
-DWITHOUT_<ENGINE>_STORAGE_ENGINE=1
比如:
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1
-DWITHOUT_FEDERATED_STORAGE_ENGINE=1
-DWITHOUT_PARTITION_STORAGE_ENGINE=1
 
如若要编译进其它功能,如SSL等,则可使用类似如下选项来实现编译时使用某库或不使用某库:
-DWITH_READLINE=1
-DWITH_SSL=system
-DWITH_ZLIB=system
-DWITH_LIBWRAP=0
 
其它常用的选项:
-DMYSQL_TCP_PORT=3306      //监听的端口号
-DMYSQL_UNIX_ADDR=/tmp/mysql.sock    //Unix通讯方式
-DENABLED_LOCAL_INFILE=1
-DEXTRA_CHARSETS=all
-DDEFAULT_CHARSET=utf8
-DDEFAULT_COLLATION=utf8_general_ci
-DWITH_DEBUG=0
-DENABLE_PROFILING=1
 
 
如果想清理此前的编译所生成的文件,则需要使用如下命令:
make clean
rm CMakeCache.txt
 
 

2、编译安装

①准备数据存放的文件系统

新建一个逻辑卷,这里假设其逻辑卷的挂载目录为/mydata,而后需要创建/mydata/data目录做为mysql数据的存放目录。

  
  
  1. [root@localhost init.d]# fdisk /dev/sda  
  2. //其中过程省略。。  
  3. [root@localhost init.d]# partprobe /dev/sda  
  4. //创建逻辑卷  
  5. [root@localhost init.d]# pvcreate /dev/sda5   
  6.  Writing physical volume data to disk "/dev/sda5"  
  7.  Physical volume "/dev/sda5" successfully created  
  8. [root@localhost init.d]# vgcreate myvg /dev/sda5  
  9.  Volume group "myvg" successfully created  
  10. [root@localhost init.d]# lvcreate -n mydata -L 5G myvg  
  11.  Logical volume "mydata" created  
  12. [root@localhost init.d]# lvs  
  13.  LV     VG     Attr   LSize Origin Snap% Move Log Copy% Convert  
  14.  mydata myvg   -wi-a- 5.00G                                        
  15.  lvtext vgtext -wi-a- 1.00G                                        
  16.  home   vol0   -wi-ao 4.88G                                        
  17.  root   vol0   -wi-ao 29.28G                                        
  18. [root@localhost init.d]# mke2fs -j /dev/myvg/mydata  
  19. //设置开机挂载  
  20. [root@localhost ~]# mkdir /mydata  
  21. [root@localhost ~]# vim /etc/fstab  
  22. //添加如下内容  
  23. /dev/myvg/mydata        /mydata                 ext3    defaults        0 0  
  24. [root@localhost ~]# mount –a //重新挂载  
  25. [root@localhost ~]# mkdir /mydata/data //作为数据的挂载目录  

②新建用户以安全方式运行进程:


  
  
  1. //创建用户  
  2. [root@localhost ~]# groupadd -r mysql  
  3. [root@localhost ~]# useradd -g mysql -r -s /sbin/nologin -M -d /mydata/data mysql  
  4. [root@localhost ~]# chown -R mysql:mysql /mydata/data  
 

③安装并初始化mysql


  
  
  1. //开始进行编译  
  2. [root@localhost src]# tar xf mysql-5.5.25a.tar.gz   
  3. [root@localhost src]# cd mysql-5.5.25a  
  4. [root@localhost src]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/mydata/data -DSYSCONFDIR=/etc -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_ARCHIVE_STORAGE_ENGINE=1 -DWITH_BLACKHOLE_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DWITH_SSL=system -DWITH_ZLIB=system -DWITH_LIBWRAP=0 -DMYSQL_UNIX_ADDR=/tmp/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci 
  5. [root@localhost src]# make && make install  
  6. [root@localhost mysql-5.5.25a]# cd ..  
  7. [root@localhost src]# cd ..  
  8. [root@localhost local]# pwd  
  9. /usr/local  
  10. [root@localhost local]# ln -sv /usr/local/src/mysql-5.5.25a mysql   
  11. [root@localhost local]# cd mysql  
  12. [root@localhost mysql]# chown -R mysql:mysql .  
  13. [root@localhost mysql]#scripts/mysql_install_db --user=mysql --datadir=/mydata/data  
  14. Installing MySQL system tables...  
 

④为mysql提供主配置文件:

 

  
  
  1. [root@localhost mysql]# cp support-files/my-large.cnf /etc/my.cnf  
  2. [root@localhost mysql]# vim /etc/my.cnf  
  3. //并修改此文件中thread_concurrency的值为你的CPU个数乘以2,比如这里使用如下行:  
  4. thread_concurrency = 2 
  5.    
  6. //另外还需要添加如下行指定mysql数据文件的存放位置:  
  7. datadir = /mydata/data   //添加此行指定mysql数据文件的存放位置  
 

⑤为mysql提供sysv服务脚本:


  
  
  1. [root@localhost mysql]# pwd  
  2. /usr/local/mysql  
  3. [root@localhost mysql]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld  
  4. [root@localhost mysql]# chmod +x /etc/rc.d/init.d/mysqld  
  5. //添加至服务列表:  
  6. [root@localhost mysql]# chkconfig --add mysqld  
  7. [root@localhost mysql]# chkconfig mysqld on  
为了使用mysql的安装符合系统使用规范,并将其开发组件导出给系统使用,这里还需要进行如下步骤:

 ⑥输出mysql的man手册至man命令的查找路径:


  
  
  1. [root@localhost mysql]# vim /etc/man.config  
  2. #####################mysql#############  
  3. MANPATH /usr/local/mysql/man  
 

 ⑦输出mysql的头文件至系统头文件路径/usr/include


  
  
  1. 这可以通过简单的创建链接实现:  
  2. [root@localhost mysql]# ln -sv /usr/local/mysql/include /usr/include/mysql  
  3. create symbolic link `/usr/include/mysql' to `/usr/local/mysql/include'  

⑧输出mysql的库文件给系统库查找路径:


  
  
  1. [root@localhost ld.so.conf.d]# echo '/usr/local/mysql/lib' > /etc/ld.so.conf.d/mysql.conf  

 ⑨修改PATH环境变量,让系统可以直接使用mysql的相关命令。


  
  
  1. export PATH=$PATH:/usr/local/mysql/bin  
 
登录尝试一下










本文转自 陈延宗 51CTO博客,原文链接:http://blog.51cto.com/407711169/1186795,如需转载请自行联系原作者
相关实践学习
如何在云端创建MySQL数据库
开始实验后,系统会自动创建一台自建MySQL的 源数据库 ECS 实例和一台 目标数据库 RDS。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助 &nbsp; &nbsp; 相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
目录
相关文章
|
1月前
|
安全 关系型数据库 MySQL
Linux下安装mysql8.0(以tar.xz包安装--编译安装)
通过上述步骤,您完成了从下载、编译、安装到配置MySQL 8.0的全过程。此过程虽然较为复杂,但提供了对MySQL安装环境的完全控制,有助于满足特定的部署需求。在实际操作中,根据具体的系统环境,可能还需调整部分步骤或解决未预见的依赖问题。始终参考官方文档和社区资源,保持安装过程与最新版本的兼容性。
664 67
|
17天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,并与使用 RPM 包安装进行了对比。通过具体案例,读者可以了解如何准备环境、下载源码、编译安装、配置服务及登录 MySQL。编译源码安装虽然复杂,但提供了更高的定制性和灵活性,适用于需要高度定制的场景。
53 3
|
20天前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据需求选择最合适的方法。通过具体案例,展示了编译源码安装的灵活性和定制性。
61 2
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤
本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置服务等,并与使用 RPM 包安装进行了对比,帮助读者根据需求选择合适的方法。编译源码安装虽然复杂,但提供了更高的定制性和灵活性。
226 2
|
1月前
|
关系型数据库 MySQL Linux
在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤
【10月更文挑战第7天】本文介绍了在 CentOS 7 中通过编译源码方式安装 MySQL 数据库的详细步骤,包括准备工作、下载源码、编译安装、配置 MySQL 服务、登录设置等。同时,文章还对比了编译源码安装与使用 RPM 包安装的优缺点,帮助读者根据自身需求选择合适的方法。
58 3
|
Ubuntu 安全 关系型数据库
百度搜索:蓝易云【Ubuntu 18.04系统编译安装MySQL 5.7教程。】
现在,您已经成功地在Ubuntu 18.04上编译和安装了MySQL 5.7。请注意,这只是基本的安装过程,您可能需要进一步配置和保护您的MySQL实例。确保在实际操作中根据您的需求进行适当的配置和调整,并设置安全的密码策略。
144 0
|
3月前
|
关系型数据库 MySQL Linux
【一键解锁神秘力量!】CentOS 7 通过编译源码方式安装 MySQL 数据库 —— 从零到英雄的数据库安装实战秘籍!
【8月更文挑战第9天】随着业务增长,对数据库的需求日益提高。在 CentOS 7 中,通过编译源码安装 MySQL 可提供更高定制性和灵活性。本文详细介绍从准备环境、下载源码、配置编译参数到安装 MySQL 的全过程,并对比 RPM 包安装方法,帮助读者根据需求选择合适方案。实践时需注意备份数据、选择合适版本、确保安全性和调优性能等要点。
217 1
|
6月前
|
关系型数据库 MySQL Linux
MySQL免编译安装和用户管理(转)
MySQL免编译安装和用户管理(转)
31 1
|
5月前
|
关系型数据库 MySQL Linux
centos linux mysql 5.5脚本全自动源码包 编译安装
centos linux mysql 5.5脚本全自动源码包 编译安装
57 0
|
关系型数据库 MySQL Linux
百度搜索:蓝易云【Cnetos7编译安装MySQL教程。】
请注意,上述步骤提供了基本的编译安装MySQL的指南,具体的过程可能会因您选择的MySQL版本和特定需求而有所不同。如果遇到任何问题,建议参考MySQL官方文档或社区资源进行进一步的研究和咨询。
93 0