免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 3642 | 回复: 4
打印 上一主题 下一主题

Linux下源码编译安装MySQL [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2011-12-22 17:57 |只看该作者 |倒序浏览

特别值得一提的是Linux Mysql有很多值得学习的地方,这里我们主要介绍Linux Mysql,包括介绍Linux Mysql安装等方面。Fedora 10下安装Linux Mysql+Apache+Php(2009-02-19 13:36:46)标签:it   分类:技术进程首先我用的各软件版本分别是:MySQL:5.1.30Apache:2.2.3Php:5.2.8

安装之前,如果安装过其他版本的Linux Mysql、Apache和Php,要先卸载。使用rpm包安装的用删除rpm包语句:[rpm -e 包名],查询包名用语句:[rpm -qa | grep 包名]。有依赖关系的包也要一次删除,这样才能成功的删除这些rpm包。

1.本次安装使用的都是源码编译安装,将Linux Mysql-5.1.30.tar.gz复制到/usr/local/src下,然后解压安装,具体步骤如下:


#cd /usr/local/src  
#tar -zxvf mysql-5.1.30.tar.gz  
#cd mysql-5.1.30  
#groupadd -r mysql //创建mysql用户组  
#useradd -m -r -g mysql -d /var/lib/mysql -s /bin/bash \  
>-c "MySQL Server" mysql  
#./configure --prefix=/usr/local/mysql \ //指定mysql安装目录  
>--sysconfdir=/etc \   //指定mysql配置文件存放目录  
>--localstatedir=/var/lib/mysql \//指定mysql数据库存放目录  
>--enable-local-infile \  //激活load data local infile语句,使mysql支持使用该语句

>--with-charset=utf8
>--with-collation=utf8_general_ci
>--with-extra-charsets=latin1
#make   //编译(需较长时间)  
#make install   //安装  
#make clean  
#make distclean  
2.Linux Mysql初始化数据库


#cd /usr/local/mysql  
#/bin/mysql_install_db --user=mysql//初始化系统数据库  
#ls /var/lib/mysql //查看存放数据库中的目录内容
3Linux Mysql.修改数据库目录所有者


#chown -R mysql:mysql /var/lib/mysql
4.复制Linux Mysql配置文件到/etc目录中,并更名为my.cnf。操作命令为:


#cp /usr/local/mysql/share/mysql/my-large.cnf /etc/my.cnf   //一般正常安装之后已经有该文件,可以不用拷贝
5.复制生成Linux Mysql服务器的自动与停止脚本


#cp /usr/local/mysql/share/mysql/mysql.server /etc/rc.d/init.d/mysql
6.修改/etc/rc.d/init.d/mysql文件中的基本路径:

#vi /etc/rc.d/init.d/mysql
将basedir=修改为basedir=/usr/local/mysql

7.将Linux Mysql服务添加到服务器管理中,并设置自启动状态:


#chkconfig --list | grep mysql //查询当前是否有mysql服务  
#chkconfig --add mysql //添加mysql服务到服务器管理中  
#chkconfig --list | grep mysql //查询此时mysql服务器的启动状态  
#chkconfig --level 35 mysql on //设置在3、5运行级别也自启动
8.启动Linux Mysql服务器


#service mysql start 或 /etc/rc.d/init.d/mysql start
9.测试Linux Mysql服务器


#/usr/local/mysql/bin/mysqladmin version测试服务器是否已启动  
#/usr/local/mysql/bin/mysqladmin pin(出现:)mysql is alive
10.Linux Mysql设置root账户密码
#/usr/local/mysql/bin/mysqladmin -u root -h 主机名 -p password '新密码'由于在编译PHP源码时,会使用到部分MySQL的库文件和头文件,若服务器还需提供PHP动态网页服务,会导致找不到相应的文件,解决办法是为目录创建一个符号连接,其实现的操作命令如下:
#ln -s /usr/local/mysql/lib/mysql /usr/lib/mysql
#ln -s /usr/local/mysql/include/mysql /usr/include/mysql

注:若正常安装后mysql命令不能使用,解决办法:在.bashrc文件中添加(alias mysql='安装目录/bin/mysql')(eg:alias mysql='/usr/local/mysql/bin/mysql')为bin文件夹下的mysql命令区一个别名或者添加环境变量,在终端输入 (export mysql="/usr/local/mysql/bin")或在/etc/profile文件中添加条目(export PATH=$PATH:/usr/local/mysql/bin)我本人安装完毕,使用service mysql start启动mysql时,出现Mysql服务启动失败信息如下:

Starting MySQL.Manager of pid-file quit without updating fi[Failed]解决办法:只要将/etc/my.cnf里面的 skip federated注释掉即可。因机器和版本的种种差异,可能每个人都会出现一些问题,这些问题大家只好去Google上查了。这样,MySQL基本上就安装完毕了,接下来我们来安装和配置Apache-2.2.3。

安装Apache-2.2.3


#cd /usr/local/src  
#tar -zxvf httpd-2.2.3.tar.gz  
#cd httpd-2.2.3  
#./configure --prefix=/usr/local/apache \  
>--enable-so \  
>--with-mpm=prefork \  
>--enable-modules="setenvif rewrite deflate vhost_alias"
#make  
#make install  
#usr/local/apache/bin/apachectl start
设置apache自启动:  
#echo "/usr/local/apache/bin/apachectl start">> /etc/rc.d/rc.local在/etc/rc.d/rc.local中添加  
#echo "/usr/local/apache/bin/apachectl start" /usr/local/apache/bin/apachectl start

或者
将apachectl复制到/etc/rc.d/init.d下
#cp /usr/local/apache/bin/apachectl /etc/rc.d/init.d/apache
在/etc/rc.d/init.d/apache的第二行加入如下内容
# httpd        Startup script for the Apache HTTP Server
#
# chkconfig: - 85 15
# description: Apache is a World Wide Web server.  It is used to serve \
#              HTML files and CGI.

#chkconfig --list | grep httpd //查看是否当前是否有apache服务
#chkconfig --add httpd
#chkconfig --level 35 httpd on //设置在3、5运行级别也自动启动

最后来安装PHP-5.2.8


#tar -zxvf php-5.2.8.tar.gz  
#cd php-5.2.8  
#./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql \  
>--with-apxs2=/usr/local/apache/bin/apxs  
#make   
#make install  
#make clean  
#make distclean
Apache中加载php模块:
#cp php.ini-dist /usr/local/lib/php.ini
#vim httpd.conf

添加如下内容:
LoadModule php5_module modules/libphp5.so
AddType application/x-httpd-php .php .phtml
AddType application/x-httpd-php-source .phps

解决Cannot load /usr/local/apache/modules/libphp5.so的方法今天安装httpd-2.2.3 和php-5.2.8,一切顺利,最后一步重新启动apache报如下错误:(真是个好编剧,总是最后发生异常)httpd: Syntax error on line 53 of /usr/local/apache/conf/httpd.conf: Cannot load /usr/local/apache/modules/libphp5.so into server: /usr/local/apache/modules/libphp5.so: cannot restore segment prot after reloc: Permission denied

解决办法:原因是Linux有一个SELinux保护模式引起的。
1关闭SELINUX的方法:
vim /etc/selinux/config 将SELINUX=enforcing 改成SELINUX=disabled  需要重启
2不关闭SELINUX的方法:
# setenforce 0
# chcon -c -v -R -u system_u -r object_r -t textrel_shlib_t /usr/local/apache/modules/libphp5.so
# service httpd restart
# setenforce 1

附一个较全的PHP编译参数:./configure --prefix=/usr/local/php --with-apxs2=/usr/local/apache/bin/apxs --with-openssl --with-zlib --disable-ctype --enable-exif --with-jpeg-dir --with-png-dir --with-zlib-dir --with-freetype-dir --enable-gd-native-ttf --with-gd --enable-mbstring --with-mysqli --with-mysql=/usr/local/mysql --with-pdo-mysql --enable-soap --enable-sqlite-utf8 --with-pear=/usr/local/php/pear


来源:http://blog.chinaunix.net/space. ... =blog&id=188823

论坛徽章:
0
2 [报告]
发表于 2012-12-17 10:56 |只看该作者
回复 1# petterchx


    如何在自己搭建的Linux系统中,安装ngix,使系统安装上就能用?

论坛徽章:
224
2022北京冬奥会纪念版徽章
日期:2015-08-10 16:30:32操作系统版块每日发帖之星
日期:2016-02-18 06:20:00操作系统版块每日发帖之星
日期:2016-03-01 06:20:00操作系统版块每日发帖之星
日期:2016-03-02 06:20:0015-16赛季CBA联赛之上海
日期:2019-09-20 12:29:3219周年集字徽章-周
日期:2019-10-01 20:47:4815-16赛季CBA联赛之八一
日期:2020-10-23 18:30:5320周年集字徽章-20	
日期:2020-10-28 14:14:2615-16赛季CBA联赛之广夏
日期:2023-02-25 16:26:26CU十四周年纪念徽章
日期:2023-04-13 12:23:1015-16赛季CBA联赛之四川
日期:2023-07-25 16:53:45操作系统版块每日发帖之星
日期:2016-05-10 19:22:58
3 [报告]
发表于 2012-12-17 11:16 |只看该作者
yum install mysql-server一行代码解决你心中的疑惑

论坛徽章:
224
2022北京冬奥会纪念版徽章
日期:2015-08-10 16:30:32操作系统版块每日发帖之星
日期:2016-02-18 06:20:00操作系统版块每日发帖之星
日期:2016-03-01 06:20:00操作系统版块每日发帖之星
日期:2016-03-02 06:20:0015-16赛季CBA联赛之上海
日期:2019-09-20 12:29:3219周年集字徽章-周
日期:2019-10-01 20:47:4815-16赛季CBA联赛之八一
日期:2020-10-23 18:30:5320周年集字徽章-20	
日期:2020-10-28 14:14:2615-16赛季CBA联赛之广夏
日期:2023-02-25 16:26:26CU十四周年纪念徽章
日期:2023-04-13 12:23:1015-16赛季CBA联赛之四川
日期:2023-07-25 16:53:45操作系统版块每日发帖之星
日期:2016-05-10 19:22:58
4 [报告]
发表于 2012-12-17 11:18 |只看该作者
cliffordl 发表于 2012-12-17 10:56
回复 1# petterchx


什么意思,你想自己做linux发现版??

论坛徽章:
224
2022北京冬奥会纪念版徽章
日期:2015-08-10 16:30:32操作系统版块每日发帖之星
日期:2016-02-18 06:20:00操作系统版块每日发帖之星
日期:2016-03-01 06:20:00操作系统版块每日发帖之星
日期:2016-03-02 06:20:0015-16赛季CBA联赛之上海
日期:2019-09-20 12:29:3219周年集字徽章-周
日期:2019-10-01 20:47:4815-16赛季CBA联赛之八一
日期:2020-10-23 18:30:5320周年集字徽章-20	
日期:2020-10-28 14:14:2615-16赛季CBA联赛之广夏
日期:2023-02-25 16:26:26CU十四周年纪念徽章
日期:2023-04-13 12:23:1015-16赛季CBA联赛之四川
日期:2023-07-25 16:53:45操作系统版块每日发帖之星
日期:2016-05-10 19:22:58
5 [报告]
发表于 2012-12-17 18:00 |只看该作者
5.1的版本有个官方文档

http://dev.mysql.com/doc/refman/ ... e-distribution.html


这里也把命令贴出来,专供懒人
  1. # Preconfiguration setup
  2. shell> groupadd mysql
  3. shell> useradd -g mysql mysql
  4. # Beginning of source-build specific instructions
  5. shell> tar zxvf mysql-VERSION.tar.gz
  6. shell> cd mysql-VERSION
  7. shell> ./configure --prefix=/usr/local/mysql
  8. shell> make
  9. shell> make install
  10. # End of source-build specific instructions
  11. # Postinstallation setup
  12. shell> cd /usr/local/mysql
  13. shell> chown -R mysql .
  14. shell> chgrp -R mysql .
  15. shell> bin/mysql_install_db --user=mysql
  16. shell> chown -R root .
  17. shell> chown -R mysql var
  18. # Next command is optional
  19. shell> cp support-files/my-medium.cnf /etc/my.cnf
  20. shell> bin/mysqld_safe --user=mysql &
  21. # Next command is optional
  22. shell> cp support-files/mysql.server /etc/init.d/mysql.server
复制代码
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP