Linux系统下构建支持Mysql的动态Web网站服务器

本文是笔者在Linux服务器上安装PHP动态Web服务器、MySQL数据库的安装配置手册。通过在服务器安装Apache、Mysql、PHP 等功能实现一个建立一个PHP全动态的Web站点。本文是以RedHat9.0 Linux作为操作系统平吧, Apache版本是1.3.29;数据库 Mysql的牌本是3.23.58、PHP的版本是4.3.4!
  Linux系统的安装在此不在讨论,本文是以Redhat 9.0最小化安装加上内核开发包的基本上进行配置安装的。对于其它安装有apache,mysql和php以及相关的软件。已经安装的请用rpm -e * 删除已经安装的包。
  1.安装Mysql3.23.58
  其实老实说直接安装Mysql官方网站提供的rpm包也是一个比较可行的办法,他的官方网站的rpm包的提供基本跟tar包发行是同步的,这点我比较喜欢,至少安装rpm包的在后面的调试中不会出现mysql库文件找不到的情况。但这里还是有必要讲一下自定义安装的步骤,毕竟网友自定义安装的还说挺多的。
  软件获取:
  安装步骤:
  tar zxvf mysql-3.23.58.tar.gz
  cd mysql-3.23.58
  ./configure --prefix=/usr/local/mysql --sysconfdir=/etc --localstatedir=/var/lib/mysql
  make
  make install
  #prefix=/usr/local/mysql mysql安装的目标目录
  #sysconfdir=/etc my.ini配置文件的路径
  #localstatedir=/var/lib/mysql 数据库存放的路径
  安装完以后要初始化数据库,当然你是升级的话不用做这步;
  /usr/local/mysql/bin/mysql_install_db
  如果系统没有mysql这个用户的话,最好做以下这步:
  useradd -M -o -r -d /var/lib/mysql -s /bin/bash -c "MySQL Server" -u 27 mysql
  然后我启动mysql
  /usr/local/mysql/bin/safe_mysqld &
  ok,先看看mysql能否正常工作
  mysql -uroot mysql
  一般情况下都是不能正常链接数据库,错误提示一般为:
  ERROR 2002: Can't connect to local MySQL server through socket '/var/lib/mysql/mysql.sock' (2)
  其实网上大家问的最多的都是整个问题,说什么链接不到mysqld.sock,其实大家不妨看看mysql的错误日志就明白怎么回事,我这里的错误日志是在
  /var/lib/mysql/*.err 你会发现mysql只所以不能启动,是因为/var/lib/mysql的权限不允许mysql服务访问,英文mysql默认是调用mysql用户来启动服务的,好了,既然知道是什么原因找到不能启动,那就简单了。我们只要
  chown -R mysql:mysql /var/lib/mysql 就行,如果还是启动不了,再慢慢调试权限,反正一般启动不了都是权限的问题。
  如果大家还是不能启动不了的话,那就用我的比较繁琐的权限的设置,反正我每次都是这么做的,一般不会有问题,见下:
  chown -R root /usr/local/mysql
  chgrp -R mysql /usr/local/mysql
  chown -R root /usr/local/mysql/bin
  chgrp -R mysql /usr/local/mysql/bin
  chgrp -R mysql /var/lib/mysql
  chmod 777 /var/lib/mysql
  chown -R root /var/lib/mysql/mysql
  chgrp -R mysql /var/lib/mysql/mysql
  chmod 777 /var/lib/mysql/mysql
  chown -R root /var/lib/mysql/mysql/*
  chgrp -R mysql /var/lib/mysql/mysql/*
  chmod 777 /var/lib/mysql/mysql/*
  chmod 777 /usr/local/mysql/lib/mysql/libmysqlclient.a
  做完上面的步骤,然后把你编译目录的一个脚本COPY过去
  cp support-files/mysql.server /etc/rc.d/init.d/mysqld
  chkconfig --add mysqld
  用ntsysv设置使mysql每次启动都能自动运行。
  好了,至此mysql安装完毕,你可以这样起动你的mysql服务
  /etc/rc.d/init.d/mysqld start
  下面这步比较关键,
  ln -s /usr/local/mysql/lib/mysql /usr/lib/mysql
  ln -s /usr/local/mysql/include/mysql /usr/include/mysql
  大家可以不做这步,大可以在编译其他软件的时候自定义myslq的库文件路径,但我还是喜欢把库文件链接到默认的位置,这样你在编译类似PHP,Vpopmail等软件时可以不用指定mysql的库文件地址。

linux

内容版权声明:除非注明,否则皆为本站原创文章。

转载注明出处:https://www.heiqu.com/wwwdsg.html