设为首页 收藏本站
查看: 3903|回复: 0

centos 6.5 编译安装 mysql 5.5.40

[复制链接]
累计签到:1 天
连续签到:1 天
发表于 2014-10-14 10:47:55 | 显示全部楼层 |阅读模式
大家好, 小金子今天跟大家一起练习编译安装MySQL5.5.40源码包.
在开始之前我们需要准备一些库文件.
1
[iyunv@diguojin ~]# yum install zlib-devel openssl-devel gcc-c++ gcc bison cmake ncurses-devel -y



一定要安装这些包, 小金子之前没有安装就开始编译MySQL,踩了好多坑, 后来上网一查才发现需要这些文件和管理工具才行.因此一定要安装.
还有如果大家编译过程中出错, 请一定要执行:
1
[iyunv@diguojin ~]# rm -f CMakeCache.txt



之后再继续安装.
安装好之后我们来添加MySQL数据库需要的账户和目录:
1
2
3
4
5
[iyunv@diguojin ~]# groupadd -r mysql
[iyunv@diguojin ~]# useradd -g mysql -r -s /sbin/nologin mysql
[iyunv@diguojin ~]# id mysql #确认用户
[iyunv@diguojin ~]# mkdir /var/data/mysql -p #存放数据库文件
[iyunv@diguojin ~]# chown mysql:mysql /var/data -R



下载MySQL源码包:mysql-5.5.40.tar.gz 点我下载MySQL5.5.40源代码
下载后上传到服务器
1
2
[iyunv@diguojin ~]# tar -xvf mysql-5.5.40.tar.gz -C /usr/local/src/
[iyunv@diguojin ~]# cd /usr/local/src/mysql-5.5.40



cmake编译MySQL的一些常用选项:
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
------------------------------------------------------------
cmake mysql 编译安装:
./configure -> cmake .
./configure --help -> cmake -LH -> ccmake .
------------------------------------------------------------
指定安装文件的安装路径常用选项
-DCMAKE_INSTALL_PREFIX=/usr/local/mysql
-DMYSQL_DATADIR=/data/mysql
-DSYSCONFDIR=/etc
------------------------------------------------------------
默认编译的存储引擎包括: csv, myisma, myisammrg, heap. 若要安装其他存储引擎,可以使用类似如下的编译选项
-DWITH_INNOBASE_STORAGE_ENGINE=1
-DWITH_ARCHIVE_STORAGE_ENGINE=1
-DWITH_BLACKHOLE_STORAGE_ENGINE=1
------------------------------------------------------------
若要明确指出不编译某存储引擎, 可以使用类似如下的选项:
-DWITHOUT_<ENGINE>_STORAGE_ENGINE=1
例如:
-DWITHOUT_EXAMPLE_STORAGE_ENGINE=1
-DWITHOUT_FEDERATED_STORAGE_ENGINE=1
------------------------------------------------------------
若要编译进其他功能, 如SSl等, 可使用类似如下选项来实现编译时使用某库文件或者, 或者不使用某库文件.
-DWITH_READLINE=1
-DWITH_SSL=system
-DWITH_ZLIB=system
-DWITH_LIBWRAP=0
------------------------------------------------------------
其他常用选项:
-DMYSQL_TCP_PORT=3306
-MYDQL_UNIX_ADDR=/tmp/mysql.sock
-DENABLED_LOCAL_INFILE=1
-DEXTRA_CHARSETS=all
-DDEFAULT_CHARSET=utf8
-DDEFAULT_COLLATION=utf8_general_ci
-DWITH_DEBUG=0
-DENABLE_PROFILING=1
------------------------------------------------------------



好, 我们开始编译
1
2
3
4
5
6
7
8
9
10
11
12
13
[iyunv@diguojin mysql-5.5.40]# cmake . -DCMAKE_INSTALL_PREFIX=/usr/local/mysql-5.5.40 \
-DMYSQL_DATADIR=/var/data/mysql \ #数据库目录
-DSYSCONFDIR=/etc \ #配置文件目录
-DWITH_INNOBASE_STORAGE_ENGINE=1 \ #启用InnoDB存储引擎
-DWITH_ARCHIVE_STORAGE_ENGINE=1 \ #启用ARCHIVE存储引擎
-DWITH_BLACKHOLE_STORAGE_ENGINE=1 \ #启用黑洞存储引擎
-DWITH_READLINE=1 \
-DWITH_SSL=system \ #启用SSL协议
-DWITH_ZLIB=system \ #启用Zlib压缩
-DWITH_LIBWRAP=0 \
-DDEFAULT_CHARSET=utf8 \ #设置字符集utf8
-DMYSQL_NUIX_ADDR=/tmp/mysql.sock \
-DDEFAULT_COLLATION=utf8_general_ci



