mysql编译安装在centos6.5

http://www.cyun.org/archives/mysql-5-5-35-cmake%E7%BC%96%E8%AF%91%E5%AE%89%E8%A3%85/

现在MySQL要下载一下真是他Oracle妈的烦人,我从百度里面找到了http://dev.mysql.com/downloads/mysql/5.1.html 这个下载地址,才逃过注册还找不到自己想要的软件的麻烦,废话不多说,说一下这个CMake的编译吧。

毕竟我非专业的开发人员, 如此专业的编译工具用的比较少,在此只是用于一个记录使用,若是有专业人员,可以跳过这里。

编译方法:

cmake -DCMAKE_INSTALL_PREFIX=/usr/local/webservice/mysql -DMYSQL_DATADIR=/usr/local/webservice/mysql/data -DDEFAULT_CHARSET=utf8 -DWITH_READLINE=1 -DWITH_SSL=system -DWITH_EMBEDDED_SERVER=1 -DENABLED_LOCAL_INFILE=1 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_MEMORY_STORAGE_ENGINE=1 -DWITH_DEBUG=0

这么一大串,其实根本用不上,只需要cmake -DCMAKE_INSTALL_PREFIX=/usr/local/webservice/mysql 这样的一段,编译通过以后,再make , make install ,即可完成整个编译的过程。

提示: 若是有相关的错误提示,则按提示安装相关的软件,本人的环境是Ubuntu。

http://tglinux.com/databases/8.html

所需软件源码包:

 

cmake-2.8.12.tar.gz
mysql-5.5.35.tar.gz

安装cmake

 

MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具。

因此,我们首先要在系统中源码编译安装cmake工具。

开发环境安装:

 

yum -y install ntp vim-enhanced gcc gcc-c++ flex bison autoconf automake bzip2-devel ncurses-devel zlib-devel libjpeg-devel libpng-devel libtiff-devel freetype-devel libXpm-devel gettext-devel  pam-devel libtool libtool-ltdl openssl openssl-devel fontconfig-devel libxml2-devel curl-devel  libicu libicu-devel libmcrypt libmcrypt-devel libmhash libmhash-devel
tar -zxvf cmake-2.8.12.1.tar.gz 
cd cmake-2.8.12.1
./configure 
make && make install
groupadd mysql
useradd -s /sbin/nologin -M -g mysql mysql
tar -zxvf mysql-5.5.35.tar.gz
cd mysql-5.5.35
cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_DATADIR=/usr/local/mysql/data -DEXTRA_CHARSETS=all -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_unicode_ci -DWITH_READLINE=1 -DWITH_SSL=system -DWITH_EMBEDDED_SERVER=1 -DENABLED_LOCAL_INFILE=1 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_MYISAM_STORAGE_ENGINE=1 -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_DEBUG=0
make && make install
cp ./support-files/my-medium.cnf /etc/my.cnf
chown -R mysql:mysql /usr/local/mysql/
chown -R mysql:mysql /usr/local/mysql/data/
cp ./support-files/mysql.server /etc/init.d/mysqld
chmod +x /etc/init.d/mysqld 
chkconfig mysqld on
ln -sv /usr/local/mysql/bin/mysqladmin /usr/sbin/mysqladmin
ln -sv /usr/local/mysql/bin/mysql /usr/sbin/mysql
ln -sv /usr/local/mysql/bin/mysqldump /usr/sbin/mysqldump
vim /etc/my.cnf
-------------------------------------------------------
basedir = /usr/local/mysql
datadir = /usr/local/mysql/data
tmpdir =/tmp
-------------------------------------------------------
/usr/local/mysql/scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql/ --datadir=/usr/local/mysql/data/
/etc/init.d/mysqld start
配置防火墙,开启3306端口
vim /etc/sysconfig/iptables
#添加如下规则到3306端口这条规则的下面即可
-A INPUT -m state --state NEW -m tcp -p tcp --dport 3306 -j ACCEPT
#重启防火墙
/etc/init.d/iptables restart  # 或  service iptables restart
启动MySQL
service mysqld start  # 或 /etc/init.d/mysqld start
测试MySQL是否启动
#查看是否有mysql进程
ps -ef | grep mysql
#查看是否有mysql端口
netstat -tnlp | grep 3306
#测试mysql,mysqladmin,mysqldump命令是否能正常使用
#读取MySQL的版本信息
mysqladmin version

