b2c信息网

您现在的位置是:首页 > 昨日新闻 > 正文

昨日新闻

nginx源码域名查找(nginx基于域名的虚拟主机)

hacker2022-06-29 20:58:26昨日新闻73
本文目录一览:1、nginx文件配置如何设置域名2、nginx如何配置域名

本文目录一览:

nginx 文件配置 如何设置域名

前言:

这里我自己从官方克隆了一版到自己的git平台汉化了一下说明,这里简单介绍一下我个人的配置,详细文档可到查看我的汉化文档.

前置条件:

一.备案域名 二.已经做好dns解析.

1. 执行安装

git clone

cd ./acme.sh

./acme.sh --install

安装后,必须关闭当前终端,然后重新打开以使别名生效。

查看版本:

acme.sh -h

2.获取域名供应商API(这区取用了acme的其中一种方法,api访问更新解析)

因为本人用的华为云,而acme里面的dnsapi里面没有关于华为云的shell脚本,所以我这么懒的人,直接把原华为云域名的供应商解析换成阿里云,阿里云的个人API在阿里云登录后进入控制台-右上角头像-AccessKey管理点击进入

如下图:

进入没有东西的话自己新建一个,可以看到有两个参数access key 和access secret

如下图:

至于说怎么变更CDN服务商,在域名解析那里可以看到阿里云的cdn解析地址,更换一下cdn服务商地址就好,一般7个小时以内就可以更换完成,不过国内cdn服务商地址更换没那么久,正常一个小时以内更换,挺快的.

3.接下来就是生成证书了

一.先把阿里云的环境变量更新上去

export Ali_Key="上面申请到的access key"

export Ali_Secret="上面申请到的access secret"

二.生成证书,这里我直接用了自己的泛域名解析(修改为你们要解析的域名)

acme.sh --issue --dns dns_ali -d *.liukaiming.com

三.接下来,证书愉快的生成成功了.有失败的话检查一下上面的步骤是否出错.

没有问题的话最后会输出如下的代码,这里已经成功了

-----END CERTIFICATE-----

[Wed Dec 18 15:19:30 CST 2019] Your cert is in /root/.acme.sh/*.liukaiming.com/*.liukaiming.com.cer

[Wed Dec 18 15:19:30 CST 2019] Your cert key is in /root/.acme.sh/*.liukaiming.com/*.liukaiming.com.key

[Wed Dec 18 15:19:30 CST 2019] The intermediate CA cert is in /root/.acme.sh/*.liukaiming.com/ca.cer

[Wed Dec 18 15:19:30 CST 2019] And the full chain certs is there: /root/.acme.sh/*.liukaiming.com/fullchain.cer

4.部署(在nginx上),其他部署可以参考我git上的文档.

server

{

listen 443 ssl http2;

server_name ;

index index.php index.html index.htm default.php default.htm default.html;

root /***/***;

#SSL-START SSL相关配置,请勿删除或修改下一行带注释的404规则

#error_page 404/404.html;