如果出现以下信息,  那么恭喜你第一阶段的配置顺利完成了
过程中如果出现错误也不要害怕, 因为你长经验的时刻就要来了, 通常是因为缺少了什么依赖的包而出现的问题, 你可以把你的错误信息铁道Google或者百度中去搜索.
1
2
3
4
5
6
7
8
9
10
11
12
13
....(此处省略一万字)
-- Performing Test HAVE_IB_GCC_ATOMIC_BUILTINS
-- Performing Test HAVE_IB_GCC_ATOMIC_BUILTINS - Success
-- Performing Test HAVE_IB_ATOMIC_PTHREAD_T_GCC
-- Performing Test HAVE_IB_ATOMIC_PTHREAD_T_GCC - Success
-- Check size of pthread_t
-- Check size of pthread_t - done
-- Performing Test HAVE_PEERCRED
-- Performing Test HAVE_PEERCRED - Success
-- Library mysqlclient depends on OSLIBS -lpthread;z;m;rt;/usr/lib64/libssl.so;/usr/lib64/libcrypto.so;dl
-- Configuring done
-- Generating done
-- Build files have been written to: /usr/local/mysql-5.5.40



我们继续
1
2
3
4
5
6
7
8
9
10
[iyunv@diguojin mysql-5.5.40]# make
....(此处省略一万字)
Scanning dependencies of target udf_example
[100%] Building C object sql/CMakeFiles/udf_example.dir/udf_example.c.o
Linking C shared module udf_example.so
[100%] Built target udf_example
Scanning dependencies of target my_safe_process
[100%] Building CXX object mysql-test/lib/My/SafeProcess/CMakeFiles/my_safe_process.dir/safe_process.cc.o
Linking CXX executable my_safe_process
[100%] Built target my_safe_process



如果没有报错,我们继续
1
2
3
4
5
6
7
8
9
10
[iyunv@diguojin mysql-5.5.40]# make install
....(此处省略一万字)
-- Installing: /usr/local/mysql-5.5.40/man/man1/mysql_upgrade.1
-- Installing: /usr/local/mysql-5.5.40/man/man1/mysqlslap.1
-- Installing: /usr/local/mysql-5.5.40/man/man1/replace.1
-- Installing: /usr/local/mysql-5.5.40/man/man1/mysql.1
-- Installing: /usr/local/mysql-5.5.40/man/man1/mysql_setpermission.1
-- Installing: /usr/local/mysql-5.5.40/man/man1/mysql_secure_installation.1
-- Installing: /usr/local/mysql-5.5.40/man/man1/mysqlimport.1
-- Installing: /usr/local/mysql-5.5.40/man/man8/mysqld.8



全部安装ok之后我们来配置下文档的权限

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
[iyunv@diguojin mysql-5.5.40]# chown :mysql /usr/local/mysql-5.5.40 -R
[iyunv@diguojin mysql-5.5.40]# cd /usr/local/mysql-5.5.40/
[iyunv@diguojin mysql-5.5.40]# chmod +x scripts/mysql_install_db
[iyunv@diguojin mysql-5.5.40]# scripts/mysql_install_db --user=mysql --datadir=/var/data/mysql/ #执行初始化脚本


....(此处省略一万字)
./bin/mysqladmin -u root password 'new-password'
./bin/mysqladmin -u root -h diguojin password 'new-password'

Alternatively you can run:
./bin/mysql_secure_installation

which will also give you the option of removing the test
databases and anonymous user created by default.  This is
strongly recommended for production servers.

See the manual for more instructions.

You can start the MySQL daemon with:
cd . ; ./bin/mysqld_safe &

You can test the MySQL daemon with mysql-test-run.pl
cd ./mysql-test ; perl mysql-test-run.pl

