2015年6月1日发布 LNMP 1.2 一键安装包国内下载

下载版:http://soft.vpser.net/lnmp/lnmp1.2.tar.gz (115KB)
MD5:75429551c2614e298e6df5ccda0d3968
完整版:http://soft.vpser.net/lnmp/lnmp1.2-full.tar.gz (303MB)
MD5:9fda60bd8d699ec53c16545af6c16360
国内下载地址:
https://api.sinas3.com/v1/SAE_lnmp/soft/lnmp1.2-full.tar.gz 下载时wget需要加–no-check-certificate参数
http://lnmp.qiniudn.com/lnmp1.2-full.tar.gz
http://lnmporg.b0.upaiyun.com/lnmp1.2-full.tar.gz

LNMP 1.2对脚本进行重写优化,使用lnmp进行大部分的管理任务、使用upgrade.sh进行程序的升级、使用addons.sh进行组件的安装和卸载。同时增加了诸多实用脚本。
安装前建议使用screen,执行:screen -S lnmp 后,执行:wget -c http://soft.vpser.net/lnmp/lnmp1.2-full.tar.gz && tar zxf lnmp1.2-full.tar.gz && cd lnmp1.2-full && ./install.sh {lnmp|lnmpa|lamp}

LNMP状态管理:lnmp {start|stop|reload|restart|kill|status}
LNMP各个程序的状态管理:lnmp {nginx|mysql|mariadb|php-fpm|pureftpd} {start|stop|reload|restart|kill|status}
虚拟主机管理:lnmp vhost {add|list|del}
数据库管理:lnmp database {add|list|del}
FTP用户管理:lnmp ftp {add|list|del}

更新记录
2015年6月1日发布LNMP 1.2

完全重写优化安装脚本、升级脚本及组件安装等大部分脚本;
状态管理、虚拟主机管理、FTP管理及数据库管理全部采用lnmp命令替换,去掉/root/vhost.sh和/root/lnmp脚本;
Nginx、MySQL/MariaDB、PHP的升级脚本整合为upgrade.sh;
缓存、加速、imageMagick、ionCube等的安装卸载采用addons.sh进行;
增加SSH防护工具DenyHosts、Failban安装脚本及DenyHosts被封IP删除脚本;
增加新的备份脚本backup.sh;
支持的Linux发行版:CentOS 5-7、RHEL 6-7、Fedora 20-21、Aliyun、Debian 6-8、Raspbian、Ubuntu 10.10-15.04;
支持ARM平台,Raspberry Pi已测试;
MySQL安装时可选5.1.73、5.5.42、5.6.23,MariaDB可选5.5.42、10.0.17;
PHP安装时可选5.2.17、5.3.29、5.4.41、5.5.25、5.6.9;
安装时增加内存优化jemalloc或gperftools;
Apache安装时可选2.2.29或2.4.12;
Apache日志统一到/home/wwwlogs/下;
更新Nginx至1.8.0;
更新Zend Guard Loader至支持PHP 5.6;
更新phpMyAdmin至4.0.10.10、4.4.7;
更新memcached脚本,php-memcache或php-memcached可选;
Nginx配置文件进行了调整,启用php和pathinfo采用include方式,默认启用spdy,增加ssl范例配置;
PHP启用pear、pecl,可以直接使用该命令安装php扩展或模块;
等诸多小的更新及调整;
2014年6月13日修复redis phpredis未安装;

由于日志占满空间导致MySQL无法启动的解决方法

查了一下Mysql手册发现这些东西也没啥用,直接删除(此操作最好在Mysql服务停止时进行,因为当前日志使用的话无法删除,而且有可能导致一些其它问题,不过用mysql>reset master命令可以直接清空日志)

root@slyar:/usr/local/mysql/var# rm -f mysql-bin.*

为了防止再次出现此类状况,直接关闭Mysql的log-bin日志功能

vim /etc/my.cnf

找到:
log-bin=mysql-bin
binlog_format=mixed

在前面加上#注释掉,:wq保存退出

最后

/etc/init.d/mysql restart

启动Mysql服务,一切正常。

Via : http://www.veryhuo.com/a/view/62402.html

如何卸载lnmp

在lnmp目录有个uninstall.sh,可以直接停止lnmp。

备用方法:

killall nginx *//终止nginx进程
/etc/init.d/mysql stop *//关闭mysql
killall mysqld *//终止mysql进程
/usr/local/php/sbin/php-fpm stop *//关闭php
killall php-cgi *//终止php-cgi进程
rm -rf /usr/local/php *//删除php文件
rm -rf /usr/local/nginx *//删除nginx文件
rm -rf /usr/local/mysql *//删除mysql文件
rm -rf /usr/local/zend *//删除zend文件
rm /etc/my.cnf *//删除配置文件
rm /etc/init.d/mysql *//删除mysql文件
rm /root/vhost.sh *//删除配置虚拟主机脚本
rm /root/lnmp *//删除lnmp文件夹

php加速器:debian[lnmp]eAccelerator的安装和参数详解

eAccelerator是一个自由开放源码PHP加速器,优化和动态内容缓存,提高了php脚本的缓存性能,使得PHP脚本在编译的状态下,对服务器的开销几乎完全消除。它还有对脚本起优化作用,以加快其执行效率。使您的PHP程序代码执效率能提高1-10倍。

Linux系统上编译安装eAccelerator
# tar zxvf eaccelerator-eaccelerator-42067ac.tar
# cd eaccelerator-eaccelerator-42067ac/
# /usr/local/php/bin/phpize
# ./configure –enable-eaccelerator=shared \
–with-php-config=/usr/local/php/bin/php-config
# make && make install && cd ..

在php.ini文件中加入以下参数:

[eaccelerator]
eaccelerator.allowed_admin_path = "/root/wwwroot"
zend_extension="/usr/local/php/lib/php/extensions/no-debug-non-zts-20100525/eaccelerator.so"
eaccelerator.shm_size="8"
eaccelerator.cache_dir="/usr/local/eaccelerator_cache"
eaccelerator.enable="1"
eaccelerator.optimizer="1"
eaccelerator.check_mtime="1"
eaccelerator.debug="0"
eaccelerator.filter=""
eaccelerator.shm_max="0"
eaccelerator.shm_ttl="3600"
eaccelerator.shm_prune_period="3600"
eaccelerator.shm_only="0"
eaccelerator.compress="1"
eaccelerator.compress_level="9"
eaccelerator.keys = "disk_only"
eaccelerator.sessions = "disk_only"
eaccelerator.content = "disk_only"

eaccelerator.allowed_admin_path = “/root/wwwroot”
eAccelerator控制面板的地址,安装包里有一个control.php文件,把它复制到网站的任意目录,可以用它查看和管理,这个必须指定,否则查看缓存内容的时候会出错,访问时候默认的用户名是:admin,密码:eAccelerator

zend_extension=”/usr/local/php/lib/php/extensions/no-debug-non-zts-20100525/eaccelerator.so”
应为php是基于zend引擎的,extension意为基于php引擎的扩展,zend_extension意为基于zend引擎的扩展

eaccelerator.shm_size=”8″
eAccelerator 可以使用的共享内存的数量 (以MB为单位) . “0” 是指操作系统的默认值,默认值是 “0”,可根据服务器的实际情况来调整:16、32、64、128都是可以的。

eaccelerator.cache_dir=”/usr/local/webserver/eaccelerator_cache”
这个目录是给磁盘缓存使用,eAccelerator 在这里储存预先编译好的代码,进程数据,内容以及用户的自定义内容。同样的数据也能被储存在共享内存中 (这样可以提高访问速度)

eaccelerator.enable=”1″
开启或关闭 eAccelerator,”1″ 为开启,”0″ 为关闭。默认值为 “1”。

eaccelerator.optimizer=”1″
启或关闭内部优化器,可以提升代码执行速度。”1″ 为开启,”0″ 为关闭。默认值为 “1”。

