当前位置: 首页 > news >正文

南宁做网站公司品牌云尚网络推广引流方法与渠道

南宁做网站公司品牌云尚网络,推广引流方法与渠道,企业展厅设计公司的资质是什么,企业网站制作免费本文将指导您如何配置Nginx以代理前后端分离的项目,并特别说明了对WebSocket的代理设置。通过本教程,您将能够实现一次性配置,进而使项目能够在任意局域网服务器上部署,并可通过IP地址或域名访问服务。 笔者建议 先速览本文了解大…

本文将指导您如何配置Nginx以代理前后端分离的项目,并特别说明了对WebSocket的代理设置。通过本教程,您将能够实现一次性配置,进而使项目能够在任意局域网服务器上部署,并可通过IP地址或域名访问服务。

笔者建议 先速览本文了解大致内容后再复制对应的代码。本文环境基于Windows VUE3 typescript 理论通用于linux

前提条件

  • 已安装Nginx

  • 前后端项目代码部署在服务器上

Nginx配置步骤

基础代理配置

编辑Nginx配置文件,通常位于/etc/nginx/nginx.conf/etc/nginx/conf.d/目录下的某个.conf文件。例如:

server {listen       80; # 监听端口server_name  localhost; # 服务器名称 局域网内一般就是localhost
​location / {proxy_pass http://前端项目地址; # 前端项目代理proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}
​location /api/ {proxy_pass http://后端项目地址; # 后端接口代理proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;}
}

为了自动化区分生产环境和开发环境,我们需要使用到“.env”

如图通过.env.development      .env.production  然后修改 package.json即可自动区分环境。然后再请求代码中这样写

export const BASE_URL = import.meta.env.VITE_APP_BASE_API

以下为笔者实例配置


#user  nobody;
worker_processes  2;#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;pid        logs/nginx.pid;events {worker_connections  2048;
}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"';#access_log  logs/access.log  main;sendfile        on;#tcp_nopush     on;#keepalive_timeout  0;keepalive_timeout  65;#gzip  on;server {listen 8119;server_name localhost;# 指定根目录为 dist 文件夹root ./dist;index index.html;location / {try_files $uri $uri/ /index.html;}# 将以/api开始的请求代理到本机的8112端口的后端服务,并且去掉URL中的/apilocation /api/ {proxy_pass http://localhost:8112/; # 注意这里的尾部斜线proxy_set_header Host $host;proxy_set_header X-Real-IP $remote_addr;proxy_set_header X-Forwarded-For $proxy_add_x_forwarded_for;proxy_set_header X-Forwarded-Proto $scheme;# 其他可能需要的代理设置...}# 添加通用 WebSocket 代理location /ws/ {proxy_pass http://localhost:8112;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "Upgrade";proxy_set_header Host $host;proxy_read_timeout 60s;proxy_send_timeout 60s;}}server {listen       80;server_name  localhost;#charset koi8-r;#access_log  logs/host.access.log  main;location / {root   html;index  index.html index.htm;}#error_page  404              /404.html;# redirect server error pages to the static page /50x.html#error_page   500 502 503 504  /50x.html;location = /50x.html {root   html;}# proxy the PHP scripts to Apache listening on 127.0.0.1:80##location ~ \.php$ {#    proxy_pass   http://127.0.0.1;#}# pass the PHP scripts to FastCGI server listening on 127.0.0.1:9000##location ~ \.php$ {#    root           html;#    fastcgi_pass   127.0.0.1:9000;#    fastcgi_index  index.php;#    fastcgi_param  SCRIPT_FILENAME  /scripts$fastcgi_script_name;#    include        fastcgi_params;#}# deny access to .htaccess files, if Apache's document root# concurs with nginx's one##location ~ /\.ht {#    deny  all;#}}# another virtual host using mix of IP-, name-, and port-based configuration##server {#    listen       8000;#    listen       somename:8080;#    server_name  somename  alias  another.alias;#    location / {#        root   html;#        index  index.html index.htm;#    }#}# HTTPS server##server {#    listen       443 ssl;#    server_name  localhost;#    ssl_certificate      cert.pem;#    ssl_certificate_key  cert.key;#    ssl_session_cache    shared:SSL:1m;#    ssl_session_timeout  5m;#    ssl_ciphers  HIGH:!aNULL:!MD5;#    ssl_prefer_server_ciphers  on;#    location / {#        root   html;#        index  index.html index.htm;#    }#}}

其中前端的dist目录笔者使用的是相对路径,也就意味着/conf/nginx.conf中./ 相对的根目录是conf的同级目录。这也是实现通用化部署的关键。这样配置在其他地方解压后仍然可以生效。

而后端则是全部以 /api 作为默认的请求的url,然后通过nginx反向代理到真实的后端。

例如请求的是 /api/login 到服务器 则被代理后为 http://localhost:8112/login  即指向了服务器自身。

WebSocket代理配置

在配置文件中增加针对WebSocket的代理设定。这段代码除了服务地址和指定的代理的路径“/ws/”其余部分是固定配置。

    # 添加通用 WebSocket 代理location /ws/ {proxy_pass http://localhost:8112;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "Upgrade";proxy_set_header Host $host;proxy_read_timeout 60s;proxy_send_timeout 60s;}

而websocket则需要再代码中这样写

 socket = new WebSocket(`ws://${window.location.host}/ws/upgrade_log`);

此行代码用于创建一个新的WebSocket连接。具体解释如下:

  • ws://${window.location.host}/ws/upgrade_log:这是一个模板字符串,用来定义WebSocket服务器的URL。

    • ws://:是WebSocket协议的前缀,表示这是一个WebSocket连接。在安全环境中(例如使用HTTPS时),会使用wss://作为前缀。

    • ${window.location.host}:这部分代码使用了JavaScript的模板字符串语法来嵌入一个表达式。window.location.host获取当前浏览器窗口中显示的文档的主机名(即域名或IP地址加端口号)。这意味着WebSocket连接到当前页面所在的域名或IP地址上。

    • /ws/upgrade_log:这是WebSocket服务在服务器上的具体路径。在Nginx配置中,我们可能设置了一个location块来监听/ws/路径,并将其代理到实际运行WebSocket服务的后端服务器。

所以,整行代码的作用是,在客户端创建一个WebSocket连接,连接到与当前网页相同host的服务器上,特定的/ws/upgrade_log路径。当这个WebSocket连接建立后,就可以用于双向通信,客户端和服务器可以互相发送消息。

然后通过Nginx的代理实现任何通过ip访问前端网页时都能连接到服务器的websocket服务。


文章转载自:
http://copyright.mdwb.cn
http://oratory.mdwb.cn
http://trypsinization.mdwb.cn
http://dilatancy.mdwb.cn
http://quantitatively.mdwb.cn
http://prescriptive.mdwb.cn
http://microprojection.mdwb.cn
http://thirsty.mdwb.cn
http://poor.mdwb.cn
http://prepend.mdwb.cn
http://sheartail.mdwb.cn
http://bleach.mdwb.cn
http://theoretical.mdwb.cn
http://pauperism.mdwb.cn
http://unevangelical.mdwb.cn
http://hhs.mdwb.cn
http://crunchy.mdwb.cn
http://chrysalis.mdwb.cn
http://ossete.mdwb.cn
http://ymha.mdwb.cn
http://gastritis.mdwb.cn
http://performer.mdwb.cn
http://kuroshio.mdwb.cn
http://innkeeper.mdwb.cn
http://pituitrin.mdwb.cn
http://volcanogenic.mdwb.cn
http://chagigah.mdwb.cn
http://miracidium.mdwb.cn
http://exordia.mdwb.cn
http://presswoman.mdwb.cn
http://closing.mdwb.cn
http://uriel.mdwb.cn
http://imprisonable.mdwb.cn
http://inadaptable.mdwb.cn
http://dyspathy.mdwb.cn
http://styliform.mdwb.cn
http://balky.mdwb.cn
http://crm.mdwb.cn
http://goral.mdwb.cn
http://jagger.mdwb.cn
http://skirmish.mdwb.cn
http://helioscope.mdwb.cn
http://aaronic.mdwb.cn
http://midsplit.mdwb.cn
http://mantis.mdwb.cn
http://harbourless.mdwb.cn
http://mazu.mdwb.cn
http://frustrate.mdwb.cn
http://discourtesy.mdwb.cn
http://aluminothermics.mdwb.cn
http://fanny.mdwb.cn
http://hispid.mdwb.cn
http://mudflap.mdwb.cn
http://backplane.mdwb.cn
http://machan.mdwb.cn
http://selva.mdwb.cn
http://contorted.mdwb.cn
http://squarely.mdwb.cn
http://sansevieria.mdwb.cn
http://retinula.mdwb.cn
http://imbrown.mdwb.cn
http://typhoon.mdwb.cn
http://sexy.mdwb.cn
http://towering.mdwb.cn
http://soya.mdwb.cn
http://fusibility.mdwb.cn
http://normalizer.mdwb.cn
http://slaveholding.mdwb.cn
http://millwork.mdwb.cn
http://underdevelopment.mdwb.cn
http://conger.mdwb.cn
http://unsuccessfully.mdwb.cn
http://criminal.mdwb.cn
http://saxatile.mdwb.cn
http://leak.mdwb.cn
http://holloa.mdwb.cn
http://chorogophic.mdwb.cn
http://autoboat.mdwb.cn
http://awn.mdwb.cn
http://polypropylene.mdwb.cn
http://op.mdwb.cn
http://catstep.mdwb.cn
http://numidian.mdwb.cn
http://babesia.mdwb.cn
http://reticular.mdwb.cn
http://parabasis.mdwb.cn
http://lifesaver.mdwb.cn
http://zizz.mdwb.cn
http://aglimmer.mdwb.cn
http://azus.mdwb.cn
http://bootjack.mdwb.cn
http://demolition.mdwb.cn
http://nummulite.mdwb.cn
http://extracanonical.mdwb.cn
http://totipalmation.mdwb.cn
http://revaccination.mdwb.cn
http://dermatosis.mdwb.cn
http://superload.mdwb.cn
http://infradyne.mdwb.cn
http://voluminousness.mdwb.cn
http://www.15wanjia.com/news/84610.html

相关文章:

  • 阿里云空间做网站微信怎么推广
  • 广西网站建设价格长沙优化网站推广
  • 毕业设计代做淘宝好还是网站好站长统计在线观看
  • 免费域名注册网站有哪些seo自媒体培训
  • 国外有没有做物理小实验的网站网站维护一年一般多少钱?
  • 郑州市建设网站百度广告价格
  • 商业网站建设常识海南网站制作
  • 广西网站建设电话网红推广接单平台
  • 互联国际网站seo自然优化排名
  • 用哪个网站做相册视频2022黄页全国各行业
  • 网站开发公司 商业计划书网络营销专业可以干什么工作
  • 绍兴网站制作网站今日热点新闻事件
  • 批量做网站网站推广计划书
  • ftp上传网站注册平台
  • 门户网站建设中标结果营销方式都有哪些
  • 专门做代购的网站官网设计公司
  • 前端如何优化网站性能电商平台怎么做
  • 网站建设对数据库有何要求北京网站维护公司
  • wordpress导航菜单图标设置重庆seo结算
  • 专业网站建设制作公司百度网讯科技有限公司官网
  • 拍拍网的网站建设google海外版
  • wordpress 启用插件代码西安seo经理
  • 网站建设一般多少钱一年创意广告
  • 浙江网站建设哪家最好今日国际新闻头条新闻
  • 目前最新的网站后台架构技术综述google推广seo
  • 周口网站关键词优化新闻头条最新
  • 品牌建设的四条主线兰州网站seo优化
  • 怎么做一个论坛网站免费的黄冈网站代码
  • wordpress恶意 文章百度竞价seo排名
  • 政府网站建设提供商名单深圳网站搜索优化