免费注册 查看新帖 |

Chinaunix

  平台 论坛 博客 文库
最近访问板块 发新帖
查看: 2094 | 回复: 0
打印 上一主题 下一主题

笔记,关于:[精华] 在OPENBSD-3.8上快速部署apache+mysql+php+ssl(最 [复制链接]

论坛徽章:
0
跳转到指定楼层
1 [收藏(0)] [报告]
发表于 2009-10-10 16:41 |只看该作者 |倒序浏览

欢迎大家转贴这个文章,但要保留下面的版权信息:  
作者:llzqq  
联系:llzqq@126.com
来自:www.chinaunix.net
本文旨在用OPENBSD自己提供的软件安装包来搭建服务器环境,当然你也可以下载原代码包编译安装,但这样就费时费力了。实际上OPENBSD给我们提供了大量的编译好的二进制安装包,利用这些二进制安装包我们可以快速部署我们需要的服务器环境,不仅省时还可以保障OPENBSD的安全性,还可以自动解决各个安装包之间的包依赖问题(用pkg_add来安装远程服务器上的软件包,包依赖问题会自动处理不需要认为干预,这个有点像通过PORT安装)。下面的文档在一个E文的文档基础上经过整理补充后形成的,那个E文档找不到了。
设立网络安装服务器的地址:
# export PKG_PATH=ftp://ftp.openbsd.org/pub/OpenBSD/3.8/packages/i386/
可以把这一句加入用户目录的.profile里,这样就不用每次写了。
1. 配置APACHE服务器:
因为APACHE是系统默认安装的,这里就省去了安装过程,下面配置APACHE这样就可以开机运行HTTP了因为在/ETC/RC脚本中已经有了HTTPD服务的启动设置
# vi /etc/rc.conf
改:
httpd_flags=NO
为:
httpd_flags=""
对apache做一初步设置
# vi /var/www/conf/httpd.conf
ExtendedStatus On
ServerAdmin llzqq@126.com
ServerName llzqq.3322.org
ServerTokens Prod
ServerSignature Off
Options Indexes FollowSymLinks 改为 Options FollowSymLinks
设置完了用另一台机器测试,老是不起作用后来发现可能是浏览缓存和域名指向的问题,用本机lynx测试比较准,没问题。
2. 安装mysql-server-4.0.24p1:
# pkg_add -v mysql-server-4.0.24p1.tgz
# cp /usr/local/share/mysql/my-medium.cnf /etc/my.cnf
如果不想让其他机器连接MYSQL,可以通过下面的操作实现:
# vi /etc/my.cnf
bind-address = 127.0.0.1 要添加在[mysqld]部分
修改
[client]
socket = /var/www/var/run/mysql/mysql.sock
[mysqld]
socket = /var/www/var/run/mysql/mysql.sock
chmod -R  +rx  /var/www/var/
以适应chroot的apache
启动MYSQL-SERVER服务器:
# /usr/local/bin/mysqld_safe &
设置ROOT的MYSQL密码:
# /usr/local/bin/mysqladmin -u root password mypass
为了方便启动和关闭MYSQL服务建立了下面的脚本:
# vi /etc/rc.d/mysqld.sh
========================================================
#!/bin/sh
# made by llzqq
# mail:openbsd@163.com
# mysql startup scripts
case "$1" in  
start)
if [ -x /usr/local/bin/mysqld_safe ]; then
/usr/local/bin/mysqld_safe &
fi
;;
stop)
pkill mysqld &
rm -f /var/run/mysql/mysql.sock & 改成rm -f /var/www/var/run/mysql/mysql.sock &以适应chroot的apache
;;
*)
echo "$0 start | stop"
;;
esac
exit 0
========================================================
# chmod 555 /etc/rc.d/mysqld.sh
设置开机启动MYSQL
# vi /etc/rc.local
if [ -f /etc/my.cnf ]; then
       /etc/rc.d/mysqld.sh start
fi
3. 安装配置PHP-4.4.1
# pkg_add -v php4-core-4.4.1p0.tgz
                      不行,总是失败,只好到ports/www/php4里,make install安装
