百度360必应搜狗淘宝本站头条
当前位置:网站首页 > 技术分类 > 正文

[ DeWeb使用技巧 ] DeWeb 实用化部署

ztj100 2024-11-23 00:01 52 浏览 0 评论

如何稳定可靠地运行DeWeb系统,以下我结合www.delphibbs.com的DeWeb部署情况,简要介绍。

一、前期准备

DeWeb目前只能运行在Windows操作系统中,要部署DeWeb应用,需要前期做准备以下:

  1. Windows操作系统的轻量应用服务器/云服务器,需要的可以 >>>「链接」
  2. 已备案的域名
  3. 已申请的ssl证书,用于实现https访问。腾讯云/阿里云都可以免费申请
  4. nginx。 我用的是小皮

二、基本框架

为了实现稳定可靠的https+DeWeb应用,目前采用的基本框架是:

nginx + DWSGuardor + 10 DeWebServer

其中:

nginx 用于实现较大并发访问和负载平衡,将80端口和443端口转发到8080~8089等10个端口,分别分流到10个DeWebServer中,理论可达2000并发+(按前期测试单个DeWebServer并发200+计算),实际1000+并发应该没问题。

DWSGuardor 用于和多个DeWevServer进行通信,监控DeWebServer的状态,发现异常可以重启指定端口的DeWebServer。

DeWebServer 用于提供指定端口(8080~8089)的DeWeb应用服务,并定时将状态信息发送给DWSGuardor。

三、DeWeb部署

DeWeb部署非常简单,直接把开发机上Source\Runtime目录直接复制到服务器即可以。目录位置随意。 一般建议为D:\DeWeb或C:\DeWeb。参考如下:


四、nginx(小皮)配置

nginx的配置管理工具很多,我用的是小皮,网址小皮面板(phpstudy) - 让天下没有难配的服务器环境!版本是8.1.1.3,其中nginx版本是1.16.1


小皮的套件中包括Apache, FTP, MySQL和nginx, 我只使用了nginx. 大家有更简洁的nginx工具欢迎在评论区留言。感谢!

其中nginx的配置如下