Please report any problems at http://bugs.mysql.com/



如果你获得的信息和上面一样的话, 恭喜你, 你又离成功近了一步

1
2
3
[iyunv@diguojin mysql-5.5.40]# ls /var/data/mysql/ #看一下是否生成了文件
mysql  performance_schema  test
#如果是这样那么我们继续



创建服务脚本
1
2
3
[iyunv@diguojin mysql-5.5.40]# cp support-files/mysql.server /etc/rc.d/init.d/mysqld
[iyunv@diguojin mysql-5.5.40]# chmod +x /etc/rc.d/init.d/mysqld #添加mysqld执行权限
[iyunv@diguojin mysql-5.5.40]# chkconfig --add mysqld #添加开机启动



创建配置文件

1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
[iyunv@diguojin mysql-5.5.40]# mv /etc/my.cnf{,.bak}
[iyunv@diguojin mysql-5.5.40]# cp support-files/my-large.cnf /etc/my.cnf
[iyunv@diguojin mysql-5.5.40]# vim /etc/my.cnf

#找到如下部分
[mysqld]
port            = 3306
socket          = /tmp/mysql.sock
skip-external-locking
key_buffer_size = 256M
max_allowed_packet = 1M
table_open_cache = 256
sort_buffer_size = 1M
read_buffer_size = 1M
read_rnd_buffer_size = 4M
myisam_sort_buffer_size = 64M
thread_cache_size = 8
query_cache_size= 16M
# Try number of CPU's*2 for thread_concurrency
thread_concurrency = 8
datadir= /var/data/mysql #添加次行内容, 就是数据库文件存放路径
:wq
#保存退出

[iyunv@diguojin mysql-5.5.40]# vim /etc/profile.d/mysql.sh
export PATH=/usr/local/mysql-5.5.40/bin:$PATH #添加次行

[iyunv@diguojin mysql-5.5.40]# . /etc/profile.d/mysql.sh #导入环境变量



好了让我们来尝试着启动MySQL服务吧
1
2
3
4
5
6
[iyunv@diguojin mysql-5.5.40]# service mysqld start
Starting MySQL..                                           [  OK  ]
[iyunv@diguojin mysql-5.5.40]#
[iyunv@diguojin mysql-5.5.40]# ss -tnl| grep :3306
LISTEN     0      50                        *:3306                     *:*   
#发现正常监听 3306端口



距离胜利越来越近了,加油^^

然后我们来配置MySQL管理员密码进行初始化
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
[iyunv@diguojin mysql-5.5.40]# mysql #使用客户端登录

Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 1
Server version: 5.5.40-log Source distribution

Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql>
#查看一下默认存在的用户

mysql> select user,password,host from mysql.user;
+------+----------+-----------+
| user | password | host      |
+------+----------+-----------+
| root |          | localhost |
| root |          | diguojin  |
| root |          | 127.0.0.1 |
| root |          | ::1       |
|      |          | localhost |
|      |          | diguojin  |
+------+----------+-----------+
6 rows in set (0.00 sec)

mysql>


#删除默认存在的账户, 要求用户只能从本地服务器访问数据库
mysql> delete from mysql.user where host!='localhost';
Query OK, 4 rows affected (0.00 sec)

#修改root管理员账号密码
mysql> update mysql.user set password=PASSWORD('p@ssw0rd') where user='root';
Query OK, 1 row affected (0.00 sec)
Rows matched: 1  Changed: 1  Warnings: 0

#更新数据库
mysql> FLUSH PRIVILEGES;
Query OK, 0 rows affected (0.00 sec)

#看一下修改后的结果
mysql> select user,password,host from mysql.user;
+------+-------------------------------------------+-----------+
| user | password                                  | host      |
+------+-------------------------------------------+-----------+
| root | *D7E39C3AF517EC9EF7086223B036E0B4F22821F8 | localhost |
|      |                                           | localhost |
+------+-------------------------------------------+-----------+
2 rows in set (0.00 sec)

mysql> \q
Bye
[iyunv@diguojin mysql-5.5.40]#