知道原因了可能是之前装其它程序(cce2k)造成有的程序已经安装版本什么的冲突了。
运行下面的命令使其生效
# cp /usr/local/share/examples/php4/php.ini-recommended /var/www/conf/php.ini
# /usr/local/sbin/phpxs -s
由于OPENBSD上的APACHE采用了CHROOT机制,要保证PHP正常工作就要建下面的目录PHP工作目录:
# mkdir /var/www/tmp
# chmod 1777 /var/www/tmp
下面选择安装几个PHP组件:
# pkg_add -v php4-gd-4.4.1p0-no_x11.tgz
                总是提示出错lib not found t1.5.0什么意思
                和上面一个原因
# /usr/local/sbin/phpxs -a gd
# pkg_add -v php4-mysql-4.4.1p0.tgz
# /usr/local/sbin/phpxs -a mysql
# pkg_add -v php4-ncurses-4.4.1p0.tgz
# /usr/local/sbin/phpxs -a ncurses
# pkg_add -v php4-imap-4.4.1p0.tgz
# /usr/local/sbin/phpxs -a imap
# pkg_add -v php4-curl-4.4.1p0.tgz
# /usr/local/sbin/phpxs -a curl
# pkg_add -v php4-dbx-4.4.1p0.tgz
# /usr/local/sbin/phpxs -a dbx
# pkg_add -v php4-ldap-4.4.1p0.tgz
# /usr/local/sbin/phpxs -a ldap
# pkg_add -v php4-pdf-4.4.1p0.tgz
# /usr/local/sbin/phpxs -a pdf
# pkg_add -v php4-snmp-4.4.1p0.tgz
# /usr/local/sbin/phpxs -a snmp
其它的到都装了,后来找到ports/www/php4里有个 extensions ,make install了,好像它是全装,好像不错。
哦好像不是那么回事,它好像是把那些php4-gd.....什么的都准备好了,而且版本更新一些,这样再用pkg_add就没问题了。
不管怎样这次没事,装完系统马上按这个一步一步来,没遇到问题。
设置apache支持PHP:
# vi /var/www/conf/httpd.conf
DirectoryIndex index.html index.php
AddType application/x-httpd-php .php
AddType application/x-httpd-php-source .phps
# vi /var/www/conf/php.ini
doc_root= "/htdocs"
register_globals = On
建立测试php页面
# vi /var/www/htdocs/test.php  

测试一下:
# pkill httpd
# /usr/sbin/httpd
在浏览器中输入http://IP/test.php实验一下
4. 安装mod_limitipconn模块来限制单IP的并发连接数
# wget http://dominia.org/djao/limit/mod_limitipconn-0.04.tar.gz
            没有wget
改用lynx
http://dominia.org/djao/limit/mod_limitipconn-0.04.tar.gz
# tar xzf mod_limitipconn-0.04.tar.gz
# cd mod_limitipconn-0.04
# vi Makefile
  
APXS = /usr/sbin/apxs
# make
# make install
让APACHE支持这个模块:
# vi /var/www/conf/httpd.conf
  

MaxConnPerIP 5
  

到次整个安装过程结束。
附件部分:
我们为让APACHE支持SSL传输配置APACHE:
# vi /var/www/conf/httpd.conf
添加下面两行:
SSLCertificateFile    /etc/ssl/server.crt
SSLCertificateKeyFile /etc/ssl/private/server.key
为了使APACHE启动时启用SSL,设置一下APACHE启动选项:
# vi /etc/rc.conf.local
改:
httpd_flags=""           # or it could have httpd_flags=NO
为:
httpd_flags="-DSSL          # or it could have httpd_flags=NO
感觉应该是httpd_flags="-DSSL"
手动启动和关闭APACHE这样做就可以了:
# apachectl startssl
# apachectl stop
应该反过来:
# apachectl stop
# apachectl startssl
而且要先设置下面的部分,才能启动SSL

