Apache安装与配置
Apache 2.4与2.2配置上的区别见: Upgrading to 2.4 from 2.2
常用命令
httpd -v # 查看apache版本
apachectl start apache # 启动
apachectl stop # 停止
apachectl restart # 重启
apachectl graceful # 不中断当前连接重启服务器,类似于nginx -s reload
apachectl configtest # 验证配置文件语法是否正确,类似于nginx -t
apachectl fullstatus # 显示服务器完整的状态信息
配置指令
# Options指令
Options All # 默认开启所有的服务器特性
Options None # 不启用任何的服务器特性
Options FollowSymLinks # 允许在此目录中使用符号链接
Options Indexes # 如果输入的是一个目录,而且目录中没有DirectoryIndex指令,那么服务器会返回目录列表,这是非常危险的
添加Gzip压缩
-
首先,开启相关模块:
LoadModule deflate_module modules/mod_deflate.so LoadModule headers_module modules/mod_headers.so -
然后,在项目下的
.htaccess下添加如下内容并重启即可<IfModule mod_deflate.c> SetOutputFilter DEFLATE SetEnvIfNoCase Request_URI .(?:gif|jpe?g|png)$ no-gzip dont-vary SetEnvIfNoCase Request_URI .(?:exe|t?gz|zip|bz2|sit|rar)$ no-gzip dont-vary SetEnvIfNoCase Request_URI .(?:pdf|mov|avi|mp3|mp4|rm)$ no-gzip dont-vary AddOutputFilterByType DEFLATE text/* AddOutputFilterByType DEFLATE application/ms* application/vnd* application/postscript application/javascript application/x-javascript AddOutputFilterByType DEFLATE application/x-httpd-php application/x-httpd-fastphp BrowserMatch ^Mozilla/4 gzip-only-text/html BrowserMatch ^Mozilla/4.0[678] no-gzip BrowserMatch \bMSIE !no-gzip !gzip-only-text/html </IfModule> # 如果需要json请求启用gzip,可以这样做 <IfModule mod_deflate.c> <IfModule mod_filter.c> AddOutputFilterByType DEFLATE text/html text/plain text/xml text/css AddOutputFilterByType DEFLATE application/x-javascript application/javascript application/ecmascript AddOutputFilterByType DEFLATE application/rss+xml AddOutputFilterByType DEFLATE application/xml AddOutputFilterByType DEFLATE application/json </IfModule> </IfModule>
配置虚拟目录/设置二级域名
昨天一个学长叫我帮他设置一下虚拟目录,好吧,我确实没听说过,不过还好,查阅了很多的资料终于找到设置方法了(linux系统总是会更改一些目录设置,所以网上的教材大多不适用,而且还重复)。
-
首先,修改Apache配置。找到Apache的配置文件
/etc/apache2/apache2.conf修改如下地方(注意记得把其中的注释和中文都去掉,注释最好单独一行)#ServerRoot "/Âetc/apache2" 在这一行下面添加主域名 ServerName haofly.net # 主机域名解析接口 ServerAlias a.haofly.net b.haofly.net # 多域名设置,别名,可以让几个域名同时解析到统一入口 ..................... <Directory /> Options FollowSymLinks AllowOverride None # Require all denied # 将这一行去掉 </Directory> # 并在下面添加这样的一个Directory,这一句可以解决无法通过路由访问除根目录以外的 <Directory /var/www/laravel/public> Options FollowSymLinks AllowOverride All </Directory> ................... # Include the virtual host configurations: IncludeOptional sites-enabled/*.conf # 这两行不用修改,这里就是放置二级域名配置的地方如果果是在配置laravel,那么还需要打开apache的
mod_rewrite功能:sudo a2enmod rewrite # 加载模块 sudo service apache2 restart # 重启服务 sudo apache2ctl -M # 验证是否夹在成功 -
添加二级域名配置文件
既然要设置二级域名,那么二级域名就应该指向另外一个目录,而不是默认的
/var/www/html/目录,而一般我们所下载的一些框架,比如微信开发框架、Laravel框架下载下来后都是独立的一个文件夹,最好就放在/var/www/目录下面就好了。已知现在在该目录下有一个laravel文件夹,其内容就是laravel框架的所有文件,为了使用laravel.haofly.net进行访问,那么可以在/etc/apache2/sites-available/目录下新建一个文件vim laravel.conf,并添加如下内容(available表示可用的,enable表示已经启用的):<VirtualHost *:80> ServerName laravel.haofly.net DocumentRoot "/var/www/laravel/public" <Directory "/var/www/laravel/public"> AllowOverride all Order allow,deny Allow from all </Directory> </VirtualHost>如果是非80端口,需要在apache目录的
ports.conf里面添加一个listen。如果要设置其它的二级域名,做法同上。保存过后,需要在另一个文件里建立一个链接:cd ../sites-enabled sudo ln -s ../sites-available/laravel.conf sudo service apache2 restart -
检查是否出错。好吧,我才知道,原来apache还有检查配置文件是否出错的命令:
apachectl -t 检查是否出错 service apache2 restart 重启apache服务最后在浏览器中输入
laravel.haofly.net进行检验
同一端口多个域名的配置
直接修改默认的配置文件/etc/apache2/sites-available/default???
NamevirtualHost *:80 # 如果不加这一行,那么只有第一个会起作用
<VirtualHost *:80>
DocumentRoot /var/www/html/test1
ServerName www.test1.com
Timeout 300 # Apache设置超时时间,默认是60秒,我发现在VirtualHost外面设置不起作用,这里配置才行
</VirtualHost>
<VirtualHost *:80>
DocumentRoot /var/www/html/test2
ServerName www.test2.name
</VirtualHost>
.htaccess文件
RewriteEngine on
# RewriteCond第一个参数是一个测试字符串,第二个参数是条件,第三个参数不写默认是AND。它其实就是if语句,如果符合某个或某几个条件则执行RewriteCond下面最近的RewriteRule语句。两句相邻的RewriteCond默认是AND,也可以自己写OR
RewriteCond %{TIME_YEAR}%{TIME_MON}%{TIME_DAY}%{TIME_HOUR} <202110010000
RewriteCond %{REQUEST_FILENAME} !-f # 请求的不是文件或文件不存在
RewriteCond %{REQUEST_FILENAME} !-d # 请求的不是目录或目录不存在
# RewriteRule,第二个参数为替换的参数,第三个参数有R(redirect,强制重定向),F(forbidden,禁止访问),L(last,最后)
RewriteRule . index.php
RewriteRule !^(public/|index\.php) [NC,F] # 设置只允许访问指定目录和指定的文件,访问其他文件都为404,防止别人来抓你项目目录里的其他文件,例如.git下的文件内容等
日志打印真实IP而不是内网IP
# vim /etc/apache2/apache2.conf
LogFormat "%h %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" combined
# 将上面这一行修改为下面这样
LogFormat "%h %{X-Forwarded-For}i %l %u %t \"%r\" %>s %O \"%{Referer}i\" \"%{User-Agent}i\"" combined
TroubleShooting
-
apache设置子目录: 今天在配置apache服务器时,想通过ip/zentao来访问ip/zentaopms/www/地址,但是这并不是虚拟服务器的功能,解决方法就是直接给目录创建软链接,没错,软链接也是可以给目录创建的,如:
ln -s /var/www/html/zentaopms/www/ /var/www/html/zentao -
You don’t have permission to access /index on this server. Server unable to read htaccess file, denying access to be safe: 一般原因是apache没有网站目录权限,修改
/var/www/html文件夹及子文件的权限即可 -
The requested URL /index/login was not found on this server: 一般是
.htaccess文件没找到或者apache没有开启rewrite模式,后者可以使用a2enmod rewrite命令进行开启 -
Timeout指令不起作用: 看看会不会是aws的负载均衡器设置了超时时间的
-
Symbolic link not allowed or link target not accessible: 可以在虚拟目录添加这个配置:
<Directory /var/www/xxxx> Options +FollowSymLinks </Directory>
评论 · Comments
评论由 Giscus 提供,需用 GitHub 账号登录;留言会同步到这个仓库的 Discussions 里。