eaccelerator.check_mtime=”1″
打开或者关闭 PHP 的文件修改检查,”1″ 是指打开,”0″ 是指关闭。默认值是 “1”。

eaccelerator.debug=”0″
开启或关闭调试日志记录。”1″ 为开启,”0″ 为关闭。默认值为 “0”。会将缓存命中得记录写入日志。

eaccelerator.filter=””
判断哪些 PHP 文件必须缓存。可以指定缓存和不缓存的文件类型(如 “*.php *.phtml”等)如果参数以 “!” 开头,则匹配这些参数的文件被忽略缓存。默认值为 “”,即,所有 PHP 文件都将被缓存。

eaccelerator.shm_max=”0″
当使用 ” eaccelerator_put() ” 函数时禁止其向共享内存中存储过大的文件。该参数指定允许存储的最大值,单位:字节 (10240, 10K, 1M)。”0″ 为不限制。默认值为 “0”。

eaccelerator.shm_ttl=”3600″
当 eAccelerator 获取新脚本的共享内存大小失败时,它将从共享内存中删除所有在最后 “shm_ttl” 秒内没有存取的脚本缓存。默认值为”0″,为不从共享内存中删除任何缓存文件。

eaccelerator.shm_prune_period=”3600″
当 eAccelerator 获取新脚本的共享内存大小失败时,他将试图从共享内存中删除早于”shm_prune_period” 秒的缓存脚本。默认值为 “0”,为不从共享内存中删除任何缓存文件。

eaccelerator.shm_only=”0″
允许或禁止将已编译脚本缓存在磁盘上。该选项对 session 数据和内容缓存无效。默认值为 “0”,为使用磁盘和共享内存进行缓存。

eaccelerator.compress=”1″
允许或禁止压缩内容缓存。默认值为 “1”,为允许压缩。

eaccelerator.compress_level=”9″
指定内容缓存的压缩等级。默认值为 “9”,为最高等级。

eaccelerator.keys = “disk_only”
eaccelerator.sessions = “disk_only”
eaccelerator.content = “disk_only”
设置内容缓存的存放的地方,可以设置为:
shm_and_disk 在共享缓存和硬盘(默认值)
shm     默认存在共享内存,如果共享内存已满或大小超过 “eaccelerator.shm_max” 的值,就存到硬盘
shm_only   只存放在共享内存
disk_only   只存放在硬盘
none     不缓存数据

Via:http://www.linuxde.net/2011/06/147.html

LNMP 修改MySQL密码的方法

修改的步骤如下:

/etc/init.d/mysql start –skip-grant-tables

cd /usr/local/mysql/bin

./mysql -u root -p

此时会提示你输入密码,但是直接回车即可。

然后出现mysql > 的提示符

之后输入:

use mysql;

UPDATE user SET password=PASSWORD(‘root’) WHERE user=’root’;

exit;

此时mysql的root密码就被改为:root

记得重新启动mysql:

/etc/init.d/mysql restart

LNMP定时重启 crontab

1、使用命令 # crontab –e ,进入cron任务表。

2、在# m h  dom mon dow   command下面,增加一行:

          00 */3 * * * /root/lnmp restart   //每隔3小时重启一次   
或者     0 0 * * * /root/lnmp restart       //每天0点重启

3、按Ctrl+O保存,回车确认,再按Ctrl+X,就可以关闭编辑界面了。

整个定时重启设置完成。

service cron start 启动cron服务

service cron restart  重启cron服务

lnmp0.9的一些bug处理方法

貌似lnmp从0.9开始,限制了不少函数,理由是出于安全考虑,但是这也影响了一些网站程序。

譬如 DiscuzX 通信失败或通过Socket连接SMTP无法发送邮件或wordpress Akismet 无法工作问题的解决方法目前LNMP 0.9禁用了部分危险函数:passthru,exec,system,chroot,scandir,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_alter,ini_restore,dl,pfsockopen,openlog,syslog,readlink,symlink,popepassthru,stream_socket_server,fsocket,fsockopen

由于禁用了pfsockopen、fsockopen 会造成 Discuzx Discuz X通行失败,通过Socket连接SMTP无法发送邮件 或wordrpess的Akismet 无法工作:引用:您的主机似乎禁用了 PHP 的 fsockopen 或 gethostbynamel 函数。在此问题修复之前,Akismet 无法工作。请联系您的主机服务管理员或防火墙管理员,并向他们提供 Akismet 的运行环境要求。解决方法:
目前最常可能用到的就是pfsockopen、fsockopen,如果将这2个函数从禁用列表里删除可以执行:

sed -i 's/disable_functions =.*/disable_functions = passthru,exec,system,chroot,scandir,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,stream_socket_server,fsocket/g' /usr/local/php/etc/php.ini

 

然后执行:/etc/init.d/php-fpm restart 重启生效

如果想完全删掉禁用列表里的函数可以执行:

sed -i 's/disable_functions =.*/disable_functions =/g' /usr/local/php/etc/php.ini

再执行:/etc/init.d/php-fpm restart 重启生效

wordpress3.4后主题管理不显示其他的主题?
解决方法:将scandir 函数从禁用列表里删掉就行了。

sed -i 's/disable_functions =.*/disable_functions = passthru,exec,system,chroot,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,stream_socket_server,fsocket/g' /usr/local/php/etc/php.ini

然后执行:/etc/init.d/php-fpm restart 重启生效

安装好ImageMagick,在后台设置好路径,但是无法预览缩略图效果?
解决方法:将exec 函数从禁用列表里删掉就行了。

sed -i 's/disable_functions =.*/disable_functions = passthru,system,chroot,chgrp,chown,shell_exec,proc_open,proc_get_status,ini_alter,ini_alter,ini_restore,dl,openlog,syslog,readlink,symlink,popepassthru,stream_socket_server,fsocket/g' /usr/local/php/etc/php.ini

然后执行:/etc/init.d/php-fpm restart 重启生效

感谢XMJ’s Blog分享。

lnmp下Nginx服务器设置防盗链最简单方法

因为nginx不支持.htaccess,所以在防盗链上比较麻烦。
1.确定要修改的文件
如果你安装lnmp后,没有新建站点,而是使用默认站点,那你需要修改的文件是/usr/local/nginx/conf/nginx.conf
如果你新建了站点,那么要修改的文件是/usr/local/nginx/conf/vhost/这个文件夹下面的相应文件,通常应该是 域名.conf
2.根据你的情况,下载或者打开相应的.conf文件,注意先备份
找到下面内容

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
expires 30d;
}

把它修改为类似下面的样子

location ~ .*\.(gif|jpg|jpeg|png|bmp|swf)$
{
valid_referers none blocked www.domin.com domin.com;
if ($invalid_referer) {
rewrite ^/ http://otherdomin.com/404.jpg;
#return 404;
}
expires 30d;
}

特别说明:
以上都不是真正防盗链,但是在其他网站调用的本站图片都已经作了防护了,如果用户通过浏览器直接输入图片地址或下载地址,仍然会显示图片,仍可下载文件,因为 valid_referers 里多了“none blocked”。
最后说下ngingx下如何彻底地实现真正意义上的防盗链,那就是把“none blocked”去掉,这样浏览器直接输入就不会显示图片了(别忘了改成自己的域名)

你要修改的地方
gif|jpg|jpeg|….,这些是你想要屏蔽的文件类型,可以根据情况修改
domin.com www.domin.com,修改为你网站的域名,或者是你允许显示你网站图片的其他网站域名,注意中间用空格分开,而不是逗号
http://otherdomin.com/404.jpg,显示给盗链者看到的图片,注意不要放到domin.com上,因为放盗链的作用,那样对方是看不到的,可以上传到一些支持外联的网络相册上。
3.保存修改后的文件,上传覆盖原始文件
需要重新启动lnmp后才能看到效果,命令是
停止lnmp:/root/lnmp stop
启动lnmp:/root/lnmp start
这样我们就实现了图片的防盗链,实际效果看下面
对了   不要忘了重启lnmp:
/root/lnmp restart
转自原文