[转载] nginx配置多个站点共用80端口
这两天自己编译lnmp环境,以前都是在windows下面用配置好了的环境,并没有遇到什么问题,今天自己去弄,问题多多,配置域名的时候就遇到很多问题:
网上的说法也是乱七八糟,各种超长配置,叫你复制粘贴。废话不多说,直接说我是怎么解决这些问题的:
1、修改主配置文件:
只用改一个地方:
在http模块里面加入你要引用的虚拟主机配置文件目录即可:
例如:include /etc/nginx/vhosts/*.conf
http { log_format main '$remote_addr - $remote_user [$time_local] "$request" ' '$status $body_bytes_sent "$http_referer" ' '"$http_user_agent" "$http_x_forwarded_for"'; access_log /var/log/nginx/access.log main; sendfile on; tcp_nopush on; tcp_nodelay on; keepalive_timeout 65; types_hash_max_size 2048; include /etc/nginx/mime.types; default_type application/octet-stream; include /etc/nginx/vhosts/*.conf; //就这里加一行就可以了 }
2、建立虚拟主机配置目录:
在/etc/nginx/下面建立vhosts文件夹,专门放置网站的配置文件。
贴一个我的配置上来:
/etc/nginx/vhosts/mytest.com.conf
server { listen 80 ; //注意这里,要把默认的那个default_server去掉,因为我们在下面要单独配置域名访问,所以这里不要留default_server,不然会报错。 server_name mytest.com mytest111.com; //这里写你想设置的域名,可以写多个,与名之间用空格隔开 root /mnt/share/mytest.com; //这里是你虚拟机的根目录,写绝对路径 # Load configuration files for the default server block. location / { index index.php index.html index.htm; //这里配置默认访问的页面 } location ~* \.php$ { //这里配置php解析.php文件 fastcgi_index index.php; fastcgi_pass 127.0.0.1:9000; include fastcgi_params; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; fastcgi_param SCRIPT_NAME $fastcgi_script_name; } error_page 404 /404.html; //默认的错误页面 location = /40x.html { } error_page 500 502 503 504 /50x.html; location = /50x.html { } }
再来一个:
server { listen 80; server_name www.xx.com; root D:/phpStudy/WWW/api-xxx; index index.html index.htm index.php; location / { try_files $uri $uri/ /index.php?$query_string; } location = /favicon.ico { log_not_found off; } location ~ \.php$ { fastcgi_pass 127.0.0.1:9000; fastcgi_param SCRIPT_FILENAME $document_root$fastcgi_script_name; include fastcgi_params; } }
3、还想再建其他虚拟机,一样的,复制上面那个文件,修改我标注的的那几个地方即可!
4、虚拟机配置文件配置好了之后,还需要在linux下面的hosts文件下面加上以上域名,不然还是会访问外网的哦。
vim /etc/hosts
127.0.0.1 mytest11.com 127.0.0.1 mytest.com
5、如果我们是要在windows下面访问虚拟机里面的linux下面的网站,那么还要在windows下面配置hosts文件,所有的域名都指向linux服务器,例如:
192.168.2.111 mytest11.com
192.168.2.111 mytest.com
经过以上5步就肯定可以访问了,再不能的检查一次,还是不能解决问题的,直接给我留言。
6、遇到的问题:
nginx: [emerg] a duplicate default server for 0.0.0.0:80 in /etc/nginx/vhosts/
遇到这个问题,肯定是:
server {
listen 80
这个地方80后面的东西都去掉,只留下端口号80,去掉就可以解决这个问题了。
转载请注明出处,分享知识,保留基本尊重。
支持http2:
server { listen 80; listen 443 ssl http2; #增加http2 server_name www.uwsxxx.com; #开启ssl并添加证书 ssl on; ssl_certificate cert/nginx_uws.pem; ssl_certificate_key cert/nginx_uws.key; ssl_session_timeout 5m; ssl_protocols TLSv1 TLSv1.1 TLSv1.2; ssl_ciphers ALL:!ADH:!EXPORT56:RC4+RSA:+HIGH:+MEDIUM:+LOW:+SSLv2:+EXP; ssl_prefer_server_ciphers on; access_log /usr/local/openresty/nginx/logs/access.log combined; location / { proxy_set_header Host $host:$proxy_port; proxy_set_header X-Real-IP $remote_addr; proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for; proxy_pass http://uws02:7867; proxy_redirect http:// $scheme://; if ( $server_port = 80 ){ rewrite ^(.*) https://$server_name$1 permanent; } } }
来自:https://blog.csdn.net/zhezhebie/article/details/73459874