由于服务器不支持从ram安装,这里从源码安装
wget http://downloads.sourceforge.net/project/wput/wput/0.6.1/wput-0.6.1.tgz tar xvf wput-0.6.1.tgz cd wput-0.6.1 ./configure make make install
debian安装就超级简单了
apt-get install wput
由于服务器不支持从ram安装,这里从源码安装
wget http://downloads.sourceforge.net/project/wput/wput/0.6.1/wput-0.6.1.tgz tar xvf wput-0.6.1.tgz cd wput-0.6.1 ./configure make make install
debian安装就超级简单了
apt-get install wput
有客户的windows服务器mysql一直占用居高不下,找我给查找原因。
查看连接数:
netstat -aon > c:\netstat.txt
看到总连接数400多个,还得去掉100多mysql的。这么小的并发怎么可能会有这么高的占用。
上传minisniffer抓取数据包,看看是否正在被攻击.经查证至少少量的php请求,主要分布为ad_js.php和mood.php。
修改缓存结构,把ad_js.php的数据库请求部分去掉。强制缓存为24小时。
< ?php /** * * 广告JS调用方式 * * @version $Id: ad_js.php 1 20:30 2010年7月8日Z tianya $ * @package DedeCMS.Site * @copyright Copyright (c) 2007 - 2010, DesDev, Inc. * @license http://help.dedecms.com/usersguide/license.html * @link http://www.dedecms.com */ $osiris_myid=$_GET['aid']; $cfg_puccache_time=86400; $cacheFile=dirname(__FILE__).'/../data/cache/myad-'.$osiris_myid.'.htm'; if (!file_exists($cacheFile)|| time() - filemtime($cacheFile) > $cfg_puccache_time){ require_once(dirname(__FILE__)."/../include/common.inc.php"); if(isset($arcID)) $aid = $arcID; $arcID = $aid = (isset($aid) && is_numeric($aid)) ? $aid : 0; if($aid==0) die(' Request Error! '); $cacheFile = DEDEDATA.'/cache/myad-'.$aid.'.htm'; if( isset($nocache) || !file_exists($cacheFile) || time() - filemtime($cacheFile) > $cfg_puccache_time ) { $row = $dsql->GetOne("SELECT * FROM `#@__myad` WHERE aid='$aid' "); $adbody = ''; if($row['timeset']==0) { $adbody = $row['normbody']; } else { $ntime = time(); if($ntime > $row['endtime'] || $ntime < $row['starttime']) { $adbody = $row['expbody']; } else { $adbody = $row['normbody']; } } $adbody = str_replace('"', '\"',$adbody); $adbody = str_replace("\r", "\\r",$adbody); $adbody = str_replace("\n", "\\n",$adbody); $adbody = "\r\n"; $fp = fopen($cacheFile, 'w'); fwrite($fp, $adbody); fclose($fp); } } include $cacheFile;
使用mysql工具查看负载
mysql -u root -p mysql> show processlist;
发现一个奇异的查询语句
$dsql->GetOne("SELECT count( mood ) AS cc FROM `#@__mood_ranking` WHERE aid = '$aid' AND ip = '$uip' AND time > $time24 ");
更改为
$dsql->GetOne("SELECT id from `#@__mood_ranking` WHERE aid = '$aid' AND time > $time24 AND ip = '$uip'");
运行良好,修改结束。
更新20130209【春节贺岁版】
增加suphp模式,用户使用更方便。
froxlor一键安装包使用示例
wget http://static.qinhai.us/sh/froxlor.sh bash froxlor.sh nmp #安装Nginx+Mysql+PHP+froxlor环境
创建froxlor任务
5/* * * * * php /var/www/froxlor/scripts/froxlor_master_cronjob.php --force /etc/init.d/cron restart
使用APT安装suphp,结果不能使用suPHP_UserGroup
apt-get install libapache2-mod-suphp
错误如下:
Invalid command 'suPHP_UserGroup', perhaps misspelled or defined by a module not included in the server configuration
原因是apt的软件包不支持suPHP_UserGroup,所以需要从源码安装suphp。搜索了一下午就没一个正确的结果,终于在一篇英文资料上找到了。原文在文末,这里简要的说下如何安装。
原文地址:http://kb.acenet.us/LAMP_Server_Installation_Guide_on_Debian_6_(Squeeze)
英文内容如下:
If you have properly pointed the DNS for your domain, you should now be able to visit your website in a browser and have your content served from your new Debian LAMP server.
Install suPHP
After getting your site up and running, we generally advise that suPHP be enabled for additional security.
suPHP is a tool for executing PHP scripts with the permissions of their owners. It consists of an Apache module (mod_suphp) and a setuid root binary (suphp) that is called by the Apache module to change the uid of the process executing the PHP interpreter. suPHP helps increase the security of your server. With scripts run as the owner, abusive processes can more easily be tracked back to a given user. Stricter script permissions are enforced since scripts are no longer run as the apache user.
We’ll now show you how to install suPHP on your Debian 6 server with the package manually compiled from source. suPHP has three different modes of operation which must be specified at compile time:
owner: Run scripts with owner UID/GID
force: Run scripts with UID/GID specified in Apache configuration
paranoid: Run scripts with owner UID/GID but also check if they match the UID/GID specified in the Apache configuration
The suPHP documentation states:
"The default is "paranoid" mode. You should *NEVER* use "force" mode as it is very dangerous.
While "owner" mode is not as dangerous as "force" mode its use is disadvised and
"paranoid" mode should be preferred."
In this guide we manually compile suPHP, but there is a pre-built package available for apt-get. This package is libapache2-mod-suphp.
Although suPHP states that the default mode is “paranoid”, the libapache2-mod-suphp is installed in “owner” mode by default. When suPHP is installed in “owner” mode, the directive suPHP_UserGroup is not recognized which is required for “force” or “paranoid” mode. When attempting to use the suPHP_UserGroup directive with suPHP in “owner” mode, you will encounter this error while restarting apache2:
Invalid command 'suPHP_UserGroup', perhaps misspelled or defined by a module not included in the server configuration
For this reason, we opt to install suPHP directly from source rather than use the pre-compile Debian package.
Install suPHP Prerequisites
apt-get install apache2-prefork-dev make gcc g++ php5-cgi wget
Disable PHP5
We’re changing the interpretter that handles PHP scripts. We’ll need to disable PHP5.
a2dismod php5
Installation
Download suPHP
Get the suPHP source. The current version is 0.7.1.
cd /
wget http://suphp.org/download/suphp-0.7.1.tar.gz
tar -zxf suphp-0.7.1.tar.gz
cd suphp-0.7.1
Compile suPHP
This will configure suPHP to use /etc as the configuration directory and set the mode to “paranoid”.
./configure --prefix=/usr --sysconfdir=/etc --with-apache-user=www-data --with-setid-mode=paranoid --with-apxs=/usr/bin/apxs2 make make install
Copy the suphp.conf file
The suPHP package comes with an example suphp.conf file. We’re going to copy this to /etc.
cp /suphp-0.7.1/doc/suphp.conf-example /etc/suphp.conf
Clean up our installation files
rm -rf /suphp-0.7.1 rm -rf /suphp-0.7.1.tar.gz
Configuring suphp.conf
Let’s modify /etc/suphp.conf for our server environment. Open the config file in your favorite editor. Throughout the course of this guide, we’ll use nano.
nano /etc/suphp.conf
Change the line:
webserver_user=wwwrun
to:
webserver_user=www-data
Change the line:
x-httpd-php="php:/usr/bin/php"
to:
application/x-httpd-suphp="php:/usr/bin/php-cgi"
Loading suPHP in apache2
suphp.load
Create a suphp.load file for apache2
nano /etc/apache2/mods-available/suphp.load
Place this line in the file and save:
LoadModule suphp_module /usr/lib/apache2/modules/mod_suphp.so
apache2 suPHP config file
Create an apache2 conf file for suPHP:
nano /etc/apache2/mods-available/suphp.conf
Place these lines in the file and save.
AddType application/x-httpd-suphp .php .php3 .php4 .php5 .phtml suPHP_AddHandler application/x-httpd-suphp suPHP_Engine on # By default, disable suPHP for debian packaged web applications as files # are owned by root and cannot be executed by suPHP because of min_uid. suPHP_Engine off # # Use a specific php config file (a dir which contains a php.ini file) # suPHP_ConfigPath /etc/php4/cgi/suphp/ # # Tells mod_suphp NOT to handle requests with the type. # suPHP_RemoveHandler
Enable suPHP in apache2
a2enmod suphp
We now need to edit our site’s VirtualHost entry to include the suPHP_UserGroup directive. Continuing from our previous guide, our site is called mywebsite.example.com. Our username is ‘mywebsite’. We’re going to edit the appropriate apache2 Virtual Host file:
nano /etc/apache2/sites-available/mywebsite.example.com
Within this file, before the closing tag at the bottom, add these lines:
suPHP_UserGroup mywebsite mywebsite
Restart Apache
service apache2 restart
At this point, suPHP is enabled and active. Let’s create a test php file in our directory to ensure it’s working properly. Again, we’re going to use the document root as described in our LAMP setup tutorial.
Testing suPHP
Create the PHP file for testing
nano /home/mywebsite/public_html/index.php
Enter this line and save:
< ?php echo 'whoim = '.exec('/usr/bin/whoami');?>
chown the file properly. We’re using the username ‘mywebsite’ in this example.
chown mywebsite.mywebsite /home/mywebsite/public_html/index.php
You should now be able to navigate to this file in a browser and see the output. In our case, we visit mywebsite.example.com and can see:
whoim = mywebsite
This shows us that the PHP script is running as the user ‘mywebsite’ instead of the Apache user ‘www-data’.
suPHP is now installed and ready for use.
Vps.net是一家世界知名的云计算提供商,博主1日的时候购买了1枚。结果遇到了奇葩事件2个。
奇葩事件一:上行无限,下行512K——媲美我国的ADSL宽带。我用了一天时间传进去2.5G数据。
奇葩事件二:抓包抓网段。博主想抓包看下为什么这么卡。结果发现包跑的N快。仔细一看竟然都不是我的数据流。 继续阅读
最新评论