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

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

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

相关实践学习
如何快速连接云数据库RDS MySQL
本场景介绍如何通过阿里云数据管理服务DMS快速连接云数据库RDS MySQL,然后进行数据表的CRUD操作。
全面了解阿里云能为你做什么
阿里云在全球各地部署高效节能的绿色数据中心,利用清洁计算为万物互联的新世界提供源源不断的能源动力,目前开服的区域包括中国(华北、华东、华南、香港)、新加坡、美国(美东、美西)、欧洲、中东、澳大利亚、日本。目前阿里云的产品涵盖弹性计算、数据库、存储与CDN、分析与搜索、云通信、网络、管理与监控、应用服务、互联网中间件、移动服务、视频服务等。通过本课程,来了解阿里云能够为你的业务带来哪些帮助     相关的阿里云产品:云服务器ECS 云服务器 ECS(Elastic Compute Service)是一种弹性可伸缩的计算服务,助您降低 IT 成本,提升运维效率,使您更专注于核心业务创新。产品详情: https://www.aliyun.com/product/ecs
相关文章
|
2天前
|
Linux
Linux安装svn并启动
Linux安装svn并启动
30 10
|
29天前
|
Oracle 关系型数据库 Linux
linux8安装oracle 11g遇到的问题记录
Oracle 11g在Linux 8上安装时会遇到link编译环节的问题。官方建议忽略安装中的链接错误,安装完成后应用DBPSU 11.2.0.4.240716补丁及一次性补丁33991024,再重新编译二进制文件,并配置监听器和数据库。但因11g已退出服务期,这些补丁需付费获取。网上信息显示22年1月的PSU补丁也可解决问题,找到该补丁后按常规方式打补丁即可。如有需求或疑问可咨询我。
63 20
|
21天前
|
弹性计算 运维 Ubuntu
os-copilot在Alibaba Cloud Linux镜像下的安装与功能测试
我顺利使用了OS Copilot的 -t -f 功能,我的疑惑是在换行的时候就直接进行提问了,每次只能写一个问题,没法连续换行更有逻辑的输入问题。 我认为 -t 管道 功能有用 ,能解决环境问题的连续性操作。 我认为 -f 管道 功能有用 ,可以单独创建可连续性提问的task问题。 我认为 | 对文件直接理解在新的服务器理解有很大的帮助。 此外,我还有建议 可以在非 co 的环境下也能进行连续性的提问。
57 7
|
2月前
|
Linux Python
Linux 安装python3.7.6
本教程介绍在Linux系统上安装Python 3.7.6的步骤。首先使用`yum`安装依赖环境,包括zlib、openssl等开发库。接着通过`wget`下载Python 3.7.6源码包并解压。创建目标文件夹`/usr/local/python3`后,进入解压目录执行配置、编译和安装命令。最后设置软链接,使`python3`和`pip3`命令生效。
|
2月前
|
关系型数据库 MySQL Linux
Linux下mysql数据库的导入与导出以及查看端口
本文详细介绍了在Linux下如何导入和导出MySQL数据库,以及查看MySQL运行端口的方法。通过这些操作,用户可以轻松进行数据库的备份与恢复,以及确认MySQL服务的运行状态和端口。掌握这些技能,对于日常数据库管理和维护非常重要。
117 8
|
2月前
|
Ubuntu Linux
Linux 各发行版安装 ping 命令指南
如何在不同 Linux 发行版(Ubuntu/Debian、CentOS/RHEL/Fedora、Arch Linux、openSUSE、Alpine Linux)上安装 `ping` 命令,详细列出各发行版的安装步骤和验证方法,帮助系统管理员和网络工程师快速排查网络问题。
184 20
|
2月前
|
NoSQL 关系型数据库 MySQL
Linux安装jdk、mysql、redis
Linux安装jdk、mysql、redis
204 7
|
2月前
|
Unix Linux 编译器
UNIX/Linux 上的安装
UNIX/Linux 上的安装。
62 2
|
2月前
|
关系型数据库 MySQL Linux
MySQL数据库下载安装教程(Windows&Linux)
本文档详细介绍了MySQL的安装步骤,包括安装前的准备工作、下载安装包、Windows和Linux系统下的具体安装流程,以及如何配置MySQL服务、设置环境变量、启动服务和连接数据库等关键操作。
|
2月前
|
JavaScript 安全 Java
java版药品不良反应智能监测系统源码,采用SpringBoot、Vue、MySQL技术开发
基于B/S架构,采用Java、SpringBoot、Vue、MySQL等技术自主研发的ADR智能监测系统,适用于三甲医院,支持二次开发。该系统能自动监测全院患者药物不良反应,通过移动端和PC端实时反馈,提升用药安全。系统涵盖规则管理、监测报告、系统管理三大模块,确保精准、高效地处理ADR事件。
101 1