然后我们就可以使用新密码登陆了
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
[iyunv@diguojin mysql-5.5.40]# mysql -u root -h localhost -p
Enter password: #输入刚才设置的密码
Welcome to the MySQL monitor.  Commands end with ; or \g.
Your MySQL connection id is 4
Server version: 5.5.40-log Source distribution

Copyright (c) 2000, 2014, Oracle and/or its affiliates. All rights reserved.

Oracle is a registered trademark of Oracle Corporation and/or its
affiliates. Other names may be trademarks of their respective
owners.

Type 'help;' or '\h' for help. Type '\c' to clear the current input statement.

mysql>



好了MySQL到此 就安装成功了!! 感谢大家!!
对了我们忘记了导入开发的库文件了, ok 很快就好
1
2
3
4
5
6
7
8
9
10
11
[iyunv@diguojin mysql-5.5.40]# ln -sv /usr/local/mysql/include/ /usr/include/mysql #软连接到系统库中
[iyunv@diguojin mysql-5.5.40]# vim /etc/ld.so.conf.d/mysql.conf #编辑这个文件, 并且添加如下路径

/usr/local/mysql-5.5.40/lib

[iyunv@diguojin mysql-5.5.40]# ldconfig #重新加载库文件
[iyunv@diguojin mysql-5.5.40]# ldconfig -p | grep mysql #让我们来检查下是不是加载好了
    libmysqlclient_r.so.16 (libc6,x86-64) => /usr/lib64/mysql/libmysqlclient_r.so.16
    libmysqlclient.so.18 (libc6,x86-64) => /usr/local/mysql-5.5.40/lib/libmysqlclient.so.18
    libmysqlclient.so.16 (libc6,x86-64) => /usr/lib64/mysql/libmysqlclient.so.16
    libmysqlclient.so (libc6,x86-64) => /usr/local/mysql-5.5.40/lib/libmysqlclient.so



好的, 大家辛苦了~ MySQL5.5.40 编译安装完成


运维网声明 1、欢迎大家加入本站运维交流群:群②:261659950 群⑤:202807635 群⑦870801961 群⑧679858003
2、本站所有主题由该帖子作者发表,该帖子作者与运维网享有帖子相关版权
3、所有作品的著作权均归原作者享有,请您和我们一样尊重他人的著作权等合法权益。如果您对作品感到满意,请购买正版
4、禁止制作、复制、发布和传播具有反动、淫秽、色情、暴力、凶杀等内容的信息,一经发现立即删除。若您因此触犯法律,一切后果自负,我们对此不承担任何责任
5、所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其内容的准确性、可靠性、正当性、安全性、合法性等负责,亦不承担任何法律责任
6、所有作品仅供您个人学习、研究或欣赏,不得用于商业或者其他用途,否则,一切后果均由您自己承担,我们对此不承担任何法律责任
7、如涉及侵犯版权等问题,请您及时通知我们,我们将立即采取措施予以解决
8、联系人Email:admin@iyunv.com 网址:www.yunweiku.com

所有资源均系网友上传或者通过网络收集,我们仅提供一个展示、介绍、观摩学习的平台,我们不对其承担任何法律责任,如涉及侵犯版权等问题,请您及时通知我们,我们将立即处理,联系人Email:kefu@iyunv.com,QQ:1061981298 本贴地址:https://www.yunweiku.com/thread-25950-1-1.html 上篇帖子: 64bit centos 6.5 编译安装 LAMP 环境 下篇帖子: centos 6.5 编译安装 httpd-2.4.10 mysql
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

扫码加入运维网微信交流群X

扫码加入运维网微信交流群

扫描二维码加入运维网微信交流群,最新一手资源尽在官方微信交流群!快快加入我们吧...

扫描微信二维码查看详情

客服E-mail:kefu@iyunv.com 客服QQ:1061981298


QQ群⑦:运维网交流群⑦ QQ群⑧:运维网交流群⑧ k8s群:运维网kubernetes交流群


提醒:禁止发布任何违反国家法律、法规的言论与图片等内容;本站内容均来自个人观点与网络等信息,非本站认同之观点.


本站大部分资源是网友从网上搜集分享而来,其版权均归原作者及其网站所有,我们尊重他人的合法权益,如有内容侵犯您的合法权益,请及时与我们联系进行核实删除!



合作伙伴: 青云cloud

快速回复 返回顶部 返回列表