PS:注释信息

cmake .
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql/ \
-DDEFAULT_CHARSET=utf8 \
-DDEFAULT_COLLATION=utf8_general_ci \
-DENABLED_PROFILING=ON \
-DWITH_EXTRA_CHARSETS:STRING=utf8,gbk \
-DWITH_READLINE=1 -DWITH_DEBUG=0 \
-DWITH_MYISAM_STORAGE_ENGINE=1 \
-DWITH_INNOBASE_STORAGE_ENGINE=1 \
-DMYSQL_DATADIR=/data/mysqldb \
-DENABLED_LOCAL_INFILE=1

[root@liu mysql-5.6.14]# cmake . \
> -DCMAKE_INSTALL_PREFIX=/usr/local/mysql/ \ mysql安装目录
> -DDEFAULT_CHARSET=utf8 \ 默认的字符集
> -DDEFAULT_COLLATION=utf8_general_ci \ 编码校对规则
> -DENABLED_PROFILING=ON \ 是否启用代码查询分析
> -DWITH_EXTRA_CHARSETS:STRING=utf8,gbk \ 额外的字符集
> -DWITH_READLINE=1 \ 使用绑定的readline
> -DWITH_DEBUG=0 \ 不开启调试
> -DWITH_MYISAM_STORAGE_ENGINE=1 \ myisam引擎
> -DWITH_INNOBASE_STORAGE_ENGINE=1 \ innodb 引擎
> -DMYSQL_DATADIR=/data/mysqldb \ 数据库存放目录
> -DENABLED_LOCAL_INFILE=1 允许从本地导入数据



 

 

 http://yanghuawu.blog.51cto.com/2638960/1351801

原创作品,允许转载,转载时请务必以超链接形式标明文章 原始出处 、作者信息和本声明。否则将追究法律责任。http://yanghuawu.blog.51cto.com/2638960/1351801

安装方式分为rpm和源码编译安装两种,本文是采用mysql源码编译方式,编译器使用Cmake。软件需要mysql-5.5.35.tar.gz和cmake-2.8.10.2.tar.gz,请自行下载。

 

1. 安装cmake

MySQL从5.5版本开始,通过./configure进行编译配置方式已经被取消,取而代之的是cmake工具。

因此,我们首先要在系统中源码编译安装cmake工具。

[root@test ~]# wget http://down1.chinaunix.net/distfiles/cmake-2.8.10.2.tar.gz

[root@test ~]# tar-zxvf cmake-2.8.10.2.tar.gz

[root@test ~]# cdcmake-2.8.10.2

[root@testcmake-2.8.10.2]# ./configure

[root@test cmake-2.8.10.2]#make;make install

 

2. 确保以下所需系统软件包已经被安装

通过 rpm -qa | grep name 的方式验证以下软件包是否已全部安装。

[root@test ~]# yum install -y gcc* gcc-c++* autoconf* automake* zlib* libxml* ncurses-devel* libgcrypt* libtool*

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

 

3. 安装前的系统设置

建立mysql安装目录及数据存放目录

安装路径:

[root@test ~]# mkdir /usr/local/mysql

数据库路径:

[root@test ~]# mkdir /data/mysql

创建用户和用户组

[root@test ~]#groupadd mysql

[root@test ~]#useradd -g mysql mysql

赋予数据存放目录权限

[root@test ~]# chown mysql:mysql -R /data/mysql

 

4. 编译安装 MySQL 5.5

通过http://www.mysql.com/downloads/mysql官方网址或国内的sohu镜像下载软件包,如目前最新的MySQL

[root@test ~]# wget http://mirrors.sohu.com/mysql/MySQL-5.5/mysql-5.5.35.tar.gz

[root@test ~]# tar -zxvf mysql-5.5.35.tar.gz

[root@test ~]# cd mysql-5.5.35  