下面是设置APACHE+SSL的过程:
1. 创建服务器KEY文件 (1024 bit) :  
# /usr/sbin/openssl genrsa -out /etc/ssl/private/server.key 1024   
2. 创建服务器CSR文件(certificate signing request)  
# /usr/sbin/openssl req -new -key /etc/ssl/private/server.key -out /etc/ssl/private/server.csr   
这里自己填写一些注册信息
3. 生成签名证书(365天有效证书):
# /usr/sbin/openssl x509 -req -days 365 -in /etc/ssl/private/server.csr -signkey /etc/ssl/private/server.key -out     /etc/ssl/server.crt  
4. 虚拟主机部分:
NameVirtualHost 192.168.10.1:*

    ServerAdmin llzqq@126.com
    DocumentRoot /var/www/llzqq
    ServerName llzqq.home.com
    ErrorLog logs/llzqq.home.com-error_log
    CustomLog logs/llzqq.home.com-access_log common
    SSLEngine on
    SSLCipherSuite ALL:!ADH:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP
    SSLCertificateFile /etc/ssl/virtualsite.com.crt
    SSLCertificateKeyFile /etc/ssl/private/server.key


    ServerAdmin llzgg@126.com
    DocumentRoot /var/www/llzgg
    ServerName llzgg.home.com
    ErrorLog logs/llzgg.home.com-error_log
    CustomLog logs/llzgg.home.com-access_log common

其他部分待续(现在没PC装OPENBSD了有些资料不好整理了)
[ 本帖最后由 llzqq 于 2005-12-4 11:17 编辑 ]

[/url]

[url=http://bbs.chinaunix.net/viewpro.php?uid=111414]FinalBSD

回复于:2005-11-20 14:01:26

引用:原帖由 MichaelBibby 于 2005-11-20 12:14 发表
为何不使用rc.local来启动mysqld呢?

rc.d更方便管理,rc.local随着时间推移,东西会一大堆,不好整:mrgreen:


FinalBSD
回复于:2005-11-20 14:03:24

引用:原帖由 llzqq 于 2005-11-20 13:34 发表
SSL和虚拟主机部分一会加上

记得加上Userdir这个部分,因为OpenBSD有个特殊的user目录来专门分离user主目录。我觉得这个很值得一提。另外将:
#!/usr/local/bin/bash
改成/bin/sh因为不是每个人都自己会去装bash。省得新手不解。:D
[ 本帖最后由 FinalBSD 于 2005-11-20 14:05 编辑 ]


MichaelBibby
回复于:2005-11-20 14:28:03

引用:原帖由 FinalBSD 于 2005-11-20 14:03 发表
记得加上Userdir这个部分,因为OpenBSD有个特殊的user目录来专门分离user主目录。我觉得这个很值得一提。

这个确实值得说一说
另外我在想,如何在添加用户的同时,在USER目录下也添加一个用户的目录(当然可以是链接)
自己修改adduser脚本?应该可以
可惜偶不会PERL
引用:
另外将:
#!/usr/local/bin/bash
改成/bin/sh因为不是每个人都自己会去装bash。省得新手不解。:D

恩,这个赞同


llzqq
回复于:2005-11-20 14:30:02

引用:原帖由 FinalBSD 于 2005-11-20 14:03 发表
记得加上Userdir这个部分,因为OpenBSD有个特殊的user目录来专门分离user主目录。我觉得这个很值得一提。另外将:
#!/usr/local/bin/bash
改成/bin/sh因为不是每个人都自己会去装bash。省得新手不解。:D

改正了。
Userdir这个咚咚没有实际用过而且现在没有空闲的PC装OPENBSD了,等以后补上吧。


FinalBSD
回复于:2005-11-20 14:31:03

引用:原帖由 MichaelBibby 于 2005-11-20 14:28 发表
这个确实值得说一说
另外我在想,如何在添加用户的同时,在USER目录下也添加一个用户的目录(当然可以是链接)
自己修改adduser脚本?应该可以
可惜偶不会PERL
恩,这个赞同

你的理解有误区吧,这里指定的userdir指的是用户的DocumentRoot,而不是home目录。所以为什么要修改adduser呢?当然DocumentRoot可以和home目录是一个地址。


MichaelBibby
回复于:2005-11-20 15:12:16

引用:原帖由 FinalBSD 于 2005-11-20 14:31 发表
你的理解有误区吧,这里指定的userdir指的是用户的DocumentRoot,而不是home目录。所以为什么要修改adduser呢?当然DocumentRoot可以和home目录是一个地址。

大概是我没说清楚
OpenBSD的httpd使用UserDir的话,有一个单独的/var/www/users目录,要让用户能够使用userdir,就可以在这个目录底下建个目录做为用户的DocumentRoot,当然,也可以做个到用户$HOME目录下某个目录的链接
我刚才说的是,在建立用户帐户的同时,为这个用户也创建一个/var/www/users下的目录或者到$HOME下某个目录的链接


czjin
回复于:2005-12-02 19:57:13

真正的好帖子,版主我尊敬你.顶!
我在做了Apache.php4.mysql后又添加了一个包,p5-apache-ASP-2.57.tgz准备学习一下ASP网页格式的测试,肯定会有失败,到时我会向版主及各位朋友请教


zero-B
回复于:2005-12-03 00:52:56

加个精吧


剑心通明
回复于:2005-12-03 11:04:23

引用:原帖由 zero-B 于 2005-12-3 00:52 发表
加个精吧

已经加了,希望各位再接再厉


llzqq
回复于:2005-12-04 11:19:30

刚才更正了几处疏漏


wallace888
回复于:2005-12-04 20:16:16

不错哈,支持lizqq兄弟!


hataking
回复于:2005-12-04 21:32:40

# export PKG_PATH=ftp://ftp.openbsd.org/pub/OpenBSD/3.8/packages/i386/
这一步是做什么的。是必需的吗?


congli
回复于:2005-12-04 21:34:21

引用:原帖由 hataking 于 2005-12-4 21:32 发表
# export PKG_PATH=ftp://ftp.openbsd.org/pub/OpenBSD/3.8/packages/i386/
这一步是做什么的。是必需的吗?

设置package下载站点,可以自己设置更快的.


czjin
回复于:2005-12-04 23:03:11

执行:# export PKG_PATH=ftp://ftp.openbsd.org/pub/OpenBSD/3.8/packages/i386/ 这一步会保存在那里?还是每次都要执行.要修改目录文件路径在那里?


llzqq
回复于:2005-12-05 09:52:05

引用:原帖由 czjin 于 2005-12-4 23:03 发表
执行:# export PKG_PATH=ftp://ftp.openbsd.org/pub/OpenBSD/3.8/packages/i386/ 这一步会保存在那里?还是每次都要执行.要修改目录文件路径在那里?

放到你的shell配置文件中,或者放到一个开机自动运行的教本中


fengliu
回复于:2005-12-15 15:47:55

各位前辈,我按照这个方法做了服务器
我想问的是我要更改web目录
默认的是/var/www/htdocs
我要改成/home/www
我试了N遍都不行。


llzqq
回复于:2005-12-15 15:51:48

引用:原帖由 fengliu 于 2005-12-15 15:47 发表
各位前辈,我按照这个方法做了服务器
我想问的是我要更改web目录
默认的是/var/www/htdocs
我要改成/home/www
我试了N遍都不行。

openbsd上的APACHE默认启用了chroot,所以你不能修改文档目录。如果你用httpd -u命令启动就可以修改了


fengliu
回复于:2005-12-15 19:50:34

引用:原帖由 llzqq 于 2005-12-15 15:51 发表
openbsd上的APACHE默认启用了chroot,所以你不能修改文档目录。如果你用httpd -u命令启动就可以修改了

谢谢了,我已经改好了!


cellin
回复于:2005-12-20 14:12:29

要是有Zend有完美了,我装了多次,都没成功


原文链接:
http://bbs.chinaunix.net/viewthread.php?tid=652368
转载请注明作者名及原文出处


本文来自ChinaUnix博客,如果查看原文请点:http://blog.chinaunix.net/u/14389/showart_2067244.html
您需要登录后才可以回帖 登录 | 注册

本版积分规则 发表回复

  

北京盛拓优讯信息技术有限公司. 版权所有 京ICP备16024965号-6 北京市公安局海淀分局网监中心备案编号:11010802020122 niuxiaotong@pcpop.com 17352615567
未成年举报专区
中国互联网协会会员  联系我们:huangweiwei@itpub.net
感谢所有关心和支持过ChinaUnix的朋友们 转载本站内容请注明原作者名及出处

清除 Cookies - ChinaUnix - Archiver - WAP - TOP