Chinaunix首页 | 论坛 | 博客
  • 博客访问: 482170
  • 博文数量: 95
  • 博客积分: 2117
  • 博客等级: 大尉
  • 技术积分: 2301
  • 用 户 组: 普通用户
  • 注册时间: 2008-06-16 21:10
个人简介

辽宁铁岭人,现居大连。1970年生。 先后供职于 中国国际海运网、大连学堂科技、大连华仁视线网络科技有限公司、大连中科海云科技有限公司,任职技术总监。 精通PHP、JAVA、Javascript、HTML、CSS等网络编程技术及Linux操作系统。 精通面向对象编程、设计模式、重构及互联网产品设计。

文章分类

全部博文(95)

文章存档

2013年(31)

2012年(2)

2011年(34)

2010年(25)

2008年(3)

分类: Mysql/postgreSQL

2011-03-25 09:26:52

特别值得一提的是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下,然后解压安装,具体步骤如下

  1. #cd /usr/local/src  
  2. #tar -zxvf mysql-5.1.30.tar.gz  
  3. #cd mysql-5.1.30  
  4. #groupadd -r mysql //创建mysql用户组  
  5. #useradd -m -r -g mysql -d /var/lib/mysql -s /bin/bash \  
  6. >-c "MySQL Server" mysql  
  7. #./configure --prefix=/usr/local/mysql \ //指定mysql安装目录  
  8. >--sysconfdir=/etc \   //指定mysql配置文件存放目录  
  9. >--localstatedir=/var/lib/mysql \//指定mysql数据库存放目录  
  10. >--enable-local-infile \  //激活load data local infile语句,使mysql支持使用该语句
  11. >--with-charset=utf8
  12. >--with-collation=utf8_general_ci
  13. >--with-extra-charsets=latin1
  14. #make   //编译(需较长时间)  
  15. #make install   //安装  
  16. #make clean  
  17. #make distclean  

2.Linux Mysql初始化数据库

  1. #cd /usr/local/mysql  
  2. #/bin/mysql_install_db --user=mysql//初始化系统数据库  
  3. #ls /var/lib/mysql //查看存放数据库中的目录内容 

3Linux Mysql.修改数据库目录所有者

  1. #chown -R mysql:mysql /var/lib/mysql 

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

  1. #cp /usr/local/mysql/share/mysql/my-large.cnf /etc/my.cnf   //一般正常安装之后已经有该文件,可以不用拷贝 

5.复制生成Linux Mysql服务器的自动与停止脚本

  1. #cp /usr/local/mysql/share/mysql/mysql.server /etc/rc.d/init.d/mysql 

6.修改/etc/rc.d/init.d/mysql文件中的基本路径:

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

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

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

8.启动Linux Mysql服务器

  1. #service mysql start 或 /etc/rc.d/init.d/mysql start 

9.测试Linux Mysql服务器

  1. #/usr/local/mysql/bin/mysqladmin version测试服务器是否已启动  
  2. #/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

  1. #cd /usr/local/src  
  2. #tar -zxvf httpd-2.2.3.tar.gz  
  3. #cd httpd-2.2.3  
  4. #./configure --prefix=/usr/local/apache \  
  5. >--enable-so \  
  6. >--with-mpm=prefork \  
  7. >--enable-modules="setenvif rewrite deflate vhost_alias" 
  8. #make  
  9. #make install  
  10. #usr/local/apache/bin/apachectl start
  11. 设置apache自启动:  
  12. #echo "/usr/local/apache/bin/apachectl start">> /etc/rc.d/rc.local在/etc/rc.d/rc.local中添加  
  13. #echo "/usr/local/apache/bin/apachectl start" /usr/local/apache/bin/apachectl start
  14. 或者
  15. 将apachectl复制到/etc/rc.d/init.d下
  16. #cp /usr/local/apache/bin/apachectl /etc/rc.d/init.d/apache
  17. 在/etc/rc.d/init.d/apache的第二行加入如下内容
  18. # 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.
  19. #chkconfig --list | grep httpd //查看是否当前是否有apache服务
  20. #chkconfig --add httpd
  21. #chkconfig --level 35 httpd on //设置在3、5运行级别也自动启动

最后来安装PHP-5.2.8

  1. #tar -zxvf php-5.2.8.tar.gz  
  2. #cd php-5.2.8  
  3. #./configure --prefix=/usr/local/php --with-mysql=/usr/local/mysql \  
  4. >--with-apxs2=/usr/local/apache/bin/apxs  
  5. #make   
  6. #make install  
  7. #make clean  
  8. #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

阅读(2121) | 评论(0) | 转发(0) |
给主人留下些什么吧!~~