[root@testmysql-5.5.35]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql -DMYSQL_UNIX_ADDR=/data/mysql/mysql.sock -DDEFAULT_CHARSET=utf8 -DDEFAULT_COLLATION=utf8_general_ci -DWITH_EXTRA_CHARSETS:STRING=utf8,gbk -DWITH_INNOBASE_STORAGE_ENGINE=1 -DWITH_READLINE=1 -DENABLED_LOCAL_INFILE=1 -DMYSQL_DATADIR=/data/mysql/ -DMYSQL_USER=mysql -DMYSQL_TCP_PORT=3306

 

参数说明:

-DCMAKE_INSTALL_PREFIX=/home/mysql/mysql   //安装目录

-DINSTALL_DATADIR=/home/mysql/data         //数据库存放目录

-DDEFAULT_CHARSET=utf8                     //使用utf8字符

-DDEFAULT_COLLATION=utf8_general_ci         //校验字符

-DEXTRA_CHARSETS=all                       //安装所有扩展字符集

-DENABLED_LOCAL_INFILE=1                   //允许从本地导入数据

 

[root@testmysql-5.5.35]# make;make install

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

 

5. 配置并初始化数据库

创建my.cnf配置文件

[root@testmysql-5.5.35]# cp support-files/my-medium.cnf /etc/my.cnf

cp:是否覆盖"/etc/my.cnf"?y

 

执行前需赋给scripts/mysql_install_db文件执行权限

[root@test ~]# cd /usr/local/mysql/

[root@test mysql]# chmod 755 scripts/mysql_install_db

 

初始化数据库

[root@test mysql]# scripts/mysql_install_db --user=mysql --basedir=/usr/local/mysql --datadir=/data/mysql/

创建管理MySQL数据库的shell脚本

[root@testmysql]# cp support-files/mysql.server /etc/init.d/mysqld

赋予shell脚本可执行权限:

[root@test mysql]# chmod +x /etc/init.d/mysqld

启动MySQL

[root@test mysql]# /etc/init.d/mysqld start

通过命令行登录管理MySQL服务器(提示输入密码时直接回车):

[root@test ~]#/usr/local/mysql/bin/mysql -u root -p

Enter password: 默认密码为空

 

设置Mysql密码

[root@test ~]#/usr/local/mysql/bin/mysqladmin password -uroot '123456'

Enter password: 123456

mysql> show databases;

mysql> create useradmin identified by "admin";  

mysql> grant select,insert,update,delete on *.* to admin@"%" Identified by"admin";                

mysql> show grants foradmin@10.1.0.0;

mysql> \q

通过SQLyog来连接MySQL(安装过程,不在描述)

 

[root@test ~]# ps -ef | grep mysql

root    20017     1  0 05:10 pts/0    00:00:00 /bin/sh/usr/local/mysql/bin/mysqld_safe --datadir=/data/mysql--pid-file=/data/mysql/test.com.pid

mysql   20282 20017  0 05:10 pts/0    00:00:00 /usr/local/mysql/bin/mysqld--basedir=/usr/local/mysql --datadir=/data/mysql --plugin-dir=/usr/local/mysql/lib/plugin--user=mysql --log-error=/data/mysql/test.com.err--pid-file=/data/mysql/test.com.pid --socket=/data/mysql/mysql.sock --port=3306

root    20309  1447  0 05:24 pts/0    00:00:00 grep mysql

 

[root@test ~]# netstat -tnl

Active Internet connections (only servers)

Proto Recv-Q Send-Q Local Address               Foreign Address             State      

tcp        0     0 0.0.0.0:3306               0.0.0.0:*                   LISTEN      

tcp       0      0 0.0.0.0:22                  0.0.0.0:*                   LISTEN      

tcp       0      0 127.0.0.1:25                0.0.0.0:*                   LISTEN      

tcp       0      0 :::22                       :::*                       LISTEN      

tcp       0      0 ::1:25                      :::*                       LISTEN  

 

本文出自 “运维IT” 博客,请务必保留此出处http://yanghuawu.blog.51cto.com/2638960/1351801

posted @ 2014-08-11 11:19  陳聽溪  阅读(195)  评论(0)    收藏  举报