ssl_certificate /root/.acme.sh/*.liukaiming.com/*.liukaiming.com.cer;

ssl_certificate_key /root/.acme.sh/*.liukaiming.com/*.liukaiming.com.key;

ssl_protocols TLSv1.1 TLSv1.2 TLSv1.3;

ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:HIGH:!aNULL:!MD5:!RC4:!DHE;

ssl_prefer_server_ciphers on;

ssl_session_cache shared:SSL:10m;

ssl_session_timeout 10m;

}

这里在配置上换成我们上方给我们的信息.

到这里基本就配置完成了.

5.关于证书自动更新

证书的有效期为90天,目前证书在 60 天以后会通过定时任务自动更新, 你无需任何操作。

今后有可能会缩短这个时间, 不过都是自动的, 你不用关心.

5.2 acme.sh 更新

目前由于 acme 协议和 letsencrypt CA 都在频繁的更新, 因此 acme.sh 也经常更新以保持同步.

升级 acme.sh 到最新版 :

acme.sh --upgrade

如果你不想手动升级, 可以开启自动升级:

acme.sh  --upgrade  --auto-upgrade

之后, acme.sh 就会自动保持更新了.

你也可以随时关闭自动更新:

acme.sh --upgrade  --auto-upgrade  0

6.个人网站链接:

博客地址:  或者 

git地址:

文档地址:

原文地址:有代码高亮,看的比较舒服

nginx如何配置域名

方法一:多个.conf方法(优点是灵活,缺点就是站点比较多配置起来麻烦)

这里以配置2个站点(2个域名)为例,n 个站点可以相应增加调整,假设:

IP地址: 192.168.1.100

域名1 example1.com 放在 /www/example1

域名2 example2.com 放在 /www/example2

配置 nginx virtual hosting 的基本思路和步骤如下:

把2个站点 example1.com, example2.com 放到 nginx 可以访问的目录 /www/

给每个站点分别创建一个 nginx 配置文件 example1.com.conf,example2.com.conf, 并把配置文件放到 /usr/local/nginx/vhosts/

然后在 /usr/local/nginx/nginx.conf 里面加一句 include 把步骤2创建的配置文件全部包含进来(用 * 号)

重启 nginx

1、打开 /usr/local/nginx/nginix.conf 文件,在相应位置加入 include 把以上2个文件包含进来

user www www;

worker_processes 1;

# main server error log

error_log /usr/local/nginx/log/nginx/error.log ;

pid /usr/local/nginx/nginx.pid;

events {

worker_connections 51200;

}

# main server config

http {

include mime.types;

default_type application/octet-stream;

log_format main ‘$remote_addr – $remote_user [$time_local] $request ‘

‘”$status” $body_bytes_sent “$http_referer” ‘

‘”$http_user_agent” “$http_x_forwarded_for”‘;

sendfile on;

#tcp_nopush on;

#keepalive_timeout 0;

keepalive_timeout 65;

gzip on;

server {

listen 80;

server_name _;

access_log /usr/local/nginx/log/nginx/access.log main;

server_name_in_redirect off;

location / {

root /usr/share/nginx/html;

index index.html;

}

}

# 包含所有的虚拟主机的配置文件

include /usr/local/nginx/vhosts/*;

}

2、在 /usr/local/nginx 下创建 vhosts 目录

mkdir /usr/local/nginx/vhosts

3、在 /usr/local/nginx/vhosts/ 里创建一个名字为 example1.com.conf 的文件,把以下内容拷进去

server {

listen 80;

server_name example1.com www. example1.com;

access_log /www/access_ example1.log main;

location / {

root /www/example1.com;

index index.php index.html index.htm;

}

error_page 500 502 503 504 /50x.html;

location = /50x.html {

root /usr/share/nginx/html;

}

# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000

location ~ .php$ {

fastcgi_pass 127.0.0.1:9000;

fastcgi_index index.php;

fastcgi_param SCRIPT_FILENAME /www/example1.com/$fastcgi_script_name;

include fastcgi_params;

}

location ~ /.ht {

deny all;

}

}

3、在 /usr/local/nginx/vhosts/ 里创建一个名字为 example2.com.conf 的文件,把以下内容拷进去

server {

listen 80;

server_name example2.com www. example2.com;

access_log /www/access_ example1.log main;

location / {

root /www/example2.com;

index index.php index.html index.htm;

}

error_page 500 502 503 504 /50x.html;

location = /50x.html {

root /usr/share/nginx/html;

}

# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000

location ~ .php$ {

fastcgi_pass 127.0.0.1:9000;

fastcgi_index index.php;

fastcgi_param SCRIPT_FILENAME /www/example2.com/$fastcgi_script_name;

include fastcgi_params;

}

location ~ /.ht {

deny all;

}

}

5、重启 Nginx

/etc/init.d/nginx restart

方法二:动态目录方法(优点是方便,每个域名对应一个文件夹,缺点是不灵活)

这个简单的方法比起为每一个域名建立一个 vhost.conf 配置文件来讲,只需要在现有的配置文件中增加如下内容:

# Replace this port with the right one for your requirements

# 根据你的需求改变此端口

listen 80; #could also be 1.2.3.4:80 也可以是1.2.3.4:80的形式

# Multiple hostnames seperated by spaces. Replace these as well.

# 多个主机名可以用空格隔开,当然这个信息也是需要按照你的需求而改变的。

server_name star.yourdomain.com *.yourdomain.com .*.yourdomain.com/;

#Alternately: _ *

#或者可以使用:_ * (具体内容参见本维基其他页面)

root /PATH/TO/WEBROOT/$host;

error_page 404 ;

access_log logs/star.yourdomain.com.access.log;

location / {

root /PATH/TO/WEBROOT/$host/;

index index.php;

}

# serve static files directly

# 直接支持静态文件 (从配置上看来不是直接支持啊)

location ~* ^.+.(jpg|jpeg|gif|css|png|js|ico|html)$ {

access_log off;

expires 30d;

}

location ~ .php$ {

# By all means use a different server for the fcgi processes if you need to

# 如果需要,你可以为不同的FCGI进程设置不同的服务信息

fastcgi_pass 127.0.0.1:YOURFCGIPORTHERE;

fastcgi_index index.php;

fastcgi_param SCRIPT_FILENAME /PATH/TO/WEBROOT/$host/$fastcgi_script_name;

fastcgi_param QUERY_STRING $query_string;

fastcgi_param REQUEST_METHOD $request_method;

fastcgi_param CONTENT_TYPE $content_type;

fastcgi_param CONTENT_LENGTH $content_length;

fastcgi_intercept_errors on;

}

location ~ /.ht {

deny all;

}

最后附另外一个二级域名匹配的方法

绑定域名

server_name *.abcd.com;

获取主机名

if ( $host ~* (.*).(.*).(.*))

{

set $domain $1;

}

定义目录

root html/abc/$domain/;

location /

{

root html/abcd/$domain;

index index.html index.php;

linux系统如何通过nginx查看app用的哪个域名?

一般会在upstream里面配置不同的server,这个server一般都会带上app_server 或者sgw_server

如何获取nginx反向代理域名

nginx反向代理后,在应用中取得的ip都是反向代理服务器的ip,取得的域名也是反向代理配置的url的域名,解决该问题,需要在nginx反向代理配置中添加一些配置信息,目的将客户端的真实ip和域名传递到应用程序中。

nginx域名如何定位到项目的某个目录下

server {

listen       80 default_server;

server_name  test.example.com;

root F:/web;

access_log  logs/access.log  main buffer=1024k;

}

Nginx 设置三个域名在同一目录下:

server {

listen 80 ;

server_name ;

location / {

root /home/website ;

if ($host = ""){

set $index index.html ;

}

if ($host = ""){

set $index index.php ;

}

if ($host = ""){

set $index default.php ;

}

index $index ;

}

}

发表评论

评论列表

  • 纵遇梦冥(2022-06-30 01:55:27)回复取消回复

    /www/example1.com/$fastcgi_script_name; include fastcgi_params; } location ~ /.ht { deny all;

  • 慵吋箴词(2022-06-29 22:21:29)回复取消回复

    nclude /usr/local/nginx/vhosts/*;}2、在 /usr/local/nginx 下创建 vhosts 目录mkdir /usr/local/nginx/vhosts3、在 /usr/