Nginx配置80端口和443端口

Nginx配置80端口和443端口

Docker配置Nginx

uwsgi配置,以下实验共用同一个uwsgi,只做微调

准备:服务器ssl证书,前端后端都要有证书,这是https协议需要

证书可以单独放一个目录中,也可以放到配置文件目录下/etc/nginx/ssl

# 这是为http协议前端的settings.js请求文件内容为:http://www.testname.top:8080后端的prod.py文件中 CORS_ORIGIN_WHITELIST为:http://www.testname.top# 这是为https协议前端的settings.js请求文件内容为:https://www.testname.top:8080后端的prod.py文件中 CORS_ORIGIN_WHITELIST为:https://www.testname.top
[uwsgi]#使用nginx连接时使用,Django程序所在服务器地址socket=0.0.0.0:8000#直接做web服务器使用,Django程序所在服务器地址#http=0.0.0.0:8000#项目目录chdir=/home/moluo/luffycity#项目中wsgi.py文件的目录,相对于项目目录wsgi-file=luffycity/wsgi.py# 进程数processes=4# 线程数threads=2# uwsgi服务器的角色master=True# 存放进程编号的文件pidfile=uwsgi.pid# 日志文件,因为uwsgi可以脱离终端在后台运行,日志看不见。我们以前的runserver是依赖终端的daemonize=uwsgi.log# 指定依赖的虚拟环境virtualenv=/home/moluo/.virtualenv/luffycity

luffy项目(双容器http)

配置前端项目

Nginx配置80端口,也就是http协议,配置前后端项目

前端静态页面请求# 创建nginx容器,并以80端口对外提供服务# /usr/share/nginx/html 是nginx在安装时,系统默认分配的项目根目录docker run -itd -p 80:80 -v /opt/luffy/luffycity/dist:/usr/share/nginx/html nginx# 执行上面的命令,理论上来说,就可以让前端项目,可以用阿里云的IP地址访问到了。# 接下来我们进入到nginx的操作系统中,通过这个系统了解前端项目怎么运行的。# 如果要进入nginx容器查看对应的内容,可以使用以下命令;docker container exec -it [容器ID] bash"""/etc/nginx              # nginx容器中nginx的配置目录/usr/share/nginx/html   # nginx容器中www目录"""

创建nginx容器, 映射nginx端口-p路径-v

docker run -d -p 80:80 --name=cli_nginx -v /opt/luffy/luffycity/dist:/usr/share/nginx/html nginx

查看docke

docker ps -a# 进入docker docker exec -it cli_nginx(容器id) bash# 下载vimapt-get updateapt-get install -y vim

配置Nginx配置文件

vim /etc/nginx/conf.d/default.conf

# 修改 server_name 对应的域名或ipserver{  listen   80;  server_name  www.testname.top;  ''''  location / {       root  /usr/share/nginx/html;       index index.html index.htm;       try_files $uri $uri/ /index.html;    #这句,解决其他非根页面的404的问题   }}

重启nginx

# 查看配置是否成功nginx -t# 平滑重启nginx -s reload

配置后端项目

创建nginx容器, 映射nginx端口-p和路径-v

docker run -d -p 8080:80 --name=ser_nginx -v /opt/luffy/luffyserver/static/:/usr/share/nginx/static nginx

查看docke

docker ps -a# 进入docker docker exec -it ser_nginx(容器id) bash# 下载vimapt-get updateapt-get install -y vim

配置Nginx配置文件

vim /etc/nginx/conf.d/default.conf

# 如果有多台服务器,可以在此处继续添加服务器地址# 负载均衡池upstream luffy {    server 127.0.0.1:8000;   # server 127.0.0.1:8000  # 可以多服务器,有权重等}#gzip  on;server {    listen  80;    server_name api.testname.top;    ''''    location / {         include uwsgi_params;         uwsgi_pass luffy;        # proxy_pass http:// luffy # 这样是反向代理的    }    # 后端数据请求,当有static文件请求时,转接到这里    location /static {          root   /usr/share/nginx/;   # 路径不用到下面的同名的文件        index  index.html index.htm;        try_files $uri $uri /index.html;    }}

重启nginx

