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

前端项目部署教程——有域名有证书

一、拉取nginx镜像

docker pull nginx //先拉取nginx镜像

二、打包前端项目

1、将Vue打包项目传输到/usr/local/vue/下blog和admin文件夹下

重点: 每一个子域名都要申请证书,在阿里云每年可以免费申请20个证书,

免费证书申请教程在 免费证书申请教程

2、将申请的证书放到/usr/local/nginx/cert下,如果没有cert目录就建一个

3、在/usr/local/nginx下创建nginx.conf文件,格式如下:

events {worker_connections  1024;
}http {include       mime.types;default_type  application/octet-stream;sendfile        on;keepalive_timeout  65;client_max_body_size     50m;client_body_buffer_size  10m; 	  client_header_timeout    1m;client_body_timeout      1m;gzip on;gzip_min_length  1k;gzip_buffers     4 16k;gzip_comp_level  4;gzip_types text/plain application/javascript application/x-javascript text/css application/xml text/javascript application/x-httpd-php image/jpeg image/gif image/png;gzip_vary on;server {listen  443 ssl;server_name  主域名;ssl on;ssl_certificate    /usr/local/nginx/cert/pem文件名称;ssl_certificate_key  /usr/local/nginx/cert/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/local/vue/blog;index  index.html index.htm;try_files $uri $uri/ /index.html;}location ^~ /api/ {proxy_pass http://IP地址:端口号/;proxy_set_header   Host             $host;proxy_set_header   X-Real-IP        $remote_addr;proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;}}server {listen  443 ssl;server_name  后台页面子域名;ssl on;ssl_certificate    /usr/local/nginx/cert/pem文件名称;ssl_certificate_key  /usr/local/nginx/cert/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/local/vue/admin;index  index.html index.htm;try_files $uri $uri/ /index.html;}location ^~ /api/ {proxy_pass http://IP地址:端口号/;proxy_set_header   Host             $host;proxy_set_header   X-Real-IP        $remote_addr;proxy_set_header   X-Forwarded-For  $proxy_add_x_forwarded_for;}}server {listen  443 ssl;server_name  websocket子域名;ssl on;ssl_certificate    /usr/local/nginx/cert/pem文件名称;ssl_certificate_key  /usr/local/nginx/cert/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 / {proxy_pass http://IP地址:端口号/websocket;proxy_http_version 1.1;proxy_set_header Upgrade $http_upgrade;proxy_set_header Connection "Upgrade";proxy_set_header Host $host:$server_port;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; }}server {listen  443 ssl;server_name  文件上传子域名;ssl on;ssl_certificate    /usr/local/nginx/cert/pem文件名称;ssl_certificate_key  /usr/local/nginx/cert/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/local/upload/; }		}	server {listen       80;server_name  主域名;rewrite ^(.*)$	https://$host$1	permanent;}server {listen       80;server_name  后台页面子域名;rewrite ^(.*)$	https://$host$1	permanent;}server {listen       80;server_name  websocket子域名;rewrite ^(.*)$	https://$host$1	permanent;}server {listen       80;server_name  文件上传子域名;rewrite ^(.*)$	https://$host$1	permanent;}}

三、运行启动nginx容器

docker run --name nginx --restart=always -p 80:80 -p 443:443 -d -v /usr/local/nginx/nginx.conf:/etc/nginx/nginx.conf -v /usr/local/vue:/usr/local/vue -v /usr/local/nginx/cert:/usr/local/nginx/cert -v /usr/local/upload:/usr/local/upload nginx

这样前端项目就已经部署完毕。访问自己的域名即可查看自己部署的项目。

http://www.lryc.cn/news/336487.html

相关文章:

  • 《看漫画学C++》第12章 可大可小的“容器”——向量
  • OpenAI推出GPTBot网络爬虫:提升AI模型同时引发道德法律争议
  • Claude使用教程
  • 【经典算法】LeetCode25:K 个一组翻转链表(Java/C/Python3,Hard)
  • 6.11物联网RK3399项目开发实录-驱动开发之定时器的使用(wulianjishu666)
  • 算法训练营第二十三天(二叉树完结)
  • mysql主从复制Slave_SQL_Running: No
  • 【SpringBoot】SpringBoot项目快速搭建
  • Terraform 状态不同步处理
  • 4.2.k8s的pod-标签管理、镜像拉取策略、容器重启策略、资源限制、优雅终止
  • 能源党建后台项目总结
  • 股票高胜率的交易法则是什么?
  • C语言 | sizeof与strlen的区别(附笔试题)
  • AI自动绘画器介绍和应用场景
  • java二叉树前中后序遍历
  • 【LeetCode刷题笔记】LeetCode 1365.有多少小于当前数字的数字
  • 室内定位中文综述阅读
  • 微信小程序uniapp+vue电力巡线任务故障报修管理系统2q91t
  • springboot国际化多语言
  • set和map
  • Open CASCADE学习|求曲面的参数空间
  • 代码随想录阅读笔记-二叉树【总结】
  • 【SpringBoot整合系列】SpringBoot整合FastDFS(二)
  • L2-2 巴音布鲁克永远的土(二分+并查集)
  • Spring Cloud学习笔记:Eureka简介,Eureka简单样例
  • 【漏洞复现】WordPress Welcart 任意文件读取漏洞(CVE-2022-4140)
  • 快速排序:深入解析其原理、实现与性能特性
  • 一文看懂Mac地址
  • 2024.4.10作业
  • python - Django创建项目