Chinaunix首页 | 论坛 | 博客
  • 博客访问: 389415
  • 博文数量: 105
  • 博客积分: 6010
  • 博客等级: 准将
  • 技术积分: 1145
  • 用 户 组: 普通用户
  • 注册时间: 2008-10-01 09:01
文章分类

全部博文(105)

文章存档

2010年(3)

2009年(93)

2008年(9)

我的朋友

分类: BSD

2009-02-11 15:22:47

本文来自http://onmp.cublog.cn,欢迎转载!

所谓的O.N.M.P.是指OpenBSD、Nginx、MySQL、PHP(fastcgi),是利用OpenBSD及其软件包搭建的时下流行的MySQL+PHP应用环境,下面对主要的软件做下介绍:

:可能是这个星球最安全的操作系统了,在十几年的时间里面只被发现了两个远程安全漏洞。

:来自俄罗斯的HTTP软件,据说性能达到老牌的Apache十倍!并且极其节约资源,是单台服务器跑PHP应用的首选。官方文档声称能达到5W个并发连接,生产环境下单台双核2.33G服务器可以跑到3W个并发连接(仅运行Nginx+PHP-fastcgi)。

:老牌的开源数据库软件。

:这个几乎无人不知,和MySQL一起构成了开源环境下最强的建站组合。

下面以为例进行讲解,按照惯例,红色为输入的命令兰色为输入的文本。root环境:

一、软件环境的搭建

OpenBSD的安装就不罗嗦了,重点是分区的部分,推荐/var/mysql、/var/log、/var/mail、/var/nginx这几个目录单独分区,并给予足够的空间。系统安装的最后询问是否默认启动Ssh服务时回答”n”。

安装必须的软件包:

export PKG_PATH=ftp://ftp.openbsd.org/pub/OpenBSD/4.4/packages/i386/
pkg_add wget mysql-server php5-fastcgi php5-gd-5.2.6-no_x11 php5-mysql phpMyAdmin lighttpd-1.4.19p3 nginx pecl-APC

装完后按提示做连接并创建PHP工作目录:

ln -s /var/www/conf/modules.sample/php5.conf /var/www/conf/modules
ln -fs /var/www/conf/php5.sample/apc.ini /var/www/conf/php5/apc.ini
ln -fs /var/www/conf/php5.sample/gd.ini /var/www/conf/php5/gd.ini
ln -fs /var/www/conf/php5.sample/mbstring.ini /var/www/conf/php5/mbstring.ini
ln -fs /var/www/conf/php5.sample/mcrypt.ini /var/www/conf/php5/mcrypt.ini
ln -fs /var/www/conf/php5.sample/mysql.ini /var/www/conf/php5/mysql.ini
mkdir /var/www/tmp
chmod 0777 /var/www/tmp
mkdir /var/nginx/html/pma/
cp -rf /var/www/phpMyAdmin/* /var/nginx/html/pma/

vi /etc/login.conf

跳到最后,加入MySQL所需的修改:

mysql:\
        :openfiles-cur=2048:\
        :openfiles-max=4096:\
        :tc=daemon:

使修改生效:

cap_mkdb /etc/login.conf

安装数据库:

/usr/local/bin/mysql_install_db

二、修改各软件的配置文件

修改nginx的默认配置文件:

vi /etc/nginx/nginx.conf

增大nginx的并发连接数:

worker_connections  51200;

加入对.php文件的支持:

        location / {
            root   /var/nginx/html;
            index  index.php index.html index.htm;
        }

(加入index.php)

将下面这段前面的注释都去掉,改成:

        location ~ \.php$ {
            root           html;
            fastcgi_pass   127.0.0.1:9000;
            fastcgi_index  index.php;
            fastcgi_param  SCRIPT_FILENAME  /var/nginx/html$fastcgi_script_name;
            include        fastcgi_params;
        }

注意兰色的部分,这个部分原来是/scripts,改成/var/nginx/html

其他的部分请酌情修改。

修改MySQL的配置文件(或从/usr/local/share/mysql目录中拷贝合适的文件为/etc/my.cnf)。

关于MySQL的配置和优化,网上有很多这方面的文章,可以自行Google,这里就不多讨论了。

贴下偶的(总内存512M,MySQL使用256M,在my-large.cnf的基础上修改):

在[mysqld]段增加或修改:

skip-innodb
skip-networking
max_connections = 600
skip-bdb
skip-name-resolve
wait_timeout= 5

保存退出。

修改phpMyAdmin的配置文件,使之可用:

vi /var/nginx/html/pma/config.inc.php

将下面这行修改成:

$cfg['blowfish_secret'] = 'a'; /* YOU MUST FILL IN THIS FOR COOKIE AUTH! */

(仅是加入了字母a而已)

保存退出。

三、系统启动脚本的修改

修改系统启动脚本,使得MySQL、PHP(fastcgi)、Nginx可以在系统启动的时候自动启动,免去手动启动的麻烦。

vi /etc/rc.local

跳到最后,加入下面的部分:

rdate -n 210.72.145.44
# Start MySQL
if [ -x /usr/local/bin/mysqld_safe ] ; then
   echo -n 'Starting MySQL...'
   su -c mysql root -c '/usr/local/bin/mysqld_safe >/dev/null 2>&1 &'
   echo "DONE"
fi
# Start php-fastcgi
if [ -x /usr/local/bin/spawn-fcgi ] ; then
   echo -n 'Starting php-fastcgi...'
   /usr/local/bin/spawn-fcgi -a 127.0.0.1 -p 9000 -C 6 -u www -f /usr/local/bin/php-fastcgi > /var/run/fcgi.pid
   echo "DONE"
fi
# Start nginx
if [ -x /usr/local/sbin/nginx ] ; then
   echo -n 'Starting nginx...'
   /usr/local/sbin/nginx
   echo "DONE"
fi

保存退出。

四、修改默认的SSH端口

vi /etc/ssh/sshd_config

在#PorT 22的下面新建一行,输入:

PorT 49813

使得Sshd监听49813端口,以避免黑客扫描22端口。

vi /etc/rc.conf.local

增加一行,输入:

sshd_flags=""

使得系统启动时启动Sshd服务。

保存退出。

reboot

等系统重启完毕,用top命令看下,O.N.M.P.环境已经搭建好了!


写在最后:

终于明白了OpenBSD官方力推packages的原因!看看吧,步骤多么简单,无须下载软件源码,无须长时间的make && make install,很短的时间就可以搭建起时兴的O.N.M.P.环境,而且安全性有很高的保障!

对MySQL的管理可以通过phpMyAdmin来完成,地址:
(xxx.xxx.xxx.xxx为你服务器的IP地址)。默认情况下MySQL的root用户是没有密码的,请第一时间设置!

本文没有加入PF的部分,因为偶写了几个语句貌似执行起来都有问题,将偶挡在了外面,留待下一版手册中解决吧!

相关博文:

[原创]OpenBSD Current版本更新系统核心和已安装软件包的方法!

Nginx官方推荐:生产系统请使用0.6.34版!

在OpenBSD中安装和使用nginx的注意事项!!!

Nginx-0.7.17 configure参数详解

在OpenBSD 4.3环境下安装Nginx 0.7.17
阅读(2556) | 评论(3) | 转发(0) |
给主人留下些什么吧!~~

chinaunix网友2010-09-17 10:02:38

既然是Nginx 为何要装lighttpd呢?

czjin2009-02-22 10:08:56

支持。我的openbsd做samba服务,98人同时在机房向机器写入word文本2小时,也没发生什么事。但多人读取视频时却发生问题。所以我坚决支持版主!版主在摸索提高openbsd磁盘性能的方法,如需要我做些测试,我将非常乐意。

chinaunix网友2009-02-16 16:00:34

openbsd 的磁盘性能是很差的。 用它作防火墙,路由器还可以。作应用服务,磁盘性能没上去,就算了吧