# 查看配置是否成功nginx -t# 平滑重启nginx -s reload

luffy项目(单容器http)

配置前后端项目

创建nginx容器, 映射nginx端口-p和路径-v

docker run -d -p 80:80 -p 8080:80 --name=luffy_nginx -v /opt/luffy/luffycity/dist:/usr/share/nginx/html -v /opt/luffy/luffyserver/static/:/usr/share/nginx/static nginx

查看docke

docker ps -a# 进入docker docker exec -it luffy_nginx(容器id) bash# 下载vimapt-get updateapt-get install -y vim

配置Nginx配置文件

vim /etc/nginx/conf.d/default.conf

看到只是把文件内容放在同一个配置文件中,这是多虚拟主机,server为一体,server_name区分

upstream luffy {    server 127.0.0.1:8000;   # server 127.0.0.1:8000  # 可以多服务器,有权重等}server{  listen   80;  server_name  www.testname.top;  ''''  location / {       root  /usr/share/nginx/html;       index index.html index.htm;       try_files $uri $uri/ /index.html;    #这句,解决其他非根页面的404的问题   }}server {    listen  80;    server_name api.testname.top;    ''''    location / {         include uwsgi_params;         uwsgi_pass luffy;        # proxy_pass http:// luffy # 这样是反向代理的    }    # 后端数据请求,当有static文件请求时,转接到这里    location /static {          root   /usr/share/nginx/;   # 路径不用到下面的同名的文件        index  index.html index.htm;        try_files $uri $uri /index.html;    }}

重启nginx

# 查看配置是否成功nginx -t# 平滑重启nginx -s reload

luffy项目(双容器https)

配置前端项目

创建nginx容器, 映射nginx端口-p和路径-v

docker run -d -p 80:80 -p 443:443 --name=cli_nginx -v /opt/luffy/luffycity/dist:/usr/share/nginx/html nginx

查看docke

docker ps -a# 进入docker docker exec -it cli_nginx(容器id) bash# 下载vimapt-get updateapt-get install -y vim

配置Nginx配置文件

vim /etc/nginx/conf.d/default.conf

# 前端的https配置server {listen 443 ssl;server_name www.testname.top;  #ssl on; ssl_certificate  /etc/nginx/ssl/cli/1_www.testname.top_bundle.crt; # 这是我们要填的证书ssl_certificate_key /etc/nginx/ssl/cli/2_www.testname.top.key;    # 这是我们要填的证书ssl_session_timeout 5m; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;ssl_protocols TLSv1 TLSv1.1 TLSv1.2;ssl_prefer_server_ciphers on; location / {     root /usr/share/nginx/html;    index index.html index.htm;    try_files $uri $uri/ /index.html;    }}server {  # 如果为http请求进来,则重定向到https    listen       80;    server_name  www.testname.top;    rewrite ^(.*)$ https://$host$1 permanent;  # 如果为http请求进来,则重定向到https    #charset koi8-r;    #access_log  /var/log/nginx/host.access.log  main;        error_page   500 502 503 504  /50x.html;    location = /50x.html {        root   /usr/share/nginx/html;    }       }

重启nginx

# 查看配置是否成功nginx -t# 平滑重启nginx -s reload

配置后端项目

创建nginx容器, 映射nginx端口-p和路径-v

# 可以加多映射端口 -p 8080:80 ,预防后台管理人员请求时用http,可以重定向回https,预防报错,重定向看上面docker run -d  -p 8080:443 --name=ser_nginx -v /opt/luffy/luffyserver/static/:/usr/share/nginx/static -v /opt/luffy/ssl/:/etc/nginx/ssl nginx

查看docke

docker ps -a# 进入docker docker exec -it ser_nginx(容器id) bash# 下载vimapt-get updateapt-get install -y vim

配置Nginx配置文件

vim /etc/nginx/conf.d/default.conf

# 后端 负载均衡池                                upstream luffy {    server 127.0.0.1:8000;}server {    listen      443 ssl;    server_name  api.testname.top;    ssl_certificate /etc/nginx/ssl/api/1_api.testname.top_bundle.crt;# 这是我们要填的证书    ssl_certificate_key /etc/nginx/ssl/api/2_api.testname.top.key;   # 这是我们要填的证书    ssl_session_timeout 5m;     ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;    ssl_prefer_server_ciphers on;     location / {         include uwsgi_params;        uwsgi_pass luffy;        # proxy_pass http:// luffy # 这样是反向代理的    }       #charset koi8-r;    #access_log  /var/log/nginx/host.access.log  main;    location /static { # 后端的动态文件        root   /usr/share/nginx/;        index  index.html index.htm;        try_files $uri $uri/ /index.html;    }        error_page   500 502 503 504  /50x.html;    location = /50x.html {        root   /usr/share/nginx/html;    }   }

重启nginx

# 查看配置是否成功nginx -t# 平滑重启nginx -s reload

luffy项目(单容器https)

创建nginx容器, 映射nginx端口-p和路径-v

# 可以加多映射端口 -p *:80 (*代表所有端口,都可以访问),预防后台管理人员请求时用http,可以重定向回https,预防报错,重定向看上面docker run -d -p 443:443 -p 8080:443 -p 80:80 --name=luffycity -v /opt/luffy/luffyclient/dist/:/usr/share/nginx/html -v /opt/luffy/luffyserver/luffyserver/static/:/usr/share/nginx/static -v /opt/luffy/ssl/:/etc/nginx/ssl nginx

查看docke

docker ps -a# 进入docker docker exec -it luffycity(容器id) bash# 下载vimapt-get updateapt-get install -y vim

配置Nginx配置文件

看到只是把文件内容放在同一个配置文件中,这是多虚拟主机,server为一体,server_name区分

vim /etc/nginx/conf.d/default.conf

# 负载均衡池upstream luffy {    server 127.0.0.1:8000;}server {listen 443 ssl;server_name www.testname.top;#ssl on; ssl_certificate  /etc/nginx/ssl/cli/1_www.testname.top_bundle.crt; # 这是我们要填的证书ssl_certificate_key /etc/nginx/ssl/cli/2_www.testname.top.key;     # 这是我们要填的证书ssl_session_timeout 5m; ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;ssl_protocols TLSv1 TLSv1.1 TLSv1.2;ssl_prefer_server_ciphers on; location / {     root /usr/share/nginx/html;    index index.html index.htm;    try_files $uri $uri/ /index.html;    }}server {    listen       80;    server_name  www.testname.top;    rewrite ^(.*)$ https://$host$1 permanent;    #charset koi8-r;    #access_log  /var/log/nginx/host.access.log  main;        error_page   500 502 503 504  /50x.html;    location = /50x.html {        root   /usr/share/nginx/html;    }       }                      server {    listen      443 ssl;    server_name  api.testname.top;    ssl_certificate /etc/nginx/ssl/api/1_api.testname.top_bundle.crt; # 这是我们要填的证书    ssl_certificate_key /etc/nginx/ssl/api/2_api.testname.top.key;    # 这是我们要填的证书    ssl_session_timeout 5m;     ssl_ciphers ECDHE-RSA-AES128-GCM-SHA256:ECDHE:ECDH:AES:HIGH:!NULL:!aNULL:!MD5:!ADH:!RC4;    ssl_protocols TLSv1 TLSv1.1 TLSv1.2;    ssl_prefer_server_ciphers on;     location / {         include uwsgi_params;        uwsgi_pass luffy;    }       #charset koi8-r;    #access_log  /var/log/nginx/host.access.log  main;    location /static {        root   /usr/share/nginx/;        index  index.html index.htm;        try_files $uri $uri/ /index.html;    }        error_page   500 502 503 504  /50x.html;    location = /50x.html {        root   /usr/share/nginx/html;    }   }

重启nginx

# 查看配置是否成功nginx -t# 平滑重启nginx -s reload

免责声明:本网信息来自于互联网,目的在于传递更多信息,并不代表本网赞同其观点。其原创性以及文中陈述文字和内容未经本站证实,对本文以及其中全部或者部分内容、文字的真实性、完整性、及时性本站不作任何保证或承诺,并请自行核实相关内容。本站不承担此类作品侵权行为的直接责任及连带责任。如若本网有任何内容侵犯您的权益,请及时联系我们,本站将会在24小时内处理完毕。
相关文章
返回顶部