分类
日历
统计
链接
其他

24 Apr.2009

配置Centos 系统 Vsftpd + Apache + PHP + MYSQL + Zend Optimizer 不指定

作者: dreamboymt   分类:WEB服务器   出处:本站原创       | |


· 使用 yum 程序安装所需开发包(以下为标准的 RPM 包名称)
# yum install gcc gcc-c++ gcc-g77 flex bison autoconf automake bzip2-devel zlib-devel ncurses-devel libjpeg-devel libpng-devel libtiff-devel freetype-devel pam-devel

· 升级yum包
# yum upgrade

· 安装Apache
# yum install httpd
# service httpd start

· 安装 PHP
# yum install php
# yum install php-gd //安装GD库
# yum install php-mysql //安装 mysql 库

· 安装 MySQL
# yum install mysql-server mysqld
# service mysqld start

· 安装 Zend Optimizer
# cd /usr/local/src
# wget http://downloads.zend.com/optimizer/3.2.2/ZendOptimizer-3.2.2-linux-glibc21-i386.tar.gz

# tar zxvf ZendOptimizer-3.2.2-linux-glibc21-i386.tar.gz
# ./ZendOptimizer-3.2.2-linux-glibc21-i386/install.sh
按照它的提示一步步进行就行了。

· 安装 Vsftpd
# yum install vsftpd
将 /etc/vsftpd/user_list文件和/etc/vsftpd/ftpusers文件中的root这一行注释掉
# root
执行以下命令

# setsebool -P ftpd_disable_trans=1

修改/etc/vsftpd/vsftpd.conf,在最后一行处添加local_root=/

# service vsftpd restart

配置FTP用户、用户组及相应权限

# groupadd webftp

添加webftp用户组,用来承载我们的FTP授权用户。

# useradd -g webftp -M -d /var/www -s /sbin/nologin wwwer

使用-g参数将它归集到webftp用户组下,-M参数不设置它的主目录(没有-M参数/home里会有个wwwer文件夹,这个文件夹没多少实际用处,所以不用设置),-d参数设定它的初始登入目录为/var/www,-s参数设定它不需要登陆系统/sbin/nologin,它被命名为wwwer(之所以这样命名,也就是根据初始登入目录来设置的,下同,登陆到www目录有一个好处是它可以直接FTP进去修改诸如404一类的页面,而不用其他过程来配置)。

# useradd -g webftp -M -d /var/www/html -s /sbin/nologin htmler

同样的方法在webftp用户组继续添加用户htmler,它也不设置主目录,也不需要登陆系统,设定它的初始登入目录为/var/www/html。

# passwd wwwer

为wwwer添加密码,两次输入。

# passwd htmler

为htmler添加密码,两次输入。

# chown -R wwwer.webftp /var/www

更改/var/www目录及其下所有文件和文件夹(-R)的所有者为webftp用户组下的wwwer用户。

# chown -R htmler.webftp /var/www/html

同样将/var/www/html目录及其下所有文件和文件夹chown给html。

 

配置基本安全策略

# getsebool -a | grep ftp

列出所有selinux全部ftp策略。

#setsebool allow_ftpd_full_access on

允许FTP完全访问。

# iptables -I INPUT -p tcp --dport 80 -j ACCEPT

插入防火墙规则(CentOS里用-A添加一条规则会处于链表尾,但表尾貌似不起作用,所以用-I插入到链表头),这条规则的意思是所有INPUT到服务器的包,-p如果是tcp协议的,--dport目标端口是80端口的,-j那么就ACCEPT。

# iptables -I INPUT -p tcp --dport 21 -j ACCEPT

同样的方法接受所有要到达服务器21端口的tcp包。

# modprobe ip_conntrack_ftp

载入IP连线跟踪模块。记住最后这一步(第九步)的基本安全策略配置在重启后全部失效,你需要重新配置一遍,当然通过修改selinux和iptables的配置文件或service iptables save是可以保持这些策略的。但你应该清晰的认识到一个问题:一个服务器应该总是保持开启状态的,如果服务器重启了,那么只有两种可能,一种是在你的控制之下,一种不在你的控制之下,当服务器重启事件不在你的控制之下时,那么你应该认识到这是很危险的情况,那么刚才那些“放行”的策略应该完全失效而不是继续保持才对。也正因为如此,我想这可能是CentOS这样做的其中一个原因。如果你要添加的规则比较多可以先保存到一个txt文件里,直接cp过来就okay。

 

· 修改程序项
# setup
可以设置系统启动需要开启的服务


时间:12:55 评论(0) 引用(0) 阅读(18494) Tags: , , , ,
发表评论
  昵称 [注册]
  密码 (游客无需密码)
  网址
  电邮
OpenID登入 权限选项 表情