前往小程序,Get更优阅读体验!
立即前往
首页
学习
活动
专区
工具
TVP
发布
社区首页 >专栏 >Linux从入门到精通之源码编译安装 MySQL

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

作者头像
DevinGeng
发布2019-04-09 16:34:26
8330
发布2019-04-09 16:34:26
举报
文章被收录于专栏:云+技术云+技术

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;

本文参与 腾讯云自媒体分享计划,分享自作者个人站点/博客。
原始发表:2013-09-24 ,如有侵权请联系 cloudcommunity@tencent.com 删除

本文分享自 作者个人站点/博客 前往查看

如有侵权,请联系 cloudcommunity@tencent.com 删除。

本文参与 腾讯云自媒体分享计划  ,欢迎热爱写作的你一起参与!

评论
登录后参与评论
0 条评论
热度
最新
推荐阅读
相关产品与服务
云数据库 SQL Server
腾讯云数据库 SQL Server (TencentDB for SQL Server)是业界最常用的商用数据库之一,对基于 Windows 架构的应用程序具有完美的支持。TencentDB for SQL Server 拥有微软正版授权,可持续为用户提供最新的功能,避免未授权使用软件的风险。具有即开即用、稳定可靠、安全运行、弹性扩缩等特点。
领券
问题归档专栏文章快讯文章归档关键词归档开发者手册归档开发者手册 Section 归档