[centos]centos下源码编译mysql
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 [[email protected]]# ./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 [[email protected]]# 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 //允许从本地导入数据 [[email protected]]# make && make install //在make与make install的时候可以看到进度百分比,感觉这一点要比configure方式要好。
5. 配置并初始化数据库
//创建my.cnf配置文件 [[email protected]]# 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 [email protected]; 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
相关推荐
CoderToy 2020-11-16
bianruifeng 2020-11-16
云中舞步 2020-11-12
敏敏张 2020-11-11
暗夜之城 2020-11-11
好记忆也需烂 2020-11-11
Coder技术文摘 2020-09-29
huacuilaifa 2020-10-29
Gexrior 2020-10-22
lpfvip00 2020-10-07
云中舞步 2020-09-11
康慧欣 2020-09-10
SCNUHB 2020-11-10
emmm00 2020-11-17
王艺强 2020-11-17
ribavnu 2020-11-16
wangshuangbao 2020-11-13
苏康申 2020-11-13