#user  nobody;
worker_processes 4;
#error_log  logs/error.log;
#error_log  logs/error.log  notice;
#error_log  logs/error.log  info;
#pid        logs/nginx.pid;
events {
     worker_connections 40960;
}
http {
    include       mime.types;
    default_type  application/octet-stream;
	
	#反向代理配置 
	upstream server_list{
		ip_hash;
		server 127.0.0.1:8080;
		server 127.0.0.1:8081;
		server 127.0.0.1:8082;
		server 127.0.0.1:8083;
		server 127.0.0.1:8084;
		server 127.0.0.1:8085;
		server 127.0.0.1:8086;
		server 127.0.0.1:8087;
		server 127.0.0.1:8088;
		server 127.0.0.1:8089;
	}
	
	
	server{
		listen 443 ssl;
		server_name doc.delphibbs.com;
		
		index ssl.html ;
		ssl_certificate      	c:/ssl/delphibbs.com.crt;
		ssl_certificate_key 	c:/ssl/delphibbs.com.key;
		ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
		ssl_ciphers ALL:!DH:!EXPORT:!RC4:+HIGH:+MEDIUM:!eNULL;
		ssl_prefer_server_ciphers on;
		

        location / {
			proxy_pass  http://127.0.0.1:3000;
        }
	}
	server{
		listen 80;
		server_name doc.delphibbs.com;
		
        location / {
			proxy_pass  http://127.0.0.1:3000;
        }
	}
	
	server{
		listen 443 ssl;
		server_name bbs.delphibbs.com;
		
		index ssl.html ;
		ssl_certificate      	c:/ssl/delphibbs.com.crt;
		ssl_certificate_key 	c:/ssl/delphibbs.com.key;
		ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
		ssl_ciphers ALL:!DH:!EXPORT:!RC4:+HIGH:+MEDIUM:!eNULL;
		ssl_prefer_server_ciphers on;
		

        location / {
			rewrite ^(/.*)$ https://www.delphibbs.com/bbs; 
        }
	}
	
	server{
		listen 80;
		server_name bbs.delphibbs.com;
		
        location / {
			rewrite ^(/.*)$ https://www.delphibbs.com/bbs; 
        }
	}
	
	server{
		listen 80;
		server_name delphibbs.com www.delphibbs.com;
		
		
        location / {
            tcp_nodelay     on;
            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_pass  http://server_list;

			# SSE support
            proxy_buffering off;
            proxy_cache off;
            proxy_read_timeout 86400s;
            proxy_send_timeout 86400s;
        }

		location /doc {
			proxy_pass  http://127.0.0.1:3000/;
		}
	} 
	server{
		listen 443 ssl;
		server_name delphibbs.com www.delphibbs.com;
		
		index ssl.html ;
		ssl_certificate      	c:/ssl/delphibbs.com.crt;
		ssl_certificate_key 	c:/ssl/delphibbs.com.key;
		ssl_protocols TLSv1 TLSv1.1 TLSv1.2;
		ssl_ciphers ALL:!DH:!EXPORT:!RC4:+HIGH:+MEDIUM:!eNULL;
		ssl_prefer_server_ciphers on;
		
        location / {
            tcp_nodelay     on;
            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_pass  http://server_list;

			# SSE support
            proxy_buffering off;
            proxy_cache off;
            proxy_read_timeout 86400s;
            proxy_send_timeout 86400s;
        }

		location /doc {
			proxy_pass  http://127.0.0.1:3000/;
		}
	}


    #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;
    # another virtual host using mix of IP-, name-, and port-based configuration
    #
    #server {
    #    listen       443;
    #    listen       somename:8080;
    #    server_name  somename  alias  another.alias;
    #    location / {
    #        root   html;
    #        index  index.html index.htm;
    #    }
    #}
    map $time_iso8601 $logdate {
        '~^(?<ymd>\\d{4}-\\d{2}-\\d{2})' $ymd;
        default                       'date-not-found';
    }
	include vhosts/*.conf;
    # 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;
    #    }
    #}
     client_max_body_size 50m;
     client_body_buffer_size 60k;
     client_body_timeout 60;
     client_header_buffer_size 64k;
     client_header_timeout 60;
     error_page 400 /error/400.html;
     error_page 403 /error/403.html;
     error_page 404 /error/404.html;
     error_page 500 /error/500.html;
     error_page 501 /error/501.html;
     error_page 502 /error/502.html;
     error_page 503 /error/503.html;
     error_page 504 /error/504.html;
     error_page 505 /error/505.html;
     error_page 506 /error/506.html;
     error_page 507 /error/507.html;
     error_page 509 /error/509.html;
     error_page 510 /error/510.html;
     
     keepalive_requests 100;
     large_client_header_buffers 4 64k;
     reset_timedout_connection on;
     send_timeout 60;
     sendfile_max_chunk 512k;
     server_names_hash_bucket_size 256;
}
     error_log C:/phpstudy_pro/WWW crit;
     worker_rlimit_nofile 100000;

由于我在网站上部署了docsify文档系统,所以这个配置中多了/doc 转到3000端口部分。不需要的可以自行移除

五、https实现

  1. 申请ssl证书。腾讯云/阿里云都可以免费申请,网上教程很多。不过现在每次只能申请3个月的
  2. 在腾讯云/阿里云后台网站下载申请的delphibbs.com的证书
  3. 解压后复制所有文件到指定文件夹(参看nginx配置文件),并重命名为指定文件名
		ssl_certificate      	c:/ssl/delphibbs.com.crt;
		ssl_certificate_key 	c:/ssl/delphibbs.com.key;
  1. 在小皮中重启nginx



六、DWSGuardor运行管理

DWSGuardor 即 DeWebServer Guardor, 用于对多个DeWebServer进行监控。

一般有一个配置文件:DWSGuardor.ini

[main]
count = 10
port = 8080
left = 500
top = 0
width = 400
height = 90

上述配置表示,

总共启动10个DeWebServer,端口从8080开始,左边距默认为500,上边距为0,宽度为400,高度为90


顶部2个按钮,“启动DWS”按钮用于一次性自动启动多个DeWebServer, “停止”按钮用于一次结束多个DeWebServer。

下部左侧为多个DeWebServer的实时状态,亮色为正常,黑色为故障;

下部右侧为异常重启情况。上图上表示2024年11月7日重启了8086端口对应的DeWebServer。

七、升级维护

DeWeb应用的更新可以通过例程中HotUpdate远程进行;

js/css更新直接修改相应的js/css文件即可,在前端浏览器中需要清除缓存;

dwVcl控件或DeWebServer更新需要先在DWSGuardor中先按“停止”按钮,再更新相应文件

八、实际运行情况

2024年4月由于一些特殊的原因,全封闭无手机无网1个半月,回来发现运行一切正常。

相关推荐

sharding-jdbc实现`分库分表`与`读写分离`

一、前言本文将基于以下环境整合...

三分钟了解mysql中主键、外键、非空、唯一、默认约束是什么

在数据库中,数据表是数据库中最重要、最基本的操作对象,是数据存储的基本单位。数据表被定义为列的集合,数据在表中是按照行和列的格式来存储的。每一行代表一条唯一的记录,每一列代表记录中的一个域。...

MySQL8行级锁_mysql如何加行级锁

MySQL8行级锁版本:8.0.34基本概念...

mysql使用小技巧_mysql使用入门

1、MySQL中有许多很实用的函数,好好利用它们可以省去很多时间:group_concat()将取到的值用逗号连接,可以这么用:selectgroup_concat(distinctid)fr...

MySQL/MariaDB中如何支持全部的Unicode?

永远不要在MySQL中使用utf8,并且始终使用utf8mb4。utf8mb4介绍MySQL/MariaDB中,utf8字符集并不是对Unicode的真正实现,即不是真正的UTF-8编码,因...

聊聊 MySQL Server 可执行注释,你懂了吗?

前言MySQLServer当前支持如下3种注释风格:...

MySQL系列-源码编译安装(v5.7.34)

一、系统环境要求...

MySQL的锁就锁住我啦!与腾讯大佬的技术交谈,是我小看它了

对酒当歌,人生几何!朝朝暮暮,唯有己脱。苦苦寻觅找工作之间,殊不知今日之事乃我心之痛,难道是我不配拥有工作嘛。自面试后他所谓的等待都过去一段时日,可惜在下京东上的小金库都要见低啦。每每想到不由心中一...

MySQL字符问题_mysql中字符串的位置

中文写入乱码问题:我输入的中文编码是urf8的,建的库是urf8的,但是插入mysql总是乱码,一堆"???????????????????????"我用的是ibatis,终于找到原因了,我是这么解决...

深圳尚学堂:mysql基本sql语句大全(三)

数据开发-经典1.按姓氏笔画排序:Select*FromTableNameOrderByCustomerNameCollateChinese_PRC_Stroke_ci_as//从少...

MySQL进行行级锁的?一会next-key锁,一会间隙锁,一会记录锁?

大家好,是不是很多人都对MySQL加行级锁的规则搞的迷迷糊糊,一会是next-key锁,一会是间隙锁,一会又是记录锁。坦白说,确实还挺复杂的,但是好在我找点了点规律,也知道如何如何用命令分析加...

一文讲清怎么利用Python Django实现Excel数据表的导入导出功能

摘要:Python作为一门简单易学且功能强大的编程语言,广受程序员、数据分析师和AI工程师的青睐。本文系统讲解了如何使用Python的Django框架结合openpyxl库实现Excel...

用DataX实现两个MySQL实例间的数据同步

DataXDataX使用Java实现。如果可以实现数据库实例之间准实时的...

MySQL数据库知识_mysql数据库基础知识

MySQL是一种关系型数据库管理系统;那废话不多说,直接上自己以前学习整理文档:查看数据库命令:(1).查看存储过程状态:showprocedurestatus;(2).显示系统变量:show...

如何为MySQL中的JSON字段设置索引

背景MySQL在2015年中发布的5.7.8版本中首次引入了JSON数据类型。自此,它成了一种逃离严格列定义的方式,可以存储各种形状和大小的JSON文档,例如审计日志、配置信息、第三方数据包、用户自定...

取消回复欢迎 发表评论: