看来我也是个懒人,半年博一次.纪录学习lamp的经历吧学习在linux上安装apache2,mysql4,php5,soopx.
前3个安装完后,发现soopx无法安装完毕.报错如下:
Fatal error: mysql extension not loaded in /var/www/class/database/mysqldatabase.php on line 74;
就其原因,可能是如下所说:
================
在 Linux 系统下安装PHP 4默认开启了 --with-mysql 选项。此默认行为可以用 --without-mysql 配置选项来禁止。如果启用 MySQL 而不指定安装目录的话,PHP 将使用绑定的 MySQL 客户端连接库。 还有其它应用程序使用 MySQL(例如 auth-mysql)的用户不要用绑定的库,而要指定 MySQL 的安装目录,如这样:--with-mysql=/path/to/mysql。这将强制 PHP 使用随 MySQL 安装的客户端连接库,就可以避免任何冲突。 PHP 5+MySQL 默认未启用,也没有绑定的 MySQL 库。其原因见此 FAQ。使用 --with-mysql[=DIR] 配置选项来加入 MySQL 的支持。可以从 MySQL 下载头文件和库。 出处:http://php./manual/zh/faq.databases.php#faq.databases.mysql.php5 ================ 在xoops中文官网上提问,贴子:http://php./manual/zh/faq.databases.php#faq.databases.mysql.php5 ================ 看来这个贴子是我最想要的了 http://www./support/documentation/server/apache/base_view 主要内容: 如何安装 Web 支持Summary:
如何安装 apache2 + php5 + mysql? Body:
1. 安装运行环境 sudo apt-get install apache2 2. 配置php5 sudo gedit /etc/php5/apache2/php.ini修改允许最大使用内存,查找 memory_limit = 8M修改为 memory_limit = 32M 修改允许最大上传尺寸,查找 upload_max_filesize = 2M修改为 upload_max_filesize = 8M 允许 mysql 和 gd 模块,检查文件最后是否包含下面的代码,如果没有添加上。(默认是在配置文件最后有添加的,检查一下以防万一) extension=mysql.so保存并关闭文件。 3. 配置 mysql,让它支持其它客户端访问,如果你不需要就不用修改。 sudo gedit /etc/mysql/my.cnf查找文件 skip-networking修改为 #skip-networking保存并关闭文件。 重新启动 mysql sudo /etc/init.d/mysql restart插入其它客户端访问用户(由于默认的账号是root@localhost,而客户端却使用root@localhost.localdomain登录) mysql -u root -e "GRANT ALL PRIVILEGES ON *.* TO root@localhost.localdomain;"安装 mysql 客户端查询工具 sudo apt-get install mysql-query-browser直接在终端输入 mysql-query-browser启动 msql 查询器,输入服务器IP:127.0.0.1 账号:root 点击 connect,就可以查询和维护数据了。
================ 安装apache2: 1、安装Apache2
2、编辑/etc/apache2/apache2.conf文件,在改动之前,请先将该配置文件做个备份。以便在出错的时候可以恢复。 >AddDefaultCharset ISO-8859-1 =>AddDefaultCharset GB2312 这样的话,我们就不会每次打开网页都是乱码了! 3、增加安全模块,以保障Apache服务的正常运行,现在我们安装mod-security。 a)首先安装libapache2-mod-security包
b)该模块默认是没激活的,我们可以在/etc/apache2/mods-available目录下看到有mod-security.load文件,但在/etc/apache2/mods-enabled目录却没有它的软链接。我们现在激活它: $sudo ln -s /etc/apache2/mods-available/mod-security.load /etc/apache2/mods-enabled/mod-security.load $sudo cp /usr/share/doc/libapache2-mod-security/examples/httpd2.conf.example-full /etc/apache2/mods-available/mod-security.conf $sudo cp /etc/apache2/mods-available/mod-security.conf /etc/apache2/mods-available/mod-security.conf.orig $sudo vi /etc/apache2/mods-available/mod-security.conf ># 检测内容长度以避免堆溢出攻击 >SecFilterForceByteRange 32 254 =>SecFilterForceByteRange 32 126 ># debug设置 >SecFilterDebugLevel 9 =>SecFilterDebugLevel 0 ># 设置缺省的动作 >SecFilterDefaultAction "deny,log,status:499" =>SecFilterDefaultAction "deny,log,status:404" ># 把设置传递给子目录 >SecFilterInheritance Off ># Redirect user on filter match ># 当匹配sh的时候,重新定向到一个特殊的警告页面,该页面是自行编写的,写些警告的话让攻击者知难而退,该段先不要生效,等到相关配置配好之后再失效不迟。记住在配好之后要使之生效。 >#SecFilter sh redirect:http://localhost/hack/warning.htm ># Prevent OS specific keywords >#过滤一些敏感的东西,我们使用*是为了攻击者使用/etc/./passwd来绕开检测 >SecFilter /etc/passwd =>SecFilter /etc/*passwd >SecFilter /bin/*sh ># Very crude filters to prevent SQL injection attacks ># 防止SQL插入(SQL Injection)攻击 >SecFilter "delete[[:space:]]+from" >SecFilter "insert[[:space:]]+into" >SecFilter "select.+from" >SecFilter "select[[:space:]]+from" >SecFilter "union[[:space:]]+from"
c)重启Apache2服务即可。
第三步可能会引起部分网站不能正常运行,可以参照着去掉某些限制,由于是安全模块,所以参照的是防火墙的做法,关掉一切不安全的,再根据需要打开必要的。 出处:http://forum./viewtopic.php?t=2143 ============== 1.将系统更新到最新状态,在做任何操作之前都要做这一步,以确保系统的稳定,同时也不会有一些莫名其妙的现象出现。
出处:http://forum./viewtopic.php?t=2193 ==================== 1、安装MySQL |
|