- ubuntu12.04环境下使用kvm ioctl接口实现最简单的虚拟机
- Ubuntu 通过无线网络安装Ubuntu Server启动系统后连接无线网络的方法
- 在Ubuntu上搭建网桥的方法
- ubuntu 虚拟机上网方式及相关配置详解
CFSDN坚持开源创造价值,我们致力于搭建一个资源共享平台,让每一个IT人在这里找到属于你的精彩世界.
这篇CFSDN的博客文章nginx,apache的alias和认证功能由作者收集整理,如果你对这篇文章有兴趣,记得点赞哟.
从年前电脑换成linux系统后就没写东西,最近有点懒,在这里讲述下nginx alias 功能,不是server alias . 首先看下看下apache 别名 怎么配置的: 。
复制代码代码如下
<VirtualHost *:80> DocumentRoot /www/zzvips.com/www 这是虚拟主机的根目录吧,但是phpMYadmin 不在这个目录下,想访问。 ServerName www.zzvips.com ServerAlias zzvips.com Alias /sdb "/www/public/phpMyAdmin/" 就需要 别名功能,://www.zzvips.com/sdb 这样就安全多了。 <Directory "/www/public/phpMyAdmin/"> Options Indexes FollowSymLinks AllowOverride None Order allow,deny Allow from all </Directory> </VirtualHost> 。
一 .Apache认证 认证的类型:Basic Digest摘要 认证方法:A、容器认证: …… B、隐藏文件认证创建.htaccess文件 方法1、容器认证 A、 进入配置文件 vi /etc/httpd/conf/httpd.conf B、 配置:大约在531行附近 配置如下: AllowOverride None ##不允许通过隐藏认证,即通过容器认证 AuthType Basic ##认证类型为Basic AuthName “ajian” ##认证名字为Ajian AuthUserFile /var/www/passwd/pass ##pass 为认证密码文件,指定密码文件存放的位置。 Require valid-user ##有效用户(注意大小写,因为Word的原因有些大小写有变化) C、 创建目录 mkdir -p /var/www/passwd 进入目录 cd /var/www/passwd D、创建Apache用户 htpasswd -c pass ajian ##pass 为密码文件Ajian为用户 更改 把Pass文件的使用权给Apache: chown apache.apache pass 附:再在Pass文件中添加一个用户:htpasswd pass tt ##添加一个TT的用户到Pass文件中 E、重启服务并测试 方法2、通过隐藏认证 和上面差不多 不过配置不一样 Httpd主配置文件 AllowOverride AuthConfig 创建隐藏文件并放到要通过认证的目录 Eg: vi /var/www/html/mrtg AuthType Basic AuthName “Ajian” AuthUserFile /var/www/passwd/pass Require valid-user 下面是例子 。
。
。
2、Nginx 登录认证 nginx 的 http auth basic 的密码是用 crypt(3) 加密的。用 apache 的 htpasswd 可以生成密码文件。 没有 apache 自行安装。我安装的是 apache2,/usr/local/apach2。 cd /usr/local/nginx/conf /usr/local/apache2/bin/htpasswd -c -d pass_file user_name #回车输入密码,-c 表示生成文件,-d 是以 crypt 加密。 vi nginx.conf cd /usr/local/nginx/conf /usr/local/apache2/bin/htpasswd -c -d pass_file user_name #回车输入密码,-c 表示生成文件,-d 是以 crypt 加密。 vi nginx.conf 在 nginx.conf 文件中加入授权声明。这里要注意 nginx 0.6.7 开始,auth_basic_user_file 的相对目录是 nginx_home/conf,以前版本的相对目录是 nginx_home。 。
复制代码代码如下
server { listen 80; server_name tuan.xywy.com; root /www/tuangou; index index.html index.htm index.php; autoindex on; auth_basic "input you user name and password"; auth_basic_user_file htpasswd.file; location ~ .php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /www/tuangou$fastcgi_script_name; include fastcgi_params; } error_page 404 /404.php; error_page 403 /404.php; access_log /logs/tuan_access.log main; } 。
针对目录的认证,在一个单独的location中,并且在该location中嵌套一个解释php的location,否则php文件不会执行并且会被下载。auth_basic在嵌套的location之后。 。
复制代码代码如下
server { listen 80; server_name tuan.xywy.com; root /www/tuangou; index index.html index.htm index.php; autoindex on; location ~ ^/admin/.* { location ~ \.php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; fastcgi_param SCRIPT_FILENAME /www/tuangou$fastcgi_script_name; include fastcgi_params; } root /www/tuangou/ ; auth_basic "auth"; auth_basic_user_file htpasswd.file; } location ~ .php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_index index.php; include fastcgi_params; } access_log /logs/tuan_access.log main; } 。
三.nginx alias功能配置自动列目录 。
复制代码代码如下
server { listen www.zzvips.com:88; server_name www.zzvips.com; autoindex on; //开启列目录功能。 # charset gbk; location /club { 访问的名字//www.zzvips.com:88/club alias /www/clublog/club.xywy.com/; 这是服务器上存放日志的地方 } 这段意思 访问www.zzvips.com:88/club 就看到club目录的东东了。 location /{ root /www/access; 这段location 也可以没有 www.zzvips.com:88 出来的是默认nxing 页面 # index index.html index.htm index.php; } error_page 500 502 503 504 /50x.html; location = /50x.html { root html; } } 。
上面nginx配置意思就是: 访问http://hou.xywy.com/:88认证进去是默认访问服务器上/www/access/里面的目录,认证进去后url=http://hou.xywy.com:88/club 就出来 /www/clublog/club.xywy.com/ 里面的目录的内容了。,可能很绕,仔细分析就好了。 root 和 alias 的区别。 最基本的区别:alias指定的目录是准确的,root是指定目录的上级目录,并且该上级目录要含有location指定名称的同名目录。另外,根据前文所述,使用alias标签的目录块中不能使用rewrite的break。 这样在看这段就很清晰了, 。
复制代码代码如下
location /abc/ { alias /home/html/abc/; } 。
在这段配置下,http://test/abc/a.html就指定的是/home/html/abc/a.html。这段配置亦可改成 。
复制代码代码如下
location /abc/ { root /home/html/; } 。
这样,nginx就会去找/home/html/目录下的abc目录了,得到的结果是相同的。 但是,如果我把alias的配置改成: 。
复制代码代码如下
location /abc/ { alias /home/html/def/; } 。
那么nginx将会从/home/html/def/取数据,这段配置还不能直接使用root配置,如果非要配置,只有在/home/html/下建立一个 def->abc的软link(快捷方式)了。 一般情况下,在location /中配置root,在location /other中配置alias是一个好习惯。 至于alias和root的区别,我估计还没有说完全,如果在配置时发现奇异问题,不妨把这两者换换试试。 刚开始我也搞来高去搞了很久包括认证单独一个目录 CGI 问题,希望大家成功。出现问题可以向我咨询大家共同进步! 本文出自 “学习要永恒” 博客 。
最后此篇关于nginx,apache的alias和认证功能的文章就讲到这里了,如果你想了解更多关于nginx,apache的alias和认证功能的内容请搜索CFSDN的文章或继续浏览相关文章,希望大家以后支持我的博客! 。
我有一个无所事事的盒子,已经运行了一段时间,今天,由于某种原因,当我尝试重新启动nginx时,得到了以下提示。 nginx: [emerg] host not found in upstream "w
我注意到,当我使用 ubuntu 命令“nginx”启动 nginx 并执行 systemctl status nginx 时。它表明 systemctl 已禁用。此外,如果我首先使用命令 syste
我的 nginx 配置如下: proxy_redirect off; proxy_set_header Host $host; proxy_set_header X-Real-IP $re
周围有两个配置文件,/etc/nginx/conf.d/default.conf和 /etc/nginx/nginx.conf,但是启用了哪一个呢?我运行的是 CentOS6.4 和 nginx/1.
我的 Nginx 配置仅适用于根位置,所有其他位置都返回“Cannot GET {location}”,其中位置是域后地址的其余部分。 这是我的/etc/nginx/sites-enabled/def
我在 nginx 中为 node.js 服务器设置了反向代理。 server { listen 80; server_name sub.domain.tld; location
我的应用程序将在两个位置提供静态文件,一个是/my/path/project/static,另一个是/my/path/project/jsutils/static。 我很难让网络服务器在两个目录中查找
我的域名注册商的 DNS 访问我的服务器并获取 nginx 默认页面,因此配置正确 我复制了一个当前正在工作的 nginx 虚拟主机,更改了 server_name和 conf 文件的名称,仅此而已。
这个问题在这里已经有了答案: Can't login in to phpPgAdmin (2 个回答) 3年前关闭。 我在centos中遇到了phpPgAdmin登录的奇怪问题,我做了所有需要的事情
我要为PoC进行的操作是向来自动态后端服务器的网页添加href。使用“ subs_filter”可以很容易地添加href,但是我需要使用响应中嵌入的信息来构造href。 是否可以使用LUA处理来自pr
我有网站服务器,它有两个代理(鱿鱼,CF),它们使用不同的 header 来获取真实的 ip。 我猜 nginx 命令 set_real_ip_from ;real_ip_header X-Forwa
在控制台显示如下: Job for nginx.service failed because the control process exited witherror code. See "syste
我有一个问题,我怀疑是 NGINX 问题。基本上,当我尝试登录到我创建的网站时,出现以下错误…… 您要查找的页面暂时不可用。请稍后再试。 有没有人以前遇到过这个? 最佳答案 如果 NGINX 虚拟主机
这是我的 nginx 配置文件: server { listen 80; server_name localhost; location / {
在我的/etc/nginx/nginx.conf 文件中,我有配置。作为:- user nginx; worker_processes 1; error_log /var/log/nginx/e
有谁知道nginx支持软退出吗?这意味着它会一直运行直到所有连接都消失或超时(超过特定时间间隔)并且在此期间也不允许新连接吗? 例如: nginx stop nginx running (2 conn
有没有办法将 Nginx 配置为类似这样的直接服务器返回 (DSR) 负载平衡器: http://blog.haproxy.com/2011/07/29/layer-4-load-balancing-
我通过 apt-get 安装了 Nginx不久前在 Debian 上,我有几个网站在上面。现在我需要安装一些额外的模块,因为我不想搞砸任何事情,所以我想在执行之前仔细检查我的过程。希望这也能帮助其他不
我知道 Apache 的 pagespeed 模块可以使页面访问更快,所以,我想知道 Nginx 是否有等效的模块? 提前致谢! 最佳答案 https://github.com/pagespeed/n
如何将worker_rlimit_nofile设置为一个更大的数字,它可以是或建议最大为多少? 我正在尝试遵循以下建议: 大多数人遇到的第二个最大限制是 与您的操作系统有关。打开一个shell,su给
我是一名优秀的程序员